summary refs log tree commit diff
path: root/Completion/Linux/Command
diff options
context:
space:
mode:
authorPeter Stephenson <pws@users.sourceforge.net>2009-04-16 09:25:34 +0000
committerPeter Stephenson <pws@users.sourceforge.net>2009-04-16 09:25:34 +0000
commit4fdb6c2352f84c79d3886cb090f252d4ada9a3dd (patch)
tree91ce1e24d7b29ecefbf948563797a7f78b1a37fc /Completion/Linux/Command
parent87a727ca39cef93e946c3f25e89c80dde5effae7 (diff)
downloadzsh-4fdb6c2352f84c79d3886cb090f252d4ada9a3dd.tar.gz
zsh-4fdb6c2352f84c79d3886cb090f252d4ada9a3dd.tar.xz
zsh-4fdb6c2352f84c79d3886cb090f252d4ada9a3dd.zip
Tomasz Pala: users/14030,14031,14032: Linux completion updates
Diffstat (limited to 'Completion/Linux/Command')
-rw-r--r--Completion/Linux/Command/.distfiles34
-rw-r--r--Completion/Linux/Command/_ethtool87
-rw-r--r--Completion/Linux/Command/_ipset14
-rw-r--r--Completion/Linux/Command/_mdmadm171
-rw-r--r--Completion/Linux/Command/_rpmbuild53
5 files changed, 319 insertions, 40 deletions
diff --git a/Completion/Linux/Command/.distfiles b/Completion/Linux/Command/.distfiles
index 62bfa19e2..c4162b8c0 100644
--- a/Completion/Linux/Command/.distfiles
+++ b/Completion/Linux/Command/.distfiles
@@ -1,9 +1,31 @@
 DISTFILES_SRC='
 .distfiles
-_acpi           _acpitool       _analyseplugin  _brctl          _chrt           
-_ethtool        _fusermount     _ionice         _ipset          _iptables       
-_iwconfig       _losetup        _lsusb          _mii-tool       _modutils       
-_mondo          _pkgtool        _sshfs          _strace         _tpb            
-_tpconfig       _tune2fs        _uml            _valgrind       _vserver        
-_yast           
+_acpi
+_acpitool
+_analyseplugin
+_brctl
+_chrt
+_ethtool
+_fusermount
+_ionice
+_ipset
+_iptables
+_iwconfig
+_losetup
+_lsusb
+_mdmadm
+_mii-tool
+_modutils
+_mondo
+_pkgtool
+_rpmbuild
+_sshfs
+_strace
+_tpb
+_tpconfig
+_tune2fs
+_uml
+_valgrind
+_vserver
+_yast
 '
diff --git a/Completion/Linux/Command/_ethtool b/Completion/Linux/Command/_ethtool
index 50ab9f741..2fabd81da 100644
--- a/Completion/Linux/Command/_ethtool
+++ b/Completion/Linux/Command/_ethtool
@@ -7,7 +7,7 @@ if [[ $CURRENT -ge 4 ]]; then
 	  rx|tx)
 		if [[ $words[2] = '-G' ]] && _message -e n 'number of ring entries' || _wanted -x onoff expl 'enabled' compadd off on
 	  ;;
-	  autoneg|adaptive-rx|adaptive-tx|raw|sg|tso)
+	  autoneg|adaptive-rx|adaptive-tx|raw|hex|sg|tso|ufo|gso)
 		_wanted -x onoff expl 'enabled' compadd off on
 	  ;;
 	  rx-usecs|rx-frames|rx-usecs-irq|rx-frames-irq|tx-usecs|tx-frames|tx-usecs-irq|tx-frames-irq|stats-block-usecs|pkt-rate-low|rx-usecs-low|rx-frames-low|tx-usecs-low|tx-frames-low|pkt-rate-high|rx-usecs-high|rx-frames-high|tx-usecs-high|tx-frames-high|sample-interval|rx-mini|rx-jumbo|offset|length|magic|value|phyad|msglvl)
@@ -22,6 +22,18 @@ if [[ $CURRENT -ge 4 ]]; then
 	  port)
 		_wanted -x port expl 'device port' compadd tp aui bnc mii
 	  ;;
