[Bash-completion-commits] ./current r1284: completion for samba

Guillaume Rousse guillomovitch at zarb.org
Mon Jan 19 22:10:47 UTC 2009


------------------------------------------------------------
revno: 1284
committer: Guillaume Rousse <guillomovitch at zarb.org>
branch nick: current
timestamp: Mon 2009-01-19 23:10:47 +0100
message:
  completion for samba
added:
  to_review/samba
-------------- next part --------------
=== added file 'to_review/samba'
--- a/to_review/samba	1970-01-01 00:00:00 +0000
+++ b/to_review/samba	2009-01-19 22:10:47 +0000
@@ -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
+}



More information about the Bash-completion-commits mailing list