Ville Skyttä 0f450219b6 Remove most "-o filenames" options to "complete".
Turn it on dynamically when needed instead; see doc/styleguide.txt for
a longer explanation.  This fixes many non-filename completions which
had been previously more or less broken due to unwanted
escape-as-filenames behavior.
2010-11-01 19:29:45 +02:00

42 lines
906 B
Bash

# POSIX sh(1) completion
have sh &&
_sh()
{
COMPREPLY=()
local cur prev
_get_comp_words_by_ref cur prev
case $prev in
-c)
return 0
;;
-o|+o)
COMPREPLY=( $( compgen -W 'allexport errexit ignoreeof monitor
noclobber noglob noexec nolog notify nounset verbose vi
xtrace' -- "$cur" ) )
return 0
;;
esac
local opts="-a -b -C -e -f -h -i -m -n -o -u -v -x"
if [[ "$cur" == -* ]]; then
COMPREPLY=( $( compgen -W "$opts -c -s" -- "$cur" ) )
return 0
elif [[ "$cur" == +* ]]; then
COMPREPLY=( $( compgen -W "${opts//-/+}" -- "$cur" ) )
return 0
fi
_filedir sh
} &&
complete -F _sh sh
# Local variables:
# mode: shell-script
# sh-basic-offset: 4
# sh-indent-comment: t
# indent-tabs-mode: nil
# End:
# ex: ts=4 sw=4 et filetype=sh