diff options
Diffstat (limited to 'contrib/perl')
-rw-r--r-- | contrib/perl | 34 |
1 files changed, 17 insertions, 17 deletions
diff --git a/contrib/perl b/contrib/perl index 77fac477..67996f94 100644 --- a/contrib/perl +++ b/contrib/perl @@ -4,7 +4,8 @@ have perl && { _perlmodules() { - COMPREPLY=( $( compgen -P "$prefix" -W "$( perl -e 'sub mods { my ($base,$dir)=@_; return if $base !~ /^\Q$ENV{cur}/; chdir($dir) or return; for (glob(q[*.pm])) {s/\.pm$//; print qq[$base$_\n]}; mods(/^(?:[.\d]+|$Config{archname}-$Config{osname}|auto)$/ ? undef : qq[${base}${_}\\\\:\\\\:],qq[$dir/$_]) for grep {-d} glob(q[*]); } mods(undef,$_) for @INC;' )" -- "$cur" ) ) + COMPREPLY=( $( compgen -P "$prefix" -W "$( perl -e 'sub mods { my ($base,$dir)=@_; return if $base !~ /^\Q$ENV{cur}/; chdir($dir) or return; for (glob(q[*.pm])) {s/\.pm$//; print qq[$base$_\n]}; mods(/^(?:[.\d]+|$Config{archname}-$Config{osname}|auto)$/ ? undef : qq[${base}${_}::],qq[$dir/$_]) for grep {-d} glob(q[*]); } mods(undef,$_) for @INC;' )" -- "$cur" ) ) + __ltrim_colon_completions "$1" } _perl() @@ -13,8 +14,7 @@ _perl() local optPrefix optSuffix COMPREPLY=() - cur=`_get_cword` - prev=${COMP_WORDS[COMP_CWORD-1]} + _get_comp_words_by_ref -n : cur prev prefix="" # If option not followed by whitespace, reassign prev and cur @@ -28,34 +28,33 @@ _perl() fi # only handle module completion for now - case "$prev" in + case $prev in -I|-x) local IFS=$'\t\n' COMPREPLY=( $( compgen -d $optPrefix $optSuffix -- "$cur" ) ) return 0 ;; -m|-M) - _perlmodules + _perlmodules "$cur" return 0 ;; esac if [[ "$cur" == -* ]]; then - COMPREPLY=( $( compgen -W '-C -s -T -u -U -W -X -h -v -V -c -w -d \ - -D -p -n -a -F -l -0 -I -m -M -P -S -x -i -e ' -- "$cur" ) ) + COMPREPLY=( $( compgen -W '-C -s -T -u -U -W -X -h -v -V -c -w -d \ + -D -p -n -a -F -l -0 -I -m -M -P -S -x -i -e ' -- "$cur" ) ) else _filedir fi } -complete -F _perl $nospace $filenames perl +complete -F _perl -o nospace -o filenames perl _perldoc() { local cur prev prefix temp COMPREPLY=() - cur=`_get_cword` - prev=${COMP_WORDS[COMP_CWORD-1]} + _get_comp_words_by_ref -n : cur prev prefix="" # completing an option (may or may not be separated by a space) @@ -76,14 +75,14 @@ _perldoc() shift splice unshift grep join map qw reverse sort unpack \ delete each exists keys values binmode close closedir \ dbmclose dbmopen die eof fileno flock format getc print \ - printf read readdir rewinddir seek seekdir select syscall \ + printf read readdir rewinddir say seek seekdir select syscall \ sysread sysseek syswrite tell telldir truncate warn write \ pack read syscall sysread syswrite unpack vec -X chdir chmod \ chown chroot fcntl glob ioctl link lstat mkdir open opendir \ readlink rename rmdir stat symlink umask unlink utime caller \ continue do dump eval exit goto last next redo return \ - sub wantarray caller import local my our package use defined \ - formline reset scalar undef \ + sub wantarray break caller import local my our state package \ + use defined formline reset scalar undef \ alarm exec fork getpgrp getppid getpriority kill pipe qx \ setpgrp setpriority sleep system times wait waitpid \ import no package require use bless dbmclose dbmopen package \ @@ -97,7 +96,7 @@ _perldoc() getnetbyaddr getnetbyname getnetent getprotobyname \ getprotobynumber getprotoent getservbyname getservbyport \ getservent sethostent setnetent setprotoent setservent \ - gmtime localtime time times' -- "$cur" ) ) + gmtime localtime time times lock' -- "$cur" ) ) return 0 ;; esac @@ -107,15 +106,16 @@ _perldoc() else # return available modules (unless it is clearly a file) if [[ "$cur" != */* ]]; then - _perlmodules + _perlmodules "$cur" COMPREPLY=( "${COMPREPLY[@]}" $( compgen -W \ '$( PAGER=/bin/cat man perl | \ sed -ne "/perl.*Perl overview/,/perlwin32/p" | \ - awk "\$NF=2 { print \$1}" | grep perl )' -- "$cur" ) ) + awk "\$NF=2 { print \$1}" | command grep perl )' -- "$cur" ) ) fi + _filedir '@(pl|PL|pm|PM|pod|POD)' fi } -complete -F _perldoc $default perldoc +complete -F _perldoc -o bashdefault perldoc } # Local variables: |