X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FDevel%2FREPL%2FPlugin%2FCompletionDriver%2FLexEnv.pm;h=ea05e9ae1e918839dbea43b0162a88724f789d2b;hb=79697f6184b05e3778e6090166d5bd9fcbd243b9;hp=f346bda9d5e31bbc08be30ade53fc72a866f329e;hpb=8051a5e0e588f2c30779c2e2982f33e6fb27fda9;p=p5sagit%2FDevel-REPL.git diff --git a/lib/Devel/REPL/Plugin/CompletionDriver/LexEnv.pm b/lib/Devel/REPL/Plugin/CompletionDriver/LexEnv.pm index f346bda..ea05e9a 100644 --- a/lib/Devel/REPL/Plugin/CompletionDriver/LexEnv.pm +++ b/lib/Devel/REPL/Plugin/CompletionDriver/LexEnv.pm @@ -2,12 +2,9 @@ package Devel::REPL::Plugin::CompletionDriver::LexEnv; use Devel::REPL::Plugin; use namespace::clean -except => [ 'meta' ]; -sub AFTER_PLUGIN { - my ($_REPL) = @_; - - if (!$_REPL->can('lexical_environment')) { - warn "Devel::REPL::Plugin::CompletionDriver::LexEnv requires Devel::REPL::Plugin::LexEnv."; - } +sub BEFORE_PLUGIN { + my $self = shift; + $self->load_plugin('Completion'); } around complete => sub { @@ -27,8 +24,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 +