]> git.vpit.fr Git - perl/modules/B-RecDeparse.git/commitdiff
Fix recursing into all gv's
authorVincent Pit <vince@profvince.com>
Wed, 20 Aug 2008 14:20:48 +0000 (16:20 +0200)
committerVincent Pit <vince@profvince.com>
Wed, 20 Aug 2008 14:20:48 +0000 (16:20 +0200)
lib/B/RecDeparse.pm
t/12-level.t

index 7244ec59e337b6174e8552216f66c8b23dd4cac1..c1e235e0399857eb7dd2e1d4e6d43cf418f7d902 100644 (file)
@@ -122,19 +122,20 @@ if (FOOL_SINGLE_DELIM) {
 
 sub pp_entersub {
  my $self = shift;
- $self->{brd_sub} = 1;
- my $body = $self->SUPER::pp_entersub(@_);
- $self->{brd_sub} = 0;
+ my $body = do {
+  local $self->{brd_sub} = 1;
+  $self->SUPER::pp_entersub(@_);
+ };
  $body =~ s/^&\s*(\w)/$1/ if $self->_recurse;
  return $body;
 }
 
 sub pp_refgen {
  my $self = shift;
- $self->{brd_sub} = 0;
my $body = $self->SUPER::pp_refgen(@_);
$self->{brd_sub} = 1;
- return $body;
+ return do {
 local $self->{brd_sub} = 0;
 $self->SUPER::pp_refgen(@_);
+ }
 }
 
 sub pp_gv {
@@ -144,9 +145,10 @@ sub pp_gv {
   $body = $self->SUPER::pp_gv(@_);
  } else {
   my $gv = $self->gv_or_padgv($_[0]);
-  ++$self->{brd_cur};
-  $body = 'sub ' . $self->indent($self->deparse_sub($gv->CV));
-  --$self->{brd_cur};
+  $body = do {
+   local @{$self}{qw/brd_sub brd_cur/} = (0, $self->{brd_cur} + 1);
+   'sub ' . $self->indent($self->deparse_sub($gv->CV));
+  };
   if (FOOL_SINGLE_DELIM) {
    $body = $key . $body;
   } else {
index a5b616377f37a695ae3e1602fd72dc93b78156a1..5c1b95ae69e5016ee5da946098f423e1d829db16 100644 (file)
@@ -3,7 +3,7 @@
 use strict;
 use warnings;
 
-use Test::More tests => (3 + 3) * 5;
+use Test::More tests => (3 + 3) * 5 + 1;
 
 use B::Deparse;
 use B::RecDeparse;
@@ -44,3 +44,7 @@ which $brd, [ ], [ qw/add mul fma/ ], 2;
 
 $brd = B::RecDeparse->new(deparse => [ $br_args ], level => 3);
 which $brd, [ ], [ qw/add mul fma/ ], 2;
+
+sub fakegv { return @_ }
+eval { $brd->coderef2text(sub { return fakegv() }) };
+is($@, '', 'don\'t croak on non-CV GV\'s at level >= 1');