X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=p5sagit%2FDevel-REPL.git;a=blobdiff_plain;f=lib%2FDevel%2FREPL%2FPlugin%2FCompletionDriver%2FLexEnv.pm;h=44de708c746b75185b0e5de9ab0523f7292da5e1;hp=2011896584f9b3634613cdaeb8437d80ca57d1e4;hb=06df07674a6770b9bef20bff5bebc7ce648d4f35;hpb=314f229330cdc3be301a39eadb68ff8f2bf13043 diff --git a/lib/Devel/REPL/Plugin/CompletionDriver/LexEnv.pm b/lib/Devel/REPL/Plugin/CompletionDriver/LexEnv.pm index 2011896..44de708 100644 --- a/lib/Devel/REPL/Plugin/CompletionDriver/LexEnv.pm +++ b/lib/Devel/REPL/Plugin/CompletionDriver/LexEnv.pm @@ -14,11 +14,7 @@ around complete => sub { my $orig = shift; my ($self, $text, $document) = @_; - # recursively find the last element - my $last = $document; - while ($last->can('last_element') && defined($last->last_element)) { - $last = $last->last_element; - } + my $last = $self->last_ppi_element($document); return $orig->(@_) unless $last->isa('PPI::Token::Symbol'); @@ -31,8 +27,20 @@ around complete => sub { map { $sigil eq '%' ? '%' . $_ : $_ } grep { /$re/ } map { substr($_, 1) } # drop lexical's sigil - keys %{$self->lexical_environment->get_context('_')}; + '$_REPL', keys %{$self->lexical_environment->get_context('_')}; }; 1; +__END__ + +=head1 NAME + +Devel::REPL::Plugin::CompletionDriver::LexEnv - Complete variable names in the REPL's lexical environment + +=head1 AUTHOR + +Shawn M Moore, C<< >> + +=cut +