summaryrefslogtreecommitdiff
path: root/plugins/fnm/fnm.plugin.zsh
diff options
context:
space:
mode:
authorTuowen Zhao <ztuowen@gmail.com>2021-09-27 13:03:58 -0600
committerTuowen Zhao <ztuowen@gmail.com>2021-09-27 13:03:58 -0600
commitc674485e6b4abe313469900997d893d2940ee843 (patch)
treed6ca6edaff3d81849489f31ca13b127acef89c75 /plugins/fnm/fnm.plugin.zsh
parent3c73976ef306d68a85d60c94be9a1dcdc33fa2bf (diff)
parent93ad3a88214b95f571e03c21f7d9bd76f9110938 (diff)
downloadzsh-c674485e6b4abe313469900997d893d2940ee843.tar.gz
zsh-c674485e6b4abe313469900997d893d2940ee843.tar.bz2
zsh-c674485e6b4abe313469900997d893d2940ee843.zip
Merge remote-tracking branch 'origin/master'
Diffstat (limited to 'plugins/fnm/fnm.plugin.zsh')
-rw-r--r--plugins/fnm/fnm.plugin.zsh23
1 files changed, 17 insertions, 6 deletions
diff --git a/plugins/fnm/fnm.plugin.zsh b/plugins/fnm/fnm.plugin.zsh
index 5ce558dcb..c161b27cd 100644
--- a/plugins/fnm/fnm.plugin.zsh
+++ b/plugins/fnm/fnm.plugin.zsh
@@ -1,12 +1,23 @@
-# COMPLETION FUNCTION
if (( $+commands[fnm] )); then
- if [[ ! -f $ZSH_CACHE_DIR/fnm_version ]] \
- || [[ "$(fnm --version)" != "$(< "$ZSH_CACHE_DIR/fnm_version")" ]] \
- || [[ ! -f $ZSH/plugins/fnm/_fnm ]]; then
- fnm completions --shell=zsh > $ZSH/plugins/fnm/_fnm
- fnm --version > $ZSH_CACHE_DIR/fnm_version
+ # remove old generated completion file
+ command rm -f "${0:A:h}/_fnm"
+
+ ver="$(fnm --version)"
+ ver_file="$ZSH_CACHE_DIR/fnm_version"
+ comp_file="$ZSH_CACHE_DIR/completions/_fnm"
+
+ mkdir -p "${comp_file:h}"
+ (( ${fpath[(Ie)${comp_file:h}]} )) || fpath=("${comp_file:h}" $fpath)
+
+ if [[ ! -f "$comp_file" || ! -f "$ver_file" || "$ver" != "$(< "$ver_file")" ]]; then
+ fnm completions --shell=zsh >| "$comp_file"
+ echo "$ver" >| "$ver_file"
fi
+
+ declare -A _comps
autoload -Uz _fnm
_comps[fnm]=_fnm
+
+ unset ver ver_file comp_file
fi