summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJohn Southworth <john.southworth@vyatta.com>2011-10-03 13:18:25 -0500
committerJohn Southworth <john.southworth@vyatta.com>2011-10-03 13:19:00 -0500
commit3d07c1fe3b82db1c73c6b9b49784370dedbe30e8 (patch)
treedcfd4d9204326966e44c1d4bf7e3719fbcdf512a
parentd4e34d096acdab1fff309871270242f6e21aceeb (diff)
downloadvyatta-op-3d07c1fe3b82db1c73c6b9b49784370dedbe30e8.tar.gz
vyatta-op-3d07c1fe3b82db1c73c6b9b49784370dedbe30e8.zip
Make completion properly handle non-last-word completions
-rw-r--r--etc/bash_completion.d/vyatta-op42
1 files changed, 30 insertions, 12 deletions
diff --git a/etc/bash_completion.d/vyatta-op b/etc/bash_completion.d/vyatta-op
index 833d4a3..d76874a 100644
--- a/etc/bash_completion.d/vyatta-op
+++ b/etc/bash_completion.d/vyatta-op
@@ -302,6 +302,9 @@ _vyatta_op_invalid_completion ()
_vyatta_op_expand ()
{
+ # We need nospace here and we have to append our own spaces
+ compopt -o nospace
+
local restore_shopts=$( shopt -p extglob nullglob | tr \\n \; )
shopt -s extglob nullglob
local cur=""
@@ -315,13 +318,17 @@ _vyatta_op_expand ()
fi
if _vyatta_pipe_completion "${COMP_WORDS[@]}"; then
- if [ "${COMP_WORDS[*]}" == "$_vyatta_op_last_comp" ] ; then
+ if [ "${COMP_WORDS[*]}" == "$_vyatta_op_last_comp" ] ||
+ [ ${#_vyatta_pipe_completions[@]} -eq 0 ]; then
_vyatta_do_pipe_help
COMPREPLY=( "" " " )
_vyatta_op_last_comp=${_vyatta_op_last_comp_init}
else
COMPREPLY=( "${_vyatta_pipe_completions[@]}" )
_vyatta_op_last_comp="${COMP_WORDS[*]}"
+ if [ ${#COMPREPLY[@]} -eq 1 ]; then
+ COMPREPLY=( "${COMPREPLY[0]} " )
+ fi
fi
eval "$restore_shopts"
return
@@ -339,7 +346,7 @@ _vyatta_op_expand ()
return 1
fi
- if [ "${COMP_WORDS[*]}" != "$_vyatta_op_last_comp" ] ; then
+ if [ "${COMP_WORDS[*]:0:$[$COMP_CWORD+1]}" != "$_vyatta_op_last_comp" ] ; then
_vyatta_set_comptype
case $_vyatta_comptype in
'imagefiles')
@@ -361,11 +368,12 @@ _vyatta_op_expand ()
# if the last command line arg is empty and we have
# an empty completion option (meaning wild card),
# append a blank(s) to the completion array to force ambiguity
- if [ -z "$cur" ] ; then
+ if [ -z "$cur" ] ||
+ [[ "${COMPREPLY[0]}" =~ "$cur" ]]; then
for comp ; do
if [ -z "$comp" ] ; then
if [ ${#COMPREPLY[@]} -eq 0 ] ; then
- COMPREPLYu=( " " "" )
+ COMPREPLY=( " " "" )
elif _vyatta_op_comprely_needs_ambiguity ; then
COMPREPLY+=( " " )
fi
@@ -374,11 +382,21 @@ _vyatta_op_expand ()
fi
# Set this environment to enable and disable debugging on the fly
if [[ $DBG_OP_COMPS -eq 1 ]]; then
- echo "Current: $cur"
- echo "Number of comps: ${#_vyatta_op_completions[@]}"
- echo "Number of non-comps: ${#_vyatta_op_noncompletions[@]}"
- echo "Last comp: $_vyatta_op_last_comp"
- echo -e "Current comp: ${COMP_WORDS[*]}\n"
+ echo -e "\nCurrent: '$cur'"
+ echo "Number of comps: ${#_vyatta_op_completions[*]}"
+ echo "Number of non-comps: ${#_vyatta_op_noncompletions[*]}"
+ echo "_vyatta_op_completions: '${_vyatta_op_completions[*]}'"
+ echo "COMPREPLY: '${COMPREPLY[@]}'"
+ echo "CWORD: $COMP_CWORD"
+ echo "Last comp: '$_vyatta_op_last_comp'"
+ echo -e "Current comp: '${COMP_WORDS[*]:0:$[$COMP_CWORD+1]}'\n"
+ fi
+
+ # This is non obvious...
+ # To have completion continue to work when working with words that aren't the last word,
+ # we have to set nospace at the beginning of this script and then append the spaces here.
+ if [ ${#COMPREPLY[@]} -eq 1 ];then
+ COMPREPLY=( "${COMPREPLY[0]} " )
fi
# if there are no completions then handle invalid commands
if [ ${#_vyatta_op_noncompletions[@]} -eq 0 ] &&
@@ -390,9 +408,9 @@ _vyatta_op_expand ()
# Stop completions from getting stuck
elif [ ${#_vyatta_op_completions[@]} -eq 1 ] &&
[[ "${COMPREPLY[0]}" =~ "$cur" ]]; then
- _vyatta_op_last_comp="${COMP_WORDS[*]}"
+ _vyatta_op_last_comp=${_vyatta_op_last_comp_init}
# if there are no completions then always show the non-comps
- elif [ "${COMP_WORDS[*]}" == "$_vyatta_op_last_comp" ] ||
+ elif [ "${COMP_WORDS[*]:0:$[$COMP_CWORD+1]}" == "$_vyatta_op_last_comp" ] ||
[ ${#_vyatta_op_completions[@]} -eq 0 ]; then
_vyatta_op_help "$cur" \
${_vyatta_op_noncompletions[@]} \
@@ -401,7 +419,7 @@ _vyatta_op_expand ()
COMPREPLY=( "" " " )
_vyatta_op_last_comp=${_vyatta_op_last_comp_init}
else
- _vyatta_op_last_comp="${COMP_WORDS[*]}"
+ _vyatta_op_last_comp="${COMP_WORDS[*]:0:$[$COMP_CWORD+1]}"
fi
eval "$restore_shopts"