From e4963ea27834f3b08e98a02233fc115ff874b2ae Mon Sep 17 00:00:00 2001 From: Kirill Zaitsev Date: Thu, 2 Apr 2015 17:40:21 +0300 Subject: [PATCH] Bash completion script for murano A script to be used for bash completion of murano CLI tool commands. Change-Id: Id50ece6b360832601eefdb9b118c646dcaebcfc5 Implements: blueprint murano-bash-completion-script --- tools/murano.bash_completion | 26 ++++++++++++++++++++++++++ 1 file changed, 26 insertions(+) create mode 100644 tools/murano.bash_completion diff --git a/tools/murano.bash_completion b/tools/murano.bash_completion new file mode 100644 index 00000000..fef64523 --- /dev/null +++ b/tools/murano.bash_completion @@ -0,0 +1,26 @@ +_murano_opts="" # lazy init +_murano_flags="" # lazy init +_murano_opts_exp="" # lazy init +_murano() +{ + local cur prev kbc + COMPREPLY=() + cur="${COMP_WORDS[COMP_CWORD]}" + prev="${COMP_WORDS[COMP_CWORD-1]}" + + if [ "x$_murano_opts" == "x" ] ; then + kbc="$(murano bash-completion | sed -e "s/ -h / /")" + _murano_opts="$(echo "$kbc" | sed -e "s/--[a-z0-9_-]*//g" -e "s/[ ][ ]*/ /g")" + _murano_flags="$(echo " $kbc" | sed -e "s/ [^-][^-][a-z0-9_-]*//g" -e "s/[ ][ ]*/ /g")" + _murano_opts_exp="$(echo "$_murano_opts" | sed -e "s/[ ]/|/g")" + fi + + if [[ " ${COMP_WORDS[@]} " =~ " "($_murano_opts_exp)" " && "$prev" != "help" ]] ; then + COMPREPLY=($(compgen -W "${_murano_flags}" -- "${cur}")) + else + COMPREPLY=($(compgen -W "${_murano_opts}" -- "${cur}")) + fi + return 0 +} +complete -o default -F _murano murano +