summaryrefslogtreecommitdiff
path: root/plugins/asdf/asdf.plugin.zsh
diff options
context:
space:
mode:
authorTuowen Zhao <ztuowen@gmail.com>2023-11-04 18:38:46 -0700
committerTuowen Zhao <ztuowen@gmail.com>2023-11-04 18:38:46 -0700
commit4d908094fdc2a0c0e9a0a072eba213fab7adef43 (patch)
tree7c17e70bcdeebbe96c84d849bdf17882007480d8 /plugins/asdf/asdf.plugin.zsh
parent4b0bbc0b263a150eb9a9b59f196914629be06a9b (diff)
parent632ed413a9ce62747ded83d7736491b081be4b49 (diff)
downloadzsh-master.tar.gz
zsh-master.tar.bz2
zsh-master.zip
Merge remote-tracking branch 'github/master'HEADmaster
Diffstat (limited to 'plugins/asdf/asdf.plugin.zsh')
-rw-r--r--plugins/asdf/asdf.plugin.zsh35
1 files changed, 19 insertions, 16 deletions
diff --git a/plugins/asdf/asdf.plugin.zsh b/plugins/asdf/asdf.plugin.zsh
index 3016282c6..7635d20c3 100644
--- a/plugins/asdf/asdf.plugin.zsh
+++ b/plugins/asdf/asdf.plugin.zsh
@@ -2,26 +2,29 @@
ASDF_DIR="${ASDF_DIR:-$HOME/.asdf}"
ASDF_COMPLETIONS="$ASDF_DIR/completions"
-# If not found, check for archlinux/AUR package (/opt/asdf-vm/)
-if [[ ! -f "$ASDF_DIR/asdf.sh" || ! -f "$ASDF_COMPLETIONS/asdf.bash" ]] && [[ -f "/opt/asdf-vm/asdf.sh" ]]; then
- ASDF_DIR="/opt/asdf-vm"
- ASDF_COMPLETIONS="$ASDF_DIR"
-fi
-
-# If not found, check for Homebrew package
-if [[ ! -f "$ASDF_DIR/asdf.sh" || ! -f "$ASDF_COMPLETIONS/asdf.bash" ]] && (( $+commands[brew] )); then
- brew_prefix="$(brew --prefix asdf)"
- ASDF_DIR="${brew_prefix}/libexec"
- ASDF_COMPLETIONS="${brew_prefix}/etc/bash_completion.d"
- unset brew_prefix
+if [[ ! -f "$ASDF_DIR/asdf.sh" || ! -f "$ASDF_COMPLETIONS/_asdf" ]]; then
+ # If not found, check for archlinux/AUR package (/opt/asdf-vm/)
+ if [[ -f "/opt/asdf-vm/asdf.sh" ]]; then
+ ASDF_DIR="/opt/asdf-vm"
+ ASDF_COMPLETIONS="$ASDF_DIR"
+ # If not found, check for Homebrew package
+ elif (( $+commands[brew] )); then
+ _ASDF_PREFIX="$(brew --prefix asdf)"
+ ASDF_DIR="${_ASDF_PREFIX}/libexec"
+ ASDF_COMPLETIONS="${_ASDF_PREFIX}/share/zsh/site-functions"
+ unset _ASDF_PREFIX
+ else
+ return
+ fi
fi
# Load command
if [[ -f "$ASDF_DIR/asdf.sh" ]]; then
- . "$ASDF_DIR/asdf.sh"
-
+ source "$ASDF_DIR/asdf.sh"
# Load completions
- if [[ -f "$ASDF_COMPLETIONS/asdf.bash" ]]; then
- . "$ASDF_COMPLETIONS/asdf.bash"
+ if [[ -f "$ASDF_COMPLETIONS/_asdf" ]]; then
+ fpath+=("$ASDF_COMPLETIONS")
+ autoload -Uz _asdf
+ compdef _asdf asdf # compdef is already loaded before loading plugins
fi
fi