summaryrefslogtreecommitdiff
path: root/plugins/tailscale/tailscale.plugin.zsh
diff options
context:
space:
mode:
authorTuowen Zhao <ztuowen@gmail.com>2026-01-04 22:47:54 -0800
committerTuowen Zhao <ztuowen@gmail.com>2026-01-04 22:47:54 -0800
commit2aa4cb7a52b28722816ecfd55f3b06293332c55c (patch)
treef02a9f3d59d109c70caf932a24e43368994e0e8c /plugins/tailscale/tailscale.plugin.zsh
parent7e951c254e779ff0620537cf43ca69dd878387b4 (diff)
parentd23d3ea69fdb839088e6e5589557cce77b34aaf8 (diff)
downloadzsh-2aa4cb7a52b28722816ecfd55f3b06293332c55c.tar.gz
zsh-2aa4cb7a52b28722816ecfd55f3b06293332c55c.tar.bz2
zsh-2aa4cb7a52b28722816ecfd55f3b06293332c55c.zip
Merge remote-tracking branch 'github/master'HEADmaster
Diffstat (limited to 'plugins/tailscale/tailscale.plugin.zsh')
-rw-r--r--plugins/tailscale/tailscale.plugin.zsh25
1 files changed, 25 insertions, 0 deletions
diff --git a/plugins/tailscale/tailscale.plugin.zsh b/plugins/tailscale/tailscale.plugin.zsh
new file mode 100644
index 000000000..8b4e1e34d
--- /dev/null
+++ b/plugins/tailscale/tailscale.plugin.zsh
@@ -0,0 +1,25 @@
+if (( ! $+commands[tailscale] && ! $+aliases[tailscale] )); then
+ return
+fi
+
+# If the completion file doesn't exist yet, we need to autoload it and
+# bind it to `tailscale`. Otherwise, compinit will have already done that.
+if [[ ! -f "$ZSH_CACHE_DIR/completions/_tailscale" ]]; then
+ typeset -g -A _comps
+ autoload -Uz _tailscale
+
+ if (( $+commands[tailscale] )); then
+ _comps[tailscale]=_tailscale
+ elif (( $+aliases[tailscale] )); then
+ _comps[${aliases[tailscale]:t}]=_tailscale
+ fi
+fi
+
+# If using the alias, let's make sure that the aliased executable is also bound
+# in case the alias points to "Tailscale" instead of "tailscale".
+# See https://github.com/ohmyzsh/ohmyzsh/discussions/12928
+if (( $+aliases[tailscale] )); then
+ _comps[${aliases[tailscale]:t}]=_tailscale
+fi
+
+tailscale completion zsh >| "$ZSH_CACHE_DIR/completions/_tailscale" &|