+	  advertise)
+		_values 'hexidecimal value (or a combination of the following)' \
+			'0x001[10 Half]' \
+			'0x002[10 Full]' \
+			'0x004[100 Half]' \
+			'0x008[100 Full]' \
+			'0x010[1000 Half(not supported by IEEE standards)]' \
+			'0x020[1000 Full]' \
+			'0x8000[2500 Full(not supported by IEEE standards)]' \
+			'0x800[10000 Full]' \
+			'0x03F[Auto]'
+	  ;;
 	  xcvr)
 		_wanted -x xcvr expl 'transceiver type' compadd internal external
 	  ;;
@@ -39,15 +51,18 @@ if [[ $CURRENT -ge 4 ]]; then
 	  sopass)
 		_message -e secureon 'password - 6 bytes in ethernet MAC hex format (xx:yy:zz:aa:bb:cc)'
 	  ;;
+	  file)
+		_wanted files expl 'raw register dump files' _files
+	  ;;
 	  *)
 	case $words[2]; in
-	  -A)
+	  -A|--pause)
 		_values -S ' ' -w 'pause options' \
 			'autoneg[Specify if pause autonegotiation is enabled]' \
 			'rx[Specify if RX pause is enabled]' \
 			'tx[Specify if TX pause is enabled]'
 	  ;;
-	  -C)
+	  -C|--coalesce)
 		_values -S ' ' -w 'coalescing settings' \
 			'adaptive-rx' 'adaptive-tx' \
 			'rx-usecs' 'rx-frames' 'rx-usecs-irq' 'rx-frames-irq' \
@@ -61,50 +76,55 @@ if [[ $CURRENT -ge 4 ]]; then
 			'tx-usecs-high' 'tx-frames-high' \
 			'sample-interval'
 	  ;;
-	  -G)
+	  -G|--set-ring)
 		_values -S ' ' -w 'ring parameters' \
 			'rx[Change number of ring entries for the RX ring]' \
 			'rx-mini[Change number of ring entries for the RX Mini ring]' \
 			'rx-jumbo[Change number of ring entries for the RX Jumbo ring]' \
 			'tx[Change number of ring entries for the TX ring]'
 	  ;;
-	  -d)
+	  -d|--register-dump)
 		_values -S ' ' -w 'register dump options' \
-			'raw[dump raw register data]'
+			'hex[dump hex register data]' \
+			'raw[dump raw register data]' \
+			'file[use contents from file rather than device]'
 	  ;;
-	  -e)
+	  -e|--eeprom-dump)
 		_values -S ' ' -w 'EEPROM dump options' \
 			'raw[dump raw EEPROM data]' \
 			'offset[dump certain portions of the EEPROM]' \
 			'length[dump certain portions of the EEPROM]'
 	  ;;
-	  -E)
+	  -E|--change-eeprom)
 		_values -S ' ' -w 'EEPROM values' \
 			'magic[device-specific key]' \
 			'offset[select byte]' \
 			'value[new value]'
 	  ;;
-	  -K)
+	  -K|--offload)
 		_values -S ' ' -w 'offload options' \
 			'rx[Specify if RX checksumming is enabled]' \
 			'tx[Specify if TX checksumming is enabled]' \
 			'sg[Specify if scatter-gather is enabled]' \
-			'tso[Specify if tcp segmentation offload is enabled]'
+			'tso[Specify if TCP segmentation offload is enabled]' \
+			'ufo[Specify if UDP segmentation offload is enabled]' \
+			'gso[Specify if generic segmentation offload is enabled]'
 	  ;;
-	  -p)
+	  -p|--identify)
 		if [[ $CURRENT -eq 4 ]] && _message -e length 'seconds'
 	  ;;
-	  -t)
+	  -t|--test)
 		_values -S ' ' -w 'selftest option' \
 			'(online)offline:perform full set of tests possibly causing normal operation interruption (default)]' \
 			'(offline)online:perform limited set of tests do not interrupting normal adapter operation]'
 	  ;;
-	  -s)
+	  -s|--change)
 		_values -S ' ' -w 'change setting' \
 			'speed[Set speed in Mb/s]' \
 			'duplex[Set full or half duplex mode]' \
 			'port[Select device port]' \
 			'autoneg[Specify if autonegotiation is enabled]' \
