diff options
author | Jesse Luehrs <doy@tozt.net> | 2013-05-30 03:12:25 -0500 |
---|---|---|
committer | Jesse Luehrs <doy@tozt.net> | 2013-05-30 03:12:25 -0500 |
commit | 071e98547d4dda83c29ea87cd4cff9115667bf24 (patch) | |
tree | 5b20f0019eb42b385f7a452c973991a1149ef625 /lib/App/REPL/Plugin/Packages.pm | |
parent | 34218fd2af78b254dd424de2289981621ee85f94 (diff) | |
download | reply-071e98547d4dda83c29ea87cd4cff9115667bf24.tar.gz reply-071e98547d4dda83c29ea87cd4cff9115667bf24.zip |
split evaluate into compile and execute
Diffstat (limited to 'lib/App/REPL/Plugin/Packages.pm')
-rw-r--r-- | lib/App/REPL/Plugin/Packages.pm | 15 |
1 files changed, 10 insertions, 5 deletions
diff --git a/lib/App/REPL/Plugin/Packages.pm b/lib/App/REPL/Plugin/Packages.pm index d35d3f0..c1c02d0 100644 --- a/lib/App/REPL/Plugin/Packages.pm +++ b/lib/App/REPL/Plugin/Packages.pm @@ -13,18 +13,23 @@ sub new { return $self; } -sub evaluate { +sub mangle_line { my $self = shift; - my ($next, $line, %args) = @_; + my ($line) = @_; + + return "package $self->{package}; $line; BEGIN { \$" . __PACKAGE__ . "::package = __PACKAGE__ }"; +} + +sub compile { + my $self = shift; + my ($next, @args) = @_; # XXX it'd be nice to avoid using globals here, but we can't use # eval_closure's environment parameter since we need to access the # information in a BEGIN block our $package = $self->{package}; - $line = "package $package; $line; BEGIN { \$" . __PACKAGE__ . "::package = __PACKAGE__ }"; - - my @result = $next->($line, %args); + my @result = $next->(@args); $self->{package} = $package; |