summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJohn Southworth <john.southworth@vyatta.com>2011-10-06 12:28:40 -0500
committerJohn Southworth <john.southworth@vyatta.com>2011-10-06 12:28:40 -0500
commit848a3848dec01b2fdeed26574b807634d12b1365 (patch)
tree3bc5a7c3e702e6086720fab0747ec71f17a3fb73
parentf5411f955624665b3c0b3e39ef6cffb2cb095b00 (diff)
downloadvyatta-cfg-848a3848dec01b2fdeed26574b807634d12b1365.tar.gz
vyatta-cfg-848a3848dec01b2fdeed26574b807634d12b1365.zip
Fix up completions for commit and compare
-rwxr-xr-xetc/bash_completion.d/vyatta-cfg55
1 files changed, 47 insertions, 8 deletions
diff --git a/etc/bash_completion.d/vyatta-cfg b/etc/bash_completion.d/vyatta-cfg
index 39fa1df..12e7e74 100755
--- a/etc/bash_completion.d/vyatta-cfg
+++ b/etc/bash_completion.d/vyatta-cfg
@@ -310,9 +310,12 @@ vyatta_rollback_complete ()
vyatta_compare_complete ()
{
# Generate completion help for the "compare" command
-
+
+ local current_prefix=$2
+ local current_word=$3
local restore_shopts=$( shopt -p extglob nullglob | tr \\n \; )
shopt -s extglob nullglob
+ compopt -o nospace
if [[ $COMP_CWORD -eq 0 ]];then
vyatta_config_complete "$@"
@@ -320,9 +323,18 @@ vyatta_compare_complete ()
return
fi
+ if [[ $DBG_CFG_COMPS -eq 1 ]];then
+ echo "In commit complete"
+ echo "args: '$@'"
+ echo "comp_cword: '$COMP_CWORD'"
+ echo "current_prefix: '$current_prefix'"
+ echo "COMP_WORDS: '${COMP_WORDS[@]}'"
+ fi
+
# Only provide completions after command name has been typed, but
# before any characters of the command argument have been entered.
- if [ $COMP_CWORD -eq 1 -a -z "${COMP_WORDS[1]}" ]; then
+ if [ $COMP_CWORD -eq 1 -a -z "${COMP_WORDS[1]}" ] ||
+ [ $COMP_CWORD -eq 1 -a -z "$current_prefix" ]; then
echo
echo "Possible completions:"
echo -e " <Enter>\tCompare working & active configurations"
@@ -332,6 +344,12 @@ vyatta_compare_complete ()
echo -e "\n Revisions:"
print_commit_log
COMPREPLY=( "" " " )
+ elif [[ -n "$current_prefix" ]] &&
+ [[ "saved" =~ "$current_prefix" ]] &&
+ [[ $COMP_CWORD -eq 1 ]]; then
+ COMPREPLY=( "saved " )
+ eval $restore_shopts
+ return
elif [ $COMP_CWORD -eq 2 -a -z "${COMP_WORDS[2]}" ]; then
if [[ "saved" =~ "${COMP_WORDS[1]}" ]]; then
echo -e "\nPossible completions:"
@@ -347,8 +365,9 @@ vyatta_compare_complete ()
echo -e "\n Revisions:"
print_commit_log
COMPREPLY=( "" " " )
- elif [ $COMP_CWORD -eq 1 ]; then
- COMPREPLY=$(compgen -W saved -- ${COMP_WORDS[$COMP_CWORD]})
+ elif [ $COMP_CWORD -eq 1 ] &&
+ [[ -n "$current_prefix" ]]; then
+ COMPREPLY=( "$current_prefix " )
else
echo -en "\nPossible completions:\n"
echo -en " <Enter>\tExecute the current command"
@@ -362,8 +381,11 @@ vyatta_commit_complete ()
{
# Generate completion help for the "commit-confirm" command
+ local current_prefix=$2
+ local current_word=$3
local restore_shopts=$( shopt -p extglob nullglob | tr \\n \; )
shopt -s extglob nullglob
+ compopt -o nospace
if [[ $COMP_CWORD -eq 0 ]];then
vyatta_config_complete "$@"
@@ -371,9 +393,18 @@ vyatta_commit_complete ()
return
fi
+ if [[ $DBG_CFG_COMPS -eq 1 ]];then
+ echo "In commit complete"
+ echo "args: '$@'"
+ echo "comp_cword: '$COMP_CWORD'"
+ echo "current_prefix: '$current_prefix'"
+ echo "COMP_WORDS: '${COMP_WORDS[@]}'"
+ fi
+
# Only provide completions after command name has been typed, but
# before any characters of the command argument have been entered.
- if [ $COMP_CWORD -eq 1 -a -z "${COMP_WORDS[1]}" ]; then
+ if [ $COMP_CWORD -eq 1 ] &&
+ [[ -z "$current_prefix" ]]; then
echo
echo "Possible completions:"
if [ "${COMP_WORDS[0]}" = "commit" ]; then
@@ -384,12 +415,20 @@ vyatta_commit_complete ()
fi
echo -e " comment\tComment for commit log"
COMPREPLY=( "" " " )
- elif [ "${COMP_WORDS[1]}" = "comment" ]; then
- echo
+ elif [[ ( -n "$current_prefix" && "comment" =~ "${current_prefix}" ) ]] &&
+ [[ $COMP_CWORD -eq 1 ]]; then
+ COMPREPLY=( "comment " )
+ eval $restore_shopts
+ return
+ elif [[ ( -n "${COMP_WORDS[1]}" && "comment" =~ "${COMP_WORDS[1]}" ) ]] &&
+ [[ $COMP_CWORD -eq 2 ]]; then
+ echo
echo "Possible completions:"
echo -e " <txt>\tText comment for commit log (e.g. \"add user bob\")"
COMPREPLY=( "" " " )
- elif [ $COMP_CWORD -eq 1 ]; then
+ eval $restore_shopts
+ return
+ elif [ $COMP_CWORD -eq 1 ];then
COMPREPLY=$(compgen -W comment -- ${COMP_WORDS[$COMP_CWORD]})
else
echo -en "\nPossible completions:\n"