+			'advertise[Set the speed and duplex advertised by autonegotiation]' \
 			'phyad[PHY address]' \
 			'xcvr[Select transceiver type]' \
 			'wol[Set Wake-on-LAN options]' \
@@ -116,26 +136,29 @@ if [[ $CURRENT -ge 4 ]]; then
 	esac
 fi
 
-cmds=(-h -a -A -c -C -g -G -i -d -e -E -k -K -p -r -S -t -s)
+cmds=(-h -a -A -c -C -g -G -i -d -e -E -k -K -p -r -S -t -s
+	--help --show-pause --pause --show-coalesce --coalesce --show-ring
+	--set-ring --driver --register-dump --eeprom-dump --change-eeprom
+	--show-offload --offload --identify --negotiate --statistics --test --change)
 
 _arguments \
 	"($cmds)1:interface:_net_interfaces" \
-	"($cmds 1)-h[shows a short help message]" \
-	"($cmds)-a[queries the specified ethernet device for pause parameter information]" \
-	"($cmds)-A[change the pause parameters of the specified ethernet device]" \
-	"($cmds)-c[queries the specified ethernet device for coalescing information]" \
-	"($cmds)-C[change the coalescing settings of the specified ethernet device]" \
-	"($cmds)-g[queries the specified ethernet device for RX/TX ring parameter information]" \
-	"($cmds)-G[change the RX/TX ring parameters of the specified ethernet device]" \
-	"($cmds)-i[queries the specified ethernet device for associated driver information]" \
-	"($cmds)-d[retrieves and prints a register dump for the specified ethernet device]" \
-	"($cmds)-e[retrieves and prints an EEPROM dump for the specified ethernet device]" \
-	"($cmds)-E[Changes EEPROM byte for the specified ethernet device]" \
-	"($cmds)-k[queries the specified ethernet device for offload information]" \
-	"($cmds)-K[change the offload parameters of the specified ethernet device]" \
-	"($cmds)-p[initiates adapter-specific action intended to identify the adapter by sight]" \
-	"($cmds)-r[restarts auto-negotiation on the specified ethernet device]" \
-	"($cmds)-S[queries the specified ethernet device for NIC- and driver-specific statistics]" \
-	"($cmds)-t[executes adapter selftest on the specified ethernet device]" \
-	"($cmds)-s[allows changing some or all settings of the specified ethernet device]" \
+	"($cmds 1)"{-h,--help}'[shows a short help message]' \
+	"($cmds)"{-a,--show-pause}'[queries the specified ethernet device for pause parameter information]' \
+	"($cmds)"{-A,--pause}'[change the pause parameters of the specified ethernet device]' \
+	"($cmds)"{-c,--show-coalesce}'[queries the specified ethernet device for coalescing information]' \
+	"($cmds)"{-C,--coalesce}'[change the coalescing settings of the specified ethernet device]' \
+	"($cmds)"{-g,--show-ring}'[queries the specified ethernet device for RX/TX ring parameter information]' \
+	"($cmds)"{-G,--set-ring}'[change the RX/TX ring parameters of the specified ethernet device]' \
+	"($cmds)"{-i,--driver}'[queries the specified ethernet device for associated driver information]' \
+	"($cmds)"{-d,--register-dump}'[retrieves and prints a register dump for the specified ethernet device]' \
+	"($cmds)"{-e,--eeprom-dump}'[retrieves and prints an EEPROM dump for the specified ethernet device]' \
+	"($cmds)"{-E,--change-eeprom}'[Changes EEPROM byte for the specified ethernet device]' \
+	"($cmds)"{-k,--show-offload}'[queries the specified ethernet device for offload information]' \
+	"($cmds)"{-K,--offload}'[change the offload parameters of the specified ethernet device]' \
+	"($cmds)"{-p,--identify}'[initiates adapter-specific action intended to identify the adapter by sight]' \
+	"($cmds)"{-r,--negotiate}'[restarts auto-negotiation on the specified ethernet device]' \
+	"($cmds)"{-S,--statistics}'[queries the specified ethernet device for NIC- and driver-specific statistics]' \
+	"($cmds)"{-t,--test}'[executes adapter selftest on the specified ethernet device]' \
+	"($cmds)"{-s,--change}'[allows changing some or all settings of the specified ethernet device]' \
 	'*:' && ret=0
