X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=p5sagit%2FDevel-REPL.git;a=blobdiff_plain;f=lib%2FDevel%2FREPL.pm;h=89c3a8b55cb9aad4ee57ba6f3831cedf5e75201a;hp=3a6db51851ed9c1bc44070433964c1a9ab3b4e92;hb=911a1c242561b001192b9541b3aa813fe0b70b41;hpb=afe61f9c1991af3ae964bd2e34056a0b4e50ff13 diff --git a/lib/Devel/REPL.pm b/lib/Devel/REPL.pm index 3a6db51..89c3a8b 100644 --- a/lib/Devel/REPL.pm +++ b/lib/Devel/REPL.pm @@ -32,7 +32,7 @@ sub run_once { my ($self) = @_; my $line = $self->read; return unless defined($line); # undefined value == EOF - my @ret = $self->execute($line); + my @ret = $self->eval($line); $self->print(@ret); return 1; } @@ -42,13 +42,43 @@ sub read { return $self->term->readline($self->prompt); } +sub eval { + my ($self, $line) = @_; + my ($to_exec, @rest) = $self->compile($line); + return @rest unless defined($to_exec); + my @ret = $self->execute($to_exec); + return @ret; +} + +sub compile { + my ($self, $line) = @_; + my $compiled = eval $self->wrap_as_sub($line); + return (undef, $self->error_return("Compile error", $@)) if $@; + return $compiled; +} + +sub wrap_as_sub { + my ($self, $line) = @_; + return qq!sub {\n!.$self->mangle_line($line).qq!\n}\n!; +} + +sub mangle_line { + my ($self, $line) = @_; + return $line; +} + sub execute { - my ($self, $to_exec) = @_; - my @ret = eval $to_exec; - @ret = ("ERROR: $@") if $@; + my ($self, $to_exec, @args) = @_; + my @ret = eval { $to_exec->(@args) }; + return $self->error_return("Runtime error", $@) if $@; return @ret; } +sub error_return { + my ($self, $type, $error) = @_; + return "${type}: ${error}"; +} + sub print { my ($self, @ret) = @_; my $fh = $self->out_fh;