summaryrefslogtreecommitdiff
path: root/plugins/procs
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/procs
parent7e951c254e779ff0620537cf43ca69dd878387b4 (diff)
parentd23d3ea69fdb839088e6e5589557cce77b34aaf8 (diff)
downloadzsh-master.tar.gz
zsh-master.tar.bz2
zsh-master.zip
Merge remote-tracking branch 'github/master'HEADmaster
Diffstat (limited to 'plugins/procs')
-rw-r--r--plugins/procs/README.md9
-rw-r--r--plugins/procs/procs.plugin.zsh21
2 files changed, 30 insertions, 0 deletions
diff --git a/plugins/procs/README.md b/plugins/procs/README.md
new file mode 100644
index 000000000..f1e663d9b
--- /dev/null
+++ b/plugins/procs/README.md
@@ -0,0 +1,9 @@
+# procs
+
+This plugin provides completion for [procs](https://github.com/dalance/procs).
+
+To use it, add `procs` to the plugins array in your zshrc file.
+
+```
+plugins=(... procs)
+```
diff --git a/plugins/procs/procs.plugin.zsh b/plugins/procs/procs.plugin.zsh
new file mode 100644
index 000000000..8b15f1d5d
--- /dev/null
+++ b/plugins/procs/procs.plugin.zsh
@@ -0,0 +1,21 @@
+if (( ! $+commands[procs] )); then
+ return
+fi
+
+# If the completion file doesn't exist yet, we need to autoload it and
+# bind it to `procs`. Otherwise, compinit will have already done that.
+if [[ ! -f "$ZSH_CACHE_DIR/completions/_procs" ]]; then
+ typeset -g -A _comps
+ autoload -Uz _procs
+ _comps[procs]=_procs
+fi
+
+{
+ autoload -Uz is-at-least
+ local _version=$(procs --version)
+ if is-at-least "0.14" "${_version#procs }"; then
+ procs --gen-completion-out zsh >| "$ZSH_CACHE_DIR/completions/_procs"
+ else
+ procs --completion-out zsh >| "$ZSH_CACHE_DIR/completions/_procs"
+ fi
+} &|