diff --git a/Completion/Linux/Command/_ipset b/Completion/Linux/Command/_ipset
index 36d269f2c..244cb8f22 100644
--- a/Completion/Linux/Command/_ipset
+++ b/Completion/Linux/Command/_ipset
@@ -11,7 +11,11 @@ _set_types () {
 		'iphash[Hash of IP addresses]' \
 		'nethash[Hash of network addresses]' \
 		'ipporthash[Hash of IP address and port pairs]' \
-		'iptree[Tree of IP addresses, optionally with timeout]'
+		'ipportiphash[Hash of IP address,port and IP address triples]' \
+		'ipportnethash[Hash of IP address,port and network address triples]' \
+		'iptree[Tree of IP addresses, optionally with timeout]' \
+		'iptreemap[Tree of IP addresses or networks]' \
+		'setlist[List of sets]'
 }
 
 if [[ $words[2] = (-q|--quiet) ]]; then
@@ -77,12 +81,18 @@ case $words[offset+2]; in
 	  nethash)
 		args=(	$hash )
 	  ;;
-	  ipporthash)
+	  ipporthash|ipportiphash|ipportnethash)
 		args=(	$from_to $hash )
 	  ;;
 	  iptree)
 	  	args=(	'--timeout[Timeout value for the entries in seconds (default 0)]:timeout' )
 	  ;;
+	  iptreemap)
+	  	args=(	'--gc[Garbage collection inverval (default 300 seconds)]:timeout' )
+	  ;;
+	  setlist)
+	  	args=(	'--size[Size of the new setlist (default 8)]:size' )
+	  ;;
 	esac
   ;;
   -T|--test)
