diff options
author | John Southworth <john.southworth@vyatta.com> | 2011-07-29 20:39:22 -0700 |
---|---|---|
committer | John Southworth <john.southworth@vyatta.com> | 2011-07-29 20:39:22 -0700 |
commit | cb6147ccd181a606628089a4222d933ed6145e9c (patch) | |
tree | cd5965019ccdf8725c4acf826d6e1a6861426024 /etc | |
parent | 78f3881862cf4890c0037e59ff4187cde812f716 (diff) | |
download | vyatta-op-cb6147ccd181a606628089a4222d933ed6145e9c.tar.gz vyatta-op-cb6147ccd181a606628089a4222d933ed6145e9c.zip |
Bugfix 2823: Operational mode command interpreter
Diffstat (limited to 'etc')
-rw-r--r-- | etc/bash_completion.d/vyatta-op | 26 | ||||
-rw-r--r-- | etc/bash_completion.d/vyatta-op-run | 62 |
2 files changed, 75 insertions, 13 deletions
diff --git a/etc/bash_completion.d/vyatta-op b/etc/bash_completion.d/vyatta-op index 5ac807e..7d6ddb5 100644 --- a/etc/bash_completion.d/vyatta-op +++ b/etc/bash_completion.d/vyatta-op @@ -101,18 +101,23 @@ _vyatta_op_init () complete -E -F _vyatta_op_expand complete -D -F _vyatta_op_default_expand - for xd in $vyatta_op_templates/* ; do - if [ -d $xd ] ; then - cmd=${xd##*/} - complete -F _vyatta_op_expand $cmd - eval alias $cmd=\'_vyatta_op_run $cmd\' - fi + # create the top level aliases for the unambiguous portions of the commands + # this is the only place we need an entire enumerated list of the subcommands + for cmd in $( ls /opt/vyatta/share/vyatta-op/templates/ ); do + for pos in $(seq 1 ${#cmd}); do + case ${cmd:0:$pos} in + for|do|done|if|fi|case|while|tr ) + continue ;; + *) ;; + esac + complete -F _vyatta_op_expand ${cmd:0:$pos} + eval alias ${cmd:0:$pos}=\'_vyatta_op_run ${cmd:0:$pos}\' + done done shopt -s histverify } - # $1: label # $2...: help _vyatta_op_print_help () @@ -177,10 +182,13 @@ _vyatta_op_help () _vyatta_op_set_node_path () { + local node _vyatta_op_node_path=$vyatta_op_templates for (( i=0 ; i<COMP_CWORD ; i++ )) ; do - if [ -f "${_vyatta_op_node_path}/${COMP_WORDS[i]}/node.def" ] ; then - _vyatta_op_node_path+=/${COMP_WORDS[i]} + # expand the command so completion continues to work with short versions + node=$(_vyatta_op_conv_node_path $_vyatta_op_node_path ${COMP_WORDS[i]}) + if [ -f "${_vyatta_op_node_path}/$node/node.def" ] ; then + _vyatta_op_node_path+=/$node elif [ -f ${_vyatta_op_node_path}/node.tag/node.def ] ; then _vyatta_op_node_path+=/node.tag else diff --git a/etc/bash_completion.d/vyatta-op-run b/etc/bash_completion.d/vyatta-op-run index 8e73773..68c9562 100644 --- a/etc/bash_completion.d/vyatta-op-run +++ b/etc/bash_completion.d/vyatta-op-run @@ -40,6 +40,42 @@ _vyatta_op_get_node_def_field () }' $file } +_vyatta_op_conv_node_path () +{ + # is the node ok, ambiguous, or invalid + local node_path + local node + local -a ARR + node_path=$1 + node=$2 + ARR=( "$node_path/$node"* ) + if [[ "${#ARR[@]}" == "1" ]]; then + echo ${ARR[0]##*/} + elif [[ "${#ARR[@]}" == "0" ]]; then + if [[ -d "${node_path}/node.tag" ]]; then + echo "$node tag" + else + echo "$node invalid" + fi + elif [[ -d "$node_path/$node" ]]; then + echo $node + else + echo "$node ambiguous" + fi +} + +_vyatta_op_conv_run_cmd () +{ + # Substitue bash positional variables + # for the same value in the expanded array + local run_cmd + run_cmd="$@" + run_cmd="${run_cmd/\"\$\@\"/${args[*]}}" + run_cmd="${run_cmd/\$\*/${args[*]}}" + run_cmd=$(echo -e "$run_cmd" | sed -e 's/\$\([0-9]\)/\$\{args\[\1\]\}/g') + echo -ne "$run_cmd" +} + _vyatta_op_run () { local -i estat @@ -51,8 +87,25 @@ _vyatta_op_run () false; estat=$? i=1 - for arg in "$@" - do + declare -a args # array of expanded arguments + for arg in "$@"; do + arg=( $(_vyatta_op_conv_node_path $tpath $arg) ) # expand the arguments + # output proper error message based on the above expansion + if [[ "${arg[1]}" == "ambiguous" ]]; then + echo -ne "\n Ambiguous command: ${args[@]} [$arg]\n" + local -a cmds=( "$tpath/$arg"* ) + _vyatta_op_node_path=$tpath + local comps=$(_vyatta_op_help $arg ${cmds[@]##*/}) + echo -e "$comps\n" | sed -e 's/^P/ P/' + eval $restore_shopts + return 1 + elif [[ "${arg[1]}" == "invalid" ]]; then + echo -ne "\n Invalid command: ${args[@]} [$arg]\n\n" + eval $restore_shopts + return 1 + fi + + args[$i]=$arg if [ -f "$tpath/$arg/node.def" ] ; then tpath+=/$arg elif [ -f $tpath/node.tag/node.def ] ; then @@ -66,6 +119,7 @@ _vyatta_op_run () done local run_cmd=$(_vyatta_op_get_node_def_field $tpath/node.def run) + run_cmd=$(_vyatta_op_conv_run_cmd "$run_cmd") # convert the positional parameters local ret=0 local cmd_regex="^(LESSOPEN=|less|pager|tail|/opt/vyatta/bin/vyatta-tshark-interface-port.pl).*" if [ -n "$run_cmd" ]; then @@ -75,8 +129,8 @@ _vyatta_op_run () eval "$run_cmd" fi else - echo "Incomplete command" >&2 - ret=1 + echo -ne "\n Incomplete command: ${args[@]}\n\n" >&2 + ret=1 fi eval $restore_shopts return $ret |