From: matthewt Date: Fri, 1 Jun 2007 01:19:57 +0000 (+0000) Subject: rewritten working with no regexps X-Git-Tag: v1.003015~165 X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=commitdiff_plain;h=ae5e19ec178afa6178efb13d556c781800ece6ca;p=p5sagit%2FDevel-REPL.git rewritten working with no regexps git-svn-id: http://dev.catalyst.perl.org/repos/bast/trunk/Devel-REPL@3458 bd8105ee-0ff8-0310-8827-fb3f25b6796d --- diff --git a/lib/Devel/REPL/Plugin/Packages.pm b/lib/Devel/REPL/Plugin/Packages.pm index 5d8ff78..1c149e2 100644 --- a/lib/Devel/REPL/Plugin/Packages.pm +++ b/lib/Devel/REPL/Plugin/Packages.pm @@ -1,48 +1,49 @@ -# First cut at handling packages. -# -# doesn't work very well, and totally doesn't work with the wrap_as_sub -# stuff ;) For comments only really - package Devel::REPL::Plugin::Packages; use Moose::Role; +use vars qw($PKG_SAVE); has 'current_package' => ( isa => 'Str', is => 'rw', - default => 'main', + default => 'Devel::REPL::Plugin::Packages::DefaultScratchpad', lazy => 1 ); +around 'wrap_as_sub' => sub { + my $orig = shift; + my ($self, @args) = @_; + my $line = $self->$orig(@args); + # prepend package def before sub { ... } + return q!package !.$self->current_package.qq!;\n${line}!; +}; + +around 'mangle_line' => sub { + my $orig = shift; + my ($self, @args) = @_; + my $line = $self->$orig(@args); + # add a BEGIN block to set the package around at the end of the sub + # without mangling the return value (we save it off into a global) + $line .= '; BEGIN { $Devel::REPL::Plugin::Packages::PKG_SAVE = __PACKAGE__; }'; + return $line; +}; + +after 'execute' => sub { + my ($self) = @_; + # if we survived execution successfully, save the new package out the global + $self->current_package($PKG_SAVE); +}; + around 'eval' => sub { -# we don't call forward to $orig here, since the new sub-wrapped system -# doesn't work. We spot package declarations and retain the name so -# that we can reenter the package for each statement. Not sure the -# regex is bob on, but then it doesn't work anyway... - my $orig=shift; - my ($self, $line)=@_; - - my @ret=("OOPS: ".__PACKAGE__.'$ret unset!'); - -# $self->print("Line is: $line"); - if($line=~/\s*package\s([\w:]*)/) { -# $self->print("Recognised as a package switch"); -# $ret=$self->$orig($line); - @ret=eval $line; -# $self->print("ret: @ret"); - # should check for good return here - $self->current_package($1); -# $self->print('curr pkg: '.$self->current_package); - } else { -# $self->print("Not a package switch"); - my $packaged_line='package ' . $self->current_package . '; '.$line; -# $self->print("packaged line: $packaged_line"); -# @ret=$self->$orig($packaged_line); - @ret=eval $packaged_line; -# $self->print("ret: @ret"); - } - return @ret; + my $orig = shift; + my ($self, @args) = @_; + # localise the $PKG_SAVE global in case of nested evals + local $PKG_SAVE; + return $self->$orig(@args); }; -1; +package Devel::REPL::Plugin::Packages::DefaultScratchpad; +# declare empty scratchpad package for cleanliness + +1;