From 89a740be2d5487c96f01e4eaae7e280caf555019 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Wed, 6 Oct 2021 22:43:09 +0200 Subject: refactor(rust)!: merge `cargo` and `rustup` plugins into `rust` plugin (#10270) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit BREAKING CHANGE: `cargo` and `rustup` plugins have been moved to the `rust` plugin since they're part of the Rust toolchain. If you're using these, update your .zshrc file to use `rust` instead. Closes #10270 Co-authored-by: Marc Cornellà --- plugins/rust/rust.plugin.zsh | 28 ++++++++++++++++++++++++++++ 1 file changed, 28 insertions(+) create mode 100644 plugins/rust/rust.plugin.zsh (limited to 'plugins/rust/rust.plugin.zsh') diff --git a/plugins/rust/rust.plugin.zsh b/plugins/rust/rust.plugin.zsh new file mode 100644 index 000000000..ced6eb4aa --- /dev/null +++ b/plugins/rust/rust.plugin.zsh @@ -0,0 +1,28 @@ +if ! (( $+commands[rustup] && $+commands[cargo] )); then + return +fi + +# Add completions folder in $ZSH_CACHE_DIR +# TODO: 2021-12-28: remove this bit of code as it exists in oh-my-zsh.sh +command mkdir -p "$ZSH_CACHE_DIR/completions" +(( ${fpath[(Ie)"$ZSH_CACHE_DIR/completions"]} )) || fpath=("$ZSH_CACHE_DIR/completions" $fpath) + +# If the completion file doesn't exist yet, we need to autoload it and +# bind it to `cargo`. Otherwise, compinit will have already done that +if [[ ! -f "$ZSH_CACHE_DIR/completions/_cargo" ]]; then + autoload -Uz _cargo + declare -A _comps + _comps[cargo]=_cargo +fi + +# If the completion file doesn't exist yet, we need to autoload it and +# bind it to `rustup`. Otherwise, compinit will have already done that +if [[ ! -f "$ZSH_CACHE_DIR/completions/_rustup" ]]; then + autoload -Uz _rustup + declare -A _comps + _comps[rustup]=_rustup +fi + +# Generate completion files in the background +rustup completions zsh >| "$ZSH_CACHE_DIR/completions/_rustup" &| +rustup completions zsh cargo >| "$ZSH_CACHE_DIR/completions/_cargo" &| -- cgit v1.2.3-70-g09d2 From a01cf8562700f3e5594f66daf40f31d9fe7ec570 Mon Sep 17 00:00:00 2001 From: Marc Cornellà Date: Wed, 29 Dec 2021 17:18:21 +0100 Subject: fix(rust): use default toolchain when completing `cargo` --- plugins/rust/rust.plugin.zsh | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) (limited to 'plugins/rust/rust.plugin.zsh') diff --git a/plugins/rust/rust.plugin.zsh b/plugins/rust/rust.plugin.zsh index ced6eb4aa..014c73b3b 100644 --- a/plugins/rust/rust.plugin.zsh +++ b/plugins/rust/rust.plugin.zsh @@ -25,4 +25,7 @@ fi # Generate completion files in the background rustup completions zsh >| "$ZSH_CACHE_DIR/completions/_rustup" &| -rustup completions zsh cargo >| "$ZSH_CACHE_DIR/completions/_cargo" &| +cat >| "$ZSH_CACHE_DIR/completions/_cargo" <<'EOF' +#compdef cargo +source $(rustc +${${(z)$(rustup default)}[1]} --print sysroot)/share/zsh/site-functions/_cargo +EOF -- cgit v1.2.3-70-g09d2