summaryrefslogtreecommitdiff
path: root/Completion/User/_perl_modules
diff options
context:
space:
mode:
authorBart Schaefer <barts@users.sourceforge.net>2000-11-14 17:47:11 +0000
committerBart Schaefer <barts@users.sourceforge.net>2000-11-14 17:47:11 +0000
commitea807260e4027adfa100dd2b3dde31baa99fad4d (patch)
tree3088934546f34b628549c2599180f9b73ca01cab /Completion/User/_perl_modules
parent2d77bd0d58490cb5df833b9ccc3d479267f879f6 (diff)
downloadzsh-ea807260e4027adfa100dd2b3dde31baa99fad4d.tar.gz
zsh-ea807260e4027adfa100dd2b3dde31baa99fad4d.zip
Changes inspired by Paul J. in case multiple versions of perl are installed.
Diffstat (limited to 'Completion/User/_perl_modules')
-rw-r--r--Completion/User/_perl_modules58
1 files changed, 35 insertions, 23 deletions
diff --git a/Completion/User/_perl_modules b/Completion/User/_perl_modules
index 84273f7fa..2ac7e9cbb 100644
--- a/Completion/User/_perl_modules
+++ b/Completion/User/_perl_modules
@@ -20,7 +20,7 @@
_perl_modules () {
local opts
zparseopts -D -a opts S: q
-
+
# Set a sensible default caching policy. This has to be done inside
# this function otherwise we wouldn't know the context for the style.
local update_policy
@@ -29,54 +29,66 @@ _perl_modules () {
zstyle ":completion:${curcontext}:" cache-policy \
_perl_modules_caching_policy
fi
-
- if ( [[ ${+_perl_modules} -eq 0 ]] || _cache_invalid perl_modules ) &&
- ! _retrieve_cache perl_modules;
+
+ local perl=${words[0]%doc} perl_modules
+ if whence $perl >/dev/null; then
+ perl_modules=_${${perl//[^[:alnum:]]/_}#_}_modules
+ elif (( ${+commands[perl]} )); then
+ perl=perl
+ perl_modules=_perl_modules
+ else
+ perl=
+ perl_modules=_unknown_perl_modules
+ fi
+
+ if ( [[ ${(P)+perl_modules} -eq 0 ]] || _cache_invalid $perl_modules ) &&
+ ! _retrieve_cache ${perl_modules#_};
then
if zstyle -t ":completion:${curcontext}:modules" try-to-use-pminst &&
(( ${+commands[pminst]} ));
then
- _perl_modules=( $(pminst) )
+ set -A $perl_modules $(pminst)
else
local inc libdir new_pms
- if (( ${+commands[perl]} )); then
- inc=( $( perl -e 'print "@INC"' ) )
+
+ if [[ ${+perl} -eq 1 ]]; then
+ inc=( $( $perl -e 'print "@INC"' ) )
else
# If perl isn't there, one wonders why the user's trying to
# complete Perl modules. Maybe her $path is wrong?
_message "Didn't find perl on \$PATH; guessing @INC ..."
-
+
inc=( /usr/lib/perl5{,/{site_perl/,}<5->.([0-9]##)}(N)
${(s.:.)PERL5LIB} )
fi
-
- typeset -agU _perl_modules # _perl_modules is global, no duplicates
- _perl_modules=( )
-
+
+ typeset -agU $perl_modules # $perl_modules is global, no duplicates
+ set -A $perl_modules
+
for libdir in $inc; do
# Ignore cwd - could be too expensive e.g. if we're near /
if [[ $libdir == '.' ]]; then break; fi
-
+
# Find all modules
if [[ -d $libdir && -x $libdir ]]; then
- cd $libdir
+ builtin cd $libdir
new_pms=( {[A-Z]*/***/,}*.pm~*blib* )
- cd $OLDPWD
+ builtin cd $OLDPWD
fi
-
+
# Convert to Perl nomenclature
new_pms=( ${new_pms:r:fs#/#::#} )
-
- _perl_modules=( $new_pms $_perl_modules )
+
+ set -A $perl_modules $new_pms ${(P)perl_modules}
done
fi
-
- _store_cache perl_modules _perl_modules
+
+ _store_cache ${perl_modules#_} $perl_modules
fi
-
+
local expl
-
- _wanted modules expl 'Perl modules' compadd "$opts[@]" -a _perl_modules
+
+ _wanted modules expl 'Perl modules' compadd "$opts[@]" -a $perl_modules
}
_perl_modules_caching_policy () {