mirror of
				git://git.code.sf.net/p/zsh/code
				synced 2025-10-26 04:30:27 +01:00 
			
		
		
		
	25324: Danek Duvall: some Solaris and more general completions
This commit is contained in:
		
							parent
							
								
									2d2d341161
								
							
						
					
					
						commit
						5b29fedad8
					
				
					 28 changed files with 1168 additions and 25 deletions
				
			
		
							
								
								
									
										26
									
								
								ChangeLog
									
										
									
									
									
								
							
							
						
						
									
										26
									
								
								ChangeLog
									
										
									
									
									
								
							|  | @ -1,3 +1,29 @@ | ||||||
|  | 2008-07-21  Peter Stephenson  <p.w.stephenson@ntlworld.com> | ||||||
|  | 
 | ||||||
|  | 	* unposted: Src/Modules/.distfiles: add missing files. | ||||||
|  | 
 | ||||||
|  | 	* Danek Duvall: 25324: Completion/Solaris/Command/_coreadm, | ||||||
|  | 	Completion/Solaris/Command/_dhcpinfo, | ||||||
|  | 	Completion/Solaris/Command/_dumpadm, | ||||||
|  | 	Completion/Solaris/Command/_gcore, | ||||||
|  | 	Completion/Solaris/Command/_inetadm, | ||||||
|  | 	Completion/Solaris/Command/_pfexec, | ||||||
|  | 	Completion/Solaris/Command/_ptree, | ||||||
|  | 	Completion/Solaris/Command/_savecore, | ||||||
|  | 	Completion/Solaris/Command/_svcadm, | ||||||
|  | 	Completion/Solaris/Command/_svccfg, | ||||||
|  | 	Completion/Solaris/Command/_svcprop, | ||||||
|  | 	Completion/Solaris/Command/_svcs, | ||||||
|  | 	Completion/Solaris/Command/_zlogin, | ||||||
|  | 	Completion/Solaris/Type/_svcs_fmri, | ||||||
|  | 	Completion/Unix/Command/_pkg_instance, | ||||||
|  | 	Completion/Unix/Command/_pkgadd, | ||||||
|  | 	Completion/Unix/Command/_pkginfo, | ||||||
|  | 	Completion/Unix/Command/_pkgrm, Completion/Unix/Command/_zfs, | ||||||
|  | 	Completion/Unix/Command/_zpool, | ||||||
|  | 	Completion/Unix/Type/_zfs_dataset, | ||||||
|  | 	Completion/Unix/Type/_zfs_pool: new completions. | ||||||
|  | 
 | ||||||
| 2008-07-21  Clint Adams  <clint@zsh.org> | 2008-07-21  Clint Adams  <clint@zsh.org> | ||||||
| 
 | 
 | ||||||
| 	* 25322: Src/Modules/db_gdbm.c: fix printing of keys. | 	* 25322: Src/Modules/db_gdbm.c: fix printing of keys. | ||||||
|  |  | ||||||
							
								
								
									
										15
									
								
								Completion/Solaris/Command/.distfiles
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								Completion/Solaris/Command/.distfiles
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,15 @@ | ||||||
|  | DISTFILES_SRC=' | ||||||
|  | _coreadm | ||||||
|  | _dhcpinfo | ||||||
|  | _dumpadm | ||||||
|  | _gcore | ||||||
|  | _inetadm | ||||||
|  | _pfexec | ||||||
|  | _ptree | ||||||
|  | _savecore | ||||||
|  | _svcadm | ||||||
|  | _svccfg | ||||||
|  | _svcprop | ||||||
|  | _svcs | ||||||
|  | _zlogin | ||||||
|  | ' | ||||||
							
								
								
									
										48
									
								
								Completion/Solaris/Command/_coreadm
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										48
									
								
								Completion/Solaris/Command/_coreadm
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,48 @@ | ||||||
|  | #compdef coreadm | ||||||
|  | 
 | ||||||
