diff options
Diffstat (limited to 'plugins/docker')
| -rw-r--r-- | plugins/docker/README.md | 2 | ||||
| -rw-r--r-- | plugins/docker/_docker | 1993 | 
2 files changed, 1440 insertions, 555 deletions
| diff --git a/plugins/docker/README.md b/plugins/docker/README.md index 1615f75f5..e91798485 100644 --- a/plugins/docker/README.md +++ b/plugins/docker/README.md @@ -1,5 +1,5 @@  ## Docker autocomplete plugin  A copy of the completion script from the -[docker](https://github.com/docker/docker/tree/master/contrib/completion/zsh) +[docker/cli](https://github.com/docker/cli/blob/master/contrib/completion/zsh/_docker)  git repo. diff --git a/plugins/docker/_docker b/plugins/docker/_docker index 1366fd61b..31b83c777 100644 --- a/plugins/docker/_docker +++ b/plugins/docker/_docker @@ -1,6 +1,6 @@  #compdef docker dockerd  # -# zsh completion for docker (http://docker.com) +# zsh completion for docker (https://docker.com)  #  # version:  0.3.0  # github:   https://github.com/felixr/docker-zsh-completion @@ -57,7 +57,7 @@ __docker_get_containers() {      type=$1; shift      [[ $kind = (stopped|all) ]] && args=($args -a) -    lines=(${(f)"$(_call_program commands docker $docker_options ps --format 'table' --no-trunc $args)"}) +    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]} @@ -78,7 +78,7 @@ __docker_get_containers() {              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* ]]; then +            if [[ ${line[${begin[STATUS]},${end[STATUS]}]} = (Exit*|Created*) ]]; then                  stopped=($stopped $s)              else                  running=($running $s) @@ -100,7 +100,7 @@ __docker_get_containers() {              (( $#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* ]]; then +            if [[ ${line[${begin[STATUS]},${end[STATUS]}]} = (Exit*|Created*) ]]; then                  stopped=($stopped $s)              else                  running=($running $s) @@ -113,27 +113,27 @@ __docker_get_containers() {      return ret  } -__docker_stoppedcontainers() { +__docker_complete_stopped_containers() {      [[ $PREFIX = -* ]] && return 1      __docker_get_containers stopped all "$@"  } -__docker_runningcontainers() { +__docker_complete_running_containers() {      [[ $PREFIX = -* ]] && return 1      __docker_get_containers running all "$@"  } -__docker_containers() { +__docker_complete_containers() {      [[ $PREFIX = -* ]] && return 1      __docker_get_containers all all "$@"  } -__docker_containers_ids() { +__docker_complete_containers_ids() {      [[ $PREFIX = -* ]] && return 1      __docker_get_containers all ids "$@"  } -__docker_containers_names() { +__docker_complete_containers_names() {      [[ $PREFIX = -* ]] && return 1      __docker_get_containers all names "$@"  } @@ -149,30 +149,32 @@ __docker_complete_info_plugins() {      return ret  } -__docker_images() { +__docker_complete_images() {      [[ $PREFIX = -* ]] && return 1      integer ret=1      declare -a images -    images=(${${${(f)"$(_call_program commands docker $docker_options images)"}[2,-1]}/(#b)([^ ]##) ##([^ ]##) ##([^ ]##)*/${match[3]}:${(r:15:: :::)match[2]} in ${match[1]}}) +    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_repositories_with_tags && ret=0 +    __docker_complete_repositories_with_tags && ret=0      return ret  } -__docker_repositories() { +__docker_complete_repositories() {      [[ $PREFIX = -* ]] && return 1 +    integer ret=1      declare -a repos -    repos=(${${${(f)"$(_call_program commands docker $docker_options images)"}%% *}[2,-1]}) +    repos=(${${${(f)${:-"$(_call_program commands docker $docker_options images)"$'\n'}}%% *}[2,-1]})      repos=(${repos#<none>}) -    _describe -t docker-repos "repositories" repos +    _describe -t docker-repos "repositories" repos && ret=0 +    return ret  } -__docker_repositories_with_tags() { +__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)"}[2,-1]}/ ##/:::}%% *}) +    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%::*}) @@ -208,7 +210,7 @@ __docker_search() {      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)"}%% *}[2,-1]}) +        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 @@ -219,16 +221,19 @@ __docker_get_log_options() {      integer ret=1      local log_driver=${opt_args[--log-driver]:-"all"} -    local -a awslogs_options fluentd_options gelf_options journald_options json_file_options syslog_options splunk_options - -    awslogs_options=("awslogs-region" "awslogs-group" "awslogs-stream") -    fluentd_options=("env" "fluentd-address" "fluentd-async-connect" "fluentd-buffer-limit" "fluentd-retry-wait" "fluentd-max-retries" "labels" "tag") -    gcplogs_options=("env" "gcp-log-cmd" "gcp-project" "labels") -    gelf_options=("env" "gelf-address" "gelf-compression-level" "gelf-compression-type" "labels" "tag") -    journald_options=("env" "labels" "tag") -    json_file_options=("env" "labels" "max-file" "max-size") -    syslog_options=("env" "labels" "syslog-address" "syslog-facility" "syslog-format" "syslog-tls-ca-cert" "syslog-tls-cert" "syslog-tls-key" "syslog-tls-skip-verify" "tag") -    splunk_options=("env" "labels" "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") +    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 @@ -236,13 +241,14 @@ __docker_get_log_options() {      [[ $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_log_drivers() { +__docker_complete_log_drivers() {      [[ $PREFIX = -*  ]] && return 1      integer ret=1      drivers=(awslogs etwlogs fluentd gcplogs gelf journald json-file none splunk syslog) @@ -250,15 +256,19 @@ __docker_log_drivers() {      return ret  } -__docker_log_options() { +__docker_complete_log_options() {      [[ $PREFIX = -* ]] && return 1      integer ret=1      if compset -P '*='; then          case "${${words[-1]%=*}#*=}" in              (syslog-format) -                syslog_format_opts=('rfc3164' 'rfc5424' 'rfc5424micro') -                _describe -t syslog-format-opts "Syslog format Options" syslog_format_opts && ret=0 +                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 @@ -293,7 +303,7 @@ __docker_complete_pid() {      if compset -P '*:'; then          case "${${words[-1]%:*}#*=}" in              (container) -                __docker_runningcontainers && ret=0 +                __docker_complete_running_containers && ret=0                  ;;              *)                  _message 'value' && ret=0 @@ -325,33 +335,40 @@ __docker_complete_ps_filters() {      if compset -P '*='; then          case "${${words[-1]%=*}#*=}" in              (ancestor) -                __docker_images && ret=0 +                __docker_complete_images && ret=0                  ;;              (before|since) -                __docker_containers && ret=0 +                __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_containers_ids && ret=0 +                __docker_complete_containers_ids && ret=0 +                ;; +            (is-task) +                _describe -t boolean-filter-opts "filter options" boolean_opts && ret=0                  ;;              (name) -                __docker_containers_names && ret=0 +                __docker_complete_containers_names && ret=0                  ;;              (network) -                __docker_networks && ret=0 +                __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 +                _describe -t status-filter-opts "status filter options" status_opts && ret=0                  ;;              (volume) -                __docker_volumes && ret=0 +                __docker_complete_volumes && ret=0                  ;;              *)                  _message 'value' && ret=0                  ;;          esac      else -        opts=('ancestor' 'before' 'exited' 'id' 'label' 'name' 'network' 'since' 'status' 'volume') +        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 @@ -388,12 +405,12 @@ __docker_complete_images_filters() {      declare -a boolean_opts opts      boolean_opts=('true' 'false') -    opts=('before' 'dangling' 'label' 'since') +    opts=('before' 'dangling' 'label' 'reference' 'since')      if compset -P '*='; then          case "${${words[-1]%=*}#*=}" in -            (before|since) -                __docker_images && ret=0 +            (before|reference|since) +                __docker_complete_images && ret=0                  ;;              (dangling)                  _describe -t boolean-filter-opts "filter options" boolean_opts && ret=0 @@ -414,12 +431,12 @@ __docker_complete_events_filter() {      integer ret=1      declare -a opts -    opts=('container' 'daemon' 'event' 'image' 'label' 'network' 'type' 'volume') +    opts=('container' 'daemon' 'event' 'image' 'label' 'network' 'scope' 'type' 'volume')      if compset -P '*='; then          case "${${words[-1]%=*}#*=}" in              (container) -                __docker_containers && ret=0 +                __docker_complete_containers && ret=0                  ;;              (daemon)                  emulate -L zsh @@ -433,16 +450,21 @@ __docker_complete_events_filter() {                  ;;              (event)                  local -a event_opts -                event_opts=('attach' 'commit' 'connect' 'copy' 'create' 'delete' 'destroy' 'detach' 'die' 'disconnect' 'exec_create' 'exec_detach' -                'exec_start' 'export' 'health_status' 'import' 'kill' 'load'  'mount' 'oom' 'pause' 'pull' 'push' 'reload' 'rename' 'resize' 'restart' 'save' 'start' -                'stop' 'tag' 'top' 'unmount' 'unpause' 'untag' 'update') +                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_images && ret=0 +                __docker_complete_images && ret=0                  ;;              (network) -                __docker_networks && ret=0 +                __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 @@ -450,7 +472,7 @@ __docker_complete_events_filter() {                  _describe -t type-filter-opts "type filter options" type_opts && ret=0                  ;;              (volume) -                __docker_volumes && ret=0 +                __docker_complete_volumes && ret=0                  ;;              *)                  _message 'value' && ret=0 @@ -463,6 +485,628 @@ __docker_complete_events_filter() {      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)--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)*"{-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)--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 numeric 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_ids" && 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 numeric 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 numeric 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)--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() { @@ -475,21 +1119,25 @@ __docker_network_complete_ls_filters() {                  __docker_complete_info_plugins Network && ret=0                  ;;              (id) -                __docker_networks_ids && ret=0 +                __docker_complete_networks_ids && ret=0                  ;;              (name) -                __docker_networks_names && ret=0 +                __docker_complete_networks_names && ret=0 +                ;; +            (scope) +                opts=('global' 'local' 'swarm') +                _describe -t scope-filter-opts "Scope filter options" opts && ret=0                  ;;              (type) -                type_opts=('builtin' 'custom') -                _describe -t type-filter-opts "Type Filter Options" type_opts && ret=0 +                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' 'type') +        opts=('driver' 'id' 'label' 'name' 'scope' 'type')          _describe -t filter-opts "Filter Options" opts -qS "=" && ret=0      fi @@ -504,7 +1152,7 @@ __docker_get_networks() {      type=$1; shift -    lines=(${(f)"$(_call_program commands docker $docker_options network ls)"}) +    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]} @@ -524,6 +1172,7 @@ __docker_get_networks() {          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 @@ -533,6 +1182,7 @@ __docker_get_networks() {          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 @@ -541,17 +1191,17 @@ __docker_get_networks() {      return ret  } -__docker_networks() { +__docker_complete_networks() {      [[ $PREFIX = -* ]] && return 1      __docker_get_networks all "$@"  } -__docker_networks_ids() { +__docker_complete_networks_ids() {      [[ $PREFIX = -* ]] && return 1      __docker_get_networks ids "$@"  } -__docker_networks_names() { +__docker_complete_networks_names() {      [[ $PREFIX = -* ]] && return 1      __docker_get_networks names "$@"  } @@ -564,6 +1214,7 @@ __docker_network_commands() {          "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 @@ -581,19 +1232,19 @@ __docker_network_subcommand() {              _arguments $(__docker_arguments) \                  $opts_help \                  "($help)*--alias=[Add network-scoped alias for the container]:alias: " \ -                "($help)--ip=[Container IPv4 address]:IPv4: " \ -                "($help)--ip6=[Container IPv6 address]:IPv6: " \ +                "($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_networks" \ -                "($help -)2:containers:__docker_containers" && ret=0 +                "($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_runningcontainers -qS ":" && ret=0 +                        __docker_complete_running_containers -qS ":" && ret=0                      fi                      ;;              esac @@ -601,6 +1252,7 @@ __docker_network_subcommand() {          (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: " \ @@ -617,32 +1269,34 @@ __docker_network_subcommand() {          (disconnect)              _arguments $(__docker_arguments) \                  $opts_help \ -                "($help -)1:network:__docker_networks" \ -                "($help -)2:containers:__docker_containers" && ret=0 +                "($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 -)*:network:__docker_networks" && ret=0 +                "($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:->filter-options" \ +                "($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 numeric IDs]" && ret=0 -            case $state in -                (filter-options) -                    __docker_network_complete_ls_filters && ret=0 -                    ;; -            esac +            ;; +        (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_networks" && ret=0 +                "($help -)*:network:__docker_complete_networks" && ret=0              ;;          (help)              _arguments $(__docker_arguments) ":subcommand:__docker_network_commands" && ret=0 @@ -695,7 +1349,7 @@ __docker_node_complete_ps_filters() {      if compset -P '*='; then          case "${${words[-1]%=*}#*=}" in              (desired-state) -                state_opts=('accepted' 'running') +                state_opts=('accepted' 'running' 'shutdown')                  _describe -t state-opts "desired state options" state_opts && ret=0                  ;;              *) @@ -720,7 +1374,7 @@ __docker_nodes() {      filter=$1; shift      [[ $filter != "none" ]] && args=("-f $filter") -    lines=(${(f)"$(_call_program commands docker $docker_options node ls $args)"}) +    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 @@ -745,7 +1399,7 @@ __docker_nodes() {      # Names      if [[ $type = (names|all) ]]; then          for line in $lines; do -            s="${line[${begin[NAME]},${end[NAME]}]%% ##}" +            s="${line[${begin[HOSTNAME]},${end[HOSTNAME]}]%% ##}"              nodes=($nodes $s)          done      fi @@ -792,7 +1446,7 @@ __docker_node_commands() {          "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 a node, defaults to current node" +        "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 @@ -809,7 +1463,7 @@ __docker_node_subcommand() {          (rm|remove)               _arguments $(__docker_arguments) \                  $opts_help \ -                "($help)--force[Force remove an active node]" \ +                "($help -f --force)"{-f,--force}"[Force remove a node from the swarm]" \                  "($help -)*:node:__docker_complete_pending_nodes" && ret=0              ;;          (demote) @@ -827,13 +1481,8 @@ __docker_node_subcommand() {          (ls|list)              _arguments $(__docker_arguments) \                  $opts_help \ -                "($help)*"{-f=,--filter=}"[Provide filter values]:filter:->filter-options" \ +                "($help)*"{-f=,--filter=}"[Provide filter values]:filter:__docker_node_complete_ls_filters" \                  "($help -q --quiet)"{-q,--quiet}"[Only display IDs]" && ret=0 -            case $state in -                (filter-options) -                    __docker_node_complete_ls_filters && ret=0 -                    ;; -            esac              ;;          (promote)               _arguments $(__docker_arguments) \ @@ -844,15 +1493,12 @@ __docker_node_subcommand() {              _arguments $(__docker_arguments) \                  $opts_help \                  "($help -a --all)"{-a,--all}"[Display all instances]" \ -                "($help)*"{-f=,--filter=}"[Provide filter values]:filter:->filter-options" \ +                "($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 -)1:node:__docker_complete_nodes" && ret=0 -            case $state in -                (filter-options) -                    __docker_node_complete_ps_filters && ret=0 -                    ;; -            esac +                "($help -q --quiet)"{-q,--quiet}"[Only display IDs]" \ +                "($help -)*:node:__docker_complete_nodes" && ret=0              ;;          (update)              _arguments $(__docker_arguments) \ @@ -875,13 +1521,42 @@ __docker_node_subcommand() {  # BO plugin -__docker_complete_plugins() { +__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 +    declare -a lines plugins args + +    filter=$1; shift +    [[ $filter != "none" ]] && args=("-f $filter") -    lines=(${(f)"$(_call_program commands docker $docker_options plugin ls)"}) +    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]} @@ -907,6 +1582,21 @@ __docker_complete_plugins() {      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=( @@ -918,6 +1608,7 @@ __docker_plugin_commands() {          "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  } @@ -930,16 +1621,68 @@ __docker_plugin_subcommand() {      opts_help=("(: -)--help[Print usage]")      case "$words[1]" in -        (disable|enable|inspect|install|ls|push|rm) +        (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 +                "($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 @@ -951,6 +1694,108 @@ __docker_plugin_subcommand() {  # 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() { @@ -962,6 +1807,10 @@ __docker_service_complete_ls_filters() {              (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                  ;; @@ -970,7 +1819,7 @@ __docker_service_complete_ls_filters() {                  ;;          esac      else -        opts=('id' 'label' 'name') +        opts=('id' 'label' 'mode' 'name')          _describe -t filter-opts "filter options" opts -qS "=" && ret=0      fi @@ -984,7 +1833,7 @@ __docker_service_complete_ps_filters() {      if compset -P '*='; then          case "${${words[-1]%=*}#*=}" in              (desired-state) -                state_opts=('accepted' 'running') +                state_opts=('accepted' 'running' 'shutdown')                  _describe -t state-opts "desired state options" state_opts && ret=0                  ;;              *) @@ -999,6 +1848,28 @@ __docker_service_complete_ps_filters() {      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 @@ -1007,7 +1878,7 @@ __docker_services() {      type=$1; shift -    lines=(${(f)"$(_call_program commands docker $docker_options service ls)"}) +    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]} @@ -1064,9 +1935,11 @@ __docker_service_commands() {      _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" -        "scale:Scale one or multiple 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"      ) @@ -1083,26 +1956,41 @@ __docker_service_subcommand() {          "($help)*--constraint=[Placement constraints]:constraint: "          "($help)--endpoint-mode=[Placement constraints]:mode:(dnsrr vip)"          "($help)*"{-e=,--env=}"[Set environment variables]:env: " -        "($help)*--group-add=[Add additional user groups to the container]:group:_groups" +        "($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_log_drivers" -        "($help)*--log-opt=[Logging driver options]:log driver options:__docker_log_options" -        "($help)*--mount=[Attach a mount to the service]:mount: " -        "($help)--name=[Service name]:name: " +        "($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)*"{-p=,--publish=}"[Publish a port as a node port]:port: " +        "($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]:window: " +        "($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:(pause continue)" +        "($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]" @@ -1115,8 +2003,15 @@ __docker_service_subcommand() {                  $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 -): :__docker_images" \ +                "($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              ;; @@ -1127,25 +2022,41 @@ __docker_service_subcommand() {                  "($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:->filter-options" \ +                "($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 -            case $state in -                (filter-options) -                    __docker_service_complete_ls_filters && ret=0 -                    ;; -            esac              ;;          (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) @@ -1160,16 +2071,12 @@ __docker_service_subcommand() {          (ps)              _arguments $(__docker_arguments) \                  $opts_help \ -                "($help -a --all)"{-a,--all}"[Display all tasks]" \ -                "($help)*"{-f=,--filter=}"[Provide filter values]:filter:->filter-options" \ +                "($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 -)1:service:__docker_complete_services" && ret=0 -            case $state in -                (filter-options) -                    __docker_service_complete_ps_filters && ret=0 -                    ;; -            esac +                "($help -q --quiet)"{-q,--quiet}"[Only display task IDs]" \ +                "($help -)*:service:__docker_complete_services" && ret=0              ;;          (update)              _arguments $(__docker_arguments) \ @@ -1178,8 +2085,21 @@ __docker_service_subcommand() {                  "($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)*--group-rm=[Remove previously added user groups from the container]:group:_groups" \ -                "($help)--image=[Service image tag]:image:__docker_repositories" \ +                "($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) @@ -1192,6 +2112,150 @@ __docker_service_subcommand() {  # 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)--bundle-file=[Path to a Distributed Application Bundle file]:dab:_files -g \"*.dab\"" \ +                "($help -c --compose-file)"{-c=,--compose-file=}"[Path to a Compose file]: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() { @@ -1201,6 +2265,8 @@ __docker_swarm_commands() {          "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 @@ -1217,15 +2283,25 @@ __docker_swarm_subcommand() {          (init)              _arguments $(__docker_arguments) \                  $opts_help \ -                "($help)--advertise-addr[Advertised address]:ip\:port: " \ +                "($help)--advertise-addr=[Advertised address]:ip\:port: " \ +                "($help)--data-path-addr=[Data path IP or interface]:ip " \ +                "($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: " && ret=0 +                "($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) \ +            _arguments $(__docker_arguments) -A '-*' \                  $opts_help \ -                "($help)--advertise-addr[Advertised address]:ip\:port: " \ +                "($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 @@ -1239,13 +2315,28 @@ __docker_swarm_subcommand() {              ;;          (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) @@ -1258,6 +2349,63 @@ __docker_swarm_subcommand() {  # 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() { @@ -1274,7 +2422,7 @@ __docker_volume_complete_ls_filters() {                  __docker_complete_info_plugins Volume && ret=0                  ;;              (name) -                __docker_volumes && ret=0 +                __docker_complete_volumes && ret=0                  ;;              *)                  _message 'value' && ret=0 @@ -1288,12 +2436,12 @@ __docker_volume_complete_ls_filters() {      return ret  } -__docker_volumes() { +__docker_complete_volumes() {      [[ $PREFIX = -* ]] && return 1      integer ret=1      declare -a lines volumes -    lines=(${(f)"$(_call_program commands docker $docker_options volume ls)"}) +    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]} @@ -1326,6 +2474,7 @@ __docker_volume_commands() {          "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 @@ -1351,25 +2500,25 @@ __docker_volume_subcommand() {              _arguments $(__docker_arguments) \                  $opts_help \                  "($help -f --format)"{-f=,--format=}"[Format the output using the given go template]:template: " \ -                "($help -)1:volume:__docker_volumes" && ret=0 +                "($help -)1:volume:__docker_complete_volumes" && ret=0              ;;          (ls)              _arguments $(__docker_arguments) \                  $opts_help \ -                "($help)*"{-f=,--filter=}"[Provide filter values]:filter:->filter-options" \ +                "($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 -            case $state in -                (filter-options) -                    __docker_volume_complete_ls_filters && ret=0 -                    ;; -            esac +            ;; +        (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_volumes" && ret=0 +                "($help -):volume:__docker_complete_volumes" && ret=0              ;;          (help)              _arguments $(__docker_arguments) ":subcommand:__docker_volume_commands" && ret=0 @@ -1388,18 +2537,32 @@ __docker_caching_policy() {  __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_subcommands} -eq 0 ]] || _cache_invalid docker_subcommands) \ -        && ! _retrieve_cache docker_subcommands; +    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=(${${${lines[$((${lines[(i)Commands:]} + 1)),${lines[(I)    *]}]}## #}/ ##/:}) +        _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 @@ -1407,193 +2570,87 @@ __docker_commands() {  }  __docker_subcommand() { -    local -a _command_args opts_help opts_build_create_run opts_build_create_run_update opts_create_run opts_create_run_update +    local -a _command_args opts_help      local expl help="--help"      integer ret=1      opts_help=("(: -)--help[Print usage]") -    opts_build_create_run=( -        "($help)--cgroup-parent=[Parent cgroup for the container]:cgroup: " -        "($help)--isolation=[Container isolation technology]:isolation:(default hyperv process)" -        "($help)--disable-content-trust[Skip image verification]" -        "($help)*--shm-size=[Size of '/dev/shm' (format is '<number><unit>')]:shm size: " -        "($help)*--ulimit=[ulimit options]:ulimit: " -        "($help)--userns=[Container user namespace]:user namespace:(host)" -    ) -    opts_build_create_run_update=( -        "($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)--cpuset-cpus=[CPUs in which to allow execution]:CPUs: " -        "($help)--cpuset-mems=[MEMs in which to allow execution]:MEMs: " -        "($help -m --memory)"{-m=,--memory=}"[Memory limit]:Memory limit: " -        "($help)--memory-swap=[Total memory limit with swap]:Memory limit: " -    ) -    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)--cidfile=[Write the container ID to the file]:CID file:_files" -        "($help)*--device=[Add a host device to the container]:device:_files" -        "($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)*--dns=[Custom DNS servers]:DNS server: " -        "($help)*--dns-opt=[Custom DNS options]:DNS option: " -        "($help)*--dns-search=[Custom DNS search domains]:DNS domains: " -        "($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-add=[Add additional groups to run as]: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)--ip=[Container IPv4 address]:IPv4: " -        "($help)--ip6=[Container IPv6 address]:IPv6: " -        "($help)--ipc=[IPC namespace to use]:IPC namespace: " -        "($help)*--link=[Add link to another container]:link:->link" -        "($help)*--link-local-ip=[Add a link-local address for the container]:IPv4/IPv6: " -        "($help)*"{-l=,--label=}"[Container metadata]:label: " -        "($help)--log-driver=[Default driver for container logs]:logging driver:__docker_log_drivers" -        "($help)*--log-opt=[Log driver specific options]:log driver options:__docker_log_options" -        "($help)--mac-address=[Container MAC address]:MAC address: " -        "($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)*--sysctl=-[sysctl options]:sysctl: " -        "($help -t --tty)"{-t,--tty}"[Allocate a pseudo-tty]" -        "($help -u --user)"{-u=,--user=}"[Username or UID]:user:_users" -        "($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)--kernel-memory=[Kernel memory limit in bytes]:Memory limit: " -        "($help)--memory-reservation=[Memory soft limit]:Memory limit: " -        "($help)--restart=[Restart policy]:restart policy:(no on-failure always unless-stopped)" -    ) -    opts_attach_exec_run_start=( -        "($help)--detach-keys=[Escape key sequence used to detach a container]:sequence:__docker_complete_detach_keys" -    )      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_runningcontainers" && ret=0 -            ;; -        (build) -            _arguments $(__docker_arguments) \ -                $opts_help \ -                $opts_build_create_run \ -                $opts_build_create_run_update \ -                "($help)*--build-arg[Build-time variables]:<varname>=<value>: " \ -                "($help -f --file)"{-f=,--file=}"[Name of the Dockerfile]:Dockerfile:_files" \ -                "($help)--force-rm[Always remove intermediate containers]" \ -                "($help)*--label=[Set metadata for an image]:label=value: " \ -                "($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 -t --tag)*"{-t=,--tag=}"[Repository, name and tag for the image]: :__docker_repositories_with_tags" \ -                "($help -):path or URL:_directories" && ret=0 +        (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              ;; -        (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_containers" \ -                "($help -): :__docker_repositories_with_tags" && ret=0 +        (build|history|import|load|pull|push|save|tag) +            __docker_image_subcommand && ret=0              ;; -        (cp) +        (checkpoint) +            local curcontext="$curcontext" 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 +                "($help -): :->command" \ +                "($help -)*:: :->option-or-argument" && ret=0 +              case $state in -                (container) -                    if compset -P "*:"; then -                        _files && ret=0 -                    else -                        __docker_containers -qS ":" && ret=0 -                    fi +                (command) +                    __docker_checkpoint_commands && ret=0 +                    ;; +                (option-or-argument) +                    curcontext=${curcontext%:*:*}:docker-${words[-1]}: +                    __docker_checkpoint_subcommand && ret=0                      ;;              esac              ;; -        (create) +        (container) +            local curcontext="$curcontext" state              _arguments $(__docker_arguments) \                  $opts_help \ -                $opts_build_create_run \ -                $opts_build_create_run_update \ -                $opts_create_run \ -                $opts_create_run_update \ -                "($help -): :__docker_images" \ -                "($help -):command: _command_names -e" \ -                "($help -)*::arguments: _normal" && ret=0 +                "($help -): :->command" \ +                "($help -)*:: :->option-or-argument" && ret=0              case $state in -                (link) -                    if compset -P "*:"; then -                        _wanted alias expl "Alias" compadd -E "" && ret=0 -                    else -                        __docker_runningcontainers -qS ":" && ret=0 -                    fi +                (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)--api-cors-header=[CORS headers in the remote API]:CORS headers: " \ +                "($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)--cluster-store=[URL of the distributed storage backend]:Cluster Store:->cluster-store" \ -                "($help)--cluster-advertise=[Address or interface name to advertise]:Instance to advertise (host\:port): " \ -                "($help)*--cluster-store-opt=[Cluster store options]:Cluster options:->cluster-store-options" \ +                "($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-search=[DNS search domains to use]:DNS search: " \                  "($help)*--dns-opt=[DNS options to use]:DNS option: " \ -                "($help)*--default-ulimit=[Default ulimits for containers]:ulimit: " \ -                "($help)--disable-legacy-registry[Disable contacting legacy registries]" \ +                "($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 -g --graph)"{-g=,--graph=}"[Root of the Docker runtime]:path:_directories" \                  "($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]" \ @@ -1603,8 +2660,8 @@ __docker_subcommand() {                  "($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_log_drivers" \ -                "($help)*--log-opt=[Default log driver options for containers]:log driver options:__docker_log_options" \ +                "($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)--mtu=[Network MTU]:mtu:(0 576 1420 1500 9000)" \ @@ -1612,8 +2669,10 @@ __docker_subcommand() {                  "($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)\"" \ @@ -1621,7 +2680,8 @@ __docker_subcommand() {                  "($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]" && ret=0 +                "($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) @@ -1650,83 +2710,29 @@ __docker_subcommand() {                      ;;              esac              ;; -        (diff) -            _arguments $(__docker_arguments) \ -                $opts_help \ -                "($help -)*:containers:__docker_containers" && 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 +        (events|info) +            __docker_system_subcommand && ret=0              ;; -        (exec) -            local state +        (image) +            local curcontext="$curcontext" 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 -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 -):containers:__docker_runningcontainers" \ -                "($help -)*::command:->anycommand" && ret=0 +                "($help -): :->command" \ +                "($help -)*:: :->option-or-argument" && ret=0              case $state in -                (anycommand) -                    shift 1 words -                    (( CURRENT-- )) -                    _normal && ret=0 +                (command) +                    __docker_image_commands && 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_containers" && 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 numeric IDs]" \ -                "($help -)*: :__docker_images" && ret=0 -            ;; -        (images) -            _arguments $(__docker_arguments) \ -                $opts_help \ -                "($help -a --all)"{-a,--all}"[Show all images]" \ -                "($help)--digests[Show digests]" \ -                "($help)*"{-f=,--filter=}"[Filter values]:filter:->filter-options" \ -                "($help)--format[Pretty-print images using a Go template]:template: " \ -                "($help)--no-trunc[Do not truncate output]" \ -                "($help -q --quiet)"{-q,--quiet}"[Only show numeric IDs]" \ -                "($help -): :__docker_repositories" && ret=0 - -            case $state in -                (filter-options) -                    __docker_complete_images_filters && ret=0 +                (option-or-argument) +                    curcontext=${curcontext%:*:*}:docker-${words[-1]}: +                    __docker_image_subcommand && ret=0                      ;;              esac              ;; -        (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_repositories_with_tags" && ret=0 -            ;; -        (info|version) -            _arguments $(__docker_arguments) \ -                $opts_help \ -		"($help -f --format)"{-f=,--format=}"[Format the output using the given go template]:template: " && ret=0 +        (images) +            words[1]='ls' +            __docker_image_subcommand && ret=0              ;;          (inspect)              local state @@ -1734,55 +2740,53 @@ __docker_subcommand() {                  $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:(image 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_containers && ret=0 +                        __docker_complete_containers && ret=0                      elif [[ ${words[(r)--type=image]} == --type=image ]]; then -                        __docker_images && ret=0 +                        __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_images && __docker_containers && ret=0 +                        __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              ;; -        (kill) -            _arguments $(__docker_arguments) \ -                $opts_help \ -                "($help -s --signal)"{-s=,--signal=}"[Signal to send]:signal:_signals" \ -                "($help -)*:containers:__docker_runningcontainers" && 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 -            ;;          (login) -            _arguments $(__docker_arguments) \ +            _arguments $(__docker_arguments) -A '-*' \                  $opts_help \                  "($help -p --password)"{-p=,--password=}"[Password]:password: " \ +                "($help)--password-stdin[Read password from stdin]" \                  "($help -u --user)"{-u=,--user=}"[Username]:username: " \                  "($help -)1:server: " && ret=0              ;;          (logout) -            _arguments $(__docker_arguments) \ +            _arguments $(__docker_arguments) -A '-*' \                  $opts_help \                  "($help -)1:server: " && 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_containers" && ret=0 -            ;;          (network)              local curcontext="$curcontext" state              _arguments $(__docker_arguments) \ @@ -1817,11 +2821,6 @@ __docker_subcommand() {                      ;;              esac              ;; -        (pause|unpause) -            _arguments $(__docker_arguments) \ -                $opts_help \ -                "($help -)*:containers:__docker_runningcontainers" && ret=0 -            ;;          (plugin)              local curcontext="$curcontext" state              _arguments $(__docker_arguments) \ @@ -1839,134 +2838,36 @@ __docker_subcommand() {                      ;;              esac              ;; -        (port) -            _arguments $(__docker_arguments) \ -                $opts_help \ -                "($help -)1:containers:__docker_runningcontainers" \ -                "($help -)2:port:_ports" && ret=0 -            ;;          (ps) -            _arguments $(__docker_arguments) \ -                $opts_help \ -                "($help -a --all)"{-a,--all}"[Show all containers]" \ -                "($help)--before=[Show only container created before...]:containers:__docker_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 numeric IDs]" \ -                "($help -s --size)"{-s,--size}"[Display total file sizes]" \ -                "($help)--since=[Show only containers created since...]:containers:__docker_containers" && 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)--disable-content-trust[Skip image signing]" \ -                "($help -): :__docker_images" && ret=0 -            ;; -        (rename) -            _arguments $(__docker_arguments) \ -                $opts_help \ -                "($help -):old name:__docker_containers" \ -                "($help -):new name: " && ret=0 -            ;; -        (restart|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_runningcontainers" && ret=0 -            ;; -        (rm) -            _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_containers && ret=0 -                    else -                        __docker_stoppedcontainers && ret=0 -                    fi -                    ;; -            esac +            words[1]='ls' +            __docker_container_subcommand && ret=0              ;;          (rmi) -            _arguments $(__docker_arguments) \ -                $opts_help \ -                "($help -f --force)"{-f,--force}"[Force removal]" \ -                "($help)--no-prune[Do not delete untagged parents]" \ -                "($help -)*: :__docker_images" && ret=0 -            ;; -        (run) -            _arguments $(__docker_arguments) \ -                $opts_help \ -                $opts_build_create_run \ -                $opts_build_create_run_update \ -                $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)--stop-signal=[Signal to kill a container]:signal:_signals" \ -                "($help)--storage-opt=[Storage driver options for the container]:storage options:->storage-opt" \ -                "($help -): :__docker_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_runningcontainers -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 - -            ;; -        (save) -            _arguments $(__docker_arguments) \ -                $opts_help \ -                "($help -o --output)"{-o=,--output=}"[Write to file]:file:_files" \ -                "($help -)*: :__docker_images" && ret=0 +            words[1]='rm' +            __docker_image_subcommand && ret=0              ;;          (search) -            _arguments $(__docker_arguments) \ +            _arguments $(__docker_arguments) -A '-*' \                  $opts_help \ -                "($help)*"{-f=,--filter=}"[Filter values]:filter:->filter-options" \ +                "($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 -                (filter-options) -                    __docker_complete_search_filters && ret=0 +                (command) +                    __docker_secret_commands && ret=0 +                    ;; +                (option-or-argument) +                    curcontext=${curcontext%:*:*}:docker-${words[-1]}: +                    __docker_secret_subcommand && ret=0                      ;;              esac              ;; @@ -1987,20 +2888,22 @@ __docker_subcommand() {                      ;;              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 stding]" \ -                "($help -)*:containers:__docker_stoppedcontainers" && ret=0 -            ;; -        (stats) +        (stack) +            local curcontext="$curcontext" state              _arguments $(__docker_arguments) \                  $opts_help \ -                "($help -a --all)"{-a,--all}"[Show all containers (default shows just running)]" \ -                "($help)--no-stream[Disable streaming stats and only pull the first result]" \ -                "($help -)*:containers:__docker_runningcontainers" && ret=0 +                "($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 @@ -2019,40 +2922,27 @@ __docker_subcommand() {                      ;;              esac              ;; -        (tag) -            _arguments $(__docker_arguments) \ -                $opts_help \ -                "($help -):source:__docker_images"\ -                "($help -):destination:__docker_repositories_with_tags" && ret=0 -            ;; -        (top) +        (system) +            local curcontext="$curcontext" state              _arguments $(__docker_arguments) \                  $opts_help \ -                "($help -)1:containers:__docker_runningcontainers" \ -                "($help -)*:: :->ps-arguments" && ret=0 +                "($help -): :->command" \ +                "($help -)*:: :->option-or-argument" && ret=0 +              case $state in -                (ps-arguments) -                    _ps && ret=0 +                (command) +                    __docker_system_commands && ret=0 +                    ;; +                (option-or-argument) +                    curcontext=${curcontext%:*:*}:docker-${words[-1]}: +                    __docker_system_subcommand && ret=0                      ;;              esac -              ;; -        (update) +        (version)              _arguments $(__docker_arguments) \                  $opts_help \ -                $opts_create_run_update \ -                $opts_build_create_run_update \ -                "($help -)*: :->values" && ret=0 - -            case $state in -                (values) -                    if [[ ${words[(r)--kernel-memory*]} = (--kernel-memory*) ]]; then -                        __docker_stoppedcontainers && ret=0 -                    else -                        __docker_containers && ret=0 -                    fi -                    ;; -            esac +                "($help -f --format)"{-f=,--format=}"[Format the output using the given go template]:template: " && ret=0              ;;          (volume)              local curcontext="$curcontext" state @@ -2071,11 +2961,6 @@ __docker_subcommand() {                      ;;              esac              ;; -        (wait) -            _arguments $(__docker_arguments) \ -                $opts_help \ -                "($help -)*:containers:__docker_runningcontainers" && ret=0 -            ;;          (help)              _arguments $(__docker_arguments) ":subcommand:__docker_commands" && ret=0              ;; | 
