X-Git-Url: http://git.vpit.fr/?a=blobdiff_plain;f=lib%2FB%2FRecDeparse.pm;h=35333fa72f97e900b60c64f2c35aa830602e1d6a;hb=a62d5a0296ab9eb32539e1644bf11bf52b09ab9f;hp=4f7b6361b923df0890348b39038f68f1167a5aa6;hpb=e4de83a1e5557e69ecdaa3ac6c61a73b73da0bc0;p=perl%2Fmodules%2FB-RecDeparse.git diff --git a/lib/B/RecDeparse.pm b/lib/B/RecDeparse.pm index 4f7b636..35333fa 100644 --- a/lib/B/RecDeparse.pm +++ b/lib/B/RecDeparse.pm @@ -5,9 +5,11 @@ use 5.008; use strict; use warnings; +use B (); + use Config; -use base qw/B::Deparse/; +use base qw; =head1 NAME @@ -35,13 +37,16 @@ our $VERSION = '0.04'; This module extends L by making it recursively replace subroutine calls encountered when deparsing. -Please refer to L documentation for what to do and how to do it. Besides the constructor syntax, everything should work the same for the two modules. +Please refer to L documentation for what to do and how to do it. +Besides the constructor syntax, everything should work the same for the two modules. =head1 METHODS =head2 C<< 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. The C option expects an integer that specifies how many levels of recursions are allowed : C<-1> means infinite while C<0> means none and match L behaviour. +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. +The C option expects an integer that specifies how many levels of recursions are allowed : C<-1> means infinite while C<0> means none and match L behaviour. =cut @@ -114,8 +119,9 @@ sub compile { sub init { my $self = shift; - $self->{brd_cur} = 0; - $self->{brd_sub} = 0; + $self->{brd_cur} = 0; + $self->{brd_sub} = 0; + $self->{brd_seen} = { }; $self->SUPER::init(@_); } @@ -137,6 +143,19 @@ if (FOOL_SINGLE_DELIM) { } } +sub deparse_sub { + my $self = shift; + my $cv = $_[0]; + + my $name; + unless ($cv->CvFLAGS & B::CVf_ANON()) { + $name = $cv->GV->SAFENAME; + } + + local $self->{brd_seen}->{$name} = 1 if defined $name; + return $self->SUPER::deparse_sub(@_); +} + sub pp_entersub { my $self = shift; @@ -162,14 +181,17 @@ sub pp_refgen { sub pp_gv { my $self = shift; + my $gv = $self->gv_or_padgv($_[0]); + my $name = $gv->NAME; + my $seen = $self->{brd_seen}; + my $body; - if ($self->{brd_sub} <= 0 || !$self->_recurse) { + if ($self->{brd_sub} <= 0 || !$self->_recurse || $seen->{$name}) { $body = $self->SUPER::pp_gv(@_); } else { - my $gv = $self->gv_or_padgv($_[0]); - $body = do { - local @{$self}{qw/brd_sub brd_cur/} = (0, $self->{brd_cur} + 1); + local @{$self}{qw} = (0, $self->{brd_cur} + 1); + local $seen->{$name} = 1; 'sub ' . $self->indent($self->deparse_sub($gv->CV)); }; @@ -187,13 +209,16 @@ sub pp_gv { =head2 C +=head2 C + =head2 C =head2 C =head2 C -Functions and methods from L reimplemented by this module. Never call them directly. +Functions and methods from L reimplemented by this module. +Never call them directly. Otherwise, L inherits all methods from L. @@ -213,7 +238,8 @@ You can contact me by mail or on C (vincent). =head1 BUGS -Please report any bugs or feature requests to C, or through the web interface at L. I will be notified, and then you'll automatically be notified of progress on your bug as I make changes. +Please report any bugs or feature requests to C, or through the web interface at L. +I will be notified, and then you'll automatically be notified of progress on your bug as I make changes. =head1 SUPPORT @@ -225,7 +251,7 @@ Tests code coverage report is available at L