X-Git-Url: http://git.vpit.fr/?a=blobdiff_plain;f=lib%2FB%2FRecDeparse.pm;h=03c7effab49656a8701e6f6ff2360caa6f84545a;hb=6fa4fee40c6f93a6b776905a869605e9f210d0b6;hp=4df9dffb441b183da5acd8a67e64507b6e6f3d76;hpb=7dfb54498a29abb83ba502c4f7dfae65d090aecf;p=perl%2Fmodules%2FB-RecDeparse.git diff --git a/lib/B/RecDeparse.pm b/lib/B/RecDeparse.pm index 4df9dff..03c7eff 100644 --- a/lib/B/RecDeparse.pm +++ b/lib/B/RecDeparse.pm @@ -1,6 +1,6 @@ package B::RecDeparse; -use 5.008001; +use 5.008_001; use strict; use warnings; @@ -17,11 +17,11 @@ B::RecDeparse - Deparse recursively into subroutines. =head1 VERSION -Version 0.07 +Version 0.09 =cut -our $VERSION = '0.07'; +our $VERSION = '0.09'; =head1 SYNOPSIS @@ -65,8 +65,8 @@ The C option expects an integer that specifies how many levels of recursi use constant { # p31268 made pp_entersub call single_delim FOOL_SINGLE_DELIM => - ($^V ge v5.9.5) - || ($^V lt v5.9.0 and $^V ge v5.8.9) + ("$]" >= 5.009_005) + || ("$]" < 5.009 and "$]" >= 5.008_009) || ($Config{perl_patchlevel} && $Config{perl_patchlevel} >= 31268) }; @@ -194,8 +194,9 @@ sub pp_gv { my $self = shift; my $gv = $self->gv_or_padgv($_[0]); - my $name = $gv->NAME; - my $cv = $gv->CV; + my $cv = $gv->FLAGS & B::SVf_ROK ? $gv->RV : undef; + my $name = $cv ? $cv->NAME_HEK || $cv->GV->NAME : $gv->NAME; + $cv ||= $gv->CV; my $seen = $self->{brd_seen}; my $body; @@ -206,7 +207,7 @@ sub pp_gv { $body = do { local @{$self}{qw} = (0, $self->{brd_cur} + 1); local $seen->{$name} = 1; - 'sub ' . $self->indent($self->deparse_sub($gv->CV)); + 'sub ' . $self->indent($self->deparse_sub($cv)); }; if (FOOL_SINGLE_DELIM) { @@ -284,7 +285,7 @@ Tests code coverage report is available at L