Closes Alioth #311614 Globbing might occur if $cur contains one of these globbing characters: * ? [ ] The bug becomes apparent: On Cygwin if the glob-string contains backslashes as well, causing a warning (Cygwin >= 1.7): MS-DOS style path detected: ... Preferred POSIX equivalent is: ... CYGWIN environment variable option "nodosfilewarning" turns off this warning. Consult the user's guide for more details about POSIX paths: http://cygwin.com/cygwin-ug-net/using.html#using-pathnames On Linux, using strace, you can see bash-completion doing an unnecessary `open' system call. Steps to reproduce on Linux using `strace': Environment: Linux, bash-completion-1.0 1. Start bash with bash-completion loaded and find out PID ($$): $ echo $$ MYPID 2. In a second bash shell, `strace' the above PID: $ strace -e trace=open -f -o strace.log -p MYPID 3. Within the first bash shell, type: $ cur="?"; _kernel_versions 4. In the second bash shell, type ^C to quick `strace'. 5. Check `strace.log', here you can see bash accessing something it shouldn't: ... open(".", O_RDONLY|O_NONBLOCK|O_LARGEFILE|O_DIRECTORY|O_CLOEXEC) = 3 ... 6. The above call to `open' disappears if $cur in _kernel_versions gets quoted, and you repeat the steps above: _kernel_versions() { COMPREPLY=( $( compgen -W '$( command ls /lib/modules )' -- "$cur" ) ) }
95 lines
1.7 KiB
Bash
95 lines
1.7 KiB
Bash
# -*- mode: shell-script; sh-basic-offset: 8; indent-tabs-mode: t -*-
|
|
# ex: ts=8 sw=8 noet filetype=sh
|
|
#
|
|
# bash completion for update-alternatives
|
|
|
|
have update-alternatives && {
|
|
_installed_alternatives()
|
|
{
|
|
local admindir
|
|
# find the admin dir
|
|
for i in alternatives dpkg/alternatives rpm/alternatives; do
|
|
[ -d /var/lib/$i ] && admindir=/var/lib/$i && break
|
|
done
|
|
for (( i=1; i < COMP_CWORD; i++ )); do
|
|
if [[ "${COMP_WORDS[i]}" == --admindir ]]; then
|
|
admindir=${COMP_WORDS[i+1]}
|
|
break
|
|
fi
|
|
done
|
|
COMPREPLY=( $( compgen -W '$( command ls $admindir )' -- "$cur" ) )
|
|
}
|
|
|
|
_update_alternatives()
|
|
{
|
|
local cur prev mode args i
|
|
|
|
COMPREPLY=()
|
|
cur=`_get_cword`
|
|
prev=${COMP_WORDS[COMP_CWORD-1]}
|
|
|
|
case "$prev" in
|
|
--@(altdir|admindir))
|
|
_filedir -d
|
|
return 0
|
|
;;
|
|
--@(help|version))
|
|
return 0
|
|
;;
|
|
esac
|
|
|
|
# find which mode to use and how many real args used so far
|
|
for (( i=1; i < COMP_CWORD; i++ )); do
|
|
if [[ "${COMP_WORDS[i]}" == --@(install|remove|auto|display|config|remove-all) ]]; then
|
|
mode=${COMP_WORDS[i]}
|
|
args=$(($COMP_CWORD - i))
|
|
break
|
|
fi
|
|
done
|
|
|
|
case $mode in
|
|
--install)
|
|
case $args in
|
|
1)
|
|
_filedir
|
|
;;
|
|
2)
|
|
_installed_alternatives
|
|
;;
|
|
3)
|
|
_filedir
|
|
;;
|
|
esac
|
|
;;
|
|
--remove)
|
|
case $args in
|
|
1)
|
|
_installed_alternatives
|
|
;;
|
|
2)
|
|
_filedir
|
|
;;
|
|
esac
|
|
;;
|
|
--auto)
|
|
_installed_alternatives
|
|
;;
|
|
--remove-all)
|
|
_installed_alternatives
|
|
;;
|
|
--display)
|
|
_installed_alternatives
|
|
;;
|
|
--config)
|
|
_installed_alternatives
|
|
;;
|
|
*)
|
|
COMPREPLY=( $( compgen -W '--verbose --quiet --help --version \
|
|
--altdir --admindir' -- "$cur" ) \
|
|
$( compgen -W '--install --remove --auto --display \
|
|
--config' -- "$cur" ) )
|
|
esac
|
|
}
|
|
complete -F _update_alternatives update-alternatives alternatives
|
|
}
|