1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040 |
- #compdef docker dockerd
- #
- # zsh completion for docker (http://docker.com)
- #
- # version: 0.3.0
- # github: https://github.com/felixr/docker-zsh-completion
- #
- # contributors:
- # - Felix Riedel
- # - Steve Durrheimer
- # - Vincent Bernat
- # - Rohan Verma
- #
- # license:
- #
- # Copyright (c) 2013, Felix Riedel
- # All rights reserved.
- #
- # Redistribution and use in source and binary forms, with or without
- # modification, are permitted provided that the following conditions are met:
- # * Redistributions of source code must retain the above copyright
- # notice, this list of conditions and the following disclaimer.
- # * Redistributions in binary form must reproduce the above copyright
- # notice, this list of conditions and the following disclaimer in the
- # documentation and/or other materials provided with the distribution.
- # * Neither the name of the <organization> nor the
- # names of its contributors may be used to endorse or promote products
- # derived from this software without specific prior written permission.
- #
- # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
- # ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
- # WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
- # DISCLAIMED. IN NO EVENT SHALL <COPYRIGHT HOLDER> BE LIABLE FOR ANY
- # DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
- # (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
- # LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
- # ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
- # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
- # SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
- #
- # Short-option stacking can be enabled with:
- # zstyle ':completion:*:*:docker:*' option-stacking yes
- # zstyle ':completion:*:*:docker-*:*' option-stacking yes
- __docker_arguments() {
- if zstyle -t ":completion:${curcontext}:" option-stacking; then
- print -- -s
- fi
- }
- __docker_get_containers() {
- [[ $PREFIX = -* ]] && return 1
- integer ret=1
- local kind type line s
- declare -a running stopped lines args names
- kind=$1; shift
- type=$1; shift
- [[ $kind = (stopped|all) ]] && args=($args -a)
- lines=(${(f)${:-"$(_call_program commands docker $docker_options ps --format 'table' --no-trunc $args)"$'\n'}})
- # Parse header line to find columns
- local i=1 j=1 k header=${lines[1]}
- declare -A begin end
- while (( j < ${#header} - 1 )); do
- i=$(( j + ${${header[$j,-1]}[(i)[^ ]]} - 1 ))
- j=$(( i + ${${header[$i,-1]}[(i) ]} - 1 ))
- k=$(( j + ${${header[$j,-1]}[(i)[^ ]]} - 2 ))
- begin[${header[$i,$((j-1))]}]=$i
- end[${header[$i,$((j-1))]}]=$k
- done
- end[${header[$i,$((j-1))]}]=-1 # Last column, should go to the end of the line
- lines=(${lines[2,-1]})
- # Container ID
- if [[ $type = (ids|all) ]]; then
- for line in $lines; do
- s="${${line[${begin[CONTAINER ID]},${end[CONTAINER ID]}]%% ##}[0,12]}"
- s="$s:${(l:15:: :::)${${line[${begin[CREATED]},${end[CREATED]}]/ ago/}%% ##}}"
- s="$s, ${${${line[${begin[IMAGE]},${end[IMAGE]}]}/:/\\:}%% ##}"
- if [[ ${line[${begin[STATUS]},${end[STATUS]}]} = (Exit*|Created*) ]]; then
- stopped=($stopped $s)
- else
- running=($running $s)
- fi
- done
- fi
- # Names: we only display the one without slash. All other names
- # are generated and may clutter the completion. However, with
- # Swarm, all names may be prefixed by the swarm node name.
- if [[ $type = (names|all) ]]; then
- for line in $lines; do
- names=(${(ps:,:)${${line[${begin[NAMES]},${end[NAMES]}]}%% *}})
- # First step: find a common prefix and strip it (swarm node case)
- (( ${#${(u)names%%/*}} == 1 )) && names=${names#${names[1]%%/*}/}
- # Second step: only keep the first name without a /
- s=${${names:#*/*}[1]}
- # If no name, well give up.
- (( $#s != 0 )) || continue
- s="$s:${(l:15:: :::)${${line[${begin[CREATED]},${end[CREATED]}]/ ago/}%% ##}}"
- s="$s, ${${${line[${begin[IMAGE]},${end[IMAGE]}]}/:/\\:}%% ##}"
- if [[ ${line[${begin[STATUS]},${end[STATUS]}]} = (Exit*|Created*) ]]; then
- stopped=($stopped $s)
- else
- running=($running $s)
- fi
- done
- fi
- [[ $kind = (running|all) ]] && _describe -t containers-running "running containers" running "$@" && ret=0
- [[ $kind = (stopped|all) ]] && _describe -t containers-stopped "stopped containers" stopped "$@" && ret=0
- return ret
- }
- __docker_complete_stopped_containers() {
- [[ $PREFIX = -* ]] && return 1
- __docker_get_containers stopped all "$@"
- }
- __docker_complete_running_containers() {
- [[ $PREFIX = -* ]] && return 1
- __docker_get_containers running all "$@"
- }
- __docker_complete_containers() {
- [[ $PREFIX = -* ]] && return 1
- __docker_get_containers all all "$@"
- }
- __docker_complete_containers_ids() {
- [[ $PREFIX = -* ]] && return 1
- __docker_get_containers all ids "$@"
- }
- __docker_complete_containers_names() {
- [[ $PREFIX = -* ]] && return 1
- __docker_get_containers all names "$@"
- }
- __docker_complete_info_plugins() {
- [[ $PREFIX = -* ]] && return 1
- integer ret=1
- emulate -L zsh
- setopt extendedglob
- local -a plugins
- plugins=(${(ps: :)${(M)${(f)${${"$(_call_program commands docker $docker_options info)"##*$'\n'Plugins:}%%$'\n'^ *}}:# $1: *}## $1: })
- _describe -t plugins "$1 plugins" plugins && ret=0
- return ret
- }
- __docker_complete_images() {
- [[ $PREFIX = -* ]] && return 1
- integer ret=1
- declare -a images
- images=(${${${(f)${:-"$(_call_program commands docker $docker_options images)"$'\n'}}[2,-1]}/(#b)([^ ]##) ##([^ ]##) ##([^ ]##)*/${match[3]}:${(r:15:: :::)match[2]} in ${match[1]}})
- _describe -t docker-images "images" images && ret=0
- __docker_complete_repositories_with_tags && ret=0
- return ret
- }
- __docker_complete_repositories() {
- [[ $PREFIX = -* ]] && return 1
- integer ret=1
- declare -a repos
- repos=(${${${(f)${:-"$(_call_program commands docker $docker_options images)"$'\n'}}%% *}[2,-1]})
- repos=(${repos#<none>})
- _describe -t docker-repos "repositories" repos && ret=0
- return ret
- }
- __docker_complete_repositories_with_tags() {
- [[ $PREFIX = -* ]] && return 1
- integer ret=1
- declare -a repos onlyrepos matched
- declare m
- repos=(${${${${(f)${:-"$(_call_program commands docker $docker_options images)"$'\n'}}[2,-1]}/ ##/:::}%% *})
- repos=(${${repos%:::<none>}#<none>})
- # Check if we have a prefix-match for the current prefix.
- onlyrepos=(${repos%::*})
- for m in $onlyrepos; do
- [[ ${PREFIX##${~~m}} != ${PREFIX} ]] && {
- # Yes, complete with tags
- repos=(${${repos/:::/:}/:/\\:})
- _describe -t docker-repos-with-tags "repositories with tags" repos && ret=0
- return ret
- }
- done
- # No, only complete repositories
- onlyrepos=(${${repos%:::*}/:/\\:})
- _describe -t docker-repos "repositories" onlyrepos -qS : && ret=0
- return ret
- }
- __docker_search() {
- [[ $PREFIX = -* ]] && return 1
- local cache_policy
- zstyle -s ":completion:${curcontext}:" cache-policy cache_policy
- if [[ -z "$cache_policy" ]]; then
- zstyle ":completion:${curcontext}:" cache-policy __docker_caching_policy
- fi
- local searchterm cachename
- searchterm="${words[$CURRENT]%/}"
- cachename=_docker-search-$searchterm
- local expl
- local -a result
- if ( [[ ${(P)+cachename} -eq 0 ]] || _cache_invalid ${cachename#_} ) \
- && ! _retrieve_cache ${cachename#_}; then
- _message "Searching for ${searchterm}..."
- result=(${${${(f)${:-"$(_call_program commands docker $docker_options search $searchterm)"$'\n'}}%% *}[2,-1]})
- _store_cache ${cachename#_} result
- fi
- _wanted dockersearch expl 'available images' compadd -a result
- }
- __docker_get_log_options() {
- [[ $PREFIX = -* ]] && return 1
- integer ret=1
- local log_driver=${opt_args[--log-driver]:-"all"}
- local -a common_options common_options2 awslogs_options fluentd_options gelf_options journald_options json_file_options logentries_options syslog_options splunk_options
- common_options=("max-buffer-size" "mode")
- common_options2=("env" "env-regex" "labels")
- awslogs_options=($common_options "awslogs-create-group" "awslogs-datetime-format" "awslogs-group" "awslogs-multiline-pattern" "awslogs-region" "awslogs-stream" "tag")
- fluentd_options=($common_options $common_options2 "fluentd-address" "fluentd-async-connect" "fluentd-buffer-limit" "fluentd-retry-wait" "fluentd-max-retries" "fluentd-sub-second-precision" "tag")
- gcplogs_options=($common_options $common_options2 "gcp-log-cmd" "gcp-meta-id" "gcp-meta-name" "gcp-meta-zone" "gcp-project")
- gelf_options=($common_options $common_options2 "gelf-address" "gelf-compression-level" "gelf-compression-type" "tag")
- journald_options=($common_options $common_options2 "tag")
- json_file_options=($common_options $common_options2 "max-file" "max-size")
- logentries_options=($common_options $common_options2 "logentries-token" "tag")
- syslog_options=($common_options $common_options2 "syslog-address" "syslog-facility" "syslog-format" "syslog-tls-ca-cert" "syslog-tls-cert" "syslog-tls-key" "syslog-tls-skip-verify" "tag")
- splunk_options=($common_options $common_options2 "splunk-caname" "splunk-capath" "splunk-format" "splunk-gzip" "splunk-gzip-level" "splunk-index" "splunk-insecureskipverify" "splunk-source" "splunk-sourcetype" "splunk-token" "splunk-url" "splunk-verify-connection" "tag")
- [[ $log_driver = (awslogs|all) ]] && _describe -t awslogs-options "awslogs options" awslogs_options "$@" && ret=0
- [[ $log_driver = (fluentd|all) ]] && _describe -t fluentd-options "fluentd options" fluentd_options "$@" && ret=0
- [[ $log_driver = (gcplogs|all) ]] && _describe -t gcplogs-options "gcplogs options" gcplogs_options "$@" && ret=0
- [[ $log_driver = (gelf|all) ]] && _describe -t gelf-options "gelf options" gelf_options "$@" && ret=0
- [[ $log_driver = (journald|all) ]] && _describe -t journald-options "journald options" journald_options "$@" && ret=0
- [[ $log_driver = (json-file|all) ]] && _describe -t json-file-options "json-file options" json_file_options "$@" && ret=0
- [[ $log_driver = (logentries|all) ]] && _describe -t logentries-options "logentries options" logentries_options "$@" && ret=0
- [[ $log_driver = (syslog|all) ]] && _describe -t syslog-options "syslog options" syslog_options "$@" && ret=0
- [[ $log_driver = (splunk|all) ]] && _describe -t splunk-options "splunk options" splunk_options "$@" && ret=0
- return ret
- }
- __docker_complete_log_drivers() {
- [[ $PREFIX = -* ]] && return 1
- integer ret=1
- drivers=(awslogs etwlogs fluentd gcplogs gelf journald json-file none splunk syslog)
- _describe -t log-drivers "log drivers" drivers && ret=0
- return ret
- }
- __docker_complete_log_options() {
- [[ $PREFIX = -* ]] && return 1
- integer ret=1
- if compset -P '*='; then
- case "${${words[-1]%=*}#*=}" in
- (syslog-format)
- local opts=('rfc3164' 'rfc5424' 'rfc5424micro')
- _describe -t syslog-format-opts "syslog format options" opts && ret=0
- ;;
- (mode)
- local opts=('blocking' 'non-blocking')
- _describe -t mode-opts "mode options" opts && ret=0
- ;;
- *)
- _message 'value' && ret=0
- ;;
- esac
- else
- __docker_get_log_options -qS "=" && ret=0
- fi
- return ret
- }
- __docker_complete_detach_keys() {
- [[ $PREFIX = -* ]] && return 1
- integer ret=1
- compset -P "*,"
- keys=(${:-{a-z}})
- ctrl_keys=(${:-ctrl-{{a-z},{@,'[','\\','^',']',_}}})
- _describe -t detach_keys "[a-z]" keys -qS "," && ret=0
- _describe -t detach_keys-ctrl "'ctrl-' + 'a-z @ [ \\\\ ] ^ _'" ctrl_keys -qS "," && ret=0
- }
- __docker_complete_pid() {
- [[ $PREFIX = -* ]] && return 1
- integer ret=1
- local -a opts vopts
- opts=('host')
- vopts=('container')
- if compset -P '*:'; then
- case "${${words[-1]%:*}#*=}" in
- (container)
- __docker_complete_running_containers && ret=0
- ;;
- *)
- _message 'value' && ret=0
- ;;
- esac
- else
- _describe -t pid-value-opts "PID Options with value" vopts -qS ":" && ret=0
- _describe -t pid-opts "PID Options" opts && ret=0
- fi
- return ret
- }
- __docker_complete_runtimes() {
- [[ $PREFIX = -* ]] && return 1
- integer ret=1
- emulate -L zsh
- setopt extendedglob
- local -a runtimes_opts
- runtimes_opts=(${(ps: :)${(f)${${"$(_call_program commands docker $docker_options info)"##*$'\n'Runtimes: }%%$'\n'^ *}}})
- _describe -t runtimes-opts "runtimes options" runtimes_opts && ret=0
- }
- __docker_complete_ps_filters() {
- [[ $PREFIX = -* ]] && return 1
- integer ret=1
- if compset -P '*='; then
- case "${${words[-1]%=*}#*=}" in
- (ancestor)
- __docker_complete_images && ret=0
- ;;
- (before|since)
- __docker_complete_containers && ret=0
- ;;
- (health)
- health_opts=('healthy' 'none' 'starting' 'unhealthy')
- _describe -t health-filter-opts "health filter options" health_opts && ret=0
- ;;
- (id)
- __docker_complete_containers_ids && ret=0
- ;;
- (is-task)
- _describe -t boolean-filter-opts "filter options" boolean_opts && ret=0
- ;;
- (name)
- __docker_complete_containers_names && ret=0
- ;;
- (network)
- __docker_complete_networks && ret=0
- ;;
- (status)
- status_opts=('created' 'dead' 'exited' 'paused' 'restarting' 'running' 'removing')
- _describe -t status-filter-opts "status filter options" status_opts && ret=0
- ;;
- (volume)
- __docker_complete_volumes && ret=0
- ;;
- *)
- _message 'value' && ret=0
- ;;
- esac
- else
- opts=('ancestor' 'before' 'exited' 'expose' 'health' 'id' 'label' 'name' 'network' 'publish' 'since' 'status' 'volume')
- _describe -t filter-opts "Filter Options" opts -qS "=" && ret=0
- fi
- return ret
- }
- __docker_complete_search_filters() {
- [[ $PREFIX = -* ]] && return 1
- integer ret=1
- declare -a boolean_opts opts
- boolean_opts=('true' 'false')
- opts=('is-automated' 'is-official' 'stars')
- if compset -P '*='; then
- case "${${words[-1]%=*}#*=}" in
- (is-automated|is-official)
- _describe -t boolean-filter-opts "filter options" boolean_opts && ret=0
- ;;
- *)
- _message 'value' && ret=0
- ;;
- esac
- else
- _describe -t filter-opts "filter options" opts -qS "=" && ret=0
- fi
- return ret
- }
- __docker_complete_images_filters() {
- [[ $PREFIX = -* ]] && return 1
- integer ret=1
- declare -a boolean_opts opts
- boolean_opts=('true' 'false')
- opts=('before' 'dangling' 'label' 'reference' 'since')
- if compset -P '*='; then
- case "${${words[-1]%=*}#*=}" in
- (before|reference|since)
- __docker_complete_images && ret=0
- ;;
- (dangling)
- _describe -t boolean-filter-opts "filter options" boolean_opts && ret=0
- ;;
- *)
- _message 'value' && ret=0
- ;;
- esac
- else
- _describe -t filter-opts "Filter Options" opts -qS "=" && ret=0
- fi
- return ret
- }
- __docker_complete_events_filter() {
- [[ $PREFIX = -* ]] && return 1
- integer ret=1
- declare -a opts
- opts=('container' 'daemon' 'event' 'image' 'label' 'network' 'scope' 'type' 'volume')
- if compset -P '*='; then
- case "${${words[-1]%=*}#*=}" in
- (container)
- __docker_complete_containers && ret=0
- ;;
- (daemon)
- emulate -L zsh
- setopt extendedglob
- local -a daemon_opts
- daemon_opts=(
- ${(f)${${"$(_call_program commands docker $docker_options info)"##*$'\n'Name: }%%$'\n'^ *}}
- ${${(f)${${"$(_call_program commands docker $docker_options info)"##*$'\n'ID: }%%$'\n'^ *}}//:/\\:}
- )
- _describe -t daemon-filter-opts "daemon filter options" daemon_opts && ret=0
- ;;
- (event)
- local -a event_opts
- event_opts=('attach' 'commit' 'connect' 'copy' 'create' 'delete' 'destroy' 'detach' 'die' 'disable' 'disconnect' 'enable' 'exec_create' 'exec_detach'
- 'exec_start' 'export' 'health_status' 'import' 'install' 'kill' 'load' 'mount' 'oom' 'pause' 'pull' 'push' 'reload' 'remove' 'rename' 'resize'
- 'restart' 'save' 'start' 'stop' 'tag' 'top' 'unmount' 'unpause' 'untag' 'update')
- _describe -t event-filter-opts "event filter options" event_opts && ret=0
- ;;
- (image)
- __docker_complete_images && ret=0
- ;;
- (network)
- __docker_complete_networks && ret=0
- ;;
- (scope)
- local -a scope_opts
- scope_opts=('local' 'swarm')
- _describe -t scope-filter-opts "scope filter options" scope_opts && ret=0
- ;;
- (type)
- local -a type_opts
- type_opts=('container' 'daemon' 'image' 'network' 'volume')
- _describe -t type-filter-opts "type filter options" type_opts && ret=0
- ;;
- (volume)
- __docker_complete_volumes && ret=0
- ;;
- *)
- _message 'value' && ret=0
- ;;
- esac
- else
- _describe -t filter-opts "filter options" opts -qS "=" && ret=0
- fi
- return ret
- }
- __docker_complete_prune_filters() {
- [[ $PREFIX = -* ]] && return 1
- integer ret=1
- declare -a opts
- opts=('until')
- if compset -P '*='; then
- case "${${words[-1]%=*}#*=}" in
- *)
- _message 'value' && ret=0
- ;;
- esac
- else
- _describe -t filter-opts "filter options" opts -qS "=" && ret=0
- fi
- return ret
- }
- # BO checkpoint
- __docker_checkpoint_commands() {
- local -a _docker_checkpoint_subcommands
- _docker_checkpoint_subcommands=(
- "create:Create a checkpoint from a running container"
- "ls:List checkpoints for a container"
- "rm:Remove a checkpoint"
- )
- _describe -t docker-checkpoint-commands "docker checkpoint command" _docker_checkpoint_subcommands
- }
- __docker_checkpoint_subcommand() {
- local -a _command_args opts_help
- local expl help="--help"
- integer ret=1
- opts_help=("(: -)--help[Print usage]")
- case "$words[1]" in
- (create)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help)--checkpoint-dir=[Use a custom checkpoint storage directory]:dir:_directories" \
- "($help)--leave-running[Leave the container running after checkpoint]" \
- "($help -)1:container:__docker_complete_running_containers" \
- "($help -)2:checkpoint: " && ret=0
- ;;
- (ls|list)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help)--checkpoint-dir=[Use a custom checkpoint storage directory]:dir:_directories" \
- "($help -)1:container:__docker_complete_containers" && ret=0
- ;;
- (rm|remove)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help)--checkpoint-dir=[Use a custom checkpoint storage directory]:dir:_directories" \
- "($help -)1:container:__docker_complete_containers" \
- "($help -)2:checkpoint: " && ret=0
- ;;
- (help)
- _arguments $(__docker_arguments) ":subcommand:__docker_checkpoint_commands" && ret=0
- ;;
- esac
- return ret
- }
- # EO checkpoint
- # BO container
- __docker_container_commands() {
- local -a _docker_container_subcommands
- _docker_container_subcommands=(
- "attach:Attach to a running container"
- "commit:Create a new image from a container's changes"
- "cp:Copy files/folders between a container and the local filesystem"
- "create:Create a new container"
- "diff:Inspect changes on a container's filesystem"
- "exec:Run a command in a running container"
- "export:Export a container's filesystem as a tar archive"
- "inspect:Display detailed information on one or more containers"
- "kill:Kill one or more running containers"
- "logs:Fetch the logs of a container"
- "ls:List containers"
- "pause:Pause all processes within one or more containers"
- "port:List port mappings or a specific mapping for the container"
- "prune:Remove all stopped containers"
- "rename:Rename a container"
- "restart:Restart one or more containers"
- "rm:Remove one or more containers"
- "run:Run a command in a new container"
- "start:Start one or more stopped containers"
- "stats:Display a live stream of container(s) resource usage statistics"
- "stop:Stop one or more running containers"
- "top:Display the running processes of a container"
- "unpause:Unpause all processes within one or more containers"
- "update:Update configuration of one or more containers"
- "wait:Block until one or more containers stop, then print their exit codes"
- )
- _describe -t docker-container-commands "docker container command" _docker_container_subcommands
- }
- __docker_container_subcommand() {
- local -a _command_args opts_help opts_attach_exec_run_start opts_create_run opts_create_run_update
- local expl help="--help"
- integer ret=1
- opts_attach_exec_run_start=(
- "($help)--detach-keys=[Escape key sequence used to detach a container]:sequence:__docker_complete_detach_keys"
- )
- opts_create_run=(
- "($help -a --attach)"{-a=,--attach=}"[Attach to stdin, stdout or stderr]:device:(STDIN STDOUT STDERR)"
- "($help)*--add-host=[Add a custom host-to-IP mapping]:host\:ip mapping: "
- "($help)*--blkio-weight-device=[Block IO (relative device weight)]:device:Block IO weight: "
- "($help)*--cap-add=[Add Linux capabilities]:capability: "
- "($help)*--cap-drop=[Drop Linux capabilities]:capability: "
- "($help)--cgroupns=[Cgroup namespace mode to use]:cgroup namespace mode: "
- "($help)--cgroup-parent=[Parent cgroup for the container]:cgroup: "
- "($help)--cidfile=[Write the container ID to the file]:CID file:_files"
- "($help)--cpus=[Number of CPUs (default 0.000)]:cpus: "
- "($help)*--device=[Add a host device to the container]:device:_files"
- "($help)*--device-cgroup-rule=[Add a rule to the cgroup allowed devices list]:device:cgroup: "
- "($help)*--device-read-bps=[Limit the read rate (bytes per second) from a device]:device:IO rate: "
- "($help)*--device-read-iops=[Limit the read rate (IO per second) from a device]:device:IO rate: "
- "($help)*--device-write-bps=[Limit the write rate (bytes per second) to a device]:device:IO rate: "
- "($help)*--device-write-iops=[Limit the write rate (IO per second) to a device]:device:IO rate: "
- "($help)--disable-content-trust[Skip image verification]"
- "($help)*--dns=[Custom DNS servers]:DNS server: "
- "($help)*--dns-option=[Custom DNS options]:DNS option: "
- "($help)*--dns-search=[Custom DNS search domains]:DNS domains: "
- "($help)*--domainname=[Container NIS domain name]:domainname:_hosts"
- "($help)*"{-e=,--env=}"[Environment variables]:environment variable: "
- "($help)--entrypoint=[Overwrite the default entrypoint of the image]:entry point: "
- "($help)*--env-file=[Read environment variables from a file]:environment file:_files"
- "($help)*--expose=[Expose a port from the container without publishing it]: "
- "($help)*--group=[Set one or more supplementary user groups for the container]:group:_groups"
- "($help -h --hostname)"{-h=,--hostname=}"[Container host name]:hostname:_hosts"
- "($help -i --interactive)"{-i,--interactive}"[Keep stdin open even if not attached]"
- "($help)--init[Run an init inside the container that forwards signals and reaps processes]"
- "($help)--ip=[IPv4 address]:IPv4: "
- "($help)--ip6=[IPv6 address]:IPv6: "
- "($help)--ipc=[IPC namespace to use]:IPC namespace: "
- "($help)--isolation=[Container isolation technology]:isolation:(default hyperv process)"
- "($help)*--link=[Add link to another container]:link:->link"
- "($help)*--link-local-ip=[Container IPv4/IPv6 link-local addresses]:IPv4/IPv6: "
- "($help)*"{-l=,--label=}"[Container metadata]:label: "
- "($help)--log-driver=[Default driver for container logs]:logging driver:__docker_complete_log_drivers"
- "($help)*--log-opt=[Log driver specific options]:log driver options:__docker_complete_log_options"
- "($help)--mac-address=[Container MAC address]:MAC address: "
- "($help)*--mount=[Attach a filesystem mount to the container]:mount: "
- "($help)--name=[Container name]:name: "
- "($help)--network=[Connect a container to a network]:network mode:(bridge none container host)"
- "($help)*--network-alias=[Add network-scoped alias for the container]:alias: "
- "($help)--oom-kill-disable[Disable OOM Killer]"
- "($help)--oom-score-adj[Tune the host's OOM preferences for containers (accepts -1000 to 1000)]"
- "($help)--pids-limit[Tune container pids limit (set -1 for unlimited)]"
- "($help -P --publish-all)"{-P,--publish-all}"[Publish all exposed ports]"
- "($help)*"{-p=,--publish=}"[Expose a container's port to the host]:port:_ports"
- "($help)--pid=[PID namespace to use]:PID namespace:__docker_complete_pid"
- "($help)--privileged[Give extended privileges to this container]"
- "($help)--read-only[Mount the container's root filesystem as read only]"
- "($help)*--security-opt=[Security options]:security option: "
- "($help)*--shm-size=[Size of '/dev/shm' (format is '<number><unit>')]:shm size: "
- "($help)--stop-signal=[Signal to kill a container]:signal:_signals"
- "($help)--stop-timeout=[Timeout (in seconds) to stop a container]:time: "
- "($help)*--sysctl=-[sysctl options]:sysctl: "
- "($help -t --tty)"{-t,--tty}"[Allocate a pseudo-tty]"
- "($help -u --user)"{-u=,--user=}"[Username or UID]:user:_users"
- "($help)*--ulimit=[ulimit options]:ulimit: "
- "($help)--userns=[Container user namespace]:user namespace:(host)"
- "($help)--tmpfs[mount tmpfs]"
- "($help)*-v[Bind mount a volume]:volume: "
- "($help)--volume-driver=[Optional volume driver for the container]:volume driver:(local)"
- "($help)*--volumes-from=[Mount volumes from the specified container]:volume: "
- "($help -w --workdir)"{-w=,--workdir=}"[Working directory inside the container]:directory:_directories"
- )
- opts_create_run_update=(
- "($help)--blkio-weight=[Block IO (relative weight), between 10 and 1000]:Block IO weight:(10 100 500 1000)"
- "($help -c --cpu-shares)"{-c=,--cpu-shares=}"[CPU shares (relative weight)]:CPU shares:(0 10 100 200 500 800 1000)"
- "($help)--cpu-period=[Limit the CPU CFS (Completely Fair Scheduler) period]:CPU period: "
- "($help)--cpu-quota=[Limit the CPU CFS (Completely Fair Scheduler) quota]:CPU quota: "
- "($help)--cpu-rt-period=[Limit the CPU real-time period]:CPU real-time period in microseconds: "
- "($help)--cpu-rt-runtime=[Limit the CPU real-time runtime]:CPU real-time runtime in microseconds: "
- "($help)--cpuset-cpus=[CPUs in which to allow execution]:CPUs: "
- "($help)--cpuset-mems=[MEMs in which to allow execution]:MEMs: "
- "($help)--kernel-memory=[Kernel memory limit in bytes]:Memory limit: "
- "($help -m --memory)"{-m=,--memory=}"[Memory limit]:Memory limit: "
- "($help)--memory-reservation=[Memory soft limit]:Memory limit: "
- "($help)--memory-swap=[Total memory limit with swap]:Memory limit: "
- "($help)--pids-limit[Tune container pids limit (set -1 for unlimited)]"
- "($help)--restart=[Restart policy]:restart policy:(no on-failure always unless-stopped)"
- )
- opts_help=("(: -)--help[Print usage]")
- case "$words[1]" in
- (attach)
- _arguments $(__docker_arguments) \
- $opts_help \
- $opts_attach_exec_run_start \
- "($help)--no-stdin[Do not attach stdin]" \
- "($help)--sig-proxy[Proxy all received signals to the process (non-TTY mode only)]" \
- "($help -):containers:__docker_complete_running_containers" && ret=0
- ;;
- (commit)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -a --author)"{-a=,--author=}"[Author]:author: " \
- "($help)*"{-c=,--change=}"[Apply Dockerfile instruction to the created image]:Dockerfile:_files" \
- "($help -m --message)"{-m=,--message=}"[Commit message]:message: " \
- "($help -p --pause)"{-p,--pause}"[Pause container during commit]" \
- "($help -):container:__docker_complete_containers" \
- "($help -): :__docker_complete_repositories_with_tags" && ret=0
- ;;
- (cp)
- local state
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -L --follow-link)"{-L,--follow-link}"[Always follow symbol link]" \
- "($help -)1:container:->container" \
- "($help -)2:hostpath:_files" && ret=0
- case $state in
- (container)
- if compset -P "*:"; then
- _files && ret=0
- else
- __docker_complete_containers -qS ":" && ret=0
- fi
- ;;
- esac
- ;;
- (create)
- local state
- _arguments $(__docker_arguments) \
- $opts_help \
- $opts_create_run \
- $opts_create_run_update \
- "($help -): :__docker_complete_images" \
- "($help -):command: _command_names -e" \
- "($help -)*::arguments: _normal" && ret=0
- case $state in
- (link)
- if compset -P "*:"; then
- _wanted alias expl "Alias" compadd -E "" && ret=0
- else
- __docker_complete_running_containers -qS ":" && ret=0
- fi
- ;;
- esac
- ;;
- (diff)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -)*:containers:__docker_complete_containers" && ret=0
- ;;
- (exec)
- local state
- _arguments $(__docker_arguments) \
- $opts_help \
- $opts_attach_exec_run_start \
- "($help -d --detach)"{-d,--detach}"[Detached mode: leave the container running in the background]" \
- "($help)*"{-e=,--env=}"[Set environment variables]:environment variable: " \
- "($help -i --interactive)"{-i,--interactive}"[Keep stdin open even if not attached]" \
- "($help)--privileged[Give extended Linux capabilities to the command]" \
- "($help -t --tty)"{-t,--tty}"[Allocate a pseudo-tty]" \
- "($help -u --user)"{-u=,--user=}"[Username or UID]:user:_users" \
- "($help -w --workdir)"{-w=,--workdir=}"[Working directory inside the container]:directory:_directories" \
- "($help -):containers:__docker_complete_running_containers" \
- "($help -)*::command:->anycommand" && ret=0
- case $state in
- (anycommand)
- shift 1 words
- (( CURRENT-- ))
- _normal && ret=0
- ;;
- esac
- ;;
- (export)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -o --output)"{-o=,--output=}"[Write to a file, instead of stdout]:output file:_files" \
- "($help -)*:containers:__docker_complete_containers" && ret=0
- ;;
- (inspect)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -f --format)"{-f=,--format=}"[Format the output using the given go template]:template: " \
- "($help -s --size)"{-s,--size}"[Display total file sizes]" \
- "($help -)*:containers:__docker_complete_containers" && ret=0
- ;;
- (kill)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -s --signal)"{-s=,--signal=}"[Signal to send]:signal:_signals" \
- "($help -)*:containers:__docker_complete_running_containers" && ret=0
- ;;
- (logs)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help)--details[Show extra details provided to logs]" \
- "($help -f --follow)"{-f,--follow}"[Follow log output]" \
- "($help -s --since)"{-s=,--since=}"[Show logs since this timestamp]:timestamp: " \
- "($help -t --timestamps)"{-t,--timestamps}"[Show timestamps]" \
- "($help)--tail=[Output the last K lines]:lines:(1 10 20 50 all)" \
- "($help -)*:containers:__docker_complete_containers" && ret=0
- ;;
- (ls|list)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -a --all)"{-a,--all}"[Show all containers]" \
- "($help)--before=[Show only container created before...]:containers:__docker_complete_containers" \
- "($help)*"{-f=,--filter=}"[Filter values]:filter:__docker_complete_ps_filters" \
- "($help)--format=[Pretty-print containers using a Go template]:template: " \
- "($help -l --latest)"{-l,--latest}"[Show only the latest created container]" \
- "($help -n --last)"{-n=,--last=}"[Show n last created containers (includes all states)]:n:(1 5 10 25 50)" \
- "($help)--no-trunc[Do not truncate output]" \
- "($help -q --quiet)"{-q,--quiet}"[Only show container IDs]" \
- "($help -s --size)"{-s,--size}"[Display total file sizes]" \
- "($help)--since=[Show only containers created since...]:containers:__docker_complete_containers" && ret=0
- ;;
- (pause|unpause)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -)*:containers:__docker_complete_running_containers" && ret=0
- ;;
- (port)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -)1:containers:__docker_complete_running_containers" \
- "($help -)2:port:_ports" && ret=0
- ;;
- (prune)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help)*--filter=[Filter values]:filter:__docker_complete_prune_filters" \
- "($help -f --force)"{-f,--force}"[Do not prompt for confirmation]" && ret=0
- ;;
- (rename)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -):old name:__docker_complete_containers" \
- "($help -):new name: " && ret=0
- ;;
- (restart)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -t --time)"{-t=,--time=}"[Number of seconds to try to stop for before killing the container]:seconds to before killing:(1 5 10 30 60)" \
- "($help -)*:containers:__docker_complete_containers" && ret=0
- ;;
- (rm)
- local state
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -f --force)"{-f,--force}"[Force removal]" \
- "($help -l --link)"{-l,--link}"[Remove the specified link and not the underlying container]" \
- "($help -v --volumes)"{-v,--volumes}"[Remove the volumes associated to the container]" \
- "($help -)*:containers:->values" && ret=0
- case $state in
- (values)
- if [[ ${words[(r)-f]} == -f || ${words[(r)--force]} == --force ]]; then
- __docker_complete_containers && ret=0
- else
- __docker_complete_stopped_containers && ret=0
- fi
- ;;
- esac
- ;;
- (run)
- local state
- _arguments $(__docker_arguments) \
- $opts_help \
- $opts_create_run \
- $opts_create_run_update \
- $opts_attach_exec_run_start \
- "($help -d --detach)"{-d,--detach}"[Detached mode: leave the container running in the background]" \
- "($help)--health-cmd=[Command to run to check health]:command: " \
- "($help)--health-interval=[Time between running the check]:time: " \
- "($help)--health-retries=[Consecutive failures needed to report unhealthy]:retries:(1 2 3 4 5)" \
- "($help)--health-timeout=[Maximum time to allow one check to run]:time: " \
- "($help)--no-healthcheck[Disable any container-specified HEALTHCHECK]" \
- "($help)--rm[Remove intermediate containers when it exits]" \
- "($help)--runtime=[Name of the runtime to be used for that container]:runtime:__docker_complete_runtimes" \
- "($help)--sig-proxy[Proxy all received signals to the process (non-TTY mode only)]" \
- "($help)--storage-opt=[Storage driver options for the container]:storage options:->storage-opt" \
- "($help -): :__docker_complete_images" \
- "($help -):command: _command_names -e" \
- "($help -)*::arguments: _normal" && ret=0
- case $state in
- (link)
- if compset -P "*:"; then
- _wanted alias expl "Alias" compadd -E "" && ret=0
- else
- __docker_complete_running_containers -qS ":" && ret=0
- fi
- ;;
- (storage-opt)
- if compset -P "*="; then
- _message "value" && ret=0
- else
- opts=('size')
- _describe -t filter-opts "storage options" opts -qS "=" && ret=0
- fi
- ;;
- esac
- ;;
- (start)
- _arguments $(__docker_arguments) \
- $opts_help \
- $opts_attach_exec_run_start \
- "($help -a --attach)"{-a,--attach}"[Attach container's stdout/stderr and forward all signals]" \
- "($help -i --interactive)"{-i,--interactive}"[Attach container's stdin]" \
- "($help -)*:containers:__docker_complete_stopped_containers" && ret=0
- ;;
- (stats)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -a --all)"{-a,--all}"[Show all containers (default shows just running)]" \
- "($help)--format=[Pretty-print images using a Go template]:template: " \
- "($help)--no-stream[Disable streaming stats and only pull the first result]" \
- "($help)--no-trunc[Do not truncate output]" \
- "($help -)*:containers:__docker_complete_running_containers" && ret=0
- ;;
- (stop)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -t --time)"{-t=,--time=}"[Number of seconds to try to stop for before killing the container]:seconds to before killing:(1 5 10 30 60)" \
- "($help -)*:containers:__docker_complete_running_containers" && ret=0
- ;;
- (top)
- local state
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -)1:containers:__docker_complete_running_containers" \
- "($help -)*:: :->ps-arguments" && ret=0
- case $state in
- (ps-arguments)
- _ps && ret=0
- ;;
- esac
- ;;
- (update)
- local state
- _arguments $(__docker_arguments) \
- $opts_help \
- $opts_create_run_update \
- "($help -)*: :->values" && ret=0
- case $state in
- (values)
- if [[ ${words[(r)--kernel-memory*]} = (--kernel-memory*) ]]; then
- __docker_complete_stopped_containers && ret=0
- else
- __docker_complete_containers && ret=0
- fi
- ;;
- esac
- ;;
- (wait)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -)*:containers:__docker_complete_running_containers" && ret=0
- ;;
- (help)
- _arguments $(__docker_arguments) ":subcommand:__docker_container_commands" && ret=0
- ;;
- esac
- return ret
- }
- # EO container
- # BO image
- __docker_image_commands() {
- local -a _docker_image_subcommands
- _docker_image_subcommands=(
- "build:Build an image from a Dockerfile"
- "history:Show the history of an image"
- "import:Import the contents from a tarball to create a filesystem image"
- "inspect:Display detailed information on one or more images"
- "load:Load an image from a tar archive or STDIN"
- "ls:List images"
- "prune:Remove unused images"
- "pull:Pull an image or a repository from a registry"
- "push:Push an image or a repository to a registry"
- "rm:Remove one or more images"
- "save:Save one or more images to a tar archive (streamed to STDOUT by default)"
- "tag:Tag an image into a repository"
- )
- _describe -t docker-image-commands "docker image command" _docker_image_subcommands
- }
- __docker_image_subcommand() {
- local -a _command_args opts_help
- local expl help="--help"
- integer ret=1
- opts_help=("(: -)--help[Print usage]")
- case "$words[1]" in
- (build)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help)*--add-host=[Add a custom host-to-IP mapping]:host\:ip mapping: " \
- "($help)*--build-arg=[Build-time variables]:<varname>=<value>: " \
- "($help)*--cache-from=[Images to consider as cache sources]: :__docker_complete_repositories_with_tags" \
- "($help -c --cpu-shares)"{-c=,--cpu-shares=}"[CPU shares (relative weight)]:CPU shares:(0 10 100 200 500 800 1000)" \
- "($help)--cgroup-parent=[Parent cgroup for the container]:cgroup: " \
- "($help)--compress[Compress the build context using gzip]" \
- "($help)--cpu-period=[Limit the CPU CFS (Completely Fair Scheduler) period]:CPU period: " \
- "($help)--cpu-quota=[Limit the CPU CFS (Completely Fair Scheduler) quota]:CPU quota: " \
- "($help)--cpu-rt-period=[Limit the CPU real-time period]:CPU real-time period in microseconds: " \
- "($help)--cpu-rt-runtime=[Limit the CPU real-time runtime]:CPU real-time runtime in microseconds: " \
- "($help)--cpuset-cpus=[CPUs in which to allow execution]:CPUs: " \
- "($help)--cpuset-mems=[MEMs in which to allow execution]:MEMs: " \
- "($help)--disable-content-trust[Skip image verification]" \
- "($help -f --file)"{-f=,--file=}"[Name of the Dockerfile]:Dockerfile:_files" \
- "($help)--force-rm[Always remove intermediate containers]" \
- "($help)--isolation=[Container isolation technology]:isolation:(default hyperv process)" \
- "($help)*--label=[Set metadata for an image]:label=value: " \
- "($help -m --memory)"{-m=,--memory=}"[Memory limit]:Memory limit: " \
- "($help)--memory-swap=[Total memory limit with swap]:Memory limit: " \
- "($help)--network=[Connect a container to a network]:network mode:(bridge none container host)" \
- "($help)--no-cache[Do not use cache when building the image]" \
- "($help)--pull[Attempt to pull a newer version of the image]" \
- "($help -q --quiet)"{-q,--quiet}"[Suppress verbose build output]" \
- "($help)--rm[Remove intermediate containers after a successful build]" \
- "($help)*--shm-size=[Size of '/dev/shm' (format is '<number><unit>')]:shm size: " \
- "($help)--squash[Squash newly built layers into a single new layer]" \
- "($help -t --tag)*"{-t=,--tag=}"[Repository, name and tag for the image]: :__docker_complete_repositories_with_tags" \
- "($help)*--ulimit=[ulimit options]:ulimit: " \
- "($help)--userns=[Container user namespace]:user namespace:(host)" \
- "($help -):path or URL:_directories" && ret=0
- ;;
- (history)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -H --human)"{-H,--human}"[Print sizes and dates in human readable format]" \
- "($help)--no-trunc[Do not truncate output]" \
- "($help -q --quiet)"{-q,--quiet}"[Only show image IDs]" \
- "($help -)*: :__docker_complete_images" && ret=0
- ;;
- (import)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help)*"{-c=,--change=}"[Apply Dockerfile instruction to the created image]:Dockerfile:_files" \
- "($help -m --message)"{-m=,--message=}"[Commit message for imported image]:message: " \
- "($help -):URL:(- http:// file://)" \
- "($help -): :__docker_complete_repositories_with_tags" && ret=0
- ;;
- (inspect)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -f --format)"{-f=,--format=}"[Format the output using the given go template]:template: " \
- "($help -)*:images:__docker_complete_images" && ret=0
- ;;
- (load)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -i --input)"{-i=,--input=}"[Read from tar archive file]:archive file:_files -g \"*.((tar|TAR)(.gz|.GZ|.Z|.bz2|.lzma|.xz|)|(tbz|tgz|txz))(-.)\"" \
- "($help -q --quiet)"{-q,--quiet}"[Suppress the load output]" && ret=0
- ;;
- (ls|list)
- local state
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -a --all)"{-a,--all}"[Show all images]" \
- "($help)--digests[Show digests]" \
- "($help)*"{-f=,--filter=}"[Filter values]:filter:__docker_complete_images_filters" \
- "($help)--format=[Pretty-print images using a Go template]:template: " \
- "($help)--no-trunc[Do not truncate output]" \
- "($help -q --quiet)"{-q,--quiet}"[Only show image IDs]" \
- "($help -): :__docker_complete_repositories" && ret=0
- ;;
- (prune)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -a --all)"{-a,--all}"[Remove all unused images, not just dangling ones]" \
- "($help)*--filter=[Filter values]:filter:__docker_complete_prune_filters" \
- "($help -f --force)"{-f,--force}"[Do not prompt for confirmation]" && ret=0
- ;;
- (pull)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -a --all-tags)"{-a,--all-tags}"[Download all tagged images]" \
- "($help)--disable-content-trust[Skip image verification]" \
- "($help -):name:__docker_search" && ret=0
- ;;
- (push)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -a --all-tags)"{-a,--all-tags}"[Push all tagged images in the repository]" \
- "($help)--disable-content-trust[Skip image signing]" \
- "($help -): :__docker_complete_images" && ret=0
- ;;
- (rm)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -f --force)"{-f,--force}"[Force removal]" \
- "($help)--no-prune[Do not delete untagged parents]" \
- "($help -)*: :__docker_complete_images" && ret=0
- ;;
- (save)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -o --output)"{-o=,--output=}"[Write to file]:file:_files" \
- "($help -)*: :__docker_complete_images" && ret=0
- ;;
- (tag)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -):source:__docker_complete_images"\
- "($help -):destination:__docker_complete_repositories_with_tags" && ret=0
- ;;
- (help)
- _arguments $(__docker_arguments) ":subcommand:__docker_container_commands" && ret=0
- ;;
- esac
- return ret
- }
- # EO image
- # BO network
- __docker_network_complete_ls_filters() {
- [[ $PREFIX = -* ]] && return 1
- integer ret=1
- if compset -P '*='; then
- case "${${words[-1]%=*}#*=}" in
- (driver)
- __docker_complete_info_plugins Network && ret=0
- ;;
- (id)
- __docker_complete_networks_ids && ret=0
- ;;
- (name)
- __docker_complete_networks_names && ret=0
- ;;
- (scope)
- opts=('global' 'local' 'swarm')
- _describe -t scope-filter-opts "Scope filter options" opts && ret=0
- ;;
- (type)
- opts=('builtin' 'custom')
- _describe -t type-filter-opts "Type filter options" opts && ret=0
- ;;
- *)
- _message 'value' && ret=0
- ;;
- esac
- else
- opts=('driver' 'id' 'label' 'name' 'scope' 'type')
- _describe -t filter-opts "Filter Options" opts -qS "=" && ret=0
- fi
- return ret
- }
- __docker_get_networks() {
- [[ $PREFIX = -* ]] && return 1
- integer ret=1
- local line s
- declare -a lines networks
- type=$1; shift
- lines=(${(f)${:-"$(_call_program commands docker $docker_options network ls)"$'\n'}})
- # Parse header line to find columns
- local i=1 j=1 k header=${lines[1]}
- declare -A begin end
- while (( j < ${#header} - 1 )); do
- i=$(( j + ${${header[$j,-1]}[(i)[^ ]]} - 1 ))
- j=$(( i + ${${header[$i,-1]}[(i) ]} - 1 ))
- k=$(( j + ${${header[$j,-1]}[(i)[^ ]]} - 2 ))
- begin[${header[$i,$((j-1))]}]=$i
- end[${header[$i,$((j-1))]}]=$k
- done
- end[${header[$i,$((j-1))]}]=-1
- lines=(${lines[2,-1]})
- # Network ID
- if [[ $type = (ids|all) ]]; then
- for line in $lines; do
- s="${line[${begin[NETWORK ID]},${end[NETWORK ID]}]%% ##}"
- s="$s:${(l:7:: :::)${${line[${begin[DRIVER]},${end[DRIVER]}]}%% ##}}"
- s="$s, ${${line[${begin[SCOPE]},${end[SCOPE]}]}%% ##}"
- networks=($networks $s)
- done
- fi
- # Names
- if [[ $type = (names|all) ]]; then
- for line in $lines; do
- s="${line[${begin[NAME]},${end[NAME]}]%% ##}"
- s="$s:${(l:7:: :::)${${line[${begin[DRIVER]},${end[DRIVER]}]}%% ##}}"
- s="$s, ${${line[${begin[SCOPE]},${end[SCOPE]}]}%% ##}"
- networks=($networks $s)
- done
- fi
- _describe -t networks-list "networks" networks "$@" && ret=0
- return ret
- }
- __docker_complete_networks() {
- [[ $PREFIX = -* ]] && return 1
- __docker_get_networks all "$@"
- }
- __docker_complete_networks_ids() {
- [[ $PREFIX = -* ]] && return 1
- __docker_get_networks ids "$@"
- }
- __docker_complete_networks_names() {
- [[ $PREFIX = -* ]] && return 1
- __docker_get_networks names "$@"
- }
- __docker_network_commands() {
- local -a _docker_network_subcommands
- _docker_network_subcommands=(
- "connect:Connect a container to a network"
- "create:Creates a new network with a name specified by the user"
- "disconnect:Disconnects a container from a network"
- "inspect:Displays detailed information on a network"
- "ls:Lists all the networks created by the user"
- "prune:Remove all unused networks"
- "rm:Deletes one or more networks"
- )
- _describe -t docker-network-commands "docker network command" _docker_network_subcommands
- }
- __docker_network_subcommand() {
- local -a _command_args opts_help
- local expl help="--help"
- integer ret=1
- opts_help=("(: -)--help[Print usage]")
- case "$words[1]" in
- (connect)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help)*--alias=[Add network-scoped alias for the container]:alias: " \
- "($help)--ip=[IPv4 address]:IPv4: " \
- "($help)--ip6=[IPv6 address]:IPv6: " \
- "($help)*--link=[Add a link to another container]:link:->link" \
- "($help)*--link-local-ip=[Add a link-local address for the container]:IPv4/IPv6: " \
- "($help -)1:network:__docker_complete_networks" \
- "($help -)2:containers:__docker_complete_containers" && ret=0
- case $state in
- (link)
- if compset -P "*:"; then
- _wanted alias expl "Alias" compadd -E "" && ret=0
- else
- __docker_complete_running_containers -qS ":" && ret=0
- fi
- ;;
- esac
- ;;
- (create)
- _arguments $(__docker_arguments) -A '-*' \
- $opts_help \
- "($help)--attachable[Enable manual container attachment]" \
- "($help)*--aux-address[Auxiliary IPv4 or IPv6 addresses used by network driver]:key=IP: " \
- "($help -d --driver)"{-d=,--driver=}"[Driver to manage the Network]:driver:(null host bridge overlay)" \
- "($help)*--gateway=[IPv4 or IPv6 Gateway for the master subnet]:IP: " \
- "($help)--internal[Restricts external access to the network]" \
- "($help)*--ip-range=[Allocate container ip from a sub-range]:IP/mask: " \
- "($help)--ipam-driver=[IP Address Management Driver]:driver:(default)" \
- "($help)*--ipam-opt=[Custom IPAM plugin options]:opt=value: " \
- "($help)--ipv6[Enable IPv6 networking]" \
- "($help)*--label=[Set metadata on a network]:label=value: " \
- "($help)*"{-o=,--opt=}"[Driver specific options]:opt=value: " \
- "($help)*--subnet=[Subnet in CIDR format that represents a network segment]:IP/mask: " \
- "($help -)1:Network Name: " && ret=0
- ;;
- (disconnect)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -)1:network:__docker_complete_networks" \
- "($help -)2:containers:__docker_complete_containers" && ret=0
- ;;
- (inspect)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -f --format)"{-f=,--format=}"[Format the output using the given go template]:template: " \
- "($help)--verbose[Show detailed information]" \
- "($help -)*:network:__docker_complete_networks" && ret=0
- ;;
- (ls)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help)--no-trunc[Do not truncate the output]" \
- "($help)*"{-f=,--filter=}"[Provide filter values]:filter:__docker_network_complete_ls_filters" \
- "($help)--format=[Pretty-print networks using a Go template]:template: " \
- "($help -q --quiet)"{-q,--quiet}"[Only display network IDs]" && ret=0
- ;;
- (prune)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help)*--filter=[Filter values]:filter:__docker_complete_prune_filters" \
- "($help -f --force)"{-f,--force}"[Do not prompt for confirmation]" && ret=0
- ;;
- (rm)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -)*:network:__docker_complete_networks" && ret=0
- ;;
- (help)
- _arguments $(__docker_arguments) ":subcommand:__docker_network_commands" && ret=0
- ;;
- esac
- return ret
- }
- # EO network
- # BO node
- __docker_node_complete_ls_filters() {
- [[ $PREFIX = -* ]] && return 1
- integer ret=1
- if compset -P '*='; then
- case "${${words[-1]%=*}#*=}" in
- (id)
- __docker_complete_nodes_ids && ret=0
- ;;
- (membership)
- membership_opts=('accepted' 'pending' 'rejected')
- _describe -t membership-opts "membership options" membership_opts && ret=0
- ;;
- (name)
- __docker_complete_nodes_names && ret=0
- ;;
- (role)
- role_opts=('manager' 'worker')
- _describe -t role-opts "role options" role_opts && ret=0
- ;;
- *)
- _message 'value' && ret=0
- ;;
- esac
- else
- opts=('id' 'label' 'membership' 'name' 'role')
- _describe -t filter-opts "filter options" opts -qS "=" && ret=0
- fi
- return ret
- }
- __docker_node_complete_ps_filters() {
- [[ $PREFIX = -* ]] && return 1
- integer ret=1
- if compset -P '*='; then
- case "${${words[-1]%=*}#*=}" in
- (desired-state)
- state_opts=('accepted' 'running' 'shutdown')
- _describe -t state-opts "desired state options" state_opts && ret=0
- ;;
- *)
- _message 'value' && ret=0
- ;;
- esac
- else
- opts=('desired-state' 'id' 'label' 'name')
- _describe -t filter-opts "filter options" opts -qS "=" && ret=0
- fi
- return ret
- }
- __docker_nodes() {
- [[ $PREFIX = -* ]] && return 1
- integer ret=1
- local line s
- declare -a lines nodes args
- type=$1; shift
- filter=$1; shift
- [[ $filter != "none" ]] && args=("-f $filter")
- lines=(${(f)${:-"$(_call_program commands docker $docker_options node ls $args)"$'\n'}})
- # Parse header line to find columns
- local i=1 j=1 k header=${lines[1]}
- declare -A begin end
- while (( j < ${#header} - 1 )); do
- i=$(( j + ${${header[$j,-1]}[(i)[^ ]]} - 1 ))
- j=$(( i + ${${header[$i,-1]}[(i) ]} - 1 ))
- k=$(( j + ${${header[$j,-1]}[(i)[^ ]]} - 2 ))
- begin[${header[$i,$((j-1))]}]=$i
- end[${header[$i,$((j-1))]}]=$k
- done
- end[${header[$i,$((j-1))]}]=-1
- lines=(${lines[2,-1]})
- # Node ID
- if [[ $type = (ids|all) ]]; then
- for line in $lines; do
- s="${line[${begin[ID]},${end[ID]}]%% ##}"
- nodes=($nodes $s)
- done
- fi
- # Names
- if [[ $type = (names|all) ]]; then
- for line in $lines; do
- s="${line[${begin[HOSTNAME]},${end[HOSTNAME]}]%% ##}"
- nodes=($nodes $s)
- done
- fi
- _describe -t nodes-list "nodes" nodes "$@" && ret=0
- return ret
- }
- __docker_complete_nodes() {
- [[ $PREFIX = -* ]] && return 1
- __docker_nodes all none "$@"
- }
- __docker_complete_nodes_ids() {
- [[ $PREFIX = -* ]] && return 1
- __docker_nodes ids none "$@"
- }
- __docker_complete_nodes_names() {
- [[ $PREFIX = -* ]] && return 1
- __docker_nodes names none "$@"
- }
- __docker_complete_pending_nodes() {
- [[ $PREFIX = -* ]] && return 1
- __docker_nodes all "membership=pending" "$@"
- }
- __docker_complete_manager_nodes() {
- [[ $PREFIX = -* ]] && return 1
- __docker_nodes all "role=manager" "$@"
- }
- __docker_complete_worker_nodes() {
- [[ $PREFIX = -* ]] && return 1
- __docker_nodes all "role=worker" "$@"
- }
- __docker_node_commands() {
- local -a _docker_node_subcommands
- _docker_node_subcommands=(
- "demote:Demote a node as manager in the swarm"
- "inspect:Display detailed information on one or more nodes"
- "ls:List nodes in the swarm"
- "promote:Promote a node as manager in the swarm"
- "rm:Remove one or more nodes from the swarm"
- "ps:List tasks running on one or more nodes, defaults to current node"
- "update:Update a node"
- )
- _describe -t docker-node-commands "docker node command" _docker_node_subcommands
- }
- __docker_node_subcommand() {
- local -a _command_args opts_help
- local expl help="--help"
- integer ret=1
- opts_help=("(: -)--help[Print usage]")
- case "$words[1]" in
- (rm|remove)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -f --force)"{-f,--force}"[Force remove a node from the swarm]" \
- "($help -)*:node:__docker_complete_pending_nodes" && ret=0
- ;;
- (demote)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -)*:node:__docker_complete_manager_nodes" && ret=0
- ;;
- (inspect)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -f --format)"{-f=,--format=}"[Format the output using the given go template]:template: " \
- "($help)--pretty[Print the information in a human friendly format]" \
- "($help -)*:node:__docker_complete_nodes" && ret=0
- ;;
- (ls|list)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help)*"{-f=,--filter=}"[Provide filter values]:filter:__docker_node_complete_ls_filters" \
- "($help -q --quiet)"{-q,--quiet}"[Only display IDs]" && ret=0
- ;;
- (promote)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -)*:node:__docker_complete_worker_nodes" && ret=0
- ;;
- (ps)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -a --all)"{-a,--all}"[Display all instances]" \
- "($help)*"{-f=,--filter=}"[Provide filter values]:filter:__docker_node_complete_ps_filters" \
- "($help)--format=[Format the output using the given go template]:template: " \
- "($help)--no-resolve[Do not map IDs to Names]" \
- "($help)--no-trunc[Do not truncate output]" \
- "($help -q --quiet)"{-q,--quiet}"[Only display IDs]" \
- "($help -)*:node:__docker_complete_nodes" && ret=0
- ;;
- (update)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help)--availability=[Availability of the node]:availability:(active pause drain)" \
- "($help)*--label-add=[Add or update a node label]:key=value: " \
- "($help)*--label-rm=[Remove a node label if exists]:label: " \
- "($help)--role=[Role of the node]:role:(manager worker)" \
- "($help -)1:node:__docker_complete_nodes" && ret=0
- ;;
- (help)
- _arguments $(__docker_arguments) ":subcommand:__docker_node_commands" && ret=0
- ;;
- esac
- return ret
- }
- # EO node
- # BO plugin
- __docker_plugin_complete_ls_filters() {
- [[ $PREFIX = -* ]] && return 1
- integer ret=1
- if compset -P '*='; then
- case "${${words[-1]%=*}#*=}" in
- (capability)
- opts=('authz' 'ipamdriver' 'logdriver' 'metricscollector' 'networkdriver' 'volumedriver')
- _describe -t capability-opts "capability options" opts && ret=0
- ;;
- (enabled)
- opts=('false' 'true')
- _describe -t enabled-opts "enabled options" opts && ret=0
- ;;
- *)
- _message 'value' && ret=0
- ;;
- esac
- else
- opts=('capability' 'enabled')
- _describe -t filter-opts "filter options" opts -qS "=" && ret=0
- fi
- return ret
- }
- __docker_plugins() {
- [[ $PREFIX = -* ]] && return 1
- integer ret=1
- local line s
- declare -a lines plugins args
- filter=$1; shift
- [[ $filter != "none" ]] && args=("-f $filter")
- lines=(${(f)${:-"$(_call_program commands docker $docker_options plugin ls $args)"$'\n'}})
- # Parse header line to find columns
- local i=1 j=1 k header=${lines[1]}
- declare -A begin end
- while (( j < ${#header} - 1 )); do
- i=$(( j + ${${header[$j,-1]}[(i)[^ ]]} - 1 ))
- j=$(( i + ${${header[$i,-1]}[(i) ]} - 1 ))
- k=$(( j + ${${header[$j,-1]}[(i)[^ ]]} - 2 ))
- begin[${header[$i,$((j-1))]}]=$i
- end[${header[$i,$((j-1))]}]=$k
- done
- end[${header[$i,$((j-1))]}]=-1
- lines=(${lines[2,-1]})
- # Name
- for line in $lines; do
- s="${line[${begin[NAME]},${end[NAME]}]%% ##}"
- s="$s:${(l:7:: :::)${${line[${begin[TAG]},${end[TAG]}]}%% ##}}"
- plugins=($plugins $s)
- done
- _describe -t plugins-list "plugins" plugins "$@" && ret=0
- return ret
- }
- __docker_complete_plugins() {
- [[ $PREFIX = -* ]] && return 1
- __docker_plugins none "$@"
- }
- __docker_complete_enabled_plugins() {
- [[ $PREFIX = -* ]] && return 1
- __docker_plugins enabled=true "$@"
- }
- __docker_complete_disabled_plugins() {
- [[ $PREFIX = -* ]] && return 1
- __docker_plugins enabled=false "$@"
- }
- __docker_plugin_commands() {
- local -a _docker_plugin_subcommands
- _docker_plugin_subcommands=(
- "disable:Disable a plugin"
- "enable:Enable a plugin"
- "inspect:Return low-level information about a plugin"
- "install:Install a plugin"
- "ls:List plugins"
- "push:Push a plugin"
- "rm:Remove a plugin"
- "set:Change settings for a plugin"
- "upgrade:Upgrade an existing plugin"
- )
- _describe -t docker-plugin-commands "docker plugin command" _docker_plugin_subcommands
- }
- __docker_plugin_subcommand() {
- local -a _command_args opts_help
- local expl help="--help"
- integer ret=1
- opts_help=("(: -)--help[Print usage]")
- case "$words[1]" in
- (disable)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -f --force)"{-f,--force}"[Force the disable of an active plugin]" \
- "($help -)1:plugin:__docker_complete_enabled_plugins" && ret=0
- ;;
- (enable)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help)--timeout=[HTTP client timeout (in seconds)]:timeout: " \
- "($help -)1:plugin:__docker_complete_disabled_plugins" && ret=0
- ;;
- (inspect)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -f --format)"{-f=,--format=}"[Format the output using the given Go template]:template: " \
- "($help -)*:plugin:__docker_complete_plugins" && ret=0
- ;;
- (install)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help)--alias=[Local name for plugin]:alias: " \
- "($help)--disable[Do not enable the plugin on install]" \
- "($help)--disable-content-trust[Skip image verification (default true)]" \
- "($help)--grant-all-permissions[Grant all permissions necessary to run the plugin]" \
- "($help -)1:plugin:__docker_complete_plugins" \
- "($help -)*:key=value: " && ret=0
- ;;
- (ls|list)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help)*"{-f=,--filter=}"[Filter output based on conditions provided]:filter:__docker_plugin_complete_ls_filters" \
- "($help --format)--format=[Format the output using the given Go template]:template: " \
- "($help)--no-trunc[Don't truncate output]" \
- "($help -q --quiet)"{-q,--quiet}"[Only display IDs]" && ret=0
- ;;
- (push)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help)--disable-content-trust[Skip image verification (default true)]" \
- "($help -)1:plugin:__docker_complete_plugins" && ret=0
- ;;
- (rm|remove)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -f --force)"{-f,--force}"[Force the removal of an active plugin]" \
- "($help -)*:plugin:__docker_complete_plugins" && ret=0
- ;;
- (set)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -)1:plugin:__docker_complete_plugins" \
- "($help -)*:key=value: " && ret=0
- ;;
- (upgrade)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help)--disable-content-trust[Skip image verification (default true)]" \
- "($help)--grant-all-permissions[Grant all permissions necessary to run the plugin]" \
- "($help)--skip-remote-check[Do not check if specified remote plugin matches existing plugin image]" \
- "($help -)1:plugin:__docker_complete_plugins" \
- "($help -):remote: " && ret=0
- ;;
- (help)
- _arguments $(__docker_arguments) ":subcommand:__docker_plugin_commands" && ret=0
- ;;
- esac
- return ret
- }
- # EO plugin
- # BO secret
- __docker_secrets() {
- [[ $PREFIX = -* ]] && return 1
- integer ret=1
- local line s
- declare -a lines secrets
- type=$1; shift
- lines=(${(f)${:-"$(_call_program commands docker $docker_options secret ls)"$'\n'}})
- # Parse header line to find columns
- local i=1 j=1 k header=${lines[1]}
- declare -A begin end
- while (( j < ${#header} - 1 )); do
- i=$(( j + ${${header[$j,-1]}[(i)[^ ]]} - 1 ))
- j=$(( i + ${${header[$i,-1]}[(i) ]} - 1 ))
- k=$(( j + ${${header[$j,-1]}[(i)[^ ]]} - 2 ))
- begin[${header[$i,$((j-1))]}]=$i
- end[${header[$i,$((j-1))]}]=$k
- done
- end[${header[$i,$((j-1))]}]=-1
- lines=(${lines[2,-1]})
- # ID
- if [[ $type = (ids|all) ]]; then
- for line in $lines; do
- s="${line[${begin[ID]},${end[ID]}]%% ##}"
- secrets=($secrets $s)
- done
- fi
- # Names
- if [[ $type = (names|all) ]]; then
- for line in $lines; do
- s="${line[${begin[NAME]},${end[NAME]}]%% ##}"
- secrets=($secrets $s)
- done
- fi
- _describe -t secrets-list "secrets" secrets "$@" && ret=0
- return ret
- }
- __docker_complete_secrets() {
- [[ $PREFIX = -* ]] && return 1
- __docker_secrets all "$@"
- }
- __docker_secret_commands() {
- local -a _docker_secret_subcommands
- _docker_secret_subcommands=(
- "create:Create a secret using stdin as content"
- "inspect:Display detailed information on one or more secrets"
- "ls:List secrets"
- "rm:Remove one or more secrets"
- )
- _describe -t docker-secret-commands "docker secret command" _docker_secret_subcommands
- }
- __docker_secret_subcommand() {
- local -a _command_args opts_help
- local expl help="--help"
- integer ret=1
- opts_help=("(: -)--help[Print usage]")
- case "$words[1]" in
- (create)
- _arguments $(__docker_arguments) -A '-*' \
- $opts_help \
- "($help)*"{-l=,--label=}"[Secret labels]:label: " \
- "($help -):secret: " && ret=0
- ;;
- (inspect)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -f --format)"{-f=,--format=}"[Format the output using the given Go template]:template: " \
- "($help -)*:secret:__docker_complete_secrets" && ret=0
- ;;
- (ls|list)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help)--format=[Format the output using the given go template]:template: " \
- "($help -q --quiet)"{-q,--quiet}"[Only display IDs]" && ret=0
- ;;
- (rm|remove)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -)*:secret:__docker_complete_secrets" && ret=0
- ;;
- (help)
- _arguments $(__docker_arguments) ":subcommand:__docker_secret_commands" && ret=0
- ;;
- esac
- return ret
- }
- # EO secret
- # BO service
- __docker_service_complete_ls_filters() {
- [[ $PREFIX = -* ]] && return 1
- integer ret=1
- if compset -P '*='; then
- case "${${words[-1]%=*}#*=}" in
- (id)
- __docker_complete_services_ids && ret=0
- ;;
- (mode)
- opts=('global' 'replicated')
- _describe -t mode-opts "mode options" opts && ret=0
- ;;
- (name)
- __docker_complete_services_names && ret=0
- ;;
- *)
- _message 'value' && ret=0
- ;;
- esac
- else
- opts=('id' 'label' 'mode' 'name')
- _describe -t filter-opts "filter options" opts -qS "=" && ret=0
- fi
- return ret
- }
- __docker_service_complete_ps_filters() {
- [[ $PREFIX = -* ]] && return 1
- integer ret=1
- if compset -P '*='; then
- case "${${words[-1]%=*}#*=}" in
- (desired-state)
- state_opts=('accepted' 'running' 'shutdown')
- _describe -t state-opts "desired state options" state_opts && ret=0
- ;;
- *)
- _message 'value' && ret=0
- ;;
- esac
- else
- opts=('desired-state' 'id' 'label' 'name')
- _describe -t filter-opts "filter options" opts -qS "=" && ret=0
- fi
- return ret
- }
- __docker_service_complete_placement_pref() {
- [[ $PREFIX = -* ]] && return 1
- integer ret=1
- if compset -P '*='; then
- case "${${words[-1]%=*}#*=}" in
- (spread)
- opts=('engine.labels' 'node.labels')
- _describe -t spread-opts "spread options" opts -qS "." && ret=0
- ;;
- *)
- _message 'value' && ret=0
- ;;
- esac
- else
- opts=('spread')
- _describe -t pref-opts "placement pref options" opts -qS "=" && ret=0
- fi
- return ret
- }
- __docker_services() {
- [[ $PREFIX = -* ]] && return 1
- integer ret=1
- local line s
- declare -a lines services
- type=$1; shift
- lines=(${(f)${:-"$(_call_program commands docker $docker_options service ls)"$'\n'}})
- # Parse header line to find columns
- local i=1 j=1 k header=${lines[1]}
- declare -A begin end
- while (( j < ${#header} - 1 )); do
- i=$(( j + ${${header[$j,-1]}[(i)[^ ]]} - 1 ))
- j=$(( i + ${${header[$i,-1]}[(i) ]} - 1 ))
- k=$(( j + ${${header[$j,-1]}[(i)[^ ]]} - 2 ))
- begin[${header[$i,$((j-1))]}]=$i
- end[${header[$i,$((j-1))]}]=$k
- done
- end[${header[$i,$((j-1))]}]=-1
- lines=(${lines[2,-1]})
- # Service ID
- if [[ $type = (ids|all) ]]; then
- for line in $lines; do
- s="${line[${begin[ID]},${end[ID]}]%% ##}"
- s="$s:${(l:7:: :::)${${line[${begin[IMAGE]},${end[IMAGE]}]}%% ##}}"
- services=($services $s)
- done
- fi
- # Names
- if [[ $type = (names|all) ]]; then
- for line in $lines; do
- s="${line[${begin[NAME]},${end[NAME]}]%% ##}"
- s="$s:${(l:7:: :::)${${line[${begin[IMAGE]},${end[IMAGE]}]}%% ##}}"
- services=($services $s)
- done
- fi
- _describe -t services-list "services" services "$@" && ret=0
- return ret
- }
- __docker_complete_services() {
- [[ $PREFIX = -* ]] && return 1
- __docker_services all "$@"
- }
- __docker_complete_services_ids() {
- [[ $PREFIX = -* ]] && return 1
- __docker_services ids "$@"
- }
- __docker_complete_services_names() {
- [[ $PREFIX = -* ]] && return 1
- __docker_services names "$@"
- }
- __docker_service_commands() {
- local -a _docker_service_subcommands
- _docker_service_subcommands=(
- "create:Create a new service"
- "inspect:Display detailed information on one or more services"
- "logs:Fetch the logs of a service or task"
- "ls:List services"
- "rm:Remove one or more services"
- "rollback:Revert changes to a service's configuration"
- "scale:Scale one or multiple replicated services"
- "ps:List the tasks of a service"
- "update:Update a service"
- )
- _describe -t docker-service-commands "docker service command" _docker_service_subcommands
- }
- __docker_service_subcommand() {
- local -a _command_args opts_help opts_create_update
- local expl help="--help"
- integer ret=1
- opts_help=("(: -)--help[Print usage]")
- opts_create_update=(
- "($help)*--constraint=[Placement constraints]:constraint: "
- "($help)--endpoint-mode=[Placement constraints]:mode:(dnsrr vip)"
- "($help)*"{-e=,--env=}"[Set environment variables]:env: "
- "($help)--health-cmd=[Command to run to check health]:command: "
- "($help)--health-interval=[Time between running the check]:time: "
- "($help)--health-retries=[Consecutive failures needed to report unhealthy]:retries:(1 2 3 4 5)"
- "($help)--health-timeout=[Maximum time to allow one check to run]:time: "
- "($help)--hostname=[Service container hostname]:hostname: " \
- "($help)--isolation=[Service container isolation mode]:isolation:(default process hyperv)" \
- "($help)*--label=[Service labels]:label: "
- "($help)--limit-cpu=[Limit CPUs]:value: "
- "($help)--limit-memory=[Limit Memory]:value: "
- "($help)--log-driver=[Logging driver for service]:logging driver:__docker_complete_log_drivers"
- "($help)*--log-opt=[Logging driver options]:log driver options:__docker_complete_log_options"
- "($help)*--mount=[Attach a filesystem mount to the service]:mount: "
- "($help)*--network=[Network attachments]:network: "
- "($help)--no-healthcheck[Disable any container-specified HEALTHCHECK]"
- "($help)--read-only[Mount the container's root filesystem as read only]"
- "($help)--replicas=[Number of tasks]:replicas: "
- "($help)--reserve-cpu=[Reserve CPUs]:value: "
- "($help)--reserve-memory=[Reserve Memory]:value: "
- "($help)--restart-condition=[Restart when condition is met]:mode:(any none on-failure)"
- "($help)--restart-delay=[Delay between restart attempts]:delay: "
- "($help)--restart-max-attempts=[Maximum number of restarts before giving up]:max-attempts: "
- "($help)--restart-window=[Window used to evaluate the restart policy]:duration: "
- "($help)--rollback-delay=[Delay between task rollbacks]:duration: "
- "($help)--rollback-failure-action=[Action on rollback failure]:action:(continue pause)"
- "($help)--rollback-max-failure-ratio=[Failure rate to tolerate during a rollback]:failure rate: "
- "($help)--rollback-monitor=[Duration after each task rollback to monitor for failure]:duration: "
- "($help)--rollback-parallelism=[Maximum number of tasks rolled back simultaneously]:number: "
- "($help)*--secret=[Specify secrets to expose to the service]:secret:__docker_complete_secrets"
- "($help)--stop-grace-period=[Time to wait before force killing a container]:grace period: "
- "($help)--stop-signal=[Signal to stop the container]:signal:_signals"
- "($help -t --tty)"{-t,--tty}"[Allocate a pseudo-TTY]"
- "($help)--update-delay=[Delay between updates]:delay: "
- "($help)--update-failure-action=[Action on update failure]:mode:(continue pause rollback)"
- "($help)--update-max-failure-ratio=[Failure rate to tolerate during an update]:fraction: "
- "($help)--update-monitor=[Duration after each task update to monitor for failure]:window: "
- "($help)--update-parallelism=[Maximum number of tasks updated simultaneously]:number: "
- "($help -u --user)"{-u=,--user=}"[Username or UID]:user:_users"
- "($help)--with-registry-auth[Send registry authentication details to swarm agents]"
- "($help -w --workdir)"{-w=,--workdir=}"[Working directory inside the container]:directory:_directories"
- )
- case "$words[1]" in
- (create)
- _arguments $(__docker_arguments) \
- $opts_help \
- $opts_create_update \
- "($help)*--container-label=[Container labels]:label: " \
- "($help)*--dns=[Set custom DNS servers]:DNS: " \
- "($help)*--dns-option=[Set DNS options]:DNS option: " \
- "($help)*--dns-search=[Set custom DNS search domains]:DNS search: " \
- "($help)*--env-file=[Read environment variables from a file]:environment file:_files" \
- "($help)--mode=[Service Mode]:mode:(global replicated)" \
- "($help)--name=[Service name]:name: " \
- "($help)*--placement-pref=[Add a placement preference]:pref:__docker_service_complete_placement_pref" \
- "($help)*"{-p=,--publish=}"[Publish a port as a node port]:port: " \
- "($help -): :__docker_complete_images" \
- "($help -):command: _command_names -e" \
- "($help -)*::arguments: _normal" && ret=0
- ;;
- (inspect)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -f --format)"{-f=,--format=}"[Format the output using the given go template]:template: " \
- "($help)--pretty[Print the information in a human friendly format]" \
- "($help -)*:service:__docker_complete_services" && ret=0
- ;;
- (logs)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -f --follow)"{-f,--follow}"[Follow log output]" \
- "($help)--no-resolve[Do not map IDs to Names]" \
- "($help)--no-task-ids[Do not include task IDs]" \
- "($help)--no-trunc[Do not truncate output]" \
- "($help)--since=[Show logs since timestamp]:timestamp: " \
- "($help)--tail=[Number of lines to show from the end of the logs]:lines:(1 10 20 50 all)" \
- "($help -t --timestamps)"{-t,--timestamps}"[Show timestamps]" \
- "($help -)1:service:__docker_complete_services" && ret=0
- ;;
- (ls|list)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help)*"{-f=,--filter=}"[Filter output based on conditions provided]:filter:__docker_service_complete_ls_filters" \
- "($help)--format=[Pretty-print services using a Go template]:template: " \
- "($help -q --quiet)"{-q,--quiet}"[Only display IDs]" && ret=0
- ;;
- (rm|remove)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -)*:service:__docker_complete_services" && ret=0
- ;;
- (rollback)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -d --detach)"{-d=false,--detach=false}"[Disable detached mode]" \
- "($help -q --quiet)"{-q,--quiet}"[Suppress progress output]" \
- "($help -)*:service:__docker_complete_services" && ret=0
- ;;
- (scale)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -d --detach)"{-d=false,--detach=false}"[Disable detached mode]" \
- "($help -)*:service:->values" && ret=0
- case $state in
- (values)
- if compset -P '*='; then
- _message 'replicas' && ret=0
- else
- __docker_complete_services -qS "="
- fi
- ;;
- esac
- ;;
- (ps)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help)*"{-f=,--filter=}"[Provide filter values]:filter:__docker_service_complete_ps_filters" \
- "($help)--format=[Format the output using the given go template]:template: " \
- "($help)--no-resolve[Do not map IDs to Names]" \
- "($help)--no-trunc[Do not truncate output]" \
- "($help -q --quiet)"{-q,--quiet}"[Only display task IDs]" \
- "($help -)*:service:__docker_complete_services" && ret=0
- ;;
- (update)
- _arguments $(__docker_arguments) \
- $opts_help \
- $opts_create_update \
- "($help)--arg=[Service command args]:arguments: _normal" \
- "($help)*--container-label-add=[Add or update container labels]:label: " \
- "($help)*--container-label-rm=[Remove a container label by its key]:label: " \
- "($help)*--dns-add=[Add or update custom DNS servers]:DNS: " \
- "($help)*--dns-rm=[Remove custom DNS servers]:DNS: " \
- "($help)*--dns-option-add=[Add or update DNS options]:DNS option: " \
- "($help)*--dns-option-rm=[Remove DNS options]:DNS option: " \
- "($help)*--dns-search-add=[Add or update custom DNS search domains]:DNS search: " \
- "($help)*--dns-search-rm=[Remove DNS search domains]:DNS search: " \
- "($help)--force[Force update]" \
- "($help)*--group-add=[Add additional supplementary user groups to the container]:group:_groups" \
- "($help)*--group-rm=[Remove previously added supplementary user groups from the container]:group:_groups" \
- "($help)--image=[Service image tag]:image:__docker_complete_repositories" \
- "($help)*--placement-pref-add=[Add a placement preference]:pref:__docker_service_complete_placement_pref" \
- "($help)*--placement-pref-rm=[Remove a placement preference]:pref:__docker_service_complete_placement_pref" \
- "($help)*--publish-add=[Add or update a port]:port: " \
- "($help)*--publish-rm=[Remove a port(target-port mandatory)]:port: " \
- "($help)--rollback[Rollback to previous specification]" \
- "($help -)1:service:__docker_complete_services" && ret=0
- ;;
- (help)
- _arguments $(__docker_arguments) ":subcommand:__docker_service_commands" && ret=0
- ;;
- esac
- return ret
- }
- # EO service
- # BO stack
- __docker_stack_complete_ps_filters() {
- [[ $PREFIX = -* ]] && return 1
- integer ret=1
- if compset -P '*='; then
- case "${${words[-1]%=*}#*=}" in
- (desired-state)
- state_opts=('accepted' 'running' 'shutdown')
- _describe -t state-opts "desired state options" state_opts && ret=0
- ;;
- *)
- _message 'value' && ret=0
- ;;
- esac
- else
- opts=('desired-state' 'id' 'name')
- _describe -t filter-opts "filter options" opts -qS "=" && ret=0
- fi
- return ret
- }
- __docker_stack_complete_services_filters() {
- [[ $PREFIX = -* ]] && return 1
- integer ret=1
- if compset -P '*='; then
- case "${${words[-1]%=*}#*=}" in
- *)
- _message 'value' && ret=0
- ;;
- esac
- else
- opts=('id' 'label' 'name')
- _describe -t filter-opts "filter options" opts -qS "=" && ret=0
- fi
- return ret
- }
- __docker_stacks() {
- [[ $PREFIX = -* ]] && return 1
- integer ret=1
- local line s
- declare -a lines stacks
- lines=(${(f)${:-"$(_call_program commands docker $docker_options stack ls)"$'\n'}})
- # Parse header line to find columns
- local i=1 j=1 k header=${lines[1]}
- declare -A begin end
- while (( j < ${#header} - 1 )); do
- i=$(( j + ${${header[$j,-1]}[(i)[^ ]]} - 1 ))
- j=$(( i + ${${header[$i,-1]}[(i) ]} - 1 ))
- k=$(( j + ${${header[$j,-1]}[(i)[^ ]]} - 2 ))
- begin[${header[$i,$((j-1))]}]=$i
- end[${header[$i,$((j-1))]}]=$k
- done
- end[${header[$i,$((j-1))]}]=-1
- lines=(${lines[2,-1]})
- # Service NAME
- for line in $lines; do
- s="${line[${begin[NAME]},${end[NAME]}]%% ##}"
- stacks=($stacks $s)
- done
- _describe -t stacks-list "stacks" stacks "$@" && ret=0
- return ret
- }
- __docker_complete_stacks() {
- [[ $PREFIX = -* ]] && return 1
- __docker_stacks "$@"
- }
- __docker_stack_commands() {
- local -a _docker_stack_subcommands
- _docker_stack_subcommands=(
- "deploy:Deploy a new stack or update an existing stack"
- "ls:List stacks"
- "ps:List the tasks in the stack"
- "rm:Remove the stack"
- "services:List the services in the stack"
- )
- _describe -t docker-stack-commands "docker stack command" _docker_stack_subcommands
- }
- __docker_stack_subcommand() {
- local -a _command_args opts_help
- local expl help="--help"
- integer ret=1
- opts_help=("(: -)--help[Print usage]")
- case "$words[1]" in
- (deploy|up)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -c --compose-file)"{-c=,--compose-file=}"[Path to a Compose file, or '-' to read from stdin]:compose file:_files -g \"*.(yml|yaml)\"" \
- "($help)--with-registry-auth[Send registry authentication details to Swarm agents]" \
- "($help -):stack:__docker_complete_stacks" && ret=0
- ;;
- (ls|list)
- _arguments $(__docker_arguments) \
- $opts_help && ret=0
- ;;
- (ps)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -a --all)"{-a,--all}"[Display all tasks]" \
- "($help)*"{-f=,--filter=}"[Filter output based on conditions provided]:filter:__docker_stack_complete_ps_filters" \
- "($help)--format=[Format the output using the given go template]:template: " \
- "($help)--no-resolve[Do not map IDs to Names]" \
- "($help)--no-trunc[Do not truncate output]" \
- "($help -q --quiet)"{-q,--quiet}"[Only display task IDs]" \
- "($help -):stack:__docker_complete_stacks" && ret=0
- ;;
- (rm|remove|down)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -):stack:__docker_complete_stacks" && ret=0
- ;;
- (services)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help)*"{-f=,--filter=}"[Filter output based on conditions provided]:filter:__docker_stack_complete_services_filters" \
- "($help)--format=[Pretty-print services using a Go template]:template: " \
- "($help -q --quiet)"{-q,--quiet}"[Only display IDs]" \
- "($help -):stack:__docker_complete_stacks" && ret=0
- ;;
- (help)
- _arguments $(__docker_arguments) ":subcommand:__docker_stack_commands" && ret=0
- ;;
- esac
- return ret
- }
- # EO stack
- # BO swarm
- __docker_swarm_commands() {
- local -a _docker_swarm_subcommands
- _docker_swarm_subcommands=(
- "init:Initialize a swarm"
- "join:Join a swarm as a node and/or manager"
- "join-token:Manage join tokens"
- "leave:Leave a swarm"
- "unlock:Unlock swarm"
- "unlock-key:Manage the unlock key"
- "update:Update the swarm"
- )
- _describe -t docker-swarm-commands "docker swarm command" _docker_swarm_subcommands
- }
- __docker_swarm_subcommand() {
- local -a _command_args opts_help
- local expl help="--help"
- integer ret=1
- opts_help=("(: -)--help[Print usage]")
- case "$words[1]" in
- (init)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help)--advertise-addr=[Advertised address]:ip\:port: " \
- "($help)--data-path-addr=[Data path IP or interface]:ip " \
- "($help)--data-path-port=[Data Path Port]:port " \
- "($help)--default-addr-pool=[Default address pool]" \
- "($help)--default-addr-pool-mask-length=[Default address pool subnet mask length]" \
- "($help)--autolock[Enable manager autolocking]" \
- "($help)--availability=[Availability of the node]:availability:(active drain pause)" \
- "($help)--cert-expiry=[Validity period for node certificates]:duration: " \
- "($help)--dispatcher-heartbeat=[Dispatcher heartbeat period]:duration: " \
- "($help)*--external-ca=[Specifications of one or more certificate signing endpoints]:endpoint: " \
- "($help)--force-new-cluster[Force create a new cluster from current state]" \
- "($help)--listen-addr=[Listen address]:ip\:port: " \
- "($help)--max-snapshots[Number of additional Raft snapshots to retain]" \
- "($help)--snapshot-interval[Number of log entries between Raft snapshots]" \
- "($help)--task-history-limit=[Task history retention limit]:limit: " && ret=0
- ;;
- (join)
- _arguments $(__docker_arguments) -A '-*' \
- $opts_help \
- "($help)--advertise-addr=[Advertised address]:ip\:port: " \
- "($help)--data-path-addr=[Data path IP or interface]:ip " \
- "($help)--availability=[Availability of the node]:availability:(active drain pause)" \
- "($help)--listen-addr=[Listen address]:ip\:port: " \
- "($help)--token=[Token for entry into the swarm]:secret: " \
- "($help -):host\:port: " && ret=0
- ;;
- (join-token)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -q --quiet)"{-q,--quiet}"[Only display token]" \
- "($help)--rotate[Rotate join token]" \
- "($help -):role:(manager worker)" && ret=0
- ;;
- (leave)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -f --force)"{-f,--force}"[Force this node to leave the swarm, ignoring warnings]" && ret=0
- ;;
- (unlock)
- _arguments $(__docker_arguments) \
- $opts_help && ret=0
- ;;
- (unlock-key)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -q --quiet)"{-q,--quiet}"[Only display token]" \
- "($help)--rotate[Rotate unlock token]" && ret=0
- ;;
- (update)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help)--autolock[Enable manager autolocking]" \
- "($help)--cert-expiry=[Validity period for node certificates]:duration: " \
- "($help)--dispatcher-heartbeat=[Dispatcher heartbeat period]:duration: " \
- "($help)*--external-ca=[Specifications of one or more certificate signing endpoints]:endpoint: " \
- "($help)--max-snapshots[Number of additional Raft snapshots to retain]" \
- "($help)--snapshot-interval[Number of log entries between Raft snapshots]" \
- "($help)--task-history-limit=[Task history retention limit]:limit: " && ret=0
- ;;
- (help)
- _arguments $(__docker_arguments) ":subcommand:__docker_network_commands" && ret=0
- ;;
- esac
- return ret
- }
- # EO swarm
- # BO system
- __docker_system_commands() {
- local -a _docker_system_subcommands
- _docker_system_subcommands=(
- "df:Show docker filesystem usage"
- "events:Get real time events from the server"
- "info:Display system-wide information"
- "prune:Remove unused data"
- )
- _describe -t docker-system-commands "docker system command" _docker_system_subcommands
- }
- __docker_system_subcommand() {
- local -a _command_args opts_help
- local expl help="--help"
- integer ret=1
- opts_help=("(: -)--help[Print usage]")
- case "$words[1]" in
- (df)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -v --verbose)"{-v,--verbose}"[Show detailed information on space usage]" && ret=0
- ;;
- (events)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help)*"{-f=,--filter=}"[Filter values]:filter:__docker_complete_events_filter" \
- "($help)--since=[Events created since this timestamp]:timestamp: " \
- "($help)--until=[Events created until this timestamp]:timestamp: " \
- "($help)--format=[Format the output using the given go template]:template: " && ret=0
- ;;
- (info)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -f --format)"{-f=,--format=}"[Format the output using the given go template]:template: " && ret=0
- ;;
- (prune)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -a --all)"{-a,--all}"[Remove all unused data, not just dangling ones]" \
- "($help)*--filter=[Filter values]:filter:__docker_complete_prune_filters" \
- "($help -f --force)"{-f,--force}"[Do not prompt for confirmation]" \
- "($help)--volumes=[Remove all unused volumes]" && ret=0
- ;;
- (help)
- _arguments $(__docker_arguments) ":subcommand:__docker_volume_commands" && ret=0
- ;;
- esac
- return ret
- }
- # EO system
- # BO volume
- __docker_volume_complete_ls_filters() {
- [[ $PREFIX = -* ]] && return 1
- integer ret=1
- if compset -P '*='; then
- case "${${words[-1]%=*}#*=}" in
- (dangling)
- dangling_opts=('true' 'false')
- _describe -t dangling-filter-opts "Dangling Filter Options" dangling_opts && ret=0
- ;;
- (driver)
- __docker_complete_info_plugins Volume && ret=0
- ;;
- (name)
- __docker_complete_volumes && ret=0
- ;;
- *)
- _message 'value' && ret=0
- ;;
- esac
- else
- opts=('dangling' 'driver' 'label' 'name')
- _describe -t filter-opts "Filter Options" opts -qS "=" && ret=0
- fi
- return ret
- }
- __docker_complete_volumes() {
- [[ $PREFIX = -* ]] && return 1
- integer ret=1
- declare -a lines volumes
- lines=(${(f)${:-"$(_call_program commands docker $docker_options volume ls)"$'\n'}})
- # Parse header line to find columns
- local i=1 j=1 k header=${lines[1]}
- declare -A begin end
- while (( j < ${#header} - 1 )); do
- i=$(( j + ${${header[$j,-1]}[(i)[^ ]]} - 1 ))
- j=$(( i + ${${header[$i,-1]}[(i) ]} - 1 ))
- k=$(( j + ${${header[$j,-1]}[(i)[^ ]]} - 2 ))
- begin[${header[$i,$((j-1))]}]=$i
- end[${header[$i,$((j-1))]}]=$k
- done
- end[${header[$i,$((j-1))]}]=-1
- lines=(${lines[2,-1]})
- # Names
- local line s
- for line in $lines; do
- s="${line[${begin[VOLUME NAME]},${end[VOLUME NAME]}]%% ##}"
- s="$s:${(l:7:: :::)${${line[${begin[DRIVER]},${end[DRIVER]}]}%% ##}}"
- volumes=($volumes $s)
- done
- _describe -t volumes-list "volumes" volumes && ret=0
- return ret
- }
- __docker_volume_commands() {
- local -a _docker_volume_subcommands
- _docker_volume_subcommands=(
- "create:Create a volume"
- "inspect:Display detailed information on one or more volumes"
- "ls:List volumes"
- "prune:Remove all unused volumes"
- "rm:Remove one or more volumes"
- )
- _describe -t docker-volume-commands "docker volume command" _docker_volume_subcommands
- }
- __docker_volume_subcommand() {
- local -a _command_args opts_help
- local expl help="--help"
- integer ret=1
- opts_help=("(: -)--help[Print usage]")
- case "$words[1]" in
- (create)
- _arguments $(__docker_arguments) -A '-*' \
- $opts_help \
- "($help -d --driver)"{-d=,--driver=}"[Volume driver name]:Driver name:(local)" \
- "($help)*--label=[Set metadata for a volume]:label=value: " \
- "($help)*"{-o=,--opt=}"[Driver specific options]:Driver option: " \
- "($help -)1:Volume name: " && ret=0
- ;;
- (inspect)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -f --format)"{-f=,--format=}"[Format the output using the given go template]:template: " \
- "($help -)1:volume:__docker_complete_volumes" && ret=0
- ;;
- (ls)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help)*"{-f=,--filter=}"[Provide filter values]:filter:__docker_volume_complete_ls_filters" \
- "($help)--format=[Pretty-print volumes using a Go template]:template: " \
- "($help -q --quiet)"{-q,--quiet}"[Only display volume names]" && ret=0
- ;;
- (prune)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -f --force)"{-f,--force}"[Do not prompt for confirmation]" && ret=0
- ;;
- (rm)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -f --force)"{-f,--force}"[Force the removal of one or more volumes]" \
- "($help -):volume:__docker_complete_volumes" && ret=0
- ;;
- (help)
- _arguments $(__docker_arguments) ":subcommand:__docker_volume_commands" && ret=0
- ;;
- esac
- return ret
- }
- # EO volume
- __docker_caching_policy() {
- oldp=( "$1"(Nmh+1) ) # 1 hour
- (( $#oldp ))
- }
- __docker_commands() {
- local cache_policy
- integer force_invalidation=0
- zstyle -s ":completion:${curcontext}:" cache-policy cache_policy
- if [[ -z "$cache_policy" ]]; then
- zstyle ":completion:${curcontext}:" cache-policy __docker_caching_policy
- fi
- if ( (( ! ${+_docker_hide_legacy_commands} )) || _cache_invalid docker_hide_legacy_commands ) \
- && ! _retrieve_cache docker_hide_legacy_commands;
- then
- _docker_hide_legacy_commands="${DOCKER_HIDE_LEGACY_COMMANDS}"
- _store_cache docker_hide_legacy_commands _docker_hide_legacy_commands
- fi
- if [[ "${_docker_hide_legacy_commands}" != "${DOCKER_HIDE_LEGACY_COMMANDS}" ]]; then
- force_invalidation=1
- _docker_hide_legacy_commands="${DOCKER_HIDE_LEGACY_COMMANDS}"
- _store_cache docker_hide_legacy_commands _docker_hide_legacy_commands
- fi
- if ( [[ ${+_docker_subcommands} -eq 0 ]] || _cache_invalid docker_subcommands ) \
- && ! _retrieve_cache docker_subcommands || [[ ${force_invalidation} -eq 1 ]];
- then
- local -a lines
- lines=(${(f)"$(_call_program commands docker 2>&1)"})
- _docker_subcommands=(${${${(M)${lines[$((${lines[(i)*Commands:]} + 1)),-1]}:# *}## #}/ ##/:})
- _docker_subcommands=($_docker_subcommands 'daemon:Enable daemon mode' 'help:Show help for a command')
- (( $#_docker_subcommands > 2 )) && _store_cache docker_subcommands _docker_subcommands
- fi
- _describe -t docker-commands "docker command" _docker_subcommands
- }
- __docker_subcommand() {
- local -a _command_args opts_help
- local expl help="--help"
- integer ret=1
- opts_help=("(: -)--help[Print usage]")
- case "$words[1]" in
- (attach|commit|cp|create|diff|exec|export|kill|logs|pause|unpause|port|rename|restart|rm|run|start|stats|stop|top|update|wait)
- __docker_container_subcommand && ret=0
- ;;
- (build|history|import|load|pull|push|save|tag)
- __docker_image_subcommand && ret=0
- ;;
- (checkpoint)
- local curcontext="$curcontext" state
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -): :->command" \
- "($help -)*:: :->option-or-argument" && ret=0
- case $state in
- (command)
- __docker_checkpoint_commands && ret=0
- ;;
- (option-or-argument)
- curcontext=${curcontext%:*:*}:docker-${words[-1]}:
- __docker_checkpoint_subcommand && ret=0
- ;;
- esac
- ;;
- (container)
- local curcontext="$curcontext" state
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -): :->command" \
- "($help -)*:: :->option-or-argument" && ret=0
- case $state in
- (command)
- __docker_container_commands && ret=0
- ;;
- (option-or-argument)
- curcontext=${curcontext%:*:*}:docker-${words[-1]}:
- __docker_container_subcommand && ret=0
- ;;
- esac
- ;;
- (daemon)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help)*--add-runtime=[Register an additional OCI compatible runtime]:runtime:__docker_complete_runtimes" \
- "($help)*--allow-nondistributable-artifacts=[Push nondistributable artifacts to specified registries]:registry: " \
- "($help)--api-cors-header=[CORS headers in the Engine API]:CORS headers: " \
- "($help)*--authorization-plugin=[Authorization plugins to load]" \
- "($help -b --bridge)"{-b=,--bridge=}"[Attach containers to a network bridge]:bridge:_net_interfaces" \
- "($help)--bip=[Network bridge IP]:IP address: " \
- "($help)--cgroup-parent=[Parent cgroup for all containers]:cgroup: " \
- "($help)--cluster-advertise=[Address or interface name to advertise]:Instance to advertise (host\:port): " \
- "($help)--cluster-store=[URL of the distributed storage backend]:Cluster Store:->cluster-store" \
- "($help)*--cluster-store-opt=[Cluster store options]:Cluster options:->cluster-store-options" \
- "($help)--config-file=[Path to daemon configuration file]:Config File:_files" \
- "($help)--containerd=[Path to containerd socket]:socket:_files -g \"*.sock\"" \
- "($help)--data-root=[Root directory of persisted Docker data]:path:_directories" \
- "($help -D --debug)"{-D,--debug}"[Enable debug mode]" \
- "($help)--default-gateway[Container default gateway IPv4 address]:IPv4 address: " \
- "($help)--default-gateway-v6[Container default gateway IPv6 address]:IPv6 address: " \
- "($help)--default-shm-size=[Default shm size for containers]:size:" \
- "($help)*--default-ulimit=[Default ulimits for containers]:ulimit: " \
- "($help)*--dns=[DNS server to use]:DNS: " \
- "($help)*--dns-opt=[DNS options to use]:DNS option: " \
- "($help)*--dns-search=[DNS search domains to use]:DNS search: " \
- "($help)*--exec-opt=[Runtime execution options]:runtime execution options: " \
- "($help)--exec-root=[Root directory for execution state files]:path:_directories" \
- "($help)--experimental[Enable experimental features]" \
- "($help)--fixed-cidr=[IPv4 subnet for fixed IPs]:IPv4 subnet: " \
- "($help)--fixed-cidr-v6=[IPv6 subnet for fixed IPs]:IPv6 subnet: " \
- "($help -G --group)"{-G=,--group=}"[Group for the unix socket]:group:_groups" \
- "($help -H --host)"{-H=,--host=}"[tcp://host:port to bind/connect to]:host: " \
- "($help)--icc[Enable inter-container communication]" \
- "($help)--init[Run an init inside containers to forward signals and reap processes]" \
- "($help)--init-path=[Path to the docker-init binary]:docker-init binary:_files" \
- "($help)*--insecure-registry=[Enable insecure registry communication]:registry: " \
- "($help)--ip=[Default IP when binding container ports]" \
- "($help)--ip-forward[Enable net.ipv4.ip_forward]" \
- "($help)--ip-masq[Enable IP masquerading]" \
- "($help)--iptables[Enable addition of iptables rules]" \
- "($help)--ipv6[Enable IPv6 networking]" \
- "($help -l --log-level)"{-l=,--log-level=}"[Logging level]:level:(debug info warn error fatal)" \
- "($help)*--label=[Key=value labels]:label: " \
- "($help)--live-restore[Enable live restore of docker when containers are still running]" \
- "($help)--log-driver=[Default driver for container logs]:logging driver:__docker_complete_log_drivers" \
- "($help)*--log-opt=[Default log driver options for containers]:log driver options:__docker_complete_log_options" \
- "($help)--max-concurrent-downloads[Set the max concurrent downloads for each pull]" \
- "($help)--max-concurrent-uploads[Set the max concurrent uploads for each push]" \
- "($help)--max-download-attempts[Set the max download attempts for each pull]" \
- "($help)--mtu=[Network MTU]:mtu:(0 576 1420 1500 9000)" \
- "($help)--oom-score-adjust=[Set the oom_score_adj for the daemon]:oom-score:(-500)" \
- "($help -p --pidfile)"{-p=,--pidfile=}"[Path to use for daemon PID file]:PID file:_files" \
- "($help)--raw-logs[Full timestamps without ANSI coloring]" \
- "($help)*--registry-mirror=[Preferred Docker registry mirror]:registry mirror: " \
- "($help)--seccomp-profile=[Path to seccomp profile]:path:_files -g \"*.json\"" \
- "($help -s --storage-driver)"{-s=,--storage-driver=}"[Storage driver to use]:driver:(aufs btrfs devicemapper overlay overlay2 vfs zfs)" \
- "($help)--selinux-enabled[Enable selinux support]" \
- "($help)--shutdown-timeout=[Set the shutdown timeout value in seconds]:time: " \
- "($help)*--storage-opt=[Storage driver options]:storage driver options: " \
- "($help)--tls[Use TLS]" \
- "($help)--tlscacert=[Trust certs signed only by this CA]:PEM file:_files -g \"*.(pem|crt)\"" \
- "($help)--tlscert=[Path to TLS certificate file]:PEM file:_files -g \"*.(pem|crt)\"" \
- "($help)--tlskey=[Path to TLS key file]:Key file:_files -g \"*.(pem|key)\"" \
- "($help)--tlsverify[Use TLS and verify the remote]" \
- "($help)--userns-remap=[User/Group setting for user namespaces]:user\:group:->users-groups" \
- "($help)--userland-proxy[Use userland proxy for loopback traffic]" \
- "($help)--userland-proxy-path=[Path to the userland proxy binary]:binary:_files" && ret=0
- case $state in
- (cluster-store)
- if compset -P '*://'; then
- _message 'host:port' && ret=0
- else
- store=('consul' 'etcd' 'zk')
- _describe -t cluster-store "Cluster Store" store -qS "://" && ret=0
- fi
- ;;
- (cluster-store-options)
- if compset -P '*='; then
- _files && ret=0
- else
- opts=('discovery.heartbeat' 'discovery.ttl' 'kv.cacertfile' 'kv.certfile' 'kv.keyfile' 'kv.path')
- _describe -t cluster-store-opts "Cluster Store Options" opts -qS "=" && ret=0
- fi
- ;;
- (users-groups)
- if compset -P '*:'; then
- _groups && ret=0
- else
- _describe -t userns-default "default Docker user management" '(default)' && ret=0
- _users && ret=0
- fi
- ;;
- esac
- ;;
- (events|info)
- __docker_system_subcommand && ret=0
- ;;
- (image)
- local curcontext="$curcontext" state
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -): :->command" \
- "($help -)*:: :->option-or-argument" && ret=0
- case $state in
- (command)
- __docker_image_commands && ret=0
- ;;
- (option-or-argument)
- curcontext=${curcontext%:*:*}:docker-${words[-1]}:
- __docker_image_subcommand && ret=0
- ;;
- esac
- ;;
- (images)
- words[1]='ls'
- __docker_image_subcommand && ret=0
- ;;
- (inspect)
- local state
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -f --format)"{-f=,--format=}"[Format the output using the given go template]:template: " \
- "($help -s --size)"{-s,--size}"[Display total file sizes if the type is container]" \
- "($help)--type=[Return JSON for specified type]:type:(container image network node plugin service volume)" \
- "($help -)*: :->values" && ret=0
- case $state in
- (values)
- if [[ ${words[(r)--type=container]} == --type=container ]]; then
- __docker_complete_containers && ret=0
- elif [[ ${words[(r)--type=image]} == --type=image ]]; then
- __docker_complete_images && ret=0
- elif [[ ${words[(r)--type=network]} == --type=network ]]; then
- __docker_complete_networks && ret=0
- elif [[ ${words[(r)--type=node]} == --type=node ]]; then
- __docker_complete_nodes && ret=0
- elif [[ ${words[(r)--type=plugin]} == --type=plugin ]]; then
- __docker_complete_plugins && ret=0
- elif [[ ${words[(r)--type=service]} == --type=secrets ]]; then
- __docker_complete_secrets && ret=0
- elif [[ ${words[(r)--type=service]} == --type=service ]]; then
- __docker_complete_services && ret=0
- elif [[ ${words[(r)--type=volume]} == --type=volume ]]; then
- __docker_complete_volumes && ret=0
- else
- __docker_complete_containers
- __docker_complete_images
- __docker_complete_networks
- __docker_complete_nodes
- __docker_complete_plugins
- __docker_complete_secrets
- __docker_complete_services
- __docker_complete_volumes && ret=0
- fi
- ;;
- esac
- ;;
- (login)
- _arguments $(__docker_arguments) -A '-*' \
- $opts_help \
- "($help -p --password)"{-p=,--password=}"[Password]:password: " \
- "($help)--password-stdin[Read password from stdin]" \
- "($help -u --username)"{-u=,--username=}"[Username]:username: " \
- "($help -)1:server: " && ret=0
- ;;
- (logout)
- _arguments $(__docker_arguments) -A '-*' \
- $opts_help \
- "($help -)1:server: " && ret=0
- ;;
- (network)
- local curcontext="$curcontext" state
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -): :->command" \
- "($help -)*:: :->option-or-argument" && ret=0
- case $state in
- (command)
- __docker_network_commands && ret=0
- ;;
- (option-or-argument)
- curcontext=${curcontext%:*:*}:docker-${words[-1]}:
- __docker_network_subcommand && ret=0
- ;;
- esac
- ;;
- (node)
- local curcontext="$curcontext" state
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -): :->command" \
- "($help -)*:: :->option-or-argument" && ret=0
- case $state in
- (command)
- __docker_node_commands && ret=0
- ;;
- (option-or-argument)
- curcontext=${curcontext%:*:*}:docker-${words[-1]}:
- __docker_node_subcommand && ret=0
- ;;
- esac
- ;;
- (plugin)
- local curcontext="$curcontext" state
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -): :->command" \
- "($help -)*:: :->option-or-argument" && ret=0
- case $state in
- (command)
- __docker_plugin_commands && ret=0
- ;;
- (option-or-argument)
- curcontext=${curcontext%:*:*}:docker-${words[-1]}:
- __docker_plugin_subcommand && ret=0
- ;;
- esac
- ;;
- (ps)
- words[1]='ls'
- __docker_container_subcommand && ret=0
- ;;
- (rmi)
- words[1]='rm'
- __docker_image_subcommand && ret=0
- ;;
- (search)
- _arguments $(__docker_arguments) -A '-*' \
- $opts_help \
- "($help)*"{-f=,--filter=}"[Filter values]:filter:__docker_complete_search_filters" \
- "($help)--limit=[Maximum returned search results]:limit:(1 5 10 25 50)" \
- "($help)--no-trunc[Do not truncate output]" \
- "($help -):term: " && ret=0
- ;;
- (secret)
- local curcontext="$curcontext" state
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -): :->command" \
- "($help -)*:: :->option-or-argument" && ret=0
- case $state in
- (command)
- __docker_secret_commands && ret=0
- ;;
- (option-or-argument)
- curcontext=${curcontext%:*:*}:docker-${words[-1]}:
- __docker_secret_subcommand && ret=0
- ;;
- esac
- ;;
- (service)
- local curcontext="$curcontext" state
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -): :->command" \
- "($help -)*:: :->option-or-argument" && ret=0
- case $state in
- (command)
- __docker_service_commands && ret=0
- ;;
- (option-or-argument)
- curcontext=${curcontext%:*:*}:docker-${words[-1]}:
- __docker_service_subcommand && ret=0
- ;;
- esac
- ;;
- (stack)
- local curcontext="$curcontext" state
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -): :->command" \
- "($help -)*:: :->option-or-argument" && ret=0
- case $state in
- (command)
- __docker_stack_commands && ret=0
- ;;
- (option-or-argument)
- curcontext=${curcontext%:*:*}:docker-${words[-1]}:
- __docker_stack_subcommand && ret=0
- ;;
- esac
- ;;
- (swarm)
- local curcontext="$curcontext" state
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -): :->command" \
- "($help -)*:: :->option-or-argument" && ret=0
- case $state in
- (command)
- __docker_swarm_commands && ret=0
- ;;
- (option-or-argument)
- curcontext=${curcontext%:*:*}:docker-${words[-1]}:
- __docker_swarm_subcommand && ret=0
- ;;
- esac
- ;;
- (system)
- local curcontext="$curcontext" state
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -): :->command" \
- "($help -)*:: :->option-or-argument" && ret=0
- case $state in
- (command)
- __docker_system_commands && ret=0
- ;;
- (option-or-argument)
- curcontext=${curcontext%:*:*}:docker-${words[-1]}:
- __docker_system_subcommand && ret=0
- ;;
- esac
- ;;
- (version)
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -f --format)"{-f=,--format=}"[Format the output using the given go template]:template: " && ret=0
- ;;
- (volume)
- local curcontext="$curcontext" state
- _arguments $(__docker_arguments) \
- $opts_help \
- "($help -): :->command" \
- "($help -)*:: :->option-or-argument" && ret=0
- case $state in
- (command)
- __docker_volume_commands && ret=0
- ;;
- (option-or-argument)
- curcontext=${curcontext%:*:*}:docker-${words[-1]}:
- __docker_volume_subcommand && ret=0
- ;;
- esac
- ;;
- (help)
- _arguments $(__docker_arguments) ":subcommand:__docker_commands" && ret=0
- ;;
- esac
- return ret
- }
- _docker() {
- # Support for subservices, which allows for `compdef _docker docker-shell=_docker_containers`.
- # Based on /usr/share/zsh/functions/Completion/Unix/_git without support for `ret`.
- if [[ $service != docker ]]; then
- _call_function - _$service
- return
- fi
- local curcontext="$curcontext" state line help="-h --help"
- integer ret=1
- typeset -A opt_args
- _arguments $(__docker_arguments) -C \
- "(: -)"{-h,--help}"[Print usage]" \
- "($help)--config[Location of client config files]:path:_directories" \
- "($help -D --debug)"{-D,--debug}"[Enable debug mode]" \
- "($help -H --host)"{-H=,--host=}"[tcp://host:port to bind/connect to]:host: " \
- "($help -l --log-level)"{-l=,--log-level=}"[Logging level]:level:(debug info warn error fatal)" \
- "($help)--tls[Use TLS]" \
- "($help)--tlscacert=[Trust certs signed only by this CA]:PEM file:_files -g "*.(pem|crt)"" \
- "($help)--tlscert=[Path to TLS certificate file]:PEM file:_files -g "*.(pem|crt)"" \
- "($help)--tlskey=[Path to TLS key file]:Key file:_files -g "*.(pem|key)"" \
- "($help)--tlsverify[Use TLS and verify the remote]" \
- "($help)--userland-proxy[Use userland proxy for loopback traffic]" \
- "($help -v --version)"{-v,--version}"[Print version information and quit]" \
- "($help -): :->command" \
- "($help -)*:: :->option-or-argument" && ret=0
- local host=${opt_args[-H]}${opt_args[--host]}
- local config=${opt_args[--config]}
- local docker_options="${host:+--host $host} ${config:+--config $config}"
- case $state in
- (command)
- __docker_commands && ret=0
- ;;
- (option-or-argument)
- curcontext=${curcontext%:*:*}:docker-$words[1]:
- __docker_subcommand && ret=0
- ;;
- esac
- return ret
- }
- _dockerd() {
- integer ret=1
- words[1]='daemon'
- __docker_subcommand && ret=0
- return ret
- }
- _docker "$@"
- # Local Variables:
- # mode: Shell-Script
- # sh-indentation: 4
- # indent-tabs-mode: nil
- # sh-basic-offset: 4
- # End:
- # vim: ft=zsh sw=4 ts=4 et
|