summaryrefslogtreecommitdiff
path: root/plugins/kubectl/kubectl.plugin.zsh
diff options
context:
space:
mode:
authorCarlo Sala <carlosalag@protonmail.com>2022-12-06 22:51:52 +0100
committerCarlo <carlosalag@protonmail.com>2022-12-07 12:20:53 +0100
commit658eb01d82c01d82b4263b3dc59e15232cb4cdaf (patch)
treeec4d1cca63b8757ee0374e1ab2851a0d33b7954f /plugins/kubectl/kubectl.plugin.zsh
parent585e7138b556db89715eb2a850f8959fdf527384 (diff)
downloadzsh-658eb01d82c01d82b4263b3dc59e15232cb4cdaf.tar.gz
zsh-658eb01d82c01d82b4263b3dc59e15232cb4cdaf.tar.bz2
zsh-658eb01d82c01d82b4263b3dc59e15232cb4cdaf.zip
refactor(kubectl): standarize completion generation
Diffstat (limited to 'plugins/kubectl/kubectl.plugin.zsh')
-rw-r--r--plugins/kubectl/kubectl.plugin.zsh22
1 files changed, 12 insertions, 10 deletions
diff --git a/plugins/kubectl/kubectl.plugin.zsh b/plugins/kubectl/kubectl.plugin.zsh
index 095d2b328..b415d1ad8 100644
--- a/plugins/kubectl/kubectl.plugin.zsh
+++ b/plugins/kubectl/kubectl.plugin.zsh
@@ -1,15 +1,17 @@
-if (( $+commands[kubectl] )); then
- # If the completion file does not exist, generate it and then source it
- # Otherwise, source it and regenerate in the background
- if [[ ! -f "$ZSH_CACHE_DIR/completions/_kubectl" ]]; then
- kubectl completion zsh | tee "$ZSH_CACHE_DIR/completions/_kubectl" >/dev/null
- source "$ZSH_CACHE_DIR/completions/_kubectl"
- else
- source "$ZSH_CACHE_DIR/completions/_kubectl"
- kubectl completion zsh | tee "$ZSH_CACHE_DIR/completions/_kubectl" >/dev/null &|
- fi
+if (( ! $+commands[kubectl] )); then
+ return
fi
+# If the completion file doesn't exist yet, we need to autoload it and
+# bind it to `kubectl`. Otherwise, compinit will have already done that.
+if [[ ! -f "$ZSH_CACHE_DIR/completions/_kubectl" ]]; then
+ typeset -g -A _comps
+ autoload -Uz _kubectl
+ _comps[kubectl]=_kubectl
+fi
+
+kubectl completion zsh >| "$ZSH_CACHE_DIR/completions/_kubectl" &|
+
# This command is used a LOT both below and in daily life
alias k=kubectl