diff --git a/to_review/samba b/to_review/samba new file mode 100644 index 00000000..27e9dcd9 --- /dev/null +++ b/to_review/samba @@ -0,0 +1,304 @@ +# -*- mode: shell-script; sh-basic-offset: 8; indent-tabs-mode: t -*- +# ex: ts=8 sw=8 noet filetype=sh +# +# bash completion for samba + +have smbclient && { +_samba_resolve_order() +{ + COMPREPLY=( $( compgen -W 'lmhosts host wins bcast' -- $cur ) ) +} + +_samba_domains() +{ + if [ -n "${COMP_SAMBA_SCAN:-}" ]; then + COMPREPLY=( $( smbtree -D | grep "^$cur" ) ) + fi +} + +_samba_hosts() +{ + if [ -n "${COMP_SAMBA_SCAN:-}" ]; then + COMPREPLY=( $( smbtree -S | grep "^$cur" ) ) + fi +} + +_smbclient() +{ + local cur prev + + COMPREPLY=() + cur=`_get_cword` + prev=${COMP_WORDS[COMP_CWORD-1]} + + case $prev in + -R) + _samba_resolve_order + return 0; + ;; + -t) + COMPREPLY=( $( compgen -W 'SJIS EUC JIS7 JIS8 JUNET \ + HEX CAP' -- $cur ) ) + return 0; + ;; + -@(s|A)) + _filedir + return 0; + ;; + -l) + _filedir -d + return 0; + ;; + -O) + COMPREPLY=( $( compgen -W 'SO_KEEPALIVE SO_REUSEADDR \ + SO_BROADCAST TCP_NODELAY IPTOS_LOWDELAY \ + IPTOS_THROUGHPUT SO_SNDBUF SO_RCVBUF \ + SO_SNDLOWAT SO_RCVLOWAT' -- $cur ) ) + return 0; + ;; + -T) + COMPREPLY=( $( compgen -W 'c x I X F b g q r N a' -- \ + $cur ) ) + return 0; + ;; + -W) + _samba_domains + return 0; + ;; + esac + + # --name=value style option + if [[ "$cur" == *=* ]]; then + prev=${cur/=*/} + cur=${cur/*=/} + case $prev in + --logfile) + _filedir -d + return 0; + ;; + --authentication-file) + _filedir + return 0; + ;; + --workgroup) + _samba_domains + return 0; + ;; + esac + fi + + if [[ "$cur" == -* ]]; then + COMPREPLY=( $( compgen -W '-b -d -L -U -I -M -m -A -N -i -O \ + -p -R -s -k -P -c -D -W -l -E --debuglevel= --logfile= \ + --workgroup=' -- $cur ) ) + fi +} +complete -F _smbclient smbclient + +_smbget() +{ + local cur prev + + COMPREPLY=() + cur=`_get_cword` + prev=${COMP_WORDS[COMP_CWORD-1]} + + case $prev in + -@(o|f|-outputfile|-rcfile)) + _filedir + return 0; + ;; + esac + + if [[ "$cur" == -* ]]; then + COMPREPLY=( $( compgen -W '-a --guest -r --resume -R \ + --recursive -u --username= -p --password= -w \ + --workgroup= -n --nonprompt -d --debuglevel= -D --dots \ + -P --keep-permissions -o --outputfile -f --rcfile -q \ + --quiet -v --verbose -b --blocksize -? --help --usage' \ + -- $cur ) ) + fi +} +complete -F _smbget smbget + +_smbcacls() +{ + local cur prev + + COMPREPLY=() + cur=`_get_cword` + prev=${COMP_WORDS[COMP_CWORD-1]} + + case $prev in + -s) + _filedir + return 0; + ;; + -l) + _filedir -d + return 0; + ;; + esac + + # --name=value style option + if [[ "$cur" == *=* ]]; then + prev=${cur/=*/} + cur=${cur/*=/} + case $prev in + --logfile) + _filedir -d + return 0; + ;; + esac + fi + + if [[ "$cur" == -* ]]; then + COMPREPLY=( $( compgen -W '-a -M -D -S -U -C -G --numeric -t \ + -h --help -V -s -d --debuglevel= -l --logfile=' -- \ + $cur ) ) + fi +} +complete -F _smbcacls smbcacls + +_smbcquotas() +{ + local cur prev + + COMPREPLY=() + cur=`_get_cword` + prev=${COMP_WORDS[COMP_CWORD-1]} + + case $prev in + -@(s|A)) + _filedir + return 0; + ;; + -l) + _filedir -d + return 0; + ;; + esac + + # --name=value style option + if [[ "$cur" == *=* ]]; then + prev=${cur/=*/} + cur=${cur/*=/} + case $prev in + --logfile) + _filedir -d + return 0; + ;; + --authentication-file) + _filedir + return 0; + ;; + esac + fi + + if [[ "$cur" == -* ]]; then + COMPREPLY=( $( compgen -W '-u -L -F -S -n -t -v -h --help -V \ + -s -d --debuglevel= -l --logfile= -N -k -A \ + --authentication-file= -U --user=' -- $cur ) ) + fi +} +complete -F _smbcquotas smbcquotas + +_smbpasswd() +{ + local cur prev + + COMPREPLY=() + cur=`_get_cword` + prev=${COMP_WORDS[COMP_CWORD-1]} + + case $prev in + -r) + _samba_hosts + return 0; + ;; + -R) + _samba_resolve_order + return 0; + ;; + -c) + _filedir + return 0; + ;; + esac + + if [[ "$cur" == -* ]]; then + COMPREPLY=( $( compgen -W '-a -c -x -d -e -D -n -r -R -m -U -h \ + -s -w -W -i -L' -- $cur ) ) + fi +} +complete -F _smbpasswd smbpasswd + +_smbtar() +{ + local cur prev + + COMPREPLY=() + cur=`_get_cword` + prev=${COMP_WORDS[COMP_CWORD-1]} + + case $prev in + -@(r|t)) + _filedir tar + return 0; + ;; + -s) + _samba_hosts + return 0; + ;; + esac + + if [[ "$cur" == -* ]]; then + COMPREPLY=( $( compgen -W '-r -i -a -v -s -p -x -X -N -b -d -l \ + -u -t' -- $cur ) ) + fi +} +complete -F _smbtar smbtar + +_smbtree() +{ + local cur prev + + COMPREPLY=() + cur=`_get_cword` + prev=${COMP_WORDS[COMP_CWORD-1]} + + case $prev in + -@(s|A)) + _filedir + return 0; + ;; + -l) + _filedir -d + return 0; + ;; + esac + + # --name=value style option + if [[ "$cur" == *=* ]]; then + prev=${cur/=*/} + cur=${cur/*=/} + case $prev in + --logfile) + _filedir -d + return 0; + ;; + --authentication-file) + _filedir + return 0; + ;; + esac + fi + + if [[ "$cur" == -* ]]; then + COMPREPLY=( $( compgen -W '-b -D -S -V -s -d --debuglevel= -l \ + --logfile= -N -k -A --authentication-file= -U --user= \ + -h --help' -- $cur ) ) + fi +} +complete -F _smbtree smbtree +}