Blob Blame History Raw
From b632845742c568b5576fdae430983deb42c7897a Mon Sep 17 00:00:00 2001
From: Lukas Rusak <lorusak@gmail.com>
Date: Wed, 22 Apr 2015 11:07:39 -0700
Subject: [PATCH] zsh-completion: add missing completions for systemd-nspawn

(cherry picked from commit 6b85708cfd371f40ed95462cd8787ee0673ad36d)
---
 shell-completion/zsh/_systemd-nspawn | 22 +++++++++++++---------
 1 file changed, 13 insertions(+), 9 deletions(-)

diff --git a/shell-completion/zsh/_systemd-nspawn b/shell-completion/zsh/_systemd-nspawn
index ceedb2c5a0..08f5696acb 100644
--- a/shell-completion/zsh/_systemd-nspawn
+++ b/shell-completion/zsh/_systemd-nspawn
@@ -11,34 +11,38 @@ _nspawn-caps(){
 }
 
 _arguments \
-    {-h,--help}'[Show this help]' \
+    {-h,--help}'[Show this help.]' \
+    '--version[Print a short version string and exit.]' \
+    {--quiet,-q}'[Turns off any status output by the tool itself.]' \
     {--directory=,-D+}'[Directory to use as file system root for the namespace container. If omitted the current directory will be used.]:directories:_directories' \
+    '--template=[Initialize root directory from template directory, if missing.]:template:_directories' \
+    {--ephemeral,-x}'[Run container with snapshot of root directory, and remove it after exit.]' \
     {--image=,-i+}'[Disk image to mount the root directory for the container from.]' \
     {--boot=,-b+}'[Automatically search for an init binary and invoke it instead of a shell or a user supplied program.]' \
     {--user=,-u+}'[Run the command under specified user, create home directory and cd into it.]' \
     {--machine=,-M+}'[Sets the machine name for this container.]' \
     '--uuid=[Set the specified uuid for the container.]' \
-    '--slice=[Make the container part of the specified slice, instead of the default machine.slice.]' \
-    '--private-network[Turn off networking in the container. This makes all network interfaces unavailable in the container, with the exception of the loopback device.]' \
+    {--slice=,-S+}'[Make the container part of the specified slice, instead of the default machine.slice.]' \
     '--private-network[Disconnect networking of the container from the host.]' \
     '--network-interface=[Assign the specified network interface to the container.]' \
     '--network-macvlan=[Create a "macvlan" interface of the specified Ethernet network interface and add it to the container.]' \
-    '--network-veth[Create a virtual Ethernet link (veth) between host and container.]' \
+    '--network-ipvlan=[Create a ipvlan network interface based on an existing network interface to the container.]' \
+    {--network-veth,-n}'[Create a virtual Ethernet link (veth) between host and container.]' \
     '--network-bridge=[Adds the host side of the Ethernet link created with --network-veth to the specified bridge.]' \
+    {--port=,-p+}'[Expose a container IP port on the host.]' \
     {--selinux-context=,-Z+}'[Sets the SELinux security context to be used to label processes in the container.]' \
     {--selinux-apifs-context=,-L+}'[Sets the SELinux security context to be used to label files in the virtual API file systems in the container.]' \
     '--capability=[List one or more additional capabilities to grant the container.]:capabilities:_nspawn-caps' \
-    '--drop-capability=[Specify one or more additional capabilities to drop for the container]' \
-    "--link-journal=[Control whether the container's journal shall be made visible to the host system.]:options:(no, host, guest, auto)" \
+    '--drop-capability=[Specify one or more additional capabilities to drop for the containerm]:capabilities:_nspawn-caps' \
+    "--link-journal=[Control whether the container's journal shall be made visible to the host system.]:options:(no host guest auto)" \
     '-j[Equivalent to --link-journal=guest.]' \
     '--read-only[Mount the root file system read only for the container.]' \
     '--bind=[Bind mount a file or directory from the host into the container.]' \
     '--bind-ro=[Bind mount a file or directory from the host into the container (read-only).]' \
+    '--tmpfs=[Mount an empty tmpfs to the specified directory.]' \
     '--setenv=[Specifies an environment variable assignment to pass to the init process in the container, in the format "NAME=VALUE".]' \
     '--share-system[Allows the container to share certain system facilities with the host.]' \
     '--register=[Controls whether the container is registered with systemd-machined(8).]' \
     '--keep-unit[Instead of creating a transient scope unit to run the container in, simply register the service or scope unit systemd-nspawn has been invoked in with systemd-machined(8).]' \
     '--personality=[Control the architecture ("personality") reported by uname(2) in the container.]' \
-    {--quiet,-q}'[Turns off any status output by the tool itself.]' \
-    {--help,-h}'[Print a short help text and exit.]' \
-    '--version[Print a short version string and exit.]'
+    '--volatile=[Run the system in volatile mode.]:volatile:(no yes state)'