diff --git a/Completion/Linux/Command/_mdmadm b/Completion/Linux/Command/_mdmadm
new file mode 100644
index 000000000..84f4748ec
--- /dev/null
+++ b/Completion/Linux/Command/_mdmadm
@@ -0,0 +1,171 @@
+#compdef mdadm
+
+typeset -A opt_args
+local -a args misc modes
+
+_raids_build () {
+	_values -S \  "MD device type" \
+		'linear[linear]' \
+		{0,raid0,stripe}'[striping]' \
+		{1,raid1,mirror}'[mirroring]' \
+		{multipath,mp}'[multiple paths to one common physical storage device]' \
+		'faulty[injects faults]'
+}
+
+_raids () {
+	_values -S \  "MD device type" \
+		'linear[linear]' \
+		{0,raid0,stripe}'[striping]' \
+		{1,raid1,mirror}'[mirroring]' \
+		{4,raid4}'[RAID 4]' \
+		{5,raid5}'[RAID 5]' \
+		{6,raid6}'[RAID 6]' \
+		{10,raid10}'[RAID 1+0]' \
+		{multipath,mp}'[multiple paths to one common physical storage device]' \
+		'faulty[injects faults]'
+}
+
+_layouts () {
+	case ${(v)opt_args[(I)-(l|-level)]} in
+		5|raid5)
+			_values -S \  "RAID5 parity block layout" \
+				{left-asymmetric,la}'[left-asymmetric]' \
+				{left-symmetric,ls}'[left-symmetric]' \
+				{right-asymmetric,ra}'[right-asymmetric]' \
+				{right-symmetric,rs}'[right-symmetric]'
+			;;
+		10|raid10)
+	                _values -s ' ' 'RAID10 layout with number of copies of each datablock' \
+        	                'n1[Near copies]' \
+        	                'n2[Near copies]' \
+        	                'n3[Near copies]' \
+        	                'n4[Near copies]' \
+        	                'n5[Near copies]' \
+        	                'n6[Near copies]' \
+        	                'n7[Near copies]' \
+        	                'n8[Near copies]' \
+        	                'n8[Near copies]' \
+        	                'f1[Far copies]' \
+        	                'f2[Far copies]' \
+        	                'f3[Far copies]' \
+        	                'f4[Far copies]' \
+        	                'f5[Far copies]' \
+        	                'f6[Far copies]' \
+        	                'f7[Far copies]' \
+        	                'f8[Far copies]' \
+        	                'f9[Far copies]'
+			;;
+		faulty)
+			_values -S \  "Failure mode" \
+				{write-transient,wt}'[write-transient]' \
+				{read-transient,rt}'[read-transient]' \
+				{write-presistent,wp}'[write-presistent]' \
+				{read-presistent,rp}'[read-presistent]' \
+				write-all'[write-all]' \
+				{read-fixable,rf}'[read-fixable]' \
+				{clear,none}'[remove any pending or periodic failure modes]' \
+				flush'[clear any persistant faults]'
+	esac
+}
+
+if (( $+words[(r)-(A|-assemble)] )); then
+	args=(
+		'(--bitmap)'--bitmap='[bitmap file to use with the array]::Bitmap file:_files'
+		'(--uuid -u)'{--uuid=,-u}'[UUID of array to assemble]:UUID'
+		'(--super-minor -m)'{--super-minor=,-m}'[minor number to look for in super-block]:Minor number'
+		'(--name -N)'{--name=,-N}'[Array name to look for in super-block]:Array name'
+		'(--config -c)'{--config=,-c}'[config file]::Config file:_files'
+		'(--scan -s)'{--scan,-s}'[scan config file for missing information]'
+		'(--run -R)'{--run,-R}'[Try to start the array even if not enough devices for a full array are present]'
+		'(--force -f)'{--force,-f}'[Assemble the array even if some superblocks appear out-of-date]'
+		'(--update,-U)'{--update=,-U}'[Update superblock]::Update the superblock:(sparc2.2 summaries uuid resync byteorder super-minor)'
+	)
+fi
+
+if (( $+words[(r)-(B|-build)] )); then
+	args=(
+		'(--bitmap)'--bitmap='[file to store/find bitmap information in]::Bitmap file:_files'
+		'(--chunk -c)'{--chunk=,-c}'[chunk size of kibibytes]:Chunk size'
+		'(--rounding)'--rounding='[rounding factor for linear array (==chunk size)]:Rounding factor'
+		'(--level -l)'{--level=,-l}'[RAID level]::RAID level:_raids_build'
+		'(--raid-devices -n)'{--raid-devices=,-n}'[number of active devices in array]:active devices number'
+		'(--bitmap-chunk)'--bitmap-chunk='[bitmap chunksize in Kilobytes]:Bitmap chunk'
+		'(--delay -d)'{--delay=,-d}'[bitmap update delay in seconds]:Bitmap update delay'
+	)
+fi
+
+if (( $+words[(r)-(C|-create)] )); then
+	args=(
+		'(--bitmap)'--bitmap='[create a bitmap for the array with the given filename]::Bitmap file:_files'
+		'(--chunk -c)'{--chunk=,-c}'[chunk size of kibibytes]:Chunk size'
+		'(--rounding)'--rounding='[rounding factor for linear array (==chunk size)]:Rounding factor'
+		'(--level -l)'{--level=,-l}'[RAID level]::RAID level:_raids'
+		'(--parity -p --layout)'{--parity=,-p,--layout=}'[RAID5/6/10 parity algorithm, faulty mode]::Layout:_layouts'
+		'(--raid-devices -n)'{--raid-devices=,-n}'[number of active devices in array]:active devices number'
+		'(--spare-devices -x)'{--spare-devices=,-x}'[number of spares (eXtras) devices in initial array]:Spare devices number'
+		'(--size -z)'{--size=,-z}'[size (in K) of each drive in RAID1/4/5/6/10]:Size of each drive'
+		'(--force -f)'{--force,-f}'[honour devices as listed on command line]'
+		'(--run -R)'{--run,-R}'[insist of running the array even if not all devices are present or some look odd]'
+		'(--readonly -o)'{--readonly,-o}'[start the array readonly]'
+		'(--name -N)'{--name=,-N}'[textual name for array - max 32 characters]:Array name'
+		'(--bitmap-chunk)'--bitmap-chunk='[bitmap chunksize in Kilobytes]:Bitmap chunk'
+		'(--delay -d)'{--delay,-d}'[bitmap update delay in seconds]:Bitmap update delay'
+	)
+fi
+
+if (( $+words[(r)-([DEXQ]|-(detail|examine(|-bitmap)|query))] )); then
+	args=(
+		'(--zero-superblock)'--zero-superblock'[erase the MD superblock from a device]'
+		'(--run -R)'{--run,-R}'[start a partially built array]'
+		'(--stop -S)'{--stop,-S}'[deactivate array, releasing all resources]'
+		'(--readonly -o)'{--readonly,-o}'[mark array as readonly]'
+		'(--readwrite -w)'{--readwrite,-w}'[mark array as readwrite]'
+		'(--test -t)'{--test,-t}'[exit status 0 if ok, 1 if degrade, 2 if dead, 4 if missing]'
+	)
+fi
+
+if (( $+words[(r)-(F|-follow|-monitor)] )); then
+	args=(
+		'(--mail -m)'{--mail=,-m}'[Address to mail alerts of failure to]:::_email_addresses'
+		'(--program -p --alert)'{--program=,-p,--alert=}'[Program to run when an event is detected]::Program:_files'
+		'(--delay -d)'{--delay=,-d}'[seconds of delay between polling state]:seconds'
+		'(--config -c)'{--config=,-c}'[specify a different config file]::Config file:_files'
+		'(--scan -s)'{--scan,-s}'[find mail-address/program in config file]'
+		'(--daemonise -f)'{--daemonise,-f}'[Fork and continue in child, parent exits]'
+		'(--pid-file -i)'{--pid-file=,-i}'[In daemon mode write pid to specified file instead of stdout]::PID file:_files'
+		'(--oneshot -1)'{--oneshot,-1}'[Check for degraded arrays, then exit]'
+		'(--test -t)'{--test,-t}'[Generate a TestMessage event against each array at startup]'
+	)
+fi
+
+if (( $+words[(r)-(G|-grow)] )); then
+	args=(
+		'(--size -z)'{--size=,-z}'[Change the active size of devices in an array]:active size'
+		'(--raid-disks -n)'{--raid-disks=,-n}'[Change the number of active devices in a RAID1 array]:number of active devices'
+	)
+fi
+
+_mds () {
+	local -a vals
+	vals=( ${${${(M)${(f)"$(< /etc/mdadm.conf)"}##ARRAY *}//ARRAY /}%%[[:blank:]]*} )
+	_describe -t mds "RAID devices" vals
+	_arguments \
+		"(-h --help)"{-h,--help}'[Display a mode specific help message]'
+}
+
+modes=(-A --assemble -B --build -C --create -F --follow --monitor -G --grow -h --help -V --version)
+misc=(-D --detail -E --examine -X --examine-bitmap -Q --query)
+
+_arguments \
+	"($misc $modes)"{-A,--assemble}'[Assemble a pre-existing array]:::_mds' \
+	"($misc $modes)"{-B,--build}'[Build a legacy array without superblocks]:::_mds' \
+	"($misc $modes)"{-C,--create}'[Create a new array]' \
+	"($misc $modes)"{-F,--follow,--monitor}'[Select Monitor mode]' \
+	"($misc $modes)"{-G,--grow}'[Change the size or shape of an active array]' \
+	"($modes -D --detail -E --examine -X --examine-bitmap)"{-D,--detail}'[Print detail of one or more md devices]' \
+	"($modes -D --detail -E --examine -X --examine-bitmap -Q --query)"{-E,--examine}'[Print content of md superblock on device(s)]' \
+	"($modes -Q --query)"{-Q,--query}'[Examine a device]' \
+	"($modes -E --examine -X --examine-bitmap)"{-X,--examine-bitmap}'[Report information about a bitmap file]' \
+	"(-)"{-h,--help}'[Display general help message]' \
+	"(-)"{-V,--version}'[Print version information for mdadm]' \
+	"$args[@]"
diff --git a/Completion/Linux/Command/_rpmbuild b/Completion/Linux/Command/_rpmbuild
new file mode 100644
index 000000000..59f997b0c
--- /dev/null
+++ b/Completion/Linux/Command/_rpmbuild
@@ -0,0 +1,53 @@
+#compdef rpmbuild
+
+local -a cmds b_cmds t_cmds options b_options
+
+cmds=(--rebuild --recompile)
+b_cmds=(-ba -bb -bp -bc -bi -bl -bs)
+t_cmds=(-ta -tb -tp -tc -ti -tl -ts)
+options=(--quiet -v -vv --verbose --rcfile --pipe --dbpath -r --root --buildroot --clean --nobuild --nodeps --nodigest --nosignature --macros
+	--rmsource --rmspec --short-circuit --sign --target -D --define -E --eval --with --without --debug --bcond --install-build-tree)
+b_options=(--clean --nobuild --nodeps --nodigest --nosignature --rmsource --rmspec --short-circuit --sign --target --debug --with --without)
+
+_arguments \
+	"($cmds $b_cmds $t_cmds)"{-ba,-ta}'[Build binary and source packages]' \
+	"($cmds $b_cmds $t_cmds)"{-bb,-tb}'[Build a binary package]' \
+	"($cmds $b_cmds $t_cmds)"{-bp,-tp}'[Execute the "%prep" stage]' \
+	"($cmds $b_cmds $t_cmds)"{-bc,-tc}'[Do the "%build" stage]' \
+	"($cmds $b_cmds $t_cmds)"{-bi,-ti}'[Do the "%install" stage]' \
+	"($cmds $b_cmds $t_cmds)"{-bl,-tl}'[Do a "list check"]' \
+	"($cmds $b_cmds $t_cmds)"{-bs,-ts}'[Build just the source package]' \
+	"($cmds $b_cmds $t_cmds * $b_options $options)"{-\?,--help}'[Show help message]' \
+	"($cmds $b_cmds $t_cmds * $b_options $options)"--querytags'[Display known query tags]' \
+	"($cmds $b_cmds $t_cmds * $b_options)"--showrc'[Display final rpmrc and macro configuration]' \
+	"($cmds $b_cmds $t_cmds * $b_options $options)"--usage'[Display brief usage message]' \
+	"($cmds $b_cmds $t_cmds * $b_options $options)"--version'[Print the version of rpm being used]' \
+	"(-v --verbose -vv)"--quiet'[Print as little as possible]' \
+	"(-v --verbose --quiet)"{-v,--verbose}'[Print verbose information]' \
+	"(-v --verbose --quiet)"-vv'[Print lots of ugly debugging information]' \
+	--rcfile'[RC files]:RC files:_files -S\:' \
+	--macros'[Macros files]:Macros files:_files -S\:' \
+	--pipe'[Command to pipe the output of rpm to]:command' \
+	--dbpath'[Set database directory]:Database directory:_files -/' \
+	"(-r --root)"{-r,--root}'[Root file system tree]:Chroot directory:_files -/' \
+	--buildroot'[Override the BuildRoot]:BuildRoot directory:_files -/' \
+	--clean'[Remove the build tree after the packages are made]' \
+	--nobuild'[Do not execute any build stages (for spec testing purposes]' \
+	--nodeps'[Do not verify build dependencies]' \
+	--nodigest"[Don't verify package digest(s)]" \
+	--nosignature"[Don't verify package signature(s)]" \
+	--rmsource'[Remove the sources after the build]' \
+	--rmspec'[Remove the spec file after the build]' \
+	--short-circuit'[Skip straight to specified stage (-bc, -bi or -bb in PLD Linux]' \
+	--sign'[Embed a GPG signature]' \
+	--target='[Set target platform]:arch-vendor-os:' \
+	{'*-D','*--define='}'[Define MACRO with value EXPR]:MACRO EXPR' \
+	{'*-E','*--eval='}'[Print macro expansion of EXPR]:EXPR' \
+	'*--with[Enable configure option for build]:option' \
+	'*--without[Disable configure option for build]:option' \
+	"($cmds $b_cmds $t_cmds * $b_options)"--bcond'[Find all --with/--without values]' \
+	--debug'[Build packages with debug information]' \
+	"($cmds $b_cmds $t_cmds * $b_options)"--install-build-tree'[Make all needed dirs for building binary rpms]' \
+	"(--clean $b_cmds $t_cmds --rebuild)"--recompile'[Recompile source package]' \
+	"(--clean $b_cmds $t_cmds --recompile)"--rebuild'[Rebuild source package]' \
+	"*:file:_files -g '(#i)*.(spec|srpm|tgz|tar|tar.gz|tar.bz2)(-.)'" && ret=0