[Bash-completion-commits] [SCM] bash-completion branch, master, updated. 3e1508e51e7ddc36c2bd55d914920443466ec959
Guillaume Rousse
guillaume at oberkampf.msr-inria.inria.fr
Mon Sep 14 19:45:37 UTC 2009
The following commit has been merged in the master branch:
commit 3e1508e51e7ddc36c2bd55d914920443466ec959
Author: Guillaume Rousse <guillaume at oberkampf.msr-inria.inria.fr>
Date: Mon Sep 14 21:48:25 2009 +0200
initial import
diff --git a/contrib/mdadm b/contrib/mdadm
new file mode 100644
index 0000000..285acee
--- /dev/null
+++ b/contrib/mdadm
@@ -0,0 +1,159 @@
+# -*- mode: shell-script; sh-basic-offset: 8; indent-tabs-mode: t -*-
+# ex: ts=8 sw=8 noet filetype=sh
+#
+# bash completion for mdadm
+
+have mdam && {
+_mdadm_raid_level()
+{
+ local mode
+
+ for (( i=1; i < COMP_CWORD; i++ )); do
+ case ${COMP_WORDS[i]} in
+ -@(C|-create))
+ mode=create
+ break
+ ;;
+ -@(B|-build))
+ mode=build
+ break
+ ;;
+ esac
+ done
+
+ case $mode in
+ create)
+ COMPREPLY=( $( compgen -W 'linear raid0 0 stripe raid1 1 mirror raid4 4 raid5 5 raid6 6 raid10 10 multipath mp faulty' -- $cur ) )
+ ;;
+ build)
+ COMPREPLY=( $( compgen -W 'linear stripe raid0 0 raid1 multipath mp faulty' -- $cur ) )
+ ;;
+ esac
+}
+
+__mdadm_raid_layout()
+{
+ local level
+ for (( i=1; i < COMP_CWORD; i++ )); do
+ if [[ "${COMP_WORDS[i]}" == -@(l|-level) ]]; then
+ level=${COMP_WORDS[i+1]}
+ break
+ fi
+ done
+
+ case $level in
+ raid5)
+ COMPREPLY=( $( compgen -W 'left-asymmetric left-symmetric right-asymmetric right-symmetric la ra ls rs' -- $cur ) )
+ ;;
+ raid10)
+ COMPREPLY=( $( compgen -W 'n o p' -- $cur ) )
+ ;;
+ faulty)
+ COMPREPLY=( $( compgen -W 'write-transient wt read-transient rt write-persistent wp read-persistent rp write-all read-fixable rf clear flush none' -- $cur ) )
+ ;;
+ esac
+}
+
+_mdadm_auto_flag()
+{
+ COMPREPLY=( $( compgen -W 'no yes md mdp part p' -- $cur ) )
+}
+
+_mdadm_update_flag()
+{
+ COMPREPLY=( $( compgen -W 'sparc2.2 summaries uuid name homehost resync byteorder super-minor' -- $cur ) )
+}
+
+
+_mdadm()
+{
+ local cur prev mode options
+
+ COMPREPLY=()
+ cur=`_get_cword`
+ prev=${COMP_WORDS[COMP_CWORD-1]}
+
+ # --name value style option
+ case $prev in
+ -@(c|b))
+ _filedir
+ return 0
+ ;;
+ -l)
+ _mdam_raid_level
+ return 0
+ ;;
+ -p)
+ _mdam_raid_layout
+ return 0
+ ;;
+ -a)
+ _mdam_auto_flag
+ return 0
+ ;;
+ -U)
+ _mdam_update_flag
+ return 0
+ ;;
+ esac
+
+ # --name=value style option
+ if [[ "$cur" == *=* ]]; then
+ prev=${cur/=*/}
+ cur=${cur/*=/}
+ case "$prev" in
+ --@(config|bitmap|backup-file))
+ _filedir
+ return 0
+ ;;
+ --level)
+ _mdam_raid_level
+ return 0
+ ;;
+ --@(layout|parity))
+ _mdam_raid_layout
+ return 0
+ ;;
+ --auto)
+ _mdam_auto_flag
+ return 0
+ ;;
+ --update)
+ _mdam_update_flag
+ return 0
+ ;;
+ esac
+ fi
+
+ options='-h --help --help-options -V --version -v --verbose -q --quiet -b --brief -f --force -c --config= -s --scan -e --metadata= --homehost='
+
+ if [[ "$cur" == -* ]]; then
+ if [[ $COMP_CWORD -eq 1 ]] ; then
+ COMPREPLY=( $( compgen -W "$options -A --assemble -B --build -C --create -F --follow --monitor -G --grow" -- $cur ) )
+ else
+ case ${COMP_WORDS[COMP_CWORD-1]} in
+ -@(A|-assemble))
+ COMPREPLY=( $( compgen -W "$options -u --uuid= -m --super-minor= -N --name= -f --force -R --run --no-degraded -a --auto -b --bitmap= --backup-file= -U --update= --auto-update-homehost" -- $cur ) )
+ ;;
+ -@(B|C|G|-build|-create|-grow))
+ COMPREPLY=( $( compgen -W "$options -n --raid-devices= -x --spare-devices= -z --size= -c --chunk= --rounding= -l --level= -p --layout= --parity= -b --bitmap= --bitmap-chunk= -W --write-mostly --write-behind= --assume-clean --backup-file= -N --name= -R --run -f --force -a --auto" -- $cur ) )
+ ;;
+ -@(F|-follow|-monitor))
+ COMPREPLY=( $( compgen -W "$options -m --mail -p --program --alert -y --syslog -d --delay -f --daemonise -i --pid-file -1 --oneshot -t --test" -- $cur ) )
+
+ ;;
+ @(/dev/*|--add|--fail|--remove))
+ COMPREPLY=( $( compgen -W "$options -a --add --re-add -r --remove -f --fail --set-faulty" -- $cur ) )
+ ;;
+ *)
+ COMPREPLY=( $( compgen -W "$options -Q --query -D --detail -E --examine --sparc2.2 -X --examine-bitmap -R --run -S --stop -o --readonly -w --readwrite --zero-superblock -t --test" -- $cur ) )
+ ;;
+ esac
+ fi
+ else
+ cur=${cur:=/dev/}
+ _filedir
+ fi
+}
+complete -F _mdadm mdadm
+}
--
bash-completion
More information about the Bash-completion-commits
mailing list