X-Git-Url: http://git.vpit.fr/?a=blobdiff_plain;f=lib%2FB%2FRecDeparse.pm;h=202cf789d77d317262ac118af266cb3c5aef5442;hb=0920b8c6458dde4547a08e052131db6a68dbdfae;hp=791c5750523092ed49d87630b8290a9c15e6752e;hpb=ed8af32fb71887b9d4bb8e43c0efa02d558da44e;p=perl%2Fmodules%2FB-RecDeparse.git diff --git a/lib/B/RecDeparse.pm b/lib/B/RecDeparse.pm index 791c575..202cf78 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,20 +17,27 @@ B::RecDeparse - Deparse recursively into subroutines. =head1 VERSION -Version 0.05 +Version 0.09 =cut -our $VERSION = '0.05'; +our $VERSION = '0.09'; =head1 SYNOPSIS - perl -MO=RecDeparse,deparse,[@B__Deparse_opts],level,-1 [ -e '...' | bleh.pl ] + # Deparse recursively a Perl one-liner : + $ perl -MO=RecDeparse,deparse,@B__Deparse_opts,level,-1 -e '...' - # Or as a module : + # Or a complete Perl script : + $ perl -MO=RecDeparse,deparse,@B__Deparse_opts,level,-1 x.pl + + # Or a single code reference : use B::RecDeparse; - my $brd = B::RecDeparse->new(deparse => [ @b__deparse_opts ], level => $level); + my $brd = B::RecDeparse->new( + deparse => \@B__Deparse_opts, + level => $level, + ); my $code = $brd->coderef2text(sub { ... }); =head1 DESCRIPTION @@ -42,7 +49,12 @@ Besides the constructor syntax, everything should work the same for the two modu =head1 METHODS -=head2 C<< new < deparse => [ @B__Deparse_opts ], level => $level > >> +=head2 C + + my $brd = B::RecDeparse->new( + deparse => \@B__Deparse_opts, + level => $level, + ); The L object constructor. You can specify the underlying L constructor arguments by passing a string or an array reference as the value of the C key. @@ -53,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) }; @@ -178,12 +190,22 @@ sub pp_refgen { } } +sub pp_srefgen { + my $self = shift; + + return do { + local $self->{brd_sub} = 0; + $self->SUPER::pp_srefgen(@_); + } +} + 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; @@ -194,7 +216,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) { @@ -207,20 +229,41 @@ sub pp_gv { return $body; } -=head2 C +=pod + +The following functions and methods from L are reimplemented by this module : + +=over 4 + +=item * + +C + +=item * + +C + +=item * + +C + +=item * + +C + +=item * -=head2 C +C -=head2 C +=item * -=head2 C +C -=head2 C +=item * -=head2 C +C -Functions and methods from L reimplemented by this module. -Never call them directly. +=back Otherwise, L inherits all methods from L. @@ -255,7 +298,7 @@ Tests code coverage report is available at L