X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=SL%2FLXDebug.pm;h=0503dcb6c8a6f33640dc3c55b125597e58e83cff;hb=36724ca5b87abfa8860c71783b037c121f33221c;hp=e22dc0f5e24127ae8f6316a380c5a9a32570f6bf;hpb=7aa53210c8a1d396b5295551b9122b8690698894;p=kivitendo-erp.git diff --git a/SL/LXDebug.pm b/SL/LXDebug.pm index e22dc0f5e..0503dcb6c 100644 --- a/SL/LXDebug.pm +++ b/SL/LXDebug.pm @@ -20,10 +20,10 @@ use constant STDERR_TARGET => 1; use Data::Dumper; use POSIX qw(strftime getpid); -use Scalar::Util qw(blessed refaddr reftype weaken); +use Scalar::Util qw(blessed refaddr weaken); use Time::HiRes qw(gettimeofday tv_interval); -use YAML; use SL::Request (); +use SL::YAML; use strict; use utf8; @@ -157,51 +157,50 @@ sub warn { $self->message(WARN, $message); } -sub dump { - my ($self, $level, $name, $variable, %options) = @_; - - my %dumped; - - my $clone_for_dump; - $clone_for_dump = sub { - my ($src) = @_; +sub clone_for_dump { + my ($src, $dumped) = @_; - return undef if !defined($src); + return undef if !defined($src); + return $src if !ref($src); - my $addr = refaddr($src); + $dumped ||= {}; + my $addr = refaddr($src); - return $dumped{$addr} if $dumped{$addr // ''}; + return $dumped->{$addr} if $dumped->{$addr // ''}; - if (blessed($src) && $src->can('as_debug_info')) { - $dumped{$addr} = $src->as_debug_info; + if (blessed($src) && $src->can('as_debug_info')) { + $dumped->{$addr} = $src->as_debug_info; - } elsif (reftype($src) eq 'ARRAY') { - $dumped{$addr} = []; + } elsif (ref($src) eq 'ARRAY') { + $dumped->{$addr} = []; - foreach my $entry (@{ $src }) { - my $exists = !!$dumped{refaddr($entry) // ''}; - push @{ $dumped{$addr} }, $clone_for_dump->($entry); + foreach my $entry (@{ $src }) { + my $exists = !!$dumped->{refaddr($entry) // ''}; + push @{ $dumped->{$addr} }, clone_for_dump($entry, $dumped); - weaken($dumped{$addr}->[-1]) if $exists; + weaken($dumped->{$addr}->[-1]) if $exists; - } + } - } elsif (reftype($src) eq 'HASH') { - $dumped{$addr} = {}; + } elsif (ref($src) =~ m{^(?:HASH|Form|SL::.+)$}) { + $dumped->{$addr} = {}; - foreach my $key (keys %{ $src }) { - my $exists = !!$dumped{refaddr($src->{$key}) // ''}; - $dumped{$addr}->{$key} = $clone_for_dump->($src->{$key}); + foreach my $key (keys %{ $src }) { + my $exists = !!$dumped->{refaddr($src->{$key}) // ''}; + $dumped->{$addr}->{$key} = clone_for_dump($src->{$key}, $dumped); - weaken($dumped{$addr}->{$key}) if $exists; - } + weaken($dumped->{$addr}->{$key}) if $exists; } + } - return $dumped{$addr} // "$src"; - }; + return $dumped->{$addr} // "$src"; +} - $variable = $clone_for_dump->($variable); +sub dump { + my ($self, $level, $name, $variable, %options) = @_; + + $variable = clone_for_dump($variable); my $dumper = Data::Dumper->new([$variable]); $dumper->Sortkeys(1); $dumper->Indent(2); @@ -215,7 +214,7 @@ sub dump { sub dump_yaml { my ($self, $level, $name, $variable) = @_; - $self->message($level, "dumping ${name}:\n" . YAML::Dump($variable)); + $self->message($level, "dumping ${name}:\n" . SL::YAML::Dump($variable)); } sub dump_sql_result { @@ -254,7 +253,7 @@ sub show_diff { return; } - my @texts = map { ref $_ ? YAML::Dump($_) : $_ } ($item1, $item2); + my @texts = map { ref $_ ? SL::YAML::Dump($_) : $_ } ($item1, $item2); $self->message($level, Text::Diff::diff(\$texts[0], \$texts[1], \%params)); } @@ -327,7 +326,7 @@ sub _write_raw { sub level2string { no warnings; # use $_[0] as a bit mask and return levelstrings separated by / - join '/', qw(info debug1 debug2 query trace error_call_trace request_timer WARNING)[ grep { (reverse split //, sprintf "%08b", $_[0])[$_] } 0..7 ] + join '/', qw(info debug1 debug2 query trace error_call_trace request_timer request WARNING trace2 show_caller)[ grep { (reverse split //, sprintf "%011b", $_[0])[$_] } 0..11 ] } sub begin_request { @@ -350,7 +349,10 @@ sub log_time { return 1 unless want_request_timer(); my $now = $self->get_request_time; - my $diff = int((($now - ($self->{previous_log_time} // 0)) * 10_000 + 5) / 10); + + return 1 unless $now; + + my $diff = $self->{previous_log_time} ? int((($now - ($self->{previous_log_time} // 0)) * 10_000 + 5) / 10) : $now * 10_0000 + 5; $self->{previous_log_time} = $now; $self->_write("time", "${now}s Δ ${diff}ms" . (@slurp ? " (@slurp)" : ''));