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%2FINC.pm;fp=lib%2FDevel%2FREPL%2FPlugin%2FCompletionDriver%2FINC.pm;h=6b882dd59def774ec233c6e7451a96eb7cc48a00;hp=0166c8c1543f70cfe0dbcac8fed6a6852c5ed659;hb=16d29e4242cfb095bdcd65a16fb3b4d4d0013240;hpb=c5cdacc287ddd3f003feec2c473f1661d4bb317f diff --git a/lib/Devel/REPL/Plugin/CompletionDriver/INC.pm b/lib/Devel/REPL/Plugin/CompletionDriver/INC.pm index 0166c8c..6b882dd 100644 --- a/lib/Devel/REPL/Plugin/CompletionDriver/INC.pm +++ b/lib/Devel/REPL/Plugin/CompletionDriver/INC.pm @@ -57,6 +57,9 @@ around complete => sub { my @found; + # most VCSes don't litter every single fucking directory with garbage. if you + # know of any other, just stick them in here. noone wants to complete + # Devel::REPL::Plugin::.svn my %ignored = ( '.' => 1, @@ -64,6 +67,7 @@ around complete => sub { '.svn' => 1, ); + # this will take a directory and add to @found all of the possible matches my $add_recursively; $add_recursively = sub { my ($path, $iteration, @more) = @_; @@ -90,9 +94,13 @@ around complete => sub { } }; + # look through all of INC: for (@INC) { my $path = $_; + + # match all of the fragments they have, so "use Moose::Meta::At" + # will only begin looking in ../Moose/Meta/ for my $subdir (@directories) { $path = File::Spec->catdir($path, $subdir);