package LXDebug;
-use constant {
- NONE => 0,
- INFO => 1,
- DEBUG1 => 2,
- DEBUG2 => 3,
+use constant NONE => 0;
+use constant INFO => 1;
+use constant DEBUG1 => 2;
+use constant DEBUG2 => 3;
+use constant QUERY => 4;
- FILE_TARGET => 0,
- STDERR_TARGET => 1 };
+use constant FILE_TARGET => 0;
+use constant STDERR_TARGET => 1;
use POSIX qw(strftime);
}
sub enter_sub {
- my ($self) = @_;
+ my ($self, $level) = @_;
+
+ return if $global_trace_subs < $level;
if (!$self->{"trace_subs"} && !$global_trace_subs) {
return;
}
sub leave_sub {
- my ($self) = @_;
+ my ($self, $level) = @_;
+
+ return if $global_trace_subs < $level;
if (!$self->{"trace_subs"} && !$global_trace_subs) {
return;
}
if ($log_level >= $level) {
- $self->_write(INFO == $level
- ? "info"
- : DEBUG1 == $level ? "debug1" : "debug2",
- $message);
+ $self->_write(INFO == $level ? "info"
+ : DEBUG1 == $level ? "debug1"
+ : DEBUG2 == $level ? "debug2"
+ : QUERY == $level ? "query":"",
+ $message );
}
}
sub disable_sub_tracing {
my ($self) = @_;
- $self->{"trace_subs"} = 1;
+ $self->{"trace_subs"} = 0;
}
sub _write {