blob: c0a81a9c1e551a8645cebc8a6a5e771b1a5e18ed (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
|
package Reply::Plugin::Autocomplete::Packages;
use strict;
use warnings;
# ABSTRACT: tab completion for package names
use base 'Reply::Plugin';
use Module::Runtime '$module_name_rx';
=head1 SYNOPSIS
; .replyrc
[ReadLine]
[Autocomplete::Packages]
=head1 DESCRIPTION
This plugin registers a tab key handler to autocomplete package names in Perl
code.
=cut
sub tab_handler {
my $self = shift;
my ($line) = @_;
# $module_name_rx does not permit trailing ::
my ($before, $package_fragment) = $line =~ /(.*?)(${module_name_rx}:?:?)$/;
return unless $package_fragment;
return if $before =~ /->\s*$/; # method call
return if $before =~ /[\$\@\%\&\*]\s*$/;
my $file_fragment = $package_fragment;
$file_fragment =~ s{::}{/}g;
my $re = qr/^\Q$file_fragment/;
my @results;
for my $inc (keys %INC) {
if ($inc =~ $re) {
$inc =~ s{/}{::}g;
$inc =~ s{\.pm$}{};
push @results, $inc;
}
}
push @results,
grep m/^\Q$package_fragment/,
@{$self->{moar_packages}||=[]};
return @results;
}
# listen for events from the Packages plugin, for its wise wisdom
# can teach us about packages that are not in %INC
sub package {
my $self = shift;
my ($pkg) = @_;
push @{$self->{moar_packages}||=[]}, $pkg;
}
1;
|