X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FDevel%2FDeclare%2FContext%2FSimple.pm;h=474025a6965f48ca8dfe4f9faa907b73bc35fe35;hb=7a3f5539a13e5f8996301deb181e65ee66687819;hp=7b0f7407edf086e419535eca6ddf8c35fb34a3a9;hpb=b0a896321dc9c1d61dc59c4c1b32cb8f920123ca;p=p5sagit%2FDevel-Declare.git diff --git a/lib/Devel/Declare/Context/Simple.pm b/lib/Devel/Declare/Context/Simple.pm index 7b0f740..474025a 100644 --- a/lib/Devel/Declare/Context/Simple.pm +++ b/lib/Devel/Declare/Context/Simple.pm @@ -5,7 +5,6 @@ use B::Hooks::EndOfScope; use strict; use warnings; -sub DEBUG { warn "@_" } sub new { my $class = shift; bless {@_}, $class; @@ -30,14 +29,26 @@ sub skipspace { $self->offset += Devel::Declare::toke_skipspace( $self->offset ); } +sub get_linestr { + my $self = shift; + my $line = Devel::Declare::get_linestr(); + return $line; +} + +sub set_linestr { + my $self = shift; + my ($line) = @_; + Devel::Declare::set_linestr($line); +} + sub strip_name { my $self = shift; $self->skipspace; if (my $len = Devel::Declare::toke_scan_word( $self->offset, 1 )) { - my $linestr = Devel::Declare::get_linestr(); + my $linestr = $self->get_linestr(); my $name = substr( $linestr, $self->offset, $len ); substr( $linestr, $self->offset, $len ) = ''; - Devel::Declare::set_linestr($linestr); + $self->set_linestr($linestr); return $name; } @@ -49,17 +60,25 @@ sub strip_proto { my $self = shift; $self->skipspace; - my $linestr = Devel::Declare::get_linestr(); + my $linestr = $self->get_linestr(); if (substr($linestr, $self->offset, 1) eq '(') { my $length = Devel::Declare::toke_scan_str($self->offset); - my $proto = Devel::Declare::get_lex_stuff(); + my $proto = Devel::Declare::get_lex_stuff(); Devel::Declare::clear_lex_stuff(); - $linestr = Devel::Declare::get_linestr(); + if( $length < 0 ) { + # Need to scan ahead more + $linestr .= $self->get_linestr(); + $length = rindex($linestr, ")") - $self->offset + 1; + } + else { + $linestr = $self->get_linestr(); + } + substr($linestr, $self->offset, $length) = ''; - Devel::Declare::set_linestr($linestr); + $self->set_linestr($linestr); + return $proto; } - return; } @@ -80,11 +99,11 @@ sub inject_if_block { $self->skipspace; - my $linestr = Devel::Declare::get_linestr; + my $linestr = $self->get_linestr; if (substr($linestr, $self->offset, 1) eq '{') { substr($linestr, $self->offset + 1, 0) = $inject; substr($linestr, $self->offset, 0) = $before; - Devel::Declare::set_linestr($linestr); + $self->set_linestr($linestr); } }