|  | _coreadm() { | ||||||
|  | 	local -a content option | ||||||
|  | 
 | ||||||
|  | 	content=( | ||||||
|  | 		"anon[Anonymous private mappings]" | ||||||
|  | 		"ctf[CTF type information]" | ||||||
|  | 		"data[Writable private file mappings]" | ||||||
|  | 		"dism[DISM mappings]" | ||||||
|  | 		"heap[Process heap]" | ||||||
|  | 		"ism[ISM mappings]" | ||||||
|  | 		"rodata[Read-only private file mappings]" | ||||||
|  | 		"shanon[Anonymous shared mappings]" | ||||||
|  | 		"shfile[File-backed shared mappings]" | ||||||
|  | 		"shm[System V shared memory]" | ||||||
|  | 		"stack[Process stack]" | ||||||
|  | 		"symtab[Symbol table sections for loaded files]" | ||||||
|  | 		"text[Readable and executable private file mappings]" | ||||||
|  | 	) | ||||||
|  | 
 | ||||||
|  | 	option=( | ||||||
|  | 		"global"\:"Allow global core dumps" | ||||||
|  | 		"global-setid"\:"Allow set-id global core dumps" | ||||||
|  | 		"log"\:"Generate a syslog message on global core dump" | ||||||
|  | 		"process"\:"Allow per-process core dumps" | ||||||
|  | 		"proc-setid"\:"Allow set-id per-process core dumps" | ||||||
|  | 	) | ||||||
|  | 
 | ||||||
|  | 	# _values doesn't quite work for us here -- the separator can be either | ||||||
|  | 	# "+" or "-" | ||||||
|  | 	_arguments -s \ | ||||||
|  | 		- set1 \ | ||||||
|  | 		'-g[Global core file name pattern]:' \ | ||||||
|  | 		'-G[Global core file content]:content:_values -s + "content" $content' \ | ||||||
|  | 		'-i[Per-process core file name pattern]:' \ | ||||||
|  | 		'-I[Per-process core file content]:content:_values -s + "content" $content' \ | ||||||
|  | 		'*-d[Disable core option]:option:(($option))' \ | ||||||
|  | 		'*-e[Enable core option]:option:(($option))' \ | ||||||
|  | 		- set2 \ | ||||||
|  | 		'-p[PID-specific per-process core file name pattern]:' \ | ||||||
|  | 		'-P[PID-specific per-process core file content]:content:_values -s + "content" $content' \ | ||||||
|  | 		'*:pids:_pids' \ | ||||||
|  | 		- set3 \ | ||||||
|  | 		'-u[Update options from coreadm.conf]' | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | _coreadm "$@" | ||||||
							
								
								
									
										36
									
								
								Completion/Solaris/Command/_dhcpinfo
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										36
									
								
								Completion/Solaris/Command/_dhcpinfo
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,36 @@ | ||||||
|  | #compdef dhcpinfo | ||||||
|  | 
 | ||||||
|  | _dhcpinfo() { | ||||||
|  | 	local -a mnemonics_v4 mnemonics_v6 | ||||||
|  | 
 | ||||||
|  | 	mnemonics_v4=( | ||||||
|  | 		Subnet UTCoffst Router Timeserv IEN116ns DNSserv Logserv | ||||||
|  | 		Cookie Lprserv Impress Resource Hostname Bootsize Dumpfile | ||||||
|  | 		DNSdmain Swapserv Rootpath ExtendP IpFwdF NLrouteF PFilter | ||||||
|  | 		MaxIpSiz IpTTL PathTO PathTbl MTU SameMtuF Broadcst | ||||||
|  | 		MaskDscF MaskSupF RDiscvyF RSolictS StaticRt TrailerF | ||||||
|  | 		ArpTimeO EthEncap TcpTTL TcpKaInt TcpKaGbF NISdmain | ||||||
|  | 		NISservs NTPservs NetBNms NetBDsts NetBNdT NetBScop | ||||||
|  | 		XFontSrv XDispMgr LeaseTim Message T1Time T2Time NW_dmain | ||||||
|  | 		NWIPOpts NIS+dom NIS+serv TFTPsrvN OptBootF MblIPAgt | ||||||
|  | 		OptBootF MblIPAgt SMTPserv POP3serv NNTPserv WWWservs | ||||||
|  | 		Fingersv IRCservs STservs STDAservs UserClas SLP_DA SLP_SS | ||||||
|  | 		AgentOpt FQDN PXEarch BootFile BootPath BootSrvA BootSrvN | ||||||
|  | 		EchoVC LeaseNeg | ||||||
|  | 	) | ||||||
|  | 
 | ||||||
|  | 	mnemonics_v6=( | ||||||
|  | 		ClientID ServerID Preference Unicast UserClass VendorClass | ||||||
|  | 		SIPNames SIPAddresses DNSAddresses DNSSearch NISServers | ||||||
|  | 		NIS+Servers NISDomain NIS+Domain SNTPServers InfoRefresh | ||||||
|  | 		BCMCDomain BCMCAddresses | ||||||
|  | 	) | ||||||
|  | 
 | ||||||
|  | 	_arguments -A \ | ||||||
|  | 		'-c[]' \ | ||||||
|  | 		'-i[Interface]:interface:' \ | ||||||
|  | 		'-n[Maximum number of lines]:limit:' \ | ||||||
|  | 		':DHCP Parameter:_values "DHCP Parameter" $mnemonics_v4' \ | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | _dhcpinfo "$@" | ||||||
							
								
								
									
										23
									
								
								Completion/Solaris/Command/_dumpadm
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								Completion/Solaris/Command/_dumpadm
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,23 @@ | ||||||
|  | #compdef dumpadm | ||||||
|  | 
 | ||||||
|  | _dumpadm() { | ||||||
|  | 	local -a content | ||||||
|  | 
 | ||||||
|  | 	content=( | ||||||
|  | 		"kernel"\:"Kernel memory pages only" | ||||||
|  | 		"all"\:"All memory pages" | ||||||
|  | 		"curproc"\:"Kernel memory pages plus curproc pages" | ||||||
|  | 	) | ||||||
|  | 
 | ||||||
|  | 	_arguments -s \ | ||||||
|  | 		'-n[Dont run savecore on reboot]' \ | ||||||
|  | 		'-u[Update dump configuration from dumpadm.conf]' \ | ||||||
|  | 		'-y[Run savecore on reboot]' \ | ||||||
|  | 		'-c[Set dump content]:dump content:(($content))' \ | ||||||
|  | 		'-d[Set dump device]:block devices:_files -g "*(-%b)"' \ | ||||||
|  | 		'-m[Set minfree size ]:' \ | ||||||
|  | 		'-s[Set the savecore directory]:directory:_files -/' \ | ||||||
|  | 		'-r[Alternate root directory]:directory:_files -/' | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | _dumpadm "$@" | ||||||
							
								
								
									
										31
									
								
								Completion/Solaris/Command/_gcore
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								Completion/Solaris/Command/_gcore
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,31 @@ | ||||||
|  | #compdef gcore | ||||||
|  | 
 | ||||||
|  | _gcore() { | ||||||
|  | 	local -a content | ||||||
|  | 
 | ||||||
|  | 	content=( | ||||||
|  | 		"anon[Anonymous private mappings]" | ||||||
|  | 		"ctf[CTF type information]" | ||||||
|  | 		"data[Writable private file mappings]" | ||||||
|  | 		"dism[DISM mappings]" | ||||||
|  | 		"heap[Process heap]" | ||||||
|  | 		"ism[ISM mappings]" | ||||||
|  | 		"rodata[Read-only private file mappings]" | ||||||
|  | 		"shanon[Anonymous shared mappings]" | ||||||
|  | 		"shfile[File-backed shared mappings]" | ||||||
|  | 		"shm[System V shared memory]" | ||||||
|  | 		"stack[Process stack]" | ||||||
|  | 		"symtab[Symbol table sections for loaded files]" | ||||||
|  | 		"text[Readable and executable private file mappings]" | ||||||
|  | 	) | ||||||
|  | 
 | ||||||
|  | 	_arguments -s \ | ||||||
|  | 		'-p[Use per-process core file repository]' \ | ||||||
|  | 		'-g[Use global core file repository]' \ | ||||||
|  | 		'-F[Force grabbing the target process]' \ | ||||||
|  | 		'-c[Set core file content]:_values -s + "content" $content' \ | ||||||
|  | 		'-o[Set core file base name]:' \ | ||||||
|  | 		'*:pids:_pids' | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | _gcore "$@" | ||||||
							
								
								
									
										16
									
								
								Completion/Solaris/Command/_inetadm
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								Completion/Solaris/Command/_inetadm
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,16 @@ | ||||||
|  | #compdef inetadm | ||||||
|  | 
 | ||||||
|  | _inetadm() { | ||||||
|  | 	_arguments -s \ | ||||||
|  | 		'-?[Help]' \ | ||||||
|  | 		'-l[List service instance properties]:FMRI:_svcs_fmri -i' \ | ||||||
|  | 		'-e[Enable specified instance]:FMRI:_svcs_fmri -i' \ | ||||||
|  | 		'-d[Disable specified instance]:FMRI:_svcs_fmri -i' \ | ||||||
|  | 		'-p[List inet service properties]' \ | ||||||
|  | 		'-m[Modify service instance properties]:FMRI:_svcs_fmri -i' \ | ||||||
|  | 		'-M[Modify inet service properties]' | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | _inetadm "$@" | ||||||
|  | 
 | ||||||
|  | # vi:tw=0 | ||||||
							
								
								
									
										31
									
								
								Completion/Solaris/Command/_pfexec
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								Completion/Solaris/Command/_pfexec
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,31 @@ | ||||||
|  | #compdef pfexec | ||||||
|  | 
 | ||||||
|  | # This is a _values-like function that completes privileges and !-prefixed | ||||||
|  | # privileges, comma-separated, and unique. | ||||||
|  | _privset() { | ||||||
|  | 	local expl p | ||||||
|  | 	local -a privs | ||||||
|  | 
 | ||||||
|  | 	privs=( ${(f)"$(ppriv -l)"} all none zone basic ) | ||||||
|  | 
 | ||||||
|  | 	# Ignore existing values | ||||||
|  | 	compset -P '*,' | ||||||
|  | 	# Ignore a leading !, maybe backslash-quoted | ||||||
|  | 	compset -P '\\#!' | ||||||
|  | 
 | ||||||
|  | 	# Remove already-referenced privs | ||||||
|  | 	for p in ${(s:,:)${IPREFIX//\\#\!/}}; do | ||||||
|  | 		privs=( ${privs:#$p} ) | ||||||
|  | 	done | ||||||
|  | 
 | ||||||
|  | 	_wanted privs expl 'privilege' compadd -qS , -a privs | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | _pfexec() { | ||||||
|  |  	_arguments \ | ||||||
|  | 		'-P[privileges to acquire]:privspec:_privset' \ | ||||||
|  |  		'(-):command name: _command_names -e' \ | ||||||
|  |  		'*::arguments: _normal' | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | _pfexec "$@" | ||||||
							
								
								
									
										23
									
								
								Completion/Solaris/Command/_ptree
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								Completion/Solaris/Command/_ptree
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,23 @@ | ||||||
|  | #compdef ptree | ||||||
|  | 
 | ||||||
|  | _ptree() { | ||||||
|  | 	local curcontext="$curcontext" context state line ret=1 | ||||||
|  | 	typeset -A opt_args | ||||||
|  | 
 | ||||||
|  | 	_arguments -s \ | ||||||
|  | 		'-a[All processes]' \ | ||||||
|  | 		'-c[Show contract memberships]' \ | ||||||
|  | 		'-z[Show processes in zone]:zone:($(zoneadm list))' \ | ||||||
|  | 		'*:pid or user:->pidoruser' && ret=0 | ||||||
|  | 
 | ||||||
|  | 	if [[ $ret -ne 0 ]]; then | ||||||
|  | 		_alternative \ | ||||||
|  | 			'users:logged-in user:(${$(who -q)\:#(users=*|\#)})' \ | ||||||
|  | 			'pids:pid:_pids' | ||||||
|  | 		ret=$? | ||||||
|  | 	fi | ||||||
|  | 
 | ||||||
|  | 	return $ret | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | _ptree "$@" | ||||||
							
								
								
									
										12
									
								
								Completion/Solaris/Command/_savecore
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								Completion/Solaris/Command/_savecore
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,12 @@ | ||||||
|  | #compdef savecore | ||||||
|  | 
 | ||||||
|  | _savecore() { | ||||||
|  | 	_arguments -s \ | ||||||
|  | 		'-L[Take live dump]' \ | ||||||
|  | 		'-v[Verbose]' \ | ||||||
|  | 		'-d[Disregard dump header valid flag]' \ | ||||||
|  | 		'-f[Save crash dump from file]:file:_files' \ | ||||||
|  | 		'::directory:_files -/' | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | _savecore "$@" | ||||||
							
								
								
									
										70
									
								
								Completion/Solaris/Command/_svcadm
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										70
									
								
								Completion/Solaris/Command/_svcadm
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,70 @@ | ||||||
|  | #compdef svcadm | ||||||
|  | 
 | ||||||
|  | _svcadm() { | ||||||
|  | 	local context state line subcmds | ||||||
|  | 	typeset -A opt_args | ||||||
|  | 
 | ||||||
|  | 	subcmds=( enable disable restart refresh mark clear milestone ) | ||||||
|  | 
 | ||||||
|  | 	if [[ $service == "svcadm" ]]; then | ||||||
|  | 		_arguments -C -A "-*" \ | ||||||
|  | 			'-v[Print actions verbosely]' \ | ||||||
|  | 			'*::command:->subcmd' && return 0 | ||||||
|  | 
 | ||||||
|  | 		if (( CURRENT == 1 )); then | ||||||
|  | 			_wanted commands expl 'svcadm subcommand' compadd -a subcmds | ||||||
|  | 			return | ||||||
|  | 		fi | ||||||
|  | 		service="$words[1]" | ||||||
|  | 		curcontext="${curcontext%:*}=$service:" | ||||||
|  | 	fi | ||||||
|  | 
 | ||||||
|  | 	case $service in | ||||||
|  | 	(enable) | ||||||
|  | 		_arguments \ | ||||||
|  | 			'-r[Recursively enable dependencies]' \ | ||||||
|  | 			'-s[Wait for service to come online]' \ | ||||||
|  | 			'-t[State change is temporary]' \ | ||||||
|  | 			'*:instance FMRI:_svcs_fmri -i' | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	(disable) | ||||||
|  | 		_arguments \ | ||||||
|  | 			'-s[Wait for service to become disabled]' \ | ||||||
|  | 			'-t[State change is temporary]' \ | ||||||
|  | 			'*:instance FMRI:_svcs_fmri -i' | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	(mark) | ||||||
|  | 		_arguments \ | ||||||
|  | 			'-I[Change state immediately]' \ | ||||||
|  | 			'-t[State change is temporary]' \ | ||||||
|  | 			':state:(degraded maintenance)' \ | ||||||
|  | 			':instance FMRI:_svcs_fmri -i' | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	(restart|refresh|clear) | ||||||
|  | 		_arguments \ | ||||||
|  | 			'*:instance FMRI:_svcs_fmri -i' | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	(milestone) | ||||||
|  | 		_arguments \ | ||||||
|  | 			'-d[Make milestone the default]' \ | ||||||
|  | 			'*:milestone FMRI:_svcs_fmri -m' | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | # 	# The delegate subcommand has been removed, replaced by just using | ||||||
|  | # 	# the restarter fmri | ||||||
|  | # 	(delegate) | ||||||
|  | # 		_arguments \ | ||||||
|  | # 			'1:restarter FMRI:_svcs_fmri -r' \ | ||||||
|  | # 			'*:instance FMRI:_svcs_fmri -i' | ||||||
|  | # 		;; | ||||||
|  | 
 | ||||||
|  | 	(*) | ||||||
|  | 		_message "unknown svcadm subcommand: $service" | ||||||
|  | 	esac | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | _svcadm "$@" | ||||||
							
								
								
									
										58
									
								
								Completion/Solaris/Command/_svccfg
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										58
									
								
								Completion/Solaris/Command/_svccfg
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,58 @@ | ||||||
|  | #compdef svccfg | ||||||
|  | 
 | ||||||
|  | _svccfg() { | ||||||
|  | 	local context state line subcmds | ||||||
|  | 
 | ||||||
|  | 	subcmds=( apply extract import validate export inventory delete addpropvalue delpropvalue ) | ||||||
|  | 
 | ||||||
|  | 	if [[ $service == "svccfg" ]]; then | ||||||
|  | 		_arguments -s \ | ||||||
|  | 			'-?[Help]' \ | ||||||
|  | 			'-v[Verbose]' \ | ||||||
|  | 			'-s[FMRI on which to operate]:fmri:_svcs_fmri -c' \ | ||||||
|  | 			- set1 \ | ||||||
|  | 			'-f[Read commands from file]:command file:_files' \ | ||||||
|  | 			- set2 \ | ||||||
|  | 			'*::command:->subcmd' && return 0 | ||||||
|  | 
 | ||||||
|  | 		if (( CURRENT == 1 )); then | ||||||
|  | 			_wanted commands expl 'svccfg subcommand' compadd -a subcmds | ||||||
|  | 			return | ||||||
|  | 		fi | ||||||
|  | 		service="$words[1]" | ||||||
|  | 		curcontext="${curcontext%:*}=$service:" | ||||||
|  | 	fi | ||||||
|  | 
 | ||||||
|  | 	case $service in | ||||||
|  | 	(import) | ||||||
|  | 		_arguments \ | ||||||
|  | 			'-V[Verify property updates]' \ | ||||||
|  | 			':file:_files' | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	(apply|validate|inventory) | ||||||
|  | 		_files | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	(export) | ||||||
|  | 		_svcs_fmri -c | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	(delete) | ||||||
|  | 		_arguments \ | ||||||
|  | 			'-f[Force deletion if online or degraded]' \ | ||||||
|  | 			'*:FMRI:_svcs_fmri -c' | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	(extract) | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	(*) | ||||||
|  | 		_message "unknown svccfg subcommand: $service" | ||||||
|  | 		;; | ||||||
|  | 	esac | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | _svccfg "$@" | ||||||
|  | 
 | ||||||
|  | # vi:tw=0 | ||||||
							
								
								
									
										23
									
								
								Completion/Solaris/Command/_svcprop
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								Completion/Solaris/Command/_svcprop
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,23 @@ | ||||||
|  | #compdef svcprop | ||||||
|  | 
 | ||||||
|  | _svcprop() { | ||||||
|  | 	_arguments -s \ | ||||||
|  | 		'-f[Designate properties by their FMRI]' \ | ||||||
|  | 		'-q[Quiet]' \ | ||||||
|  | 		'-t[Use multi-property output format]' \ | ||||||
|  | 		'-v[Verbose]' \ | ||||||
|  | 		- set1 \ | ||||||
|  | 		'-w[Waits for the selected property or property group to change]' \ | ||||||
|  | 		'-p[Prints values of named property or property group]' \ | ||||||
|  | 		':FMRI:_svcs_fmri -i' \ | ||||||
|  | 		- set2 \ | ||||||
|  | 		'(-c -s)-C[Retrieve properties without composition]' \ | ||||||
|  | 		'(-C -s)-c[Retrieve properties with composition]' \ | ||||||
|  | 		'(-c -C)-s[Retrieve properties from snapshot]:snapshot:' \ | ||||||
|  | 		'*-p[Prints values of named property or property group]' \ | ||||||
|  | 		'*:FMRI:_svcs_fmri -i' | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | _svcprop "$@" | ||||||
|  | 
 | ||||||
|  | # vi:tw=0 | ||||||
							
								
								
									
										32
									
								
								Completion/Solaris/Command/_svcs
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								Completion/Solaris/Command/_svcs
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,32 @@ | ||||||
|  | #compdef svcs | ||||||
|  | 
 | ||||||
|  | _svcs() { | ||||||
|  | 	local -a cols | ||||||
|  | 
 | ||||||
|  | 	cols=( | ||||||
|  | 		ctid\:"Contract ID" desc\:"Description" fmri\:"FMRI" | ||||||
|  | 		inst\:"Instance name" nsta\:"Next state (abbr)" nstate\:"Next state" | ||||||
|  | 		scope\:"Scope name" svc\:"Service name" sta\:"State (abbr)" | ||||||
|  | 		state\:"State" stime\:"Start time" | ||||||
|  | 	) | ||||||
|  | 
 | ||||||
|  | 	_arguments -s \ | ||||||
|  | 		'(-l -x -d -D)-a[List all instances]' \ | ||||||
|  | 		'(-l -x -D -a -R)-d[List dependencies]' \ | ||||||
|  | 		'(-l -x -d -a -R)-D[List dependents]' \ | ||||||
|  | 		'(-l -x)-H[Suppress header line]' \ | ||||||
|  | 		'(-)-l[Print detailed status about services and instances]' \ | ||||||
|  | 		'(-l -x)-o[Display specific columns]:column:_values -s , "column" ${^cols/\:/[}\]' \ | ||||||
|  | 		'(-l -x)-p[List processes]' \ | ||||||
|  | 		'(-l -x -d -D)-R[List services with the given restarter]:instance FMRI:_svcs_fmri -i' \ | ||||||
|  | 		'(-l -x)-s[Sort by a column]:column:(($cols))' \ | ||||||
|  | 		'(-l -x)-S[Reverse sort by a column]:column:(($cols))' \ | ||||||
|  | 		'(-l)-v[verbose columns]' \ | ||||||
|  | 		'(-l)-x[Display explanation for service states]' \ | ||||||
|  | 		'(-l -x)-\?[Print help]' \ | ||||||
|  | 		'*:FMRI or pattern:_svcs_fmri -i' | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | _svcs "$@" | ||||||
|  | 
 | ||||||
|  | # vi:tw=0 | ||||||
							
								
								
									
										16
									
								
								Completion/Solaris/Command/_zlogin
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								Completion/Solaris/Command/_zlogin
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,16 @@ | ||||||
|  | #compdef zlogin | ||||||
|  | 
 | ||||||
|  | _zlogin() { | ||||||
|  | 	_arguments -s \ | ||||||
|  | 		'-E[Disable escape character]' \ | ||||||
|  | 		'-e[Specify escape character]:character:' \ | ||||||
|  | 		'-l[Specify username]:username:_users' \ | ||||||
|  | 		':zonename:' \ | ||||||
|  | 		- set1 \ | ||||||
|  | 		'-C[Connect to zone console]' \ | ||||||
|  | 		- set2 \ | ||||||
|  | 		'-S["Safe" login mode]' \ | ||||||
|  | 		':utility' | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | _zlogin "$@" | ||||||
							
								
								
									
										3
									
								
								Completion/Solaris/Type/.distfiles
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								Completion/Solaris/Type/.distfiles
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,3 @@ | ||||||
|  | DISTFILES_SRC=' | ||||||
|  | _svcs_fmri | ||||||
|  | ' | ||||||
							
								
								
									
										82
									
								
								Completion/Solaris/Type/_svcs_fmri
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										82
									
								
								Completion/Solaris/Type/_svcs_fmri
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,82 @@ | ||||||
|  | #autoload | ||||||
|  | 
 | ||||||
|  | _svcs_fmri() { | ||||||
|  | 	local type="$argv[$#]" | ||||||
|  | 	local fmri_abbrevs m i | ||||||
|  | 	typeset -a -g _smf_fmris | ||||||
|  | 
 | ||||||
|  | 	local update_policy | ||||||
|  | 	zstyle -s ":completion:${curcontext}:" cache-policy update_policy | ||||||
|  | 	if [[ -z "$update_policy" ]]; then | ||||||
|  | 		zstyle ":completion:${curcontext}:" cache-policy _smf_caching_policy | ||||||
|  | 	fi | ||||||
|  | 	# The cache really must be per-host | ||||||
|  | 	local cache_id=smf_fmri:$HOST | ||||||
|  | 
 | ||||||
|  | 	# TODO: Do something useful with the expand and/or ambiguous styles. | ||||||
|  | 	case $type in | ||||||
|  | 	(-i|-c) | ||||||
|  | 		# We probably also need an option to eliminate ambiguous | ||||||
|  | 		# results for use in places where that's not allowed. | ||||||
|  | 
 | ||||||
|  | 		# Grab all FMRIs that have a word beginning with $PREFIX, | ||||||
|  | 		# making sure not to return the portion of the FMRI before | ||||||
|  | 		# $PREFIX.  Use the cache if it exists and the user wants to. | ||||||
|  | 		if ( [[ $#_smf_fmris -eq 0 ]] || _cache_invalid $cache_id ) && ! _retrieve_cache $cache_id; then | ||||||
|  | 			_smf_fmris=( ${(f)"$(svcs -a -H -o fmri)"} ) | ||||||
|  | 			_store_cache $cache_id _smf_fmris | ||||||
|  | 		fi | ||||||
|  | 		# Each element of the array is removed which doesn't match (^|.*/)$PREFIX.* | ||||||
|  | 		fmri_abbrevs=( ${(M)_smf_fmris:#((#s)|*[/:])$PREFIX*} ) | ||||||
|  | 
 | ||||||
|  | 		# Go through the remaining elements and remove the characters | ||||||
|  | 		# in front of $PREFIX. | ||||||
|  | 		for i in {1..$#fmri_abbrevs}; do | ||||||
|  | 			# Either one of these will work, but they're too | ||||||
|  | 			# greedy, preventing multiple matches below. | ||||||
|  | 			fmri_abbrevs[i]=${${fmri_abbrevs[i]}/((#s)|*[\/:])(#b)($PREFIX*)/$match[1]} | ||||||
|  | 			#fmri_abbrevs[i]=${${(M)${fmri_abbrevs[i]}:#(#b)((#s)|*/)$PREFIX*}#$match[1]} | ||||||
|  | 		done | ||||||
|  | 
 | ||||||
|  | 		# Remove the "default" instance identifier if we can (not for | ||||||
|  | 		# svccfg) | ||||||
|  | 		# TODO Can't remove default when there are other instances. | ||||||
|  | 		if [[ $type == "-i" ]]; then | ||||||
|  | 			fmri_abbrevs=( ${fmri_abbrevs//:default(#e)/} ) | ||||||
|  | 		fi | ||||||
|  | 
 | ||||||
|  | 		# Search for a second match within each result. | ||||||
|  | 		# for m in $fmri_abbrevs; do | ||||||
|  | 		# 	if [[ -n ${(M)m:#((#s)|*/)$PREFIX*/$PREFIX*} ]]; then | ||||||
|  | 		# 		fmri_abbrevs=( $fmri_abbrevs ${${(SMI:1:)m%%/$PREFIX*}#/} ) | ||||||
|  | 		# 	fi | ||||||
|  | 		# done | ||||||
|  | 
 | ||||||
|  | 		# After playing with _multi_parts, I'm not sure it's actually that useful. | ||||||
|  | 		# _wanted fmri expl "full or unambiguously abbreviated FMRIs" _multi_parts / fmri_abbrevs | ||||||
|  | 		_wanted fmri expl "full or unambiguously abbreviated FMRIs" compadd $fmri_abbrevs | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	(-m) | ||||||
|  | 		_wanted fmri expl "milestone FMRIs" \ | ||||||
|  | 			compadd $(svcs -H -o fmri svc:/milestone/\*) all | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	(-r) | ||||||
|  | 		# TODO: need some way to pick out only restarters | ||||||
|  | 		_wanted fmri expl "restarter FMRIs" compadd master svc:/network/inetd:default | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	(*) | ||||||
|  | 		_message "unknown argument to _svcs_fmri: $type" | ||||||
|  | 		;; | ||||||
|  | 	esac | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | _smf_caching_policy() { | ||||||
|  | 	# /etc/svc/repository.db is not a public interface, so this is kinda | ||||||
|  | 	# grody. | ||||||
|  | 	[[ ! -f "$1" || /etc/svc/repository.db -nt "$1" ]] | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | _svcs_fmri "$@" | ||||||
|  | @ -142,6 +142,10 @@ _php | ||||||
| _pine | _pine | ||||||
| _ping | _ping | ||||||
| _pkg-config | _pkg-config | ||||||
|  | _pkg_instance | ||||||
|  | _pkgadd | ||||||
|  | _pkginfo | ||||||
|  | _pkgrm | ||||||
| _pon | _pon | ||||||
| _postfix | _postfix | ||||||
| _prcs | _prcs | ||||||
|  | @ -223,5 +227,7 @@ _yodl | ||||||
| _yp | _yp | ||||||
| _zcat | _zcat | ||||||
| _zdump | _zdump | ||||||
|  | _zfs | ||||||
| _zip | _zip | ||||||
|  | _zpool | ||||||
| ' | ' | ||||||
|  |  | ||||||
							
								
								
									
										20
									
								
								Completion/Unix/Command/_pkg_instance
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								Completion/Unix/Command/_pkg_instance
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,20 @@ | ||||||
|  | #autoload | ||||||
|  | 
 | ||||||
|  | local -A opts | ||||||
|  | local whicharg | ||||||
|  | 
 | ||||||
|  | zparseopts -E -D -- '-_opts:=opts' | ||||||
|  | 
 | ||||||
|  | whicharg=${opts#*:} | ||||||
|  | 
 | ||||||
|  | case ${opts%:*} in | ||||||
|  | (installed) | ||||||
|  | 	compadd "$@" - ${opt_args[$whicharg]}/var/sadm/pkg/*/pkginfo(:h:t) | ||||||
|  | 	;; | ||||||
|  | (spooled) | ||||||
|  | 	compadd "$@" - ${opt_args[$whicharg]}/*(:t) | ||||||
|  | 	;; | ||||||
|  | (uninstalled) | ||||||
|  | 	compadd "$@" - ${opt_args[$whicharg]:-/var/spool/pkg}/*/pkgmap(:h:t) | ||||||
|  | 	;; | ||||||
|  | esac | ||||||
							
								
								
									
										32
									
								
								Completion/Unix/Command/_pkgadd
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								Completion/Unix/Command/_pkgadd
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,32 @@ | ||||||
|  | #compdef pkgadd | ||||||
|  | 
 | ||||||
|  | _pkgadd_pass() { | ||||||
|  | 	_values -S : 'password descriptor' \ | ||||||
|  | 	'(file env console)pass[Literal password]:password:' \ | ||||||
|  | 	'(pass file console)env[Environment variable]:environment:_parameters -g "*export*"' \ | ||||||
|  | 	'(pass env console)file[File]:file:_files' \ | ||||||
|  | 	'(pass env file)console[From /dev/tty]' | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | _pkgadd() { | ||||||
|  | 	_arguments -s \ | ||||||
|  | 	'-d[Device]:device file:_files' \ | ||||||
|  | 	'-x[HTTP(S) proxy]:HTTP proxy: ' \ | ||||||
|  | 	'-k[Keystore]:keystore:_files' \ | ||||||
|  | 	'-P[Password to decrypt keystore]:password:_pkgadd_pass' \ | ||||||
|  | 	'-Y[Select packages by category]:category: ' \ | ||||||
|  | 	- set1 \ | ||||||
|  | 	'-n[Non-interactive mode]' \ | ||||||
|  | 	'-v[Trace all scripts]' \ | ||||||
|  | 	'-a[Admin file]:admin file:_files' \ | ||||||
|  | 	"-M[Don't use vfstab file]" \ | ||||||
|  | 	'-R[Root path]:root path:_files -/' \ | ||||||
|  | 	'-r[Response file]:response file:_files' \ | ||||||
|  | 	'-V[Alternate vfstab file]:vfstab file:_files' \ | ||||||
|  | 	'*:package instance:_pkg_instance --_opts uninstalled:-d' \ | ||||||
|  | 	- set2 \ | ||||||
|  | 	'-s[Spool package]:spool directory:_files -/' \ | ||||||
|  | 	'*:package instance:_pkg_instance --_opts uninstalled:-d' | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | _pkgadd "$@" | ||||||
							
								
								
									
										22
									
								
								Completion/Unix/Command/_pkginfo
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								Completion/Unix/Command/_pkginfo
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,22 @@ | ||||||
|  | #compdef pkginfo | ||||||
|  | 
 | ||||||
|  | _pkginfo() { | ||||||
|  | 	_arguments -s \ | ||||||
|  | 	'(-q -r -x)-l[Long listing]' \ | ||||||
|  | 	'(-l -r -x)-q[Quiet mode]' \ | ||||||
|  | 	'(-l -q -x)-r[Relocation base]' \ | ||||||
|  | 	'(-l -q -r)-x[Extracted listing]' \ | ||||||
|  | 	'-c[Category]:category: ' \ | ||||||
|  | 	'-a[Architecture]:architecture: ' \ | ||||||
|  | 	'-v[Version]:version: ' \ | ||||||
|  | 	- set1 \ | ||||||
|  | 	'(-p)-i[Select completely installed packages]' \ | ||||||
|  | 	'(-i)-p[Select partially installed packages]' \ | ||||||
|  | 	'-R[Root path]:root path:_files -/' \ | ||||||
|  | 	'*:package instance:_pkg_instance --_opts installed:set1--R' \ | ||||||
|  | 	- set2 \ | ||||||
|  | 	'-d[Device]:device file:_files' \ | ||||||
|  | 	'*:package instance:_pkg_instance --_opts uninstalled:set2--d' | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | _pkginfo "$@" | ||||||
							
								
								
									
										20
									
								
								Completion/Unix/Command/_pkgrm
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								Completion/Unix/Command/_pkgrm
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,20 @@ | ||||||
|  | #compdef pkgrm | ||||||
|  | 
 | ||||||
|  | _pkgrm() { | ||||||
|  | 	_arguments -s \ | ||||||
|  | 	'-Y[Select packages by category]:category: ' \ | ||||||
|  | 	- set1 \ | ||||||
|  | 	'-n[Non-interactive mode]' \ | ||||||
|  | 	'-v[Trace all scripts]' \ | ||||||
|  | 	'-a[Admin file]:admin file:_files' \ | ||||||
|  | 	"-A[Force removal of all files]" \ | ||||||
|  | 	"-M[Don't use vfstab file]" \ | ||||||
|  | 	'-R[Root path]:root path:_files -/' \ | ||||||
|  | 	'-V[Alternate vfstab file]:vfstab file:_files' \ | ||||||
|  | 	'*:package instance:_pkg_instance --_opts installed:set1--R' \ | ||||||
|  | 	- set2 \ | ||||||
|  | 	'-s[Spool package]:spool directory:_files -/' \ | ||||||
|  | 	'*:package instance:_pkg_instance --_opts spooled:set2--s' | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | _pkgrm "$@" | ||||||
							
								
								
									
										238
									
								
								Completion/Unix/Command/_zfs
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										238
									
								
								Completion/Unix/Command/_zfs
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,238 @@ | ||||||
|  | #compdef zfs | ||||||
|  | 
 | ||||||
|  | _zfs() { | ||||||
|  | 	local context state line expl | ||||||
|  | 	typeset -A opt_args | ||||||
|  | 	local -a subcmds rw_properties rw_propnames ro_properties | ||||||
|  | 
 | ||||||
|  | 	subcmds=( | ||||||
|  | 		"create" "destroy" "clone" "promote" "rename" "snapshot" | ||||||
|  | 		"rollback" "list" "set" "get" "inherit" "mount" "unmount" | ||||||
|  | 		"share" "unshare" "send" "receive" "allow" "unallow" | ||||||
|  | 		"upgrade" | ||||||
|  | 	) | ||||||
|  | 
 | ||||||
|  | 	ro_properties=( | ||||||
|  | 		"name" "type" "creation" "used" "available" "referenced" | ||||||
|  | 		"compressratio" "mounted" "origin" | ||||||
|  | 	) | ||||||
|  | 
 | ||||||
|  | 	# TODO: Be cleverer about what values can be set.  Is there any way to | ||||||
|  | 	# set the sorting for *size properties to false by default? | ||||||
|  | 	rw_properties=( | ||||||
|  | 		"aclinherit:value:(discard noallow secure passthrough)" | ||||||
|  | 		"aclmode:value:(discard groupmask passthrough)" | ||||||
|  | 		"atime:value:(on off)" | ||||||
|  | 		"canmount:value:(on off)" | ||||||
|  | 		"checksum:value:(on off fletcher2 fletcher4 sha256)" | ||||||
|  | 		"compression:value:(on off lzjb gzip gzip-{1..9})" | ||||||
|  | 		"copies:value:(1 2 3)" | ||||||
|  | 		"devices:value:(on off)" | ||||||
|  | 		"exec:value:(on off)" | ||||||
|  | 		"mountpoint:value:{if [[ -prefix /* ]]; then _path_files -/; else _wanted mountpoints expl 'mountpoint (type \"/\" to start completing paths)' compadd legacy none; fi}" | ||||||
|  | 		"quota:number or 'none':{if [[ -prefix [0-9]## ]]; then _message -e 'number'; elif [[ $PREFIX == quota= ]]; then _wanted none expl 'number or none' compadd none; else _wanted none expl 'quota' compadd none; fi}" | ||||||
|  | 		"readonly:value:(on off)" | ||||||
|  | 		"recordsize:value:(512 1K 2K 4K 8K 16K 32K 64K 128K)" | ||||||
|  | 		"reservation:value:" # <size>, "none" | ||||||
|  | 		"setuid:value:(on off)" | ||||||
|  | 		"shareiscsi:value:(on off)" # or "type=<type>" | ||||||
|  | 		"sharenfs:value:(on off)" # or share(1M) options | ||||||
|  | 		"snapdir:value:(hidden visible)" | ||||||
|  | 		"version:value:(1 2 current)" | ||||||
|  | 		"volblocksize:value:(512 1K 2K 4K 8K 16K 32K 64K 128K)" | ||||||
|  | 		"volsize:value:" # <size> | ||||||
|  | 		"xattr:value:(on off)" | ||||||
|  | 		"zoned:value:(on off)" | ||||||
|  | 	) | ||||||
|  | 
 | ||||||
|  | 	rw_propnames=( ${rw_properties%%:*} ) | ||||||
|  | 
 | ||||||
|  | 	if [[ $service == "zfs" ]]; then | ||||||
|  | 		_arguments -C -A "-*" \ | ||||||
|  | 			'-\?[Help]' \ | ||||||
|  | 			'*::command:->subcmd' && return 0 | ||||||
|  | 
 | ||||||
|  | 		if (( CURRENT == 1 )); then | ||||||
|  | 			_wanted commands expl "zfs subcommand" compadd -a subcmds | ||||||
|  | 			return | ||||||
|  | 		fi | ||||||
|  | 		service="$words[1]" | ||||||
|  | 		curcontext="${curcontext%:*}=$service:" | ||||||
|  | 	fi | ||||||
|  | 
 | ||||||
|  | 	case $service in | ||||||
|  | 	("create") | ||||||
|  | 		_arguments -A "-*" \ | ||||||
|  | 			'-p[Create parent datasets]' \ | ||||||
|  | 			'-o[Set initial properties]:property:_values -s , "property" $rw_properties' \ | ||||||
|  | 			- set1 \ | ||||||
|  | 			':filesystem:' \ | ||||||
|  | 			- set2 \ | ||||||
|  | 			'-s[Create sparse volume]' \ | ||||||
|  | 			'-b[Set volblocksize]:blocksize:' \ | ||||||
|  | 			'-V[Set size]:size:' \ | ||||||
|  | 			':volume:' | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	("destroy") | ||||||
|  | 		_arguments -A "-*" \ | ||||||
|  | 			'-r[Recursively destroy all children]' \ | ||||||
|  | 			'-R[Recursively destroy all dependents]' \ | ||||||
|  | 			'-f[Force unmounts]' \ | ||||||
|  | 			':filesystem/volume/snapshot:_zfs_dataset' | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	("snapshot") | ||||||
|  | 		_arguments -A "-*" \ | ||||||
|  | 			'-r[Recursively snapshot all descendant datasets]' \ | ||||||
|  | 			':filesystem/volume:_zfs_dataset -t fs -t vol -S@' | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	("rollback") | ||||||
|  | 		_arguments -A "-*" \ | ||||||
|  | 			'-r[Recursively destroy more recent snapshots]' \ | ||||||
|  | 			'-R[Recursively destroy more recent snapshots and clones]' \ | ||||||
|  | 			'-f[Force unmounts]' \ | ||||||
|  | 			':snapshot:_zfs_dataset -t snap' | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	("clone") | ||||||
|  | 		_arguments -A "-*" \ | ||||||
|  | 			'-p[Create parent datasets]' \ | ||||||
|  | 			# XXX needs to bail if there are no snapshots | ||||||
|  | 			':snapshot:_zfs_dataset -t snap' \ | ||||||
|  | 			':filesystem/volume:' | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	("promote") | ||||||
|  | 		# XXX complete only cloned filesystems | ||||||
|  | 		_arguments \ | ||||||
|  | 			':filesystem:_zfs_dataset -t fs' \ | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	("rename") | ||||||
|  | 		_arguments -A "-*" \ | ||||||
|  | 			- set1 \ | ||||||
|  | 			'-p[Create parent datasets]' \ | ||||||
|  | 			':filesystem/volume/snapshot:_zfs_dataset' \ | ||||||
|  | 			':filesystem/volume/snapshot:' \ | ||||||
|  | 			- set2 \ | ||||||
|  | 			'-r[Recursively rename snapshots of all descendent datasets]' \ | ||||||
|  | 			':snapshot:_zfs_dataset -t snap' \ | ||||||
|  | 			':snapshot:' | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	("list") | ||||||
|  | 		_arguments -A "-*" \ | ||||||
|  | 			'-r[Recursively display children]' \ | ||||||
|  | 			'-H[Scripting mode]' \ | ||||||
|  | 			'-o[Properties to list]:property:_values -s , "property" $ro_properties $rw_propnames' \ | ||||||
|  | 			'*-s[Sort key (ascending)]:property:_values "property" $ro_properties $rw_propnames' \ | ||||||
|  | 			'*-S[Sort key (descending)]:property:_values "property" $ro_properties $rw_propnames' \ | ||||||
|  | 			'-t[Dataset types to list]:dataset type:_values -s , "dataset type" filesystem snapshot volume' \ | ||||||
|  | 			'*:filesystem/volume/snapshot:_zfs_dataset' | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	("set") | ||||||
|  | 		_arguments \ | ||||||
|  | 			':property:_values -s , "property" $rw_properties' \ | ||||||
|  | 			'*:filesystem/volume:_zfs_dataset -t fs -t vol' | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	("get") | ||||||
|  | 		_arguments -A "-*" \ | ||||||
|  | 			"-r[Recursively display children's properties]" \ | ||||||
|  | 			'-H[Scripting mode]' \ | ||||||
|  | 			'-p[Display numbers exactly]' \ | ||||||
|  | 			'-s[Specify sources]:source:_values -s , "source" local default inherited temporary none' \ | ||||||
|  | 			'-o[Specify fields]:field:_values -s , "field" name property value source' \ | ||||||
|  | 			':property:_values -s , "property" $ro_properties $rw_propnames all' \ | ||||||
|  | 			'*:filesystem/volume/snapshot:_zfs_dataset' | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	("inherit") | ||||||
|  | 		_arguments -A "-*" \ | ||||||
|  | 			'-r[Recursively inherit property for all children]' \ | ||||||
|  | 			':property:_values -s , "property" $ro_properties $rw_properties' \ | ||||||
|  | 			'*:filesystem/volume:_zfs_dataset -t fs -t vol' | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	("mount") | ||||||
|  | 		_arguments -A "-*" \ | ||||||
|  | 			'-o[Mount options]:mount options:_values -s , "option" {,no}{devices,exec,setuid} ro rw' \ | ||||||
|  | 			'-O[Overlay mount]' \ | ||||||
|  | 			'-v[Report mount progress]' \ | ||||||
|  | 			- set1 \ | ||||||
|  | 			':filesystem:_zfs_dataset -t fs' \ | ||||||
|  | 			- set2 \ | ||||||
|  | 			'-a[Mount all available ZFS filesystems]' | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	("unmount") | ||||||
|  | 		_arguments -A "-*" \ | ||||||
|  | 			- set1 \ | ||||||
|  | 			'-f[Force unmount]' \ | ||||||
|  | 			':filesystem:_zfs_dataset -t fs -t mtpt' \ | ||||||
|  | 			- set2 \ | ||||||
|  | 			'-a[Unmount all ZFS filesystems]' | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	("share") | ||||||
|  | 		_arguments -A "-*" \ | ||||||
|  | 			- set1 \ | ||||||
|  | 			'-a[Share all available ZFS filesystems]' \ | ||||||
|  | 			- set2 \ | ||||||
|  | 			':filesystem:_zfs_dataset -t fs' | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	("unshare") | ||||||
|  | 		_arguments -A "-*" \ | ||||||
|  | 			- set1 \ | ||||||
|  | 			'-a[Unshare all shared ZFS filesystems]' \ | ||||||
|  | 			- set2 \ | ||||||
|  | 			'-F[Force unshare]' \ | ||||||
|  | 			':filesystem:_zfs_dataset -t fs -t mtpt' | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	("send") | ||||||
|  | 		_arguments -A "-*" \ | ||||||
|  | 			'-i[Generate an incremental stream]:snapshot:_zfs_dataset -t snap' \ | ||||||
|  | 			':snapshot:_zfs_dataset -t snap' | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	("receive") | ||||||
|  | 		_arguments -A "-*" \ | ||||||
|  | 			'-v[Verbose]' \ | ||||||
|  | 			'-n[Do not receive the stream]' \ | ||||||
|  | 			'-F[Force a rollback if necessary]' \ | ||||||
|  | 			- set1 \ | ||||||
|  | 			':filesystem/volume/snapshot:_zfs_dataset' \ | ||||||
|  | 			- set2 \ | ||||||
|  | 			'-d[Set path prefix]:filesystem:_zfs_dataset -t fs' | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	("allow"|"unallow") | ||||||
|  | 		_message "unimplemented zfs subcommand: $service" | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	("upgrade") | ||||||
|  | 		_arguments -A "-*" \ | ||||||
|  | 			- set1 \ | ||||||
|  | 			'-v[Verbose]' \ | ||||||
|  | 			- set2 \ | ||||||
|  | 			'-a[Upgrade all filesystems on all pools]' \ | ||||||
|  | 			'-r[Upgrade descendent filesystems, too]' \ | ||||||
|  | 			'-V[Upgrade to specified version]:version:(1 2)' \ | ||||||
|  | 			- set3 \ | ||||||
|  | 			'-r[Upgrade descendent filesystems, too]' \ | ||||||
|  | 			'-V[Upgrade to specified version]:version:(1 2)' \ | ||||||
|  | 			':filesystem:_zfs_dataset -t fs' \ | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	(*) | ||||||
|  | 		_message "unknown zfs subcommand: $service" | ||||||
|  | 		;; | ||||||
|  | 	esac | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | _zfs "$@" | ||||||
							
								
								
									
										201
									
								
								Completion/Unix/Command/_zpool
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										201
									
								
								Completion/Unix/Command/_zpool
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,201 @@ | ||||||
|  | #compdef zpool | ||||||
|  | 
 | ||||||
|  | _zpool() { | ||||||
|  | 	local -a subcmds fields | ||||||
|  | 
 | ||||||
|  | 	subcmds=( | ||||||
|  | 		  create destroy add remove list iostat status online | ||||||
|  | 		  offline clear attach detach replace scrub import export  | ||||||
|  | 		  upgrade history get set | ||||||
|  | 	) | ||||||
|  | 
 | ||||||
|  | 	fields=( | ||||||
|  | 		name\:"Pool name" size\:"Total size" used\:"Space used" | ||||||
|  | 		available\:"Space available" capacity\:"Space used (percentage)" | ||||||
|  | 		health\:"Health status" | ||||||
|  | 	) | ||||||
|  | 
 | ||||||
|  | 	properties=( | ||||||
|  | 		"bootfs:value:" | ||||||
|  | 		"autoreplace:value:(on off)" | ||||||
|  | 		"delegation:value:(on off)" | ||||||
|  | 	) | ||||||
|  | 	propnames=( ${properties%%:*} ) | ||||||
|  | 
 | ||||||
|  | 	import_properties=( | ||||||
|  | 		xattr | ||||||
|  | 		copies | ||||||
|  | 		shareiscsi | ||||||
|  | 		canmount | ||||||
|  | 		share | ||||||
|  | 		sharenfs | ||||||
|  | 		userprop | ||||||
|  | 		mount | ||||||
|  | 	) | ||||||
|  | 
 | ||||||
|  | 	if [[ $service == "zpool" ]]; then | ||||||
|  | 		_arguments -C -A "-*" \ | ||||||
|  | 			'-\?[Help]' \ | ||||||
|  | 			'*::command:->subcmd' && return 0 | ||||||
|  | 
 | ||||||
|  | 		if (( CURRENT == 1 )); then | ||||||
|  | 			_wanted commands expl "zpool subcommand" compadd -a subcmds | ||||||
|  | 			return | ||||||
|  | 		fi | ||||||
|  | 		service="$words[1]" | ||||||
|  | 		curcontext="${curcontext%:*}=$service:" | ||||||
|  | 	fi | ||||||
|  | 
 | ||||||
|  | 	case $service in | ||||||
|  | 	(clear) | ||||||
|  | 		_arguments \ | ||||||
|  | 			':pool name:_zfs_pool' \ | ||||||
|  | 			'*:virtual device:_files' | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	(create) | ||||||
|  | 		# TODO: investigate better vdev handling | ||||||
|  | 		_arguments -A "-*" \ | ||||||
|  | 			'-f[Force use of in-use devices]' \ | ||||||
|  | 			'-n[Display configuration without creating pool]' \ | ||||||
|  | 			'-R[Use alternate root]:alternate root:_files -/' \ | ||||||
|  | 			'-m[Set mountpoint for root dataset]:mountpoint:' \ | ||||||
|  | 			':pool name:' \ | ||||||
|  | 			'*:virtual device:_files' | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	(destroy) | ||||||
|  | 		_arguments -A "-*" \ | ||||||
|  | 			'-f[Force active datasets to be unmounted]' \ | ||||||
|  | 			':pool name:_zfs_pool' | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	(add) | ||||||
|  | 		_arguments -A "-*" \ | ||||||
|  | 			'-f[Force use of in-use devices]' \ | ||||||
|  | 			'-n[Display configuration without modifying pool]' \ | ||||||
|  | 			':pool name:_zfs_pool' \ | ||||||
|  | 			'*:virtual device:_files' | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	(list) | ||||||
|  | 		_arguments \ | ||||||
|  | 			'-H[Scripted mode]' \ | ||||||
|  | 			'-o[Fields to list]:field:_values -s , "field" ${^fields/\:/[}\]' \ | ||||||
|  | 			'::pool name:_zfs_pool' | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	(iostat) | ||||||
|  | 		_arguments -A "-*" \ | ||||||
|  | 			'-v[Verbose statistics]' \ | ||||||
|  | 			'*::pool name:_zfs_pool' \ | ||||||
|  | 			'::interval:' \ | ||||||
|  | 			'::count:' | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	(status) | ||||||
|  | 		_arguments -A "-*" \ | ||||||
|  | 			'-v[Verbose information]' \ | ||||||
|  | 			'-x[Show only unhealthy pools]' \ | ||||||
|  | 			'*::pool name:_zfs_pool' | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	(offline) | ||||||
|  | 		_arguments -A "-*" \ | ||||||
|  | 			'-t[Offline until next reboot]' \ | ||||||
|  | 			':pool name:_zfs_pool' \ | ||||||
|  | 			'*:virtual device:_files' | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	(online) | ||||||
|  | 		_arguments \ | ||||||
|  | 			':pool name:_zfs_pool' \ | ||||||
|  | 			'*:virtual device:_files' | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	(attach) | ||||||
|  | 		# TODO: first device should choose first from existing. | ||||||
|  | 		_arguments \ | ||||||
|  | 			'-f[Force attach, even if in use]' \ | ||||||
|  | 			':pool name:_zfs_pool' \ | ||||||
|  | 			':virtual device:_files' \ | ||||||
|  | 			':virtual device:_files' | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	(detach) | ||||||
|  | 		_arguments \ | ||||||
|  | 			':pool name:_zfs_pool' \ | ||||||
|  | 			':virtual device:_files' | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	(replace) | ||||||
|  | 		_arguments -A "-*" \ | ||||||
|  | 			'-f[Force attach, even if in use]' \ | ||||||
|  | 			':pool name:_zfs_pool' \ | ||||||
|  | 			':virtual device:_files' \ | ||||||
|  | 			'::virtual device:_files' | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	(scrub) | ||||||
|  | 		_arguments -A "-*" \ | ||||||
|  | 			'-s[Stop scrubbing]' \ | ||||||
|  | 			'*:pool name:_zfs_pool' | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	(export) | ||||||
|  | 		_arguments -A "-*" \ | ||||||
|  | 			'-f[Forcefully unmount all datasets]' \ | ||||||
|  | 			'*:pool name:_zfs_pool' | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	(import) | ||||||
|  | 		# TODO: -o should complete options | ||||||
|  | 		_arguments -A "-*" \ | ||||||
|  | 			'*-d[Search for devices or files in directory]:_files -/' \ | ||||||
|  | 			'-D[Destroyed pools]' \ | ||||||
|  | 			'-f[Force import]' \ | ||||||
|  | 			- set1 \ | ||||||
|  | 			'-o[Mount options]' \ | ||||||
|  | 			'-p[Set property]:property:_values -s , "property" $import_properties' \ | ||||||
|  | 			'-R[Alternate root]:_files -/' \ | ||||||
|  | 			'*:pool name or id:_zfs_pool' \ | ||||||
|  | 			'::new pool name:' \ | ||||||
|  | 			- set2 \ | ||||||
|  | 			'-a[All pools]' | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	(get) | ||||||
|  | 		_arguments -A "-*" \ | ||||||
|  | 			':property:_values -s , "property" $propnames all' \ | ||||||
|  | 			'*:pool name:_zfs_pool' | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	(set) | ||||||
|  | 		_arguments -A "-*" \ | ||||||
|  | 			':property:_values -s , "property" $properties' \ | ||||||
|  | 			'*:pool name:_zfs_pool' | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	(upgrade) | ||||||
|  | 		_arguments -A "-*" \ | ||||||
|  | 			- set1 \ | ||||||
|  | 			'-v[Display ZFS versions and descriptions]' \ | ||||||
|  | 			- set2 \ | ||||||
|  | 			'-a[Upgrade all pools]' \ | ||||||
|  | 			'*:pool name:_zfs_pool' | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	(history) | ||||||
|  | 		_arguments -A "-*" \ | ||||||
|  | 			'-i[Display internal events]' \ | ||||||
|  | 			'-l[Long format]' \ | ||||||
|  | 			'*:pool name:_zfs_pool' | ||||||
|  | 		;; | ||||||
|  | 
 | ||||||
|  | 	(*) | ||||||
|  | 		_message "unknown zpool subcommand: $service" | ||||||
|  | 		;; | ||||||
|  | 	esac | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | _zpool "$@" | ||||||
|  | @ -48,4 +48,6 @@ _urls | ||||||
| _user_at_host | _user_at_host | ||||||
| _users | _users | ||||||
| _users_on | _users_on | ||||||
|  | _zfs_dataset | ||||||
|  | _zfs_pool | ||||||
| ' | ' | ||||||
|  |  | ||||||
							
								
								
									
										22
									
								
								Completion/Unix/Type/_zfs_dataset
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								Completion/Unix/Type/_zfs_dataset
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,22 @@ | ||||||
|  | #autoload | ||||||
|  | 
 | ||||||
|  | local -a type typearg list | ||||||
|  | 
 | ||||||
|  | zparseopts -D -E -a type t+: | ||||||
|  | 
 | ||||||
|  | [[ -n $type[(r)fs] ]]   && typearg=( filesystem ) | ||||||
|  | [[ -n $type[(r)vol] ]]  && typearg=( $typearg volume ) | ||||||
|  | [[ -n $type[(r)snap] ]] && typearg=( $typearg snapshot ) | ||||||
|  | [[ -n $typearg ]] && typearg=( -t ${(j:,:)typearg} ) | ||||||
|  | 
 | ||||||
|  | datasetlist=( ${="$(zfs list -H -o name $typearg)":#no datasets available} ) | ||||||
|  | 
 | ||||||
|  | expl_type=${typearg[2,-1]//,/\/} | ||||||
|  | if [[ -n $type[(r)mtpt] ]]; then | ||||||
|  | 	mlist=( ${="$(zfs list -H -o mountpoint $typearg)":#no mountpoints available} ) | ||||||
|  | 	datasetlist=( $datasetlist $mlist ) | ||||||
|  | 	expl_type="$expl_type/mountpoint" | ||||||
|  | fi | ||||||
|  | 
 | ||||||
|  | # compadd "$@" - $list | ||||||
|  | _wanted dataset expl "$expl_type" _multi_parts "$@" / datasetlist | ||||||
							
								
								
									
										3
									
								
								Completion/Unix/Type/_zfs_pool
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								Completion/Unix/Type/_zfs_pool
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,3 @@ | ||||||
|  | #autoload | ||||||
|  | 
 | ||||||
|  | compadd "$@" - $(zpool list -H -o name) | ||||||
|  | @ -1,27 +1,59 @@ | ||||||
| DISTFILES_SRC=' | DISTFILES_SRC=' | ||||||
|     .cvsignore .distfiles .exrc | .cvsignore | ||||||
|     cap.mdd cap.c | .distfiles | ||||||
|     clone.mdd clone.c | .exrc | ||||||
|     curses.mdd curses.c curses_keys.awk | cap.mdd | ||||||
|     datetime.mdd datetime.c | cap.c | ||||||
|     example.mdd example.c | clone.mdd | ||||||
|     files.mdd files.c | clone.c | ||||||
|     langinfo.mdd langinfo.c | curses.mdd | ||||||
|     mapfile.mdd mapfile.c | curses.c | ||||||
|     mathfunc.mdd mathfunc.c | curses_keys.awk | ||||||
|     newuser.mdd newuser.c | datetime.mdd | ||||||
|     parameter.mdd parameter.c | datetime.c | ||||||
|     pcre.mdd pcre.c | db_gdbm.mdd | ||||||
|     regex.mdd regex.c | db_gdbm.c | ||||||
|     socket.mdd socket.c | example.mdd | ||||||
|     stat.mdd stat.c | example.c | ||||||
|     system.mdd system.c errnames1.awk errnames2.awk | files.mdd | ||||||
|     tcp.mdd tcp.c tcp.h | files.c | ||||||
|     termcap.mdd termcap.c | langinfo.mdd | ||||||
|     terminfo.mdd terminfo.c | langinfo.c | ||||||
|     zftp.mdd zftp.c | mapfile.mdd | ||||||
|     zprof.mdd zprof.c | mapfile.c | ||||||
|     zselect.mdd zselect.c | mathfunc.mdd | ||||||
|     zutil.mdd zutil.c | mathfunc.c | ||||||
|     zpty.mdd zpty.c | newuser.mdd | ||||||
|  | newuser.c | ||||||
|  | parameter.mdd | ||||||
|  | parameter.c | ||||||
|  | pcre.mdd | ||||||
|  | pcre.c | ||||||
|  | regex.mdd | ||||||
|  | regex.c | ||||||
|  | socket.mdd | ||||||
|  | socket.c | ||||||
|  | stat.mdd | ||||||
|  | stat.c | ||||||
|  | system.mdd | ||||||
|  | system.c | ||||||
|  | errnames1.awk | ||||||
|  | errnames2.awk | ||||||
|  | tcp.mdd | ||||||
|  | tcp.c | ||||||
|  | tcp.h | ||||||
|  | termcap.mdd | ||||||
|  | termcap.c | ||||||
|  | terminfo.mdd | ||||||
|  | terminfo.c | ||||||
|  | zftp.mdd | ||||||
|  | zftp.c | ||||||
|  | zprof.mdd | ||||||
|  | zprof.c | ||||||
|  | zselect.mdd | ||||||
|  | zselect.c | ||||||
|  | zutil.mdd | ||||||
|  | zutil.c | ||||||
|  | zpty.mdd | ||||||
|  | zpty.c | ||||||
| ' | ' | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue