From d2dc3bd2da531754778d1e9d7fb082715fc532f1 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Tue, 12 Jul 2022 18:40:39 +0200 Subject: [PATCH 001/672] feat(brew): run `brew shellenv` command at plugin load (#10874) --- plugins/brew/README.md | 12 ++++++++---- plugins/brew/brew.plugin.zsh | 30 +++++++++++++++++++++++++++--- 2 files changed, 35 insertions(+), 7 deletions(-) diff --git a/plugins/brew/README.md b/plugins/brew/README.md index bf952bf01..64e0e1153 100644 --- a/plugins/brew/README.md +++ b/plugins/brew/README.md @@ -8,19 +8,23 @@ To use it, add `brew` to the plugins array of your zshrc file: plugins=(... brew) ``` +## Shellenv + +This plugin also executes `brew shellenv` at plugin load to set up many useful variables, such as `HOMEBREW_PREFIX` or `HOMEBREW_REPOSITORY`. + ## Aliases | Alias | Command | Description | -|----------|---------------------------------------|---------------------------------------------------------------------| +| -------- | ------------------------------------- | ------------------------------------------------------------------- | +| `bcubc` | `brew upgrade --cask && brew cleanup` | Update outdated casks, then run cleanup. | +| `bcubo` | `brew update && brew outdated --cask` | Update Homebrew data, then list outdated casks. | | `brewp` | `brew pin` | Pin a specified formula so that it's not upgraded. | | `brews` | `brew list -1` | List installed formulae or the installed files for a given formula. | | `brewsp` | `brew list --pinned` | List pinned formulae, or show the version of a given formula. | -| `bubo` | `brew update && brew outdated` | Update Homebrew data, then list outdated formulae and casks. | | `bubc` | `brew upgrade && brew cleanup` | Upgrade outdated formulae and casks, then run cleanup. | +| `bubo` | `brew update && brew outdated` | Update Homebrew data, then list outdated formulae and casks. | | `bubu` | `bubo && bubc` | Do the last two operations above. | | `buf` | `brew upgrade --formula` | Upgrade only formulas (not casks). | -| `bcubo` | `brew update && brew outdated --cask` | Update Homebrew data, then list outdated casks. | -| `bcubc` | `brew upgrade --cask && brew cleanup` | Update outdated casks, then run cleanup. | ## Completion diff --git a/plugins/brew/brew.plugin.zsh b/plugins/brew/brew.plugin.zsh index 070a083d0..4a2322216 100644 --- a/plugins/brew/brew.plugin.zsh +++ b/plugins/brew/brew.plugin.zsh @@ -1,11 +1,35 @@ +if (( ! $+commands[brew] )); then + if [[ -x /opt/homebrew/bin/brew ]]; then + BREW_LOCATION="/opt/homebrew/bin/brew" + elif [[ -x /usr/local/bin/brew ]]; then + BREW_LOCATION="/usr/local/bin/brew" + elif [[ -x /home/linuxbrew/.linuxbrew/bin/brew ]]; then + BREW_LOCATION="/home/linuxbrew/.linuxbrew/bin/brew" + elif [[ -x "$HOME/.linuxbrew/bin/brew" ]]; then + BREW_LOCATION="$HOME/.linuxbrew/bin/brew" + else + return + fi +fi + +if [[ -z "$HOMEBREW_PREFIX" ]]; then + if [[ -z $BREW_LOCATION ]]; then + eval "$(brew shellenv)" + else + eval "$("$BREW_LOCATION" shellenv)" + fi +fi + +unset BREW_LOCATION + +alias bcubc='brew upgrade --cask && brew cleanup' +alias bcubo='brew update && brew outdated --cask' alias brewp='brew pin' alias brewsp='brew list --pinned' -alias bubo='brew update && brew outdated' alias bubc='brew upgrade && brew cleanup' +alias bubo='brew update && brew outdated' alias bubu='bubo && bubc' alias buf='brew upgrade --formula' -alias bcubo='brew update && brew outdated --cask' -alias bcubc='brew upgrade --cask && brew cleanup' function brews() { local formulae="$(brew leaves | xargs brew deps --installed --for-each)" From 5336e59db1b76b9b5439099cbc5a311796d32ba9 Mon Sep 17 00:00:00 2001 From: Ian Cowan <38896380+iccowan@users.noreply.github.com> Date: Tue, 12 Jul 2022 12:46:42 -0400 Subject: [PATCH 002/672] chore(git): fix unintentional latex in documentation (#11018) --- plugins/git/README.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/plugins/git/README.md b/plugins/git/README.md index b9a0309f3..0700dcc32 100644 --- a/plugins/git/README.md +++ b/plugins/git/README.md @@ -23,7 +23,7 @@ plugins=(... git) | gb | git branch | | gba | git branch -a | | gbd | git branch -d | -| gbda | git branch --no-color --merged \| grep -vE "^([+*]\|\s*($(git_main_branch)\|$(git_develop_branch))\s*$)" \| xargs git branch -d 2>/dev/null | +| gbda | git branch --no-color --merged \| grep -vE "^([+*]\|\s*($(git_main_branch)\|$(git_develop_branch))\s*$)" \| xargs git branch -d 2>/dev/null | | gbD | git branch -D | | gbl | git blame -b -w | | gbnm | git branch --no-merged | @@ -42,12 +42,12 @@ plugins=(... git) | gcans! | git commit -v -a -s --no-edit --amend | | gcam | git commit -a -m | | gcas | git commit -a -s | -| gcasm | git commit -a -s -m | +| gcasm | git commit -a -s -m | | gcsm | git commit -s -m | | gcb | git checkout -b | | gcf | git config --list | | gcl | git clone --recurse-submodules | -| gccd | git clone --recurse-submodules "$@" && cd "$(basename $_ .git)" | +| gccd | git clone --recurse-submodules "$@" && cd "$(basename $_ .git)" | | gclean | git clean -id | | gpristine | git reset --hard && git clean -dffx | | gcm | git checkout $(git_main_branch) | From 4506210c38774bc5da1a0495c2a911776cf6f2cb Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Sun, 19 Jun 2022 12:54:11 +0200 Subject: [PATCH 003/672] fix(lib): don't attach to tty in `wl-copy` and `xclip` (#10953) Fixes #10925 --- lib/clipboard.zsh | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/lib/clipboard.zsh b/lib/clipboard.zsh index 4e3ba0a45..272b41598 100644 --- a/lib/clipboard.zsh +++ b/lib/clipboard.zsh @@ -58,10 +58,10 @@ function detect-clipboard() { function clipcopy() { cat "${1:-/dev/stdin}" > /dev/clipboard; } function clippaste() { cat /dev/clipboard; } elif [ -n "${WAYLAND_DISPLAY:-}" ] && (( ${+commands[wl-copy]} )) && (( ${+commands[wl-paste]} )); then - function clipcopy() { wl-copy < "${1:-/dev/stdin}"; } + function clipcopy() { wl-copy < "${1:-/dev/stdin}" &>/dev/null &|; } function clippaste() { wl-paste; } elif [ -n "${DISPLAY:-}" ] && (( ${+commands[xclip]} )); then - function clipcopy() { xclip -in -selection clipboard < "${1:-/dev/stdin}"; } + function clipcopy() { xclip -in -selection clipboard < "${1:-/dev/stdin}" &>/dev/null &|; } function clippaste() { xclip -out -selection clipboard; } elif [ -n "${DISPLAY:-}" ] && (( ${+commands[xsel]} )); then function clipcopy() { xsel --clipboard --input < "${1:-/dev/stdin}"; } From 39573125e4971b34e26f4cb3aaa210a74ea6ca34 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Sun, 19 Jun 2022 12:49:32 +0200 Subject: [PATCH 004/672] feat(lib): wait for input to copy to the clipboard (#10953) --- lib/clipboard.zsh | 18 +++++++++--------- 1 file changed, 9 insertions(+), 9 deletions(-) diff --git a/lib/clipboard.zsh b/lib/clipboard.zsh index 272b41598..aab21a28a 100644 --- a/lib/clipboard.zsh +++ b/lib/clipboard.zsh @@ -52,37 +52,37 @@ function detect-clipboard() { emulate -L zsh if [[ "${OSTYPE}" == darwin* ]] && (( ${+commands[pbcopy]} )) && (( ${+commands[pbpaste]} )); then - function clipcopy() { pbcopy < "${1:-/dev/stdin}"; } + function clipcopy() { cat "${1:-/dev/stdin}" | pbcopy; } function clippaste() { pbpaste; } elif [[ "${OSTYPE}" == (cygwin|msys)* ]]; then function clipcopy() { cat "${1:-/dev/stdin}" > /dev/clipboard; } function clippaste() { cat /dev/clipboard; } elif [ -n "${WAYLAND_DISPLAY:-}" ] && (( ${+commands[wl-copy]} )) && (( ${+commands[wl-paste]} )); then - function clipcopy() { wl-copy < "${1:-/dev/stdin}" &>/dev/null &|; } + function clipcopy() { cat "${1:-/dev/stdin}" | wl-copy &>/dev/null &|; } function clippaste() { wl-paste; } elif [ -n "${DISPLAY:-}" ] && (( ${+commands[xclip]} )); then - function clipcopy() { xclip -in -selection clipboard < "${1:-/dev/stdin}" &>/dev/null &|; } + function clipcopy() { cat "${1:-/dev/stdin}" | xclip -selection clipboard -in &>/dev/null &|; } function clippaste() { xclip -out -selection clipboard; } elif [ -n "${DISPLAY:-}" ] && (( ${+commands[xsel]} )); then - function clipcopy() { xsel --clipboard --input < "${1:-/dev/stdin}"; } + function clipcopy() { cat "${1:-/dev/stdin}" | xsel --clipboard --input; } function clippaste() { xsel --clipboard --output; } elif (( ${+commands[lemonade]} )); then - function clipcopy() { lemonade copy < "${1:-/dev/stdin}"; } + function clipcopy() { cat "${1:-/dev/stdin}" | lemonade copy; } function clippaste() { lemonade paste; } elif (( ${+commands[doitclient]} )); then - function clipcopy() { doitclient wclip < "${1:-/dev/stdin}"; } + function clipcopy() { cat "${1:-/dev/stdin}" | doitclient wclip; } function clippaste() { doitclient wclip -r; } elif (( ${+commands[win32yank]} )); then - function clipcopy() { win32yank -i < "${1:-/dev/stdin}"; } + function clipcopy() { cat "${1:-/dev/stdin}" | win32yank -i; } function clippaste() { win32yank -o; } elif [[ $OSTYPE == linux-android* ]] && (( $+commands[termux-clipboard-set] )); then - function clipcopy() { termux-clipboard-set < "${1:-/dev/stdin}"; } + function clipcopy() { cat "${1:-/dev/stdin}" | termux-clipboard-set; } function clippaste() { termux-clipboard-get; } elif [ -n "${TMUX:-}" ] && (( ${+commands[tmux]} )); then function clipcopy() { tmux load-buffer "${1:--}"; } function clippaste() { tmux save-buffer -; } elif [[ $(uname -r) = *icrosoft* ]]; then - function clipcopy() { clip.exe < "${1:-/dev/stdin}"; } + function clipcopy() { cat "${1:-/dev/stdin}" | clip.exe; } function clippaste() { powershell.exe -noprofile -command Get-Clipboard; } else function _retry_clipboard_detection_or_fail() { From ef8e63a7fd30e04079e54ea76043c1db76e24ddf Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Tue, 12 Jul 2022 18:56:09 +0200 Subject: [PATCH 005/672] fix(lib): prefer `xsel` over `xclip` in clipboard.zsh See #10925 --- lib/clipboard.zsh | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/lib/clipboard.zsh b/lib/clipboard.zsh index aab21a28a..ad83fc4b2 100644 --- a/lib/clipboard.zsh +++ b/lib/clipboard.zsh @@ -10,8 +10,8 @@ # - pbcopy, pbpaste (macOS) # - cygwin (Windows running Cygwin) # - wl-copy, wl-paste (if $WAYLAND_DISPLAY is set) -# - xclip (if $DISPLAY is set) # - xsel (if $DISPLAY is set) +# - xclip (if $DISPLAY is set) # - lemonade (for SSH) https://github.com/pocke/lemonade # - doitclient (for SSH) http://www.chiark.greenend.org.uk/~sgtatham/doit/ # - win32yank (Windows) @@ -60,12 +60,12 @@ function detect-clipboard() { elif [ -n "${WAYLAND_DISPLAY:-}" ] && (( ${+commands[wl-copy]} )) && (( ${+commands[wl-paste]} )); then function clipcopy() { cat "${1:-/dev/stdin}" | wl-copy &>/dev/null &|; } function clippaste() { wl-paste; } - elif [ -n "${DISPLAY:-}" ] && (( ${+commands[xclip]} )); then - function clipcopy() { cat "${1:-/dev/stdin}" | xclip -selection clipboard -in &>/dev/null &|; } - function clippaste() { xclip -out -selection clipboard; } elif [ -n "${DISPLAY:-}" ] && (( ${+commands[xsel]} )); then function clipcopy() { cat "${1:-/dev/stdin}" | xsel --clipboard --input; } function clippaste() { xsel --clipboard --output; } + elif [ -n "${DISPLAY:-}" ] && (( ${+commands[xclip]} )); then + function clipcopy() { cat "${1:-/dev/stdin}" | xclip -selection clipboard -in &>/dev/null &|; } + function clippaste() { xclip -out -selection clipboard; } elif (( ${+commands[lemonade]} )); then function clipcopy() { cat "${1:-/dev/stdin}" | lemonade copy; } function clippaste() { lemonade paste; } From 0726c1099fec6599dbf91a260f21d6d45fd8f309 Mon Sep 17 00:00:00 2001 From: Hans Donner Date: Tue, 12 Jul 2022 19:25:27 +0200 Subject: [PATCH 006/672] fix(aws): allow non-space characters in profile names (#11040) --- plugins/aws/aws.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/aws/aws.plugin.zsh b/plugins/aws/aws.plugin.zsh index b8625d7ac..2167f552c 100644 --- a/plugins/aws/aws.plugin.zsh +++ b/plugins/aws/aws.plugin.zsh @@ -147,7 +147,7 @@ function aws_change_access_key() { function aws_profiles() { [[ -r "${AWS_CONFIG_FILE:-$HOME/.aws/config}" ]] || return 1 - grep --color=never -Eo '\[.*\]' "${AWS_CONFIG_FILE:-$HOME/.aws/config}" | sed -E 's/^[[:space:]]*\[(profile)?[[:space:]]*([-_[:alnum:]\.@]+)\][[:space:]]*$/\2/g' + grep --color=never -Eo '\[.*\]' "${AWS_CONFIG_FILE:-$HOME/.aws/config}" | sed -E 's/^[[:space:]]*\[(profile)?[[:space:]]*([^[:space:]]+)\][[:space:]]*$/\2/g' } function _aws_profiles() { From 0c7ce363c903e1e3255d4d30255ff4790678ace9 Mon Sep 17 00:00:00 2001 From: hellzbellz <31550512+Hellzbellz123@users.noreply.github.com> Date: Tue, 12 Jul 2022 10:36:43 -0700 Subject: [PATCH 007/672] chore(lib): only create `afind` alias if `ack` is installed (#11017) --- lib/misc.zsh | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/lib/misc.zsh b/lib/misc.zsh index a5d3af998..1f637083a 100644 --- a/lib/misc.zsh +++ b/lib/misc.zsh @@ -24,10 +24,10 @@ env_default 'LESS' '-R' ## super user alias alias _='sudo ' -## more intelligent acking for ubuntu users +## more intelligent acking for ubuntu users and no alias for users without ack if (( $+commands[ack-grep] )); then alias afind='ack-grep -il' -else +elif (( $+commands[ack] )); then alias afind='ack -il' fi From 249c708ed3a4a7a63d16a6e911a46b6fb9623cbd Mon Sep 17 00:00:00 2001 From: Anubhav Sharma Date: Tue, 12 Jul 2022 13:44:32 -0400 Subject: [PATCH 008/672] fix(frontcube): fix escape of reset color sequence (#10921) --- themes/frontcube.zsh-theme | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/themes/frontcube.zsh-theme b/themes/frontcube.zsh-theme index f9488d0ac..de6348329 100644 --- a/themes/frontcube.zsh-theme +++ b/themes/frontcube.zsh-theme @@ -1,7 +1,7 @@ PROMPT=' %{$fg_bold[gray]%}%~%{$fg_bold[blue]%}%{$fg_bold[blue]%} % %{$reset_color%} -%{$fg[green]%}➞ %{$reset_color%' +%{$fg[green]%}➞ %{$reset_color%}' RPROMPT='$(git_prompt_info) $(ruby_prompt_info)' From bb6c14cdfd0b7d543d0d9c2e5f0c0a9409a82084 Mon Sep 17 00:00:00 2001 From: Brian Wright <4408242+PennRobotics@users.noreply.github.com> Date: Tue, 26 Jul 2022 11:46:10 +0200 Subject: [PATCH 009/672] fix(updater): correct spelling of `curl` flag (#11072) --- tools/check_for_upgrade.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tools/check_for_upgrade.sh b/tools/check_for_upgrade.sh index 009c273fa..cc527e72d 100644 --- a/tools/check_for_upgrade.sh +++ b/tools/check_for_upgrade.sh @@ -65,7 +65,7 @@ function is_update_available() { local remote_head remote_head=$( if (( ${+commands[curl]} )); then - curl --conect-timeout 2 -fsSL -H 'Accept: application/vnd.github.v3.sha' $api_url 2>/dev/null + curl --connect-timeout 2 -fsSL -H 'Accept: application/vnd.github.v3.sha' $api_url 2>/dev/null elif (( ${+commands[wget]} )); then wget -T 2 -O- --header='Accept: application/vnd.github.v3.sha' $api_url 2>/dev/null elif (( ${+commands[fetch]} )); then From af2daa7ab7dde3674f4861ef684773410b9cccd4 Mon Sep 17 00:00:00 2001 From: Christopher Boyd <6323077+cpboyd@users.noreply.github.com> Date: Wed, 27 Jul 2022 12:06:28 -0400 Subject: [PATCH 010/672] feat(flutter): use up-to-date zsh completion (#11062) --- plugins/flutter/_flutter | 37 ------------------------------ plugins/flutter/flutter.plugin.zsh | 15 ++++++++++++ 2 files changed, 15 insertions(+), 37 deletions(-) delete mode 100644 plugins/flutter/_flutter diff --git a/plugins/flutter/_flutter b/plugins/flutter/_flutter deleted file mode 100644 index ab6ce4265..000000000 --- a/plugins/flutter/_flutter +++ /dev/null @@ -1,37 +0,0 @@ -#compdef flutter -#autoload - -local -a _1st_arguments -_1st_arguments=( - "analyze":"Analyze the project's Dart code." - "assemble":"Assemble and build flutter resources." - "attach":"Attach to a running application." - "build":"Flutter build commands." - "channel":"List or switch flutter channels." - "clean":"Delete the build/ and .dart_tool/ directories." - "config":"Configure Flutter settings." - "create":"Create a new Flutter project." - "devices":"List all connected devices." - "doctor":"Show information about the installed tooling." - "drive":"Runs Flutter Driver tests for the current project." - "emulators":"List, launch and create emulators." - "format":" Format one or more dart files." - "help":"Display help information for flutter." - "install":"Install a Flutter app on an attached device." - "logs":"Show log output for running Flutter apps." - "make-host-app-editable":"Moves host apps from generated directories to non-generated directories so that they can be edited by developers." - "precache":"Populates the Flutter tool's cache of binary artifacts." - "pub":"Commands for managing Flutter packages." - "run":"Run your Flutter app on an attached device." - "screenshot":"Take a screenshot from a connected device." - "test":"Run Flutter unit tests for the current project." - "upgrade":"Upgrade your copy of Flutter." - "version":"List or switch flutter versions." -) - -_arguments -C '*:: :->subcmds' - -if (( CURRENT == 1 )); then - _describe -t commands "flutter command" _1st_arguments - return -fi diff --git a/plugins/flutter/flutter.plugin.zsh b/plugins/flutter/flutter.plugin.zsh index 80b74f64a..44d196cd4 100644 --- a/plugins/flutter/flutter.plugin.zsh +++ b/plugins/flutter/flutter.plugin.zsh @@ -12,3 +12,18 @@ alias flrd="flutter run --debug" alias flrp="flutter run --profile" alias flrr="flutter run --release" alias flupgrd="flutter upgrade" + +# COMPLETION FUNCTION +if (( ! $+commands[flutter] )); then + return +fi + +# If the completion file doesn't exist yet, we need to autoload it and +# bind it to `flutter`. Otherwise, compinit will have already done that. +if [[ ! -f "$ZSH_CACHE_DIR/completions/_flutter" ]]; then + typeset -g -A _comps + autoload -Uz _flutter + _comps[flutter]=_flutter +fi + +flutter zsh-completion >| "$ZSH_CACHE_DIR/completions/_flutter" &| \ No newline at end of file From 8362ae285a5c227cb20387543483a3597fa31931 Mon Sep 17 00:00:00 2001 From: Felix Stupp Date: Wed, 27 Jul 2022 16:07:53 +0000 Subject: [PATCH 011/672] fix(git-auto-fetch): don't override native `stat` command (#11068) --- plugins/git-auto-fetch/git-auto-fetch.plugin.zsh | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/plugins/git-auto-fetch/git-auto-fetch.plugin.zsh b/plugins/git-auto-fetch/git-auto-fetch.plugin.zsh index efe8cbe66..2e029639c 100644 --- a/plugins/git-auto-fetch/git-auto-fetch.plugin.zsh +++ b/plugins/git-auto-fetch/git-auto-fetch.plugin.zsh @@ -2,7 +2,8 @@ : ${GIT_AUTO_FETCH_INTERVAL:=60} # Necessary for the git-fetch-all function -zmodload zsh/datetime zsh/stat +zmodload zsh/datetime +zmodload -F zsh/stat b:zstat # only zstat command, not stat command function git-fetch-all { ( From aa75eeea3348b906f2016be0e44335889e0faed1 Mon Sep 17 00:00:00 2001 From: Anatoli Babenia Date: Fri, 29 Jul 2022 14:05:34 +0300 Subject: [PATCH 012/672] chore(copybuffer): format shortcut and lighten text (#11078) --- plugins/copybuffer/README.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/plugins/copybuffer/README.md b/plugins/copybuffer/README.md index da138bdbd..a53d1c813 100644 --- a/plugins/copybuffer/README.md +++ b/plugins/copybuffer/README.md @@ -1,7 +1,7 @@ # `copybuffer` plugin -This plugin binds the ctrl-o keyboard shortcut to a command that copies the text -that is currently typed in the command line ($BUFFER) to the system clipboard. +This plugin adds the ctrl-o keyboard shortcut to copy the current text +in the command line to the system clipboard. This is useful if you type a command - and before you hit enter to execute it - want to copy it maybe so you can paste it into a script, gist or whatnot. From 4fcf52c2b1e086596d96b04f9c1ff3d742194857 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Mon, 1 Aug 2022 20:54:45 +0200 Subject: [PATCH 013/672] fix: don't use `$functions_source` for compatibility with zsh < 5.4 --- plugins/aliases/aliases.plugin.zsh | 23 +++++----- plugins/shell-proxy/shell-proxy.plugin.zsh | 51 ++++++++++++---------- 2 files changed, 42 insertions(+), 32 deletions(-) diff --git a/plugins/aliases/aliases.plugin.zsh b/plugins/aliases/aliases.plugin.zsh index 4e1e0558e..9864de957 100644 --- a/plugins/aliases/aliases.plugin.zsh +++ b/plugins/aliases/aliases.plugin.zsh @@ -1,11 +1,14 @@ -# with lots of 3rd-party amazing aliases installed, just need something to explore it quickly. -# -# - acs: alias cheatsheet -# group alias by command, pass addition argv to grep. -function acs(){ - (( $+commands[python3] )) || { - echo "[error] No python executable detected" - return +# Handle $0 according to the standard: +# https://zdharma-continuum.github.io/Zsh-100-Commits-Club/Zsh-Plugin-Standard.html +0="${${ZERO:-${0:#$ZSH_ARGZERO}}:-${(%):-%N}}" +0="${${(M)0:#/*}:-$PWD/$0}" + +eval ' + function acs(){ + (( $+commands[python3] )) || { + echo "[error] No python executable detected" + return + } + alias | python3 "'"${0:h}"'/cheatsheet.py" "$@" } - alias | python3 ${functions_source[$0]:h}/cheatsheet.py $@ -} +' diff --git a/plugins/shell-proxy/shell-proxy.plugin.zsh b/plugins/shell-proxy/shell-proxy.plugin.zsh index 9d45b5269..4fdbe9322 100644 --- a/plugins/shell-proxy/shell-proxy.plugin.zsh +++ b/plugins/shell-proxy/shell-proxy.plugin.zsh @@ -1,32 +1,39 @@ #!/usr/bin/bash # shellcheck disable=SC1090,SC2154 -proxy() { - # deprecate $DEFAULT_PROXY, use SHELLPROXY_URL instead - if [[ -n "$DEFAULT_PROXY" && -z "$SHELLPROXY_URL" ]]; then - echo >&2 "proxy: DEFAULT_PROXY is deprecated, use SHELLPROXY_URL instead" - SHELLPROXY_URL="$DEFAULT_PROXY" - unset DEFAULT_PROXY - fi +# Handle $0 according to the standard: +# https://zdharma-continuum.github.io/Zsh-100-Commits-Club/Zsh-Plugin-Standard.html +0="${${ZERO:-${0:#$ZSH_ARGZERO}}:-${(%):-%N}}" +0="${${(M)0:#/*}:-$PWD/$0}" - # deprecate CONFIG_PROXY, use SHELLPROXY_CONFIG instead - if [[ -n "$CONFIG_PROXY" && -z "$SHELLPROXY_CONFIG" ]]; then - echo >&2 "proxy: CONFIG_PROXY is deprecated, use SHELLPROXY_CONFIG instead" - SHELLPROXY_CONFIG="$CONFIG_PROXY" - unset CONFIG_PROXY - fi +eval ' + proxy() { + # deprecate $DEFAULT_PROXY, use SHELLPROXY_URL instead + if [[ -n "$DEFAULT_PROXY" && -z "$SHELLPROXY_URL" ]]; then + echo >&2 "proxy: DEFAULT_PROXY is deprecated, use SHELLPROXY_URL instead" + SHELLPROXY_URL="$DEFAULT_PROXY" + unset DEFAULT_PROXY + fi - # the proxy.py script is in the same directory as this function - local proxy="${functions_source[$0]:A:h}/proxy.py" + # deprecate CONFIG_PROXY, use SHELLPROXY_CONFIG instead + if [[ -n "$CONFIG_PROXY" && -z "$SHELLPROXY_CONFIG" ]]; then + echo >&2 "proxy: CONFIG_PROXY is deprecated, use SHELLPROXY_CONFIG instead" + SHELLPROXY_CONFIG="$CONFIG_PROXY" + unset CONFIG_PROXY + fi - # capture the output of the proxy script and bail out if it fails - local output - output="$(SHELLPROXY_URL="$SHELLPROXY_URL" SHELLPROXY_CONFIG="$SHELLPROXY_CONFIG" "$proxy" "$1")" || - return $? + # the proxy.py script is in the same directory as this function + local proxy="'"${0:h}"'/proxy.py" - # evaluate the output generated by the proxy script - source <(echo "$output") -} + # capture the output of the proxy script and bail out if it fails + local output + output="$(SHELLPROXY_URL="$SHELLPROXY_URL" SHELLPROXY_CONFIG="$SHELLPROXY_CONFIG" "$proxy" "$1")" || + return $? + + # evaluate the output generated by the proxy script + source <(echo "$output") + } +' _proxy() { local -r commands=('enable' 'disable' 'status') From 0346cdf7f63bcddc704cc0551f260d31adb8fc9d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Tue, 2 Aug 2022 19:27:54 +0200 Subject: [PATCH 014/672] docs: document new aliases policy (#11045) --- .github/PULL_REQUEST_TEMPLATE.md | 1 + CONTRIBUTING.md | 21 +++++++++++++++++++++ 2 files changed, 22 insertions(+) diff --git a/.github/PULL_REQUEST_TEMPLATE.md b/.github/PULL_REQUEST_TEMPLATE.md index 1abae8913..5c94caeb5 100644 --- a/.github/PULL_REQUEST_TEMPLATE.md +++ b/.github/PULL_REQUEST_TEMPLATE.md @@ -9,6 +9,7 @@ - [ ] The code is mine or it's from somewhere with an MIT-compatible license. - [ ] The code is efficient, to the best of my ability, and does not waste computer resources. - [ ] The code is stable and I have tested it myself, to the best of my abilities. +- [ ] If the code introduces new aliases, I provide a valid use case for all plugin users down below. ## Changes: diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index 2bd877892..59cf96012 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -104,6 +104,27 @@ maintainers) by mentioning their GitHub handle (starting with `@`) in your messa For any extensive change, such as a new plugin, you will have to find testers to +1 your PR. +### New plugin aliases + +We acknowledge that aliases are a core part of Oh My Zsh. There are plugins that have +100 aliases! + +This has become an issue for two opposing reasons: + +- Some users want to have their personal aliases in Oh My Zsh. +- Some users don't want any aliases at all and feel that there are too many. + +Because of this, from now on we're requiring that new aliases follow these conditions: + +1. They will be used by many people, not just a few. +2. The aliases will be used many times and for common tasks. +3. Prefer one generic alias over many specific ones. +4. When justifying the need for an alias, talk about workflows where you'll use it, + preferably in combination with other aliases. +5. If there exists a command with the same name, look for a different alias name. + +This list is not exhaustive! Please remember that your alias will be in the machines of many people, +so it should be justified why they should have it. + ---- ## Use the Search, Luke From 97134d1eed19b72a9c4bf90a2effa847221608bf Mon Sep 17 00:00:00 2001 From: Ben Walton Date: Tue, 2 Aug 2022 18:28:44 +0100 Subject: [PATCH 015/672] fix(cli): make `omz` honour symlinks when changing `.zshrc` (#11082) --- lib/cli.zsh | 30 +++++++++++++++--------------- 1 file changed, 15 insertions(+), 15 deletions(-) diff --git a/lib/cli.zsh b/lib/cli.zsh index b71f6d9ce..db659c11f 100644 --- a/lib/cli.zsh +++ b/lib/cli.zsh @@ -280,9 +280,10 @@ multi == 1 && length(\$0) > 0 { " local zdot="${ZDOTDIR:-$HOME}" - awk "$awk_script" "$zdot/.zshrc" > "$zdot/.zshrc.new" \ - && command mv -f "$zdot/.zshrc" "$zdot/.zshrc.bck" \ - && command mv -f "$zdot/.zshrc.new" "$zdot/.zshrc" + local zshrc="${${:-"${zdot}/.zshrc"}:A}" + awk "$awk_script" "$zshrc" > "$zdot/.zshrc.new" \ + && command cp -f "$zshrc" "$zdot/.zshrc.bck" \ + && command mv -f "$zdot/.zshrc.new" "$zshrc" # Exit if the new .zshrc file wasn't created correctly [[ $? -eq 0 ]] || { @@ -294,8 +295,7 @@ multi == 1 && length(\$0) > 0 { # Exit if the new .zshrc file has syntax errors if ! command zsh -n "$zdot/.zshrc"; then _omz::log error "broken syntax in '"${zdot/#$HOME/\~}/.zshrc"'. Rolling back changes..." - command mv -f "$zdot/.zshrc" "$zdot/.zshrc.new" - command mv -f "$zdot/.zshrc.bck" "$zdot/.zshrc" + command mv -f "$zdot/.zshrc.bck" "$zshrc" return 1 fi @@ -354,9 +354,10 @@ multi == 1 && /^[^#]*\)/ { " local zdot="${ZDOTDIR:-$HOME}" - awk "$awk_script" "$zdot/.zshrc" > "$zdot/.zshrc.new" \ - && command mv -f "$zdot/.zshrc" "$zdot/.zshrc.bck" \ - && command mv -f "$zdot/.zshrc.new" "$zdot/.zshrc" + local zshrc="${${:-"${zdot}/.zshrc"}:A}" + awk "$awk_script" "$zshrc" > "$zdot/.zshrc.new" \ + && command cp -f "$zshrc" "$zdot/.zshrc.bck" \ + && command mv -f "$zdot/.zshrc.new" "$zshrc" # Exit if the new .zshrc file wasn't created correctly [[ $? -eq 0 ]] || { @@ -368,8 +369,7 @@ multi == 1 && /^[^#]*\)/ { # Exit if the new .zshrc file has syntax errors if ! command zsh -n "$zdot/.zshrc"; then _omz::log error "broken syntax in '"${zdot/#$HOME/\~}/.zshrc"'. Rolling back changes..." - command mv -f "$zdot/.zshrc" "$zdot/.zshrc.new" - command mv -f "$zdot/.zshrc.bck" "$zdot/.zshrc" + command mv -f "$zdot/.zshrc.bck" "$zshrc" return 1 fi @@ -715,7 +715,8 @@ END { ' local zdot="${ZDOTDIR:-$HOME}" - awk "$awk_script" "$zdot/.zshrc" > "$zdot/.zshrc.new" \ + local zshrc="${${:-"${zdot}/.zshrc"}:A}" + awk "$awk_script" "$zshrc" > "$zdot/.zshrc.new" \ || { # Prepend ZSH_THEME= line to .zshrc if it doesn't exist cat < "$zdot/.zshrc.new" \ - && command mv -f "$zdot/.zshrc" "$zdot/.zshrc.bck" \ - && command mv -f "$zdot/.zshrc.new" "$zdot/.zshrc" + && command cp -f "$zshrc" "$zdot/.zshrc.bck" \ + && command mv -f "$zdot/.zshrc.new" "$zshrc" # Exit if the new .zshrc file wasn't created correctly [[ $? -eq 0 ]] || { @@ -737,8 +738,7 @@ EOF # Exit if the new .zshrc file has syntax errors if ! command zsh -n "$zdot/.zshrc"; then _omz::log error "broken syntax in '"${zdot/#$HOME/\~}/.zshrc"'. Rolling back changes..." - command mv -f "$zdot/.zshrc" "$zdot/.zshrc.new" - command mv -f "$zdot/.zshrc.bck" "$zdot/.zshrc" + command mv -f "$zdot/.zshrc.bck" "$zshrc" return 1 fi From ff2b0e48aef19655316eb9d52b893bd713eb0759 Mon Sep 17 00:00:00 2001 From: LittleboyHarry Date: Wed, 10 Aug 2022 17:58:19 +0800 Subject: [PATCH 016/672] fix(debian): remove aptitude-only `-P` flag (#11053) --- plugins/debian/debian.plugin.zsh | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/plugins/debian/debian.plugin.zsh b/plugins/debian/debian.plugin.zsh index e4db8fe33..f649a5b16 100644 --- a/plugins/debian/debian.plugin.zsh +++ b/plugins/debian/debian.plugin.zsh @@ -89,22 +89,22 @@ else alias afu="su -lc '$apt-file update'" alias au="su -lc '$apt_pref $apt_upgr' root" function ai() { - cmd="su -lc 'aptitude -P install $@' root" + cmd="su -lc '$apt_pref install $@' root" print "$cmd" eval "$cmd" } function ap() { - cmd="su -lc '$apt_pref -P purge $@' root" + cmd="su -lc '$apt_pref purge $@' root" print "$cmd" eval "$cmd" } function ar() { - cmd="su -lc '$apt_pref -P remove $@' root" + cmd="su -lc '$apt_pref remove $@' root" print "$cmd" eval "$cmd" } function aar() { - cmd="su -lc '$apt_pref -P autoremove $@' root" + cmd="su -lc '$apt_pref autoremove $@' root" print "$cmd" eval "$cmd" } From e857cc8cb93cf5f1f474c8a84b6ec644be7bdd2e Mon Sep 17 00:00:00 2001 From: Wei Huang Date: Wed, 10 Aug 2022 07:17:47 -0700 Subject: [PATCH 017/672] feat(git): alias `gluc` to sync with current branch in upstream (#11101) --- plugins/git/README.md | 1 + plugins/git/git.plugin.zsh | 1 + 2 files changed, 2 insertions(+) diff --git a/plugins/git/README.md b/plugins/git/README.md index 0700dcc32..050c13d81 100644 --- a/plugins/git/README.md +++ b/plugins/git/README.md @@ -184,6 +184,7 @@ plugins=(... git) | gupom | git pull --rebase origin $(git_main_branch) | | gupomi | git pull --rebase=interactive origin $(git_main_branch) | | glum | git pull upstream $(git_main_branch) | +| gluc | git pull upstream $(git_current_branch) | | gwch | git whatchanged -p --abbrev-commit --pretty=medium | | gwip | git add -A; git rm $(git ls-files --deleted) 2> /dev/null; git commit --no-verify --no-gpg-sign -m "--wip-- [skip ci]" | | gam | git am | diff --git a/plugins/git/git.plugin.zsh b/plugins/git/git.plugin.zsh index be6adc7ce..f25453bc1 100644 --- a/plugins/git/git.plugin.zsh +++ b/plugins/git/git.plugin.zsh @@ -310,6 +310,7 @@ alias gupav='git pull --rebase --autostash -v' alias gupom='git pull --rebase origin $(git_main_branch)' alias gupomi='git pull --rebase=interactive origin $(git_main_branch)' alias glum='git pull upstream $(git_main_branch)' +alias gluc='git pull upstream $(git_current_branch)' alias gwch='git whatchanged -p --abbrev-commit --pretty=medium' alias gwip='git add -A; git rm $(git ls-files --deleted) 2> /dev/null; git commit --no-verify --no-gpg-sign -m "--wip-- [skip ci]"' From 835a0a5d17765243cabee782acb5905a9aab33c3 Mon Sep 17 00:00:00 2001 From: 180909 Date: Wed, 10 Aug 2022 22:18:59 +0800 Subject: [PATCH 018/672] feat(golang): add `gow` alias for `go work` (#11105) --- plugins/golang/README.md | 1 + plugins/golang/golang.plugin.zsh | 1 + 2 files changed, 2 insertions(+) diff --git a/plugins/golang/README.md b/plugins/golang/README.md index 979c89010..3b7d1e19f 100644 --- a/plugins/golang/README.md +++ b/plugins/golang/README.md @@ -35,3 +35,4 @@ plugins=(... golang) | gotod | `go tool dist` | Utility to bootstrap, build and test go runtime | | gotofx | `go tool fix` | Fixes an application to use newer features | | gov | `go vet` | Vet examines Go source code and reports suspicious constructs | +| gow | `go work` | Work provides access to operations on workspaces | diff --git a/plugins/golang/golang.plugin.zsh b/plugins/golang/golang.plugin.zsh index 4dafecd86..0dbaab069 100644 --- a/plugins/golang/golang.plugin.zsh +++ b/plugins/golang/golang.plugin.zsh @@ -32,3 +32,4 @@ alias gotoc='go tool compile' alias gotod='go tool dist' alias gotofx='go tool fix' alias gov='go vet' +alias gow='go work' From b74a15a80e24ae12e533a38e580cd0a939dece31 Mon Sep 17 00:00:00 2001 From: Felipe Contreras Date: Sun, 14 Aug 2022 10:00:30 -0500 Subject: [PATCH 019/672] feat(gitfast): update to git-completion 1.3.7 (#11114) --- plugins/gitfast/git-completion.bash | 89 +++++++++++++++++++++------- plugins/gitfast/git-prompt.sh | 91 +++++++++++++++-------------- plugins/gitfast/update | 2 +- 3 files changed, 115 insertions(+), 67 deletions(-) diff --git a/plugins/gitfast/git-completion.bash b/plugins/gitfast/git-completion.bash index 2603ba7bb..dd06b5048 100644 --- a/plugins/gitfast/git-completion.bash +++ b/plugins/gitfast/git-completion.bash @@ -49,6 +49,11 @@ # and git-switch completion (e.g., completing "foo" when "origin/foo" # exists). # +# GIT_COMPLETION_SHOW_ALL_COMMANDS +# +# When set to "1" suggest all commands, including plumbing commands +# which are hidden by default (e.g. "cat-file" on "git ca"). +# # GIT_COMPLETION_SHOW_ALL # # When set to "1" suggest all options, including options which are @@ -321,19 +326,19 @@ __gitcomp_builtin_apply_default=" --exclude= --include= --no-add --stat --numsta __gitcomp_builtin_archive_default=" --output= --remote= --exec= --no-output -- --no-remote --no-exec" __gitcomp_builtin_bisect__helper_default=" --bisect-reset --bisect-next-check --bisect-terms --bisect-start --bisect-next --bisect-state --bisect-log --bisect-replay --bisect-skip --bisect-visualize --bisect-run --no-log --log" __gitcomp_builtin_blame_default=" --incremental --root --show-stats --progress --score-debug --show-name --show-number --porcelain --line-porcelain --show-email --ignore-rev= --ignore-revs-file= --color-lines --color-by-age --minimal --contents= --abbrev --no-incremental -- --no-root --no-show-stats --no-progress --no-score-debug --no-show-name --no-show-number --no-porcelain --no-line-porcelain --no-show-email --no-ignore-rev --no-ignore-revs-file --no-color-lines --no-color-by-age --no-minimal --no-contents --no-abbrev" -__gitcomp_builtin_branch_default=" --verbose --quiet --track --set-upstream-to= --unset-upstream --color --remotes --contains --no-contains --abbrev --all --delete --move --copy --list --show-current --create-reflog --edit-description --merged --no-merged --column --sort= --points-at= --ignore-case --format= -- --no-verbose --no-quiet --no-track --no-set-upstream-to --no-unset-upstream --no-color --no-remotes --no-abbrev --no-all --no-delete --no-move --no-copy --no-list --no-show-current --no-create-reflog --no-edit-description --no-column --no-sort --no-points-at --no-ignore-case --no-format" +__gitcomp_builtin_branch_default=" --verbose --quiet --track --set-upstream-to= --unset-upstream --color --remotes --contains --no-contains --abbrev --all --delete --move --copy --list --show-current --create-reflog --edit-description --merged --no-merged --column --sort= --points-at= --ignore-case --recurse-submodules --format= -- --no-verbose --no-quiet --no-track --no-set-upstream-to --no-unset-upstream --no-color --no-remotes --no-abbrev --no-all --no-delete --no-move --no-copy --no-list --no-show-current --no-create-reflog --no-edit-description --no-column --no-sort --no-points-at --no-ignore-case --no-recurse-submodules --no-format" __gitcomp_builtin_bugreport_default=" --output-directory= --suffix= --no-output-directory -- --no-suffix" -__gitcomp_builtin_cat_file_default=" --textconv --filters --path= --allow-unknown-type --buffer --batch --batch-check --follow-symlinks --batch-all-objects --unordered --no-path -- --no-allow-unknown-type --no-buffer --no-follow-symlinks --no-batch-all-objects --no-unordered" +__gitcomp_builtin_cat_file_default=" --allow-unknown-type --batch --batch-check --batch-command --batch-all-objects --buffer --follow-symlinks --unordered --textconv --filters --path= --no-allow-unknown-type -- --no-buffer --no-follow-symlinks --no-unordered --no-path" __gitcomp_builtin_check_attr_default=" --all --cached --stdin --no-all -- --no-cached --no-stdin" __gitcomp_builtin_check_ignore_default=" --quiet --verbose --stdin --non-matching --no-index --index -- --no-quiet --no-verbose --no-stdin --no-non-matching" __gitcomp_builtin_check_mailmap_default=" --stdin --no-stdin" __gitcomp_builtin_checkout_default=" --guess --overlay --quiet --recurse-submodules --progress --merge --conflict= --detach --track --orphan= --ignore-other-worktrees --ours --theirs --patch --ignore-skip-worktree-bits --pathspec-from-file= --pathspec-file-nul --no-guess -- --no-overlay --no-quiet --no-recurse-submodules --no-progress --no-merge --no-conflict --no-detach --no-track --no-orphan --no-ignore-other-worktrees --no-patch --no-ignore-skip-worktree-bits --no-pathspec-from-file --no-pathspec-file-nul" __gitcomp_builtin_checkout__worker_default=" --prefix= --no-prefix" -__gitcomp_builtin_checkout_index_default=" --all --force --quiet --no-create --index --stdin --temp --prefix= --stage= --create -- --no-all --no-force --no-quiet --no-index --no-stdin --no-temp --no-prefix" +__gitcomp_builtin_checkout_index_default=" --all --ignore-skip-worktree-bits --force --quiet --no-create --index --stdin --temp --prefix= --stage= --create -- --no-all --no-ignore-skip-worktree-bits --no-force --no-quiet --no-index --no-stdin --no-temp --no-prefix" __gitcomp_builtin_cherry_default=" --abbrev --verbose --no-abbrev -- --no-verbose" __gitcomp_builtin_cherry_pick_default=" --quit --continue --abort --skip --cleanup= --no-commit --edit --signoff --mainline= --rerere-autoupdate --strategy= --strategy-option= --gpg-sign --ff --allow-empty --allow-empty-message --keep-redundant-commits --commit -- --no-cleanup --no-edit --no-signoff --no-mainline --no-rerere-autoupdate --no-strategy --no-strategy-option --no-gpg-sign --no-ff --no-allow-empty --no-allow-empty-message --no-keep-redundant-commits" __gitcomp_builtin_clean_default=" --quiet --dry-run --interactive --exclude= --no-quiet -- --no-dry-run --no-interactive" -__gitcomp_builtin_clone_default=" --verbose --quiet --progress --reject-shallow --no-checkout --bare --mirror --local --no-hardlinks --shared --recurse-submodules --jobs= --template= --reference= --reference-if-able= --dissociate --origin= --branch= --upload-pack= --depth= --shallow-since= --shallow-exclude= --single-branch --no-tags --shallow-submodules --separate-git-dir= --config= --server-option= --ipv4 --ipv6 --filter= --remote-submodules --sparse --checkout --hardlinks --tags -- --no-verbose --no-quiet --no-progress --no-reject-shallow --no-bare --no-mirror --no-local --no-shared --no-recurse-submodules --no-recursive --no-jobs --no-template --no-reference --no-reference-if-able --no-dissociate --no-origin --no-branch --no-upload-pack --no-depth --no-shallow-since --no-shallow-exclude --no-single-branch --no-shallow-submodules --no-separate-git-dir --no-config --no-server-option --no-ipv4 --no-ipv6 --no-filter --no-remote-submodules --no-sparse" +__gitcomp_builtin_clone_default=" --verbose --quiet --progress --reject-shallow --no-checkout --bare --mirror --local --no-hardlinks --shared --recurse-submodules --jobs= --template= --reference= --reference-if-able= --dissociate --origin= --branch= --upload-pack= --depth= --shallow-since= --shallow-exclude= --single-branch --no-tags --shallow-submodules --separate-git-dir= --config= --server-option= --ipv4 --ipv6 --filter= --also-filter-submodules --remote-submodules --sparse --checkout --hardlinks --tags -- --no-verbose --no-quiet --no-progress --no-reject-shallow --no-bare --no-mirror --no-local --no-shared --no-recurse-submodules --no-recursive --no-jobs --no-template --no-reference --no-reference-if-able --no-dissociate --no-origin --no-branch --no-upload-pack --no-depth --no-shallow-since --no-shallow-exclude --no-single-branch --no-shallow-submodules --no-separate-git-dir --no-config --no-server-option --no-ipv4 --no-ipv6 --no-filter --no-also-filter-submodules --no-remote-submodules --no-sparse" __gitcomp_builtin_column_default=" --command= --mode --raw-mode= --width= --indent= --nl= --padding= --no-command -- --no-mode --no-raw-mode --no-width --no-indent --no-nl --no-padding" __gitcomp_builtin_commit_default=" --quiet --verbose --file= --author= --date= --message= --reedit-message= --reuse-message= --fixup= --squash= --reset-author --trailer= --signoff --template= --edit --cleanup= --status --gpg-sign --all --include --interactive --patch --only --no-verify --dry-run --short --branch --ahead-behind --porcelain --long --null --amend --no-post-rewrite --untracked-files --pathspec-from-file= --pathspec-file-nul --verify --post-rewrite -- --no-quiet --no-verbose --no-file --no-author --no-date --no-message --no-reedit-message --no-reuse-message --no-fixup --no-squash --no-reset-author --no-signoff --no-template --no-edit --no-cleanup --no-status --no-gpg-sign --no-all --no-include --no-interactive --no-patch --no-only --no-dry-run --no-short --no-branch --no-ahead-behind --no-porcelain --no-long --no-null --no-amend --no-untracked-files --no-pathspec-from-file --no-pathspec-file-nul" __gitcomp_builtin_commit_graph_default=" --object-dir= --no-object-dir" @@ -346,31 +351,33 @@ __gitcomp_builtin_describe_default=" --contains --debug --all --tags --long --fi __gitcomp_builtin_difftool_default=" --gui --dir-diff --no-prompt --symlinks --tool= --tool-help --trust-exit-code --extcmd= --no-index --index -- --no-gui --no-dir-diff --no-symlinks --no-tool --no-tool-help --no-trust-exit-code --no-extcmd" __gitcomp_builtin_env__helper_default=" --type= --default= --exit-code --no-default -- --no-exit-code" __gitcomp_builtin_fast_export_default=" --progress= --signed-tags= --tag-of-filtered-object= --reencode= --export-marks= --import-marks= --import-marks-if-exists= --fake-missing-tagger --full-tree --use-done-feature --no-data --refspec= --anonymize --anonymize-map= --reference-excluded-parents --show-original-ids --mark-tags --data -- --no-progress --no-signed-tags --no-tag-of-filtered-object --no-reencode --no-export-marks --no-import-marks --no-import-marks-if-exists --no-fake-missing-tagger --no-full-tree --no-use-done-feature --no-refspec --no-anonymize --no-reference-excluded-parents --no-show-original-ids --no-mark-tags" -__gitcomp_builtin_fetch_default=" --verbose --quiet --all --set-upstream --append --atomic --upload-pack= --force --multiple --tags --jobs= --prefetch --prune --prune-tags --recurse-submodules --dry-run --write-fetch-head --keep --update-head-ok --progress --depth= --shallow-since= --shallow-exclude= --deepen= --unshallow --update-shallow --refmap= --server-option= --ipv4 --ipv6 --negotiation-tip= --negotiate-only --filter= --auto-maintenance --auto-gc --show-forced-updates --write-commit-graph --stdin --no-verbose -- --no-quiet --no-all --no-set-upstream --no-append --no-atomic --no-upload-pack --no-force --no-multiple --no-tags --no-jobs --no-prefetch --no-prune --no-prune-tags --no-recurse-submodules --no-dry-run --no-write-fetch-head --no-keep --no-update-head-ok --no-progress --no-depth --no-shallow-since --no-shallow-exclude --no-deepen --no-update-shallow --no-server-option --no-ipv4 --no-ipv6 --no-negotiation-tip --no-negotiate-only --no-filter --no-auto-maintenance --no-auto-gc --no-show-forced-updates --no-write-commit-graph --no-stdin" +__gitcomp_builtin_fetch_default=" --verbose --quiet --all --set-upstream --append --atomic --upload-pack= --force --multiple --tags --jobs= --prefetch --prune --prune-tags --recurse-submodules --dry-run --write-fetch-head --keep --update-head-ok --progress --depth= --shallow-since= --shallow-exclude= --deepen= --unshallow --refetch --update-shallow --refmap= --server-option= --ipv4 --ipv6 --negotiation-tip= --negotiate-only --filter= --auto-maintenance --auto-gc --show-forced-updates --write-commit-graph --stdin --no-verbose -- --no-quiet --no-all --no-set-upstream --no-append --no-atomic --no-upload-pack --no-force --no-multiple --no-tags --no-jobs --no-prefetch --no-prune --no-prune-tags --no-recurse-submodules --no-dry-run --no-write-fetch-head --no-keep --no-update-head-ok --no-progress --no-depth --no-shallow-since --no-shallow-exclude --no-deepen --no-update-shallow --no-server-option --no-ipv4 --no-ipv6 --no-negotiation-tip --no-negotiate-only --no-filter --no-auto-maintenance --no-auto-gc --no-show-forced-updates --no-write-commit-graph --no-stdin" __gitcomp_builtin_fmt_merge_msg_default=" --log --message= --into-name= --file= --no-log -- --no-message --no-into-name --no-file" __gitcomp_builtin_for_each_ref_default=" --shell --perl --python --tcl --count= --format= --color --sort= --points-at= --merged --no-merged --contains --no-contains --ignore-case -- --no-shell --no-perl --no-python --no-tcl --no-count --no-format --no-color --no-sort --no-points-at --no-ignore-case" __gitcomp_builtin_for_each_repo_default=" --config= --no-config" __gitcomp_builtin_format_patch_default=" --numbered --no-numbered --signoff --stdout --cover-letter --numbered-files --suffix= --start-number= --reroll-count= --filename-max-length= --rfc --cover-from-description= --subject-prefix= --output-directory= --keep-subject --no-binary --zero-commit --ignore-if-in-upstream --no-stat --add-header= --to= --cc= --from --in-reply-to= --attach --inline --thread --signature= --base= --signature-file= --quiet --progress --interdiff= --range-diff= --creation-factor= --binary -- --no-numbered --no-signoff --no-stdout --no-cover-letter --no-numbered-files --no-suffix --no-start-number --no-reroll-count --no-filename-max-length --no-cover-from-description --no-zero-commit --no-ignore-if-in-upstream --no-add-header --no-to --no-cc --no-from --no-in-reply-to --no-attach --no-thread --no-signature --no-base --no-signature-file --no-quiet --no-progress --no-interdiff --no-range-diff --no-creation-factor" __gitcomp_builtin_fsck_default=" --verbose --unreachable --dangling --tags --root --cache --reflogs --full --connectivity-only --strict --lost-found --progress --name-objects --no-verbose -- --no-unreachable --no-dangling --no-tags --no-root --no-cache --no-reflogs --no-full --no-connectivity-only --no-strict --no-lost-found --no-progress --no-name-objects" __gitcomp_builtin_fsck_objects_default=" --verbose --unreachable --dangling --tags --root --cache --reflogs --full --connectivity-only --strict --lost-found --progress --name-objects --no-verbose -- --no-unreachable --no-dangling --no-tags --no-root --no-cache --no-reflogs --no-full --no-connectivity-only --no-strict --no-lost-found --no-progress --no-name-objects" +__gitcomp_builtin_fsmonitor__daemon_default="" __gitcomp_builtin_gc_default=" --quiet --prune --aggressive --keep-largest-pack --no-quiet -- --no-prune --no-aggressive --no-keep-largest-pack" __gitcomp_builtin_grep_default=" --cached --no-index --untracked --exclude-standard --recurse-submodules --invert-match --ignore-case --word-regexp --text --textconv --recursive --max-depth= --extended-regexp --basic-regexp --fixed-strings --perl-regexp --line-number --column --full-name --files-with-matches --name-only --files-without-match --only-matching --count --color --break --heading --context= --before-context= --after-context= --threads= --show-function --function-context --and --or --not --quiet --all-match --index -- --no-cached --no-untracked --no-exclude-standard --no-recurse-submodules --no-invert-match --no-ignore-case --no-word-regexp --no-text --no-textconv --no-recursive --no-extended-regexp --no-basic-regexp --no-fixed-strings --no-perl-regexp --no-line-number --no-column --no-full-name --no-files-with-matches --no-name-only --no-files-without-match --no-only-matching --no-count --no-color --no-break --no-heading --no-context --no-before-context --no-after-context --no-threads --no-show-function --no-function-context --no-or --no-quiet --no-all-match" __gitcomp_builtin_hash_object_default=" --stdin --stdin-paths --no-filters --literally --path= --filters -- --no-stdin --no-stdin-paths --no-literally --no-path" -__gitcomp_builtin_help_default=" --all --man --web --info --verbose --guides --config --no-man -- --no-web --no-info --no-verbose" +__gitcomp_builtin_help_default=" --all --external-commands --aliases --man --web --info --verbose --guides --config --no-external-commands -- --no-aliases --no-man --no-web --no-info --no-verbose" +__gitcomp_builtin_hook_default="" __gitcomp_builtin_init_default=" --template= --bare --shared --quiet --separate-git-dir= --initial-branch= --object-format= --no-template -- --no-bare --no-quiet --no-separate-git-dir --no-initial-branch --no-object-format" __gitcomp_builtin_init_db_default=" --template= --bare --shared --quiet --separate-git-dir= --initial-branch= --object-format= --no-template -- --no-bare --no-quiet --no-separate-git-dir --no-initial-branch --no-object-format" __gitcomp_builtin_interpret_trailers_default=" --in-place --trim-empty --where= --if-exists= --if-missing= --only-trailers --only-input --unfold --parse --no-divider --trailer= --divider -- --no-in-place --no-trim-empty --no-where --no-if-exists --no-if-missing --no-only-trailers --no-only-input --no-unfold --no-trailer" __gitcomp_builtin_log_default=" --quiet --source --use-mailmap --decorate-refs= --decorate-refs-exclude= --decorate --no-quiet -- --no-source --no-use-mailmap --no-mailmap --no-decorate-refs --no-decorate-refs-exclude --no-decorate" __gitcomp_builtin_ls_files_default=" --cached --deleted --modified --others --ignored --stage --killed --directory --eol --empty-directory --unmerged --resolve-undo --exclude= --exclude-from= --exclude-per-directory= --exclude-standard --full-name --recurse-submodules --error-unmatch --with-tree= --abbrev --debug --deduplicate --sparse --no-cached -- --no-deleted --no-modified --no-others --no-ignored --no-stage --no-killed --no-directory --no-eol --no-empty-directory --no-unmerged --no-resolve-undo --no-exclude-per-directory --no-recurse-submodules --no-error-unmatch --no-with-tree --no-abbrev --no-debug --no-deduplicate --no-sparse" __gitcomp_builtin_ls_remote_default=" --quiet --upload-pack= --tags --heads --refs --get-url --sort= --symref --server-option= --no-quiet -- --no-upload-pack --no-tags --no-heads --no-refs --no-get-url --no-sort --no-symref --no-server-option" -__gitcomp_builtin_ls_tree_default=" --long --name-only --name-status --full-name --full-tree --abbrev --no-long -- --no-name-only --no-name-status --no-full-name --no-full-tree --no-abbrev" +__gitcomp_builtin_ls_tree_default=" --long --name-only --name-status --object-only --full-name --full-tree --format= --abbrev --no-full-name -- --no-full-tree --no-abbrev" __gitcomp_builtin_merge_default=" --stat --summary --log --squash --commit --edit --cleanup= --ff --ff-only --rerere-autoupdate --verify-signatures --strategy= --strategy-option= --message= --file --into-name= --verbose --quiet --abort --quit --continue --allow-unrelated-histories --progress --gpg-sign --autostash --overwrite-ignore --signoff --no-verify --verify -- --no-stat --no-summary --no-log --no-squash --no-commit --no-edit --no-cleanup --no-ff --no-rerere-autoupdate --no-verify-signatures --no-strategy --no-strategy-option --no-message --no-into-name --no-verbose --no-quiet --no-abort --no-quit --no-continue --no-allow-unrelated-histories --no-progress --no-gpg-sign --no-autostash --no-overwrite-ignore --no-signoff" __gitcomp_builtin_merge_base_default=" --all --octopus --independent --is-ancestor --fork-point --no-all" __gitcomp_builtin_merge_file_default=" --stdout --diff3 --zdiff3 --ours --theirs --union --marker-size= --quiet --no-stdout -- --no-diff3 --no-zdiff3 --no-ours --no-theirs --no-union --no-marker-size --no-quiet" __gitcomp_builtin_mktree_default=" --missing --batch --no-missing -- --no-batch" __gitcomp_builtin_multi_pack_index_default=" --object-dir= --no-object-dir" __gitcomp_builtin_mv_default=" --verbose --dry-run --sparse --no-verbose -- --no-dry-run --no-sparse" -__gitcomp_builtin_name_rev_default=" --name-only --tags --refs= --exclude= --all --stdin --undefined --always --no-name-only -- --no-tags --no-refs --no-exclude --no-all --no-stdin --no-undefined --no-always" +__gitcomp_builtin_name_rev_default=" --name-only --tags --refs= --exclude= --all --stdin --annotate-stdin --undefined --always --no-name-only -- --no-tags --no-refs --no-exclude --no-all --no-stdin --no-annotate-stdin --no-undefined --no-always" __gitcomp_builtin_notes_default=" --ref= --no-ref" __gitcomp_builtin_pack_objects_default=" --quiet --progress --all-progress --all-progress-implied --index-version= --max-pack-size= --local --incremental --window= --window-memory= --depth= --reuse-delta --reuse-object --delta-base-offset --threads= --non-empty --revs --unpacked --all --reflog --indexed-objects --stdin-packs --stdout --include-tag --keep-unreachable --pack-loose-unreachable --unpack-unreachable --sparse --thin --shallow --honor-pack-keep --keep-pack= --compression= --keep-true-parents --use-bitmap-index --write-bitmap-index --filter= --missing= --exclude-promisor-objects --delta-islands --uri-protocol= --no-quiet -- --no-progress --no-all-progress --no-all-progress-implied --no-local --no-incremental --no-window --no-depth --no-reuse-delta --no-reuse-object --no-delta-base-offset --no-threads --no-non-empty --no-revs --no-stdin-packs --no-stdout --no-include-tag --no-keep-unreachable --no-pack-loose-unreachable --no-unpack-unreachable --no-sparse --no-thin --no-shallow --no-honor-pack-keep --no-keep-pack --no-compression --no-keep-true-parents --no-use-bitmap-index --no-write-bitmap-index --no-filter --no-exclude-promisor-objects --no-delta-islands --no-uri-protocol" __gitcomp_builtin_pack_refs_default=" --all --prune --no-all -- --no-prune" @@ -383,12 +390,12 @@ __gitcomp_builtin_range_diff_default=" --creation-factor= --no-dual-color --note __gitcomp_builtin_read_tree_default=" --index-output= --empty --verbose --trivial --aggressive --reset --prefix= --exclude-per-directory= --dry-run --no-sparse-checkout --debug-unpack --recurse-submodules --quiet --sparse-checkout -- --no-empty --no-verbose --no-trivial --no-aggressive --no-reset --no-dry-run --no-debug-unpack --no-recurse-submodules --no-quiet" __gitcomp_builtin_rebase_default=" --onto= --keep-base --no-verify --quiet --verbose --no-stat --signoff --committer-date-is-author-date --reset-author-date --ignore-whitespace --whitespace= --force-rebase --no-ff --continue --skip --abort --quit --edit-todo --show-current-patch --apply --merge --interactive --rerere-autoupdate --empty= --autosquash --gpg-sign --autostash --exec= --rebase-merges --fork-point --strategy= --strategy-option= --root --reschedule-failed-exec --reapply-cherry-picks --verify --stat --ff -- --no-onto --no-keep-base --no-quiet --no-verbose --no-signoff --no-committer-date-is-author-date --no-reset-author-date --no-ignore-whitespace --no-whitespace --no-force-rebase --no-rerere-autoupdate --no-autosquash --no-gpg-sign --no-autostash --no-exec --no-rebase-merges --no-fork-point --no-strategy --no-strategy-option --no-root --no-reschedule-failed-exec --no-reapply-cherry-picks" __gitcomp_builtin_receive_pack_default=" --quiet --no-quiet" -__gitcomp_builtin_reflog_default=" --quiet --source --use-mailmap --decorate-refs= --decorate-refs-exclude= --decorate --no-quiet -- --no-source --no-use-mailmap --no-mailmap --no-decorate-refs --no-decorate-refs-exclude --no-decorate" +__gitcomp_builtin_reflog_default="" __gitcomp_builtin_remote_default=" --verbose --no-verbose" __gitcomp_builtin_repack_default=" --quiet --local --write-bitmap-index --delta-islands --unpack-unreachable= --keep-unreachable --window= --window-memory= --depth= --threads= --max-pack-size= --pack-kept-objects --keep-pack= --geometric= --write-midx --no-quiet -- --no-local --no-write-bitmap-index --no-delta-islands --no-unpack-unreachable --no-keep-unreachable --no-window --no-window-memory --no-depth --no-threads --no-max-pack-size --no-pack-kept-objects --no-keep-pack --no-geometric --no-write-midx" __gitcomp_builtin_replace_default=" --list --delete --edit --graft --convert-graft-file --raw --format= --no-raw -- --no-format" __gitcomp_builtin_rerere_default=" --rerere-autoupdate --no-rerere-autoupdate" -__gitcomp_builtin_reset_default=" --quiet --mixed --soft --hard --merge --keep --recurse-submodules --patch --intent-to-add --pathspec-from-file= --pathspec-file-nul --no-quiet -- --no-mixed --no-soft --no-hard --no-merge --no-keep --no-recurse-submodules --no-patch --no-intent-to-add --no-pathspec-from-file --no-pathspec-file-nul" +__gitcomp_builtin_reset_default=" --quiet --no-refresh --mixed --soft --hard --merge --keep --recurse-submodules --patch --intent-to-add --pathspec-from-file= --pathspec-file-nul --refresh -- --no-quiet --no-mixed --no-soft --no-hard --no-merge --no-keep --no-recurse-submodules --no-patch --no-intent-to-add --no-pathspec-from-file --no-pathspec-file-nul" __gitcomp_builtin_restore_default=" --source= --staged --worktree --ignore-unmerged --overlay --quiet --recurse-submodules --progress --merge --conflict= --ours --theirs --patch --ignore-skip-worktree-bits --pathspec-from-file= --pathspec-file-nul --no-source -- --no-staged --no-worktree --no-ignore-unmerged --no-overlay --no-quiet --no-recurse-submodules --no-progress --no-merge --no-conflict --no-patch --no-ignore-skip-worktree-bits --no-pathspec-from-file --no-pathspec-file-nul" __gitcomp_builtin_revert_default=" --quit --continue --abort --skip --cleanup= --no-commit --edit --signoff --mainline= --rerere-autoupdate --strategy= --strategy-option= --gpg-sign --commit -- --no-cleanup --no-edit --no-signoff --no-mainline --no-rerere-autoupdate --no-strategy --no-strategy-option --no-gpg-sign" __gitcomp_builtin_rm_default=" --dry-run --quiet --cached --ignore-unmatch --sparse --pathspec-from-file= --pathspec-file-nul --no-dry-run -- --no-quiet --no-cached --no-ignore-unmatch --no-sparse --no-pathspec-from-file --no-pathspec-file-nul" @@ -416,7 +423,7 @@ __gitcomp_builtin_verify_tag_default=" --verbose --raw --format= --no-verbose -- __gitcomp_builtin_version_default=" --build-options --no-build-options" __gitcomp_builtin_whatchanged_default=" --quiet --source --use-mailmap --decorate-refs= --decorate-refs-exclude= --decorate --no-quiet -- --no-source --no-use-mailmap --no-mailmap --no-decorate-refs --no-decorate-refs-exclude --no-decorate" __gitcomp_builtin_write_tree_default=" --missing-ok --prefix= --no-missing-ok -- --no-prefix" -__gitcomp_builtin_send_email_default="--cc= --smtp-server= --identity= --smtp-ssl --sender= --from= --cc-cover --no-to-cover --sendmail-cmd= --signed-off-cc --signed-off-by-cc --in-reply-to= --no-cc --confirm= --no-bcc --to= --annotate --smtp-encryption= --relogin-delay= --to-cmd= --smtp-domain= --smtp-auth= --bcc= --quiet --subject= --chain-reply-to --cc-cmd= --no-format-patch --transfer-encoding= --smtp-user= --reply-to= --force --dry-run --no-identity --no-validate --8bit-encoding= --to-cover --compose --thread --format-patch --no-thread --smtp-server-option= --compose-encoding= --smtp-server-port= --no-smtp-auth --no-signed-off-cc --no-signed-off-by-cc --smtp-debug= --no-suppress-from --suppress-from --no-to --dump-aliases --xmailer --no-annotate --no-cc-cover --smtp-pass= --smtp-ssl-cert-path= --no-chain-reply-to --suppress-cc= --validate --batch-size= --envelope-sender= --no-xmailer --numbered --no-numbered --signoff --stdout --cover-letter --numbered-files --suffix= --start-number= --reroll-count= --filename-max-length= --rfc --cover-from-description= --subject-prefix= --output-directory= --keep-subject --no-binary --zero-commit --ignore-if-in-upstream --no-stat --add-header= --from --attach --inline --signature= --base= --signature-file= --progress --interdiff= --range-diff= --creation-factor= --binary -- --no-signoff --no-stdout --no-cover-letter --no-numbered-files --no-suffix --no-start-number --no-reroll-count --no-filename-max-length --no-cover-from-description --no-zero-commit --no-ignore-if-in-upstream --no-add-header --no-from --no-in-reply-to --no-attach --no-signature --no-base --no-signature-file --no-quiet --no-progress --no-interdiff --no-range-diff --no-creation-factor" +__gitcomp_builtin_send_email_default="--sender= --from= --smtp-auth= --8bit-encoding= --no-format-patch --no-bcc --no-suppress-from --no-annotate --relogin-delay= --no-cc --no-signed-off-cc --no-signed-off-by-cc --no-chain-reply-to --smtp-debug= --smtp-domain= --chain-reply-to --dry-run --compose --bcc= --smtp-user= --thread --cc-cover --identity= --to= --reply-to= --no-cc-cover --suppress-cc= --to-cmd= --smtp-server= --smtp-ssl-cert-path= --no-thread --smtp-server-option= --quiet --batch-size= --envelope-sender= --smtp-ssl --no-to --validate --format-patch --suppress-from --cc= --compose-encoding= --to-cover --in-reply-to= --annotate --smtp-encryption= --cc-cmd= --smtp-server-port= --smtp-pass= --signed-off-cc --signed-off-by-cc --no-xmailer --subject= --no-to-cover --confirm= --transfer-encoding= --no-smtp-auth --sendmail-cmd= --no-validate --no-identity --dump-aliases --xmailer --force --numbered --no-numbered --signoff --stdout --cover-letter --numbered-files --suffix= --start-number= --reroll-count= --filename-max-length= --rfc --cover-from-description= --subject-prefix= --output-directory= --keep-subject --no-binary --zero-commit --ignore-if-in-upstream --no-stat --add-header= --from --attach --inline --signature= --base= --signature-file= --progress --interdiff= --range-diff= --creation-factor= --binary -- --no-signoff --no-stdout --no-cover-letter --no-numbered-files --no-suffix --no-start-number --no-reroll-count --no-filename-max-length --no-cover-from-description --no-zero-commit --no-ignore-if-in-upstream --no-add-header --no-from --no-in-reply-to --no-attach --no-signature --no-base --no-signature-file --no-quiet --no-progress --no-interdiff --no-range-diff --no-creation-factor" __gitcomp_builtin_get_default () { @@ -2841,6 +2848,10 @@ _git_restore () --*) __gitcomp_builtin restore ;; + *) + if __git rev-parse --verify --quiet HEAD >/dev/null; then + __git_complete_index_file "--modified" + fi esac } @@ -2942,9 +2953,37 @@ _git_show_branch () __git_complete_revlist } +__gitcomp_directories () +{ + local _tmp_dir _tmp_completions _found=0 + + # Get the directory of the current token; this differs from dirname + # in that it keeps up to the final trailing slash. If no slash found + # that's fine too. + [[ "$cur" =~ .*/ ]] + _tmp_dir=$BASH_REMATCH + + # Find possible directory completions, adding trailing '/' characters, + # de-quoting, and handling unusual characters. + while IFS= read -r -d $'\0' c ; do + # If there are directory completions, find ones that start + # with "$cur", the current token, and put those in COMPREPLY + if [[ $c == "$cur"* ]]; then + COMPREPLY+=("$c/") + _found=1 + fi + done < <(git ls-tree -z -d --name-only HEAD $_tmp_dir) + + if [[ $_found == 0 ]] && [[ "$cur" =~ /$ ]]; then + # No possible further completions any deeper, so assume we're at + # a leaf directory and just consider it complete + __gitcomp_direct_append "$cur " + fi +} + _git_sparse_checkout () { - local subcommands="list init set disable" + local subcommands="list init set disable add reapply" local subcommand="$(__git_find_on_cmdline "$subcommands")" if [ -z "$subcommand" ]; then __gitcomp "$subcommands" @@ -2952,14 +2991,14 @@ _git_sparse_checkout () fi case "$subcommand,$cur" in - init,--*) - __gitcomp_opts "--cone" - ;; - set,--*) - __gitcomp_opts "--stdin" - ;; - *) + *,--*) + __gitcomp_builtin sparse-checkout_$subcommand "" "--" ;; + set,*|add,*) + if [ "$(__git config core.sparseCheckoutCone)" == "true" ] || + [ -n "$(__git_find_on_cmdline --cone)" ]; then + __gitcomp_directories + fi esac } @@ -3411,7 +3450,13 @@ __git_main () then __gitcomp "$GIT_TESTING_PORCELAIN_COMMAND_LIST" else - __gitcomp_nl "$(__git --list-cmds=list-mainporcelain,others,nohelpers,alias,list-complete,config)" + local list_cmds=list-mainporcelain,others,nohelpers,alias,list-complete,config + + if test "${GIT_COMPLETION_SHOW_ALL_COMMANDS-}" = "1" + then + list_cmds=builtins,$list_cmds + fi + __gitcomp_nl "$(__git --list-cmds=$list_cmds)" fi ;; esac @@ -3589,9 +3634,9 @@ if ! git --list-cmds=main >/dev/null 2>&1; then __git_cmds[list-complete]="apply blame cherry config difftool fsck help instaweb mergetool prune reflog remote repack replace request-pull send-email show-branch stage whatchanged" __git_cmds[list-guide]="attributes cli core-tutorial credentials cvs-migration diffcore everyday faq glossary hooks ignore mailmap modules namespaces remote-helpers repository-layout revisions submodules tutorial tutorial-2 workflows" __git_cmds[list-mainporcelain]="add am archive bisect branch bundle checkout cherry-pick citool clean clone commit describe diff fetch format-patch gc grep gui init log maintenance merge mv notes pull push range-diff rebase reset restore revert rm shortlog show sparse-checkout stash status submodule switch tag worktree gitk" - __git_cmds[main]="add add--interactive am annotate apply archimport archive bisect bisect--helper blame branch bugreport bundle cat-file check-attr check-ignore check-mailmap check-ref-format checkout checkout--worker checkout-index cherry cherry-pick citool clean clone column commit commit-graph commit-tree config count-objects credential credential-cache credential-cache--daemon credential-gnome-keyring credential-libsecret credential-store cvsexportcommit cvsimport cvsserver daemon describe diff diff-files diff-index diff-tree difftool difftool--helper env--helper fast-export fast-import fetch fetch-pack filter-branch fmt-merge-msg for-each-ref for-each-repo format-patch fsck fsck-objects gc get-tar-commit-id grep gui gui--askpass hash-object help http-backend http-fetch http-push imap-send index-pack init init-db instaweb interpret-trailers log ls-files ls-remote ls-tree mailinfo mailsplit maintenance merge merge-base merge-file merge-index merge-octopus merge-one-file merge-ours merge-recursive merge-recursive-ours merge-recursive-theirs merge-resolve merge-subtree merge-tree mergetool mktag mktree multi-pack-index mv mw name-rev notes p4 pack-objects pack-redundant pack-refs patch-id pickaxe prune prune-packed pull push quiltimport range-diff read-tree rebase receive-pack reflog remote remote-ext remote-fd remote-ftp remote-ftps remote-http remote-https remote-mediawiki repack replace request-pull rerere reset restore rev-list rev-parse revert rm send-email send-pack sh-i18n--envsubst shell shortlog show show-branch show-index show-ref sparse-checkout stage stash status stripspace submodule submodule--helper subtree svn switch symbolic-ref tag unpack-file unpack-objects update-index update-ref update-server-info upload-archive upload-archive--writer upload-pack var verify-commit verify-pack verify-tag version web--browse whatchanged worktree write-tree" + __git_cmds[main]="add add--interactive am annotate apply archimport archive bisect bisect--helper blame branch bugreport bundle cat-file check-attr check-ignore check-mailmap check-ref-format checkout checkout--worker checkout-index cherry cherry-pick citool clean clone column commit commit-graph commit-tree config count-objects credential credential-cache credential-cache--daemon credential-store cvsexportcommit cvsimport cvsserver daemon describe diff diff-files diff-index diff-tree difftool difftool--helper env--helper fast-export fast-import fetch fetch-pack filter-branch fmt-merge-msg for-each-ref for-each-repo format-patch fsck fsck-objects fsmonitor--daemon gc get-tar-commit-id grep gui gui--askpass hash-object help hook http-backend http-fetch http-push imap-send index-pack init init-db instaweb interpret-trailers legacy-rebase legacy-stash log ls-files ls-remote ls-tree mailinfo mailsplit maintenance merge merge-base merge-file merge-index merge-octopus merge-one-file merge-ours merge-recursive merge-recursive-ours merge-recursive-theirs merge-resolve merge-subtree merge-tree mergetool mktag mktree multi-pack-index mv name-rev notes p4 pack-objects pack-redundant pack-refs patch-id pickaxe prune prune-packed pull push quiltimport range-diff read-tree rebase rebase--helper receive-pack reflog relink remote remote-ext remote-fd remote-ftp remote-ftps remote-http remote-https remote-testsvn repack replace request-pull rerere reset restore rev-list rev-parse revert rm send-email send-pack serve sh-i18n--envsubst shell shortlog show show-branch show-index show-ref sparse-checkout stage stash status stripspace submodule submodule--helper svn switch symbolic-ref tag unpack-file unpack-objects update-index update-ref update-server-info upload-archive upload-archive--writer upload-pack var verify-commit verify-pack verify-tag version web--browse whatchanged worktree write-tree" __git_cmds[others]="" - __git_cmds[parseopt]="add am apply archive bisect--helper blame branch bugreport cat-file check-attr check-ignore check-mailmap checkout checkout--worker checkout-index cherry cherry-pick clean clone column commit commit-graph config count-objects credential-cache credential-cache--daemon credential-store describe difftool env--helper fast-export fetch fmt-merge-msg for-each-ref for-each-repo format-patch fsck fsck-objects gc grep hash-object help init init-db interpret-trailers log ls-files ls-remote ls-tree merge merge-base merge-file mktree multi-pack-index mv name-rev notes pack-objects pack-refs pickaxe prune prune-packed pull push range-diff read-tree rebase receive-pack reflog remote repack replace rerere reset restore revert rm send-pack shortlog show show-branch show-index show-ref sparse-checkout stage stash status stripspace switch symbolic-ref tag update-index update-ref update-server-info upload-pack verify-commit verify-pack verify-tag version whatchanged write-tree " + __git_cmds[parseopt]="add am apply archive bisect--helper blame branch bugreport cat-file check-attr check-ignore check-mailmap checkout checkout--worker checkout-index cherry cherry-pick clean clone column commit commit-graph config count-objects credential-cache credential-cache--daemon credential-store describe difftool env--helper fast-export fetch fmt-merge-msg for-each-ref for-each-repo format-patch fsck fsck-objects fsmonitor--daemon gc grep hash-object help hook init init-db interpret-trailers log ls-files ls-remote ls-tree merge merge-base merge-file mktree multi-pack-index mv name-rev notes pack-objects pack-refs pickaxe prune prune-packed pull push range-diff read-tree rebase receive-pack reflog remote repack replace rerere reset restore revert rm send-pack shortlog show show-branch show-index show-ref sparse-checkout stage stash status stripspace switch symbolic-ref tag update-index update-ref update-server-info upload-pack verify-commit verify-pack verify-tag version whatchanged write-tree " # Override __git __git () diff --git a/plugins/gitfast/git-prompt.sh b/plugins/gitfast/git-prompt.sh index db7c0068f..1435548e0 100644 --- a/plugins/gitfast/git-prompt.sh +++ b/plugins/gitfast/git-prompt.sh @@ -66,6 +66,11 @@ # git always compare HEAD to @{upstream} # svn always compare HEAD to your SVN upstream # +# By default, __git_ps1 will compare HEAD to your SVN upstream if it can +# find one, or @{upstream} otherwise. Once you have set +# GIT_PS1_SHOWUPSTREAM, you can override it on a per-repository basis by +# setting the bash.showUpstream config variable. +# # You can change the separator between the branch name and the above # state symbols by setting GIT_PS1_STATESEPARATOR. The default separator # is SP. @@ -79,11 +84,6 @@ # single '?' character by setting GIT_PS1_COMPRESSSPARSESTATE, or omitted # by setting GIT_PS1_OMITSPARSESTATE. # -# By default, __git_ps1 will compare HEAD to your SVN upstream if it can -# find one, or @{upstream} otherwise. Once you have set -# GIT_PS1_SHOWUPSTREAM, you can override it on a per-repository basis by -# setting the bash.showUpstream config variable. -# # If you would like to see more information about the identity of # commits checked out as a detached HEAD, set GIT_PS1_DESCRIBE_STYLE # to one of these values: @@ -115,7 +115,7 @@ __git_ps1_show_upstream () { local key value local svn_remote svn_url_pattern count n - local upstream=git legacy="" verbose="" name="" + local upstream_type=git legacy="" verbose="" name="" svn_remote=() # get some config options from git-config @@ -132,7 +132,7 @@ __git_ps1_show_upstream () svn-remote.*.url) svn_remote[$((${#svn_remote[@]} + 1))]="$value" svn_url_pattern="$svn_url_pattern\\|$value" - upstream=svn+git # default upstream is SVN if available, else git + upstream_type=svn+git # default upstream type is SVN if available, else git ;; esac done <<< "$output" @@ -141,16 +141,16 @@ __git_ps1_show_upstream () local option for option in ${GIT_PS1_SHOWUPSTREAM}; do case "$option" in - git|svn) upstream="$option" ;; + git|svn) upstream_type="$option" ;; verbose) verbose=1 ;; legacy) legacy=1 ;; name) name=1 ;; esac done - # Find our upstream - case "$upstream" in - git) upstream="@{upstream}" ;; + # Find our upstream type + case "$upstream_type" in + git) upstream_type="@{upstream}" ;; svn*) # get the upstream from the "git-svn-id: ..." in a commit message # (git-svn uses essentially the same procedure internally) @@ -167,12 +167,12 @@ __git_ps1_show_upstream () if [[ -z "$svn_upstream" ]]; then # default branch name for checkouts with no layout: - upstream=${GIT_SVN_ID:-git-svn} + upstream_type=${GIT_SVN_ID:-git-svn} else - upstream=${svn_upstream#/} + upstream_type=${svn_upstream#/} fi - elif [[ "svn+git" = "$upstream" ]]; then - upstream="@{upstream}" + elif [[ "svn+git" = "$upstream_type" ]]; then + upstream_type="@{upstream}" fi ;; esac @@ -180,11 +180,11 @@ __git_ps1_show_upstream () # Find how many commits we are ahead/behind our upstream if [[ -z "$legacy" ]]; then count="$(git rev-list --count --left-right \ - "$upstream"...HEAD 2>/dev/null)" + "$upstream_type"...HEAD 2>/dev/null)" else # produce equivalent output to --count for older versions of git local commits - if commits="$(git rev-list --left-right "$upstream"...HEAD 2>/dev/null)" + if commits="$(git rev-list --left-right "$upstream_type"...HEAD 2>/dev/null)" then local commit behind=0 ahead=0 for commit in $commits @@ -214,26 +214,26 @@ __git_ps1_show_upstream () *) # diverged from upstream p="<>" ;; esac - else + else # verbose, set upstream instead of p case "$count" in "") # no upstream - p="" ;; + upstream="" ;; "0 0") # equal to upstream - p=" u=" ;; + upstream="|u=" ;; "0 "*) # ahead of upstream - p=" u+${count#0 }" ;; + upstream="|u+${count#0 }" ;; *" 0") # behind upstream - p=" u-${count% 0}" ;; + upstream="|u-${count% 0}" ;; *) # diverged from upstream - p=" u+${count#* }-${count% *}" ;; + upstream="|u+${count#* }-${count% *}" ;; esac if [[ -n "$count" && -n "$name" ]]; then __git_ps1_upstream_name=$(git rev-parse \ - --abbrev-ref "$upstream" 2>/dev/null) + --abbrev-ref "$upstream_type" 2>/dev/null) if [ $pcmode = yes ] && [ $ps1_expanded = yes ]; then - p="$p \${__git_ps1_upstream_name}" + upstream="$upstream \${__git_ps1_upstream_name}" else - p="$p ${__git_ps1_upstream_name}" + upstream="$upstream ${__git_ps1_upstream_name}" # not needed anymore; keep user's # environment clean unset __git_ps1_upstream_name @@ -245,7 +245,8 @@ __git_ps1_show_upstream () # Helper function that is meant to be called from __git_ps1. It # injects color codes into the appropriate gitstring variables used -# to build a gitstring. +# to build a gitstring. Colored variables are responsible for clearing +# their own color. __git_ps1_colorize_gitstring () { if [[ -n ${ZSH_VERSION-} ]]; then @@ -271,22 +272,23 @@ __git_ps1_colorize_gitstring () else branch_color="$bad_color" fi - c="$branch_color$c" + if [ -n "$c" ]; then + c="$branch_color$c$c_clear" + fi + b="$branch_color$b$c_clear" - z="$c_clear$z" - if [ "$w" = "*" ]; then - w="$bad_color$w" + if [ -n "$w" ]; then + w="$bad_color$w$c_clear" fi if [ -n "$i" ]; then - i="$ok_color$i" + i="$ok_color$i$c_clear" fi if [ -n "$s" ]; then - s="$flags_color$s" + s="$flags_color$s$c_clear" fi if [ -n "$u" ]; then - u="$bad_color$u" + u="$bad_color$u$c_clear" fi - r="$c_clear$r" } # Helper function to read the first line of a file into a variable. @@ -512,7 +514,8 @@ __git_ps1 () local u="" local h="" local c="" - local p="" + local p="" # short version of upstream state indicator + local upstream="" # verbose version of upstream state indicator if [ "true" = "$inside_gitdir" ]; then if [ "true" = "$bare_repo" ]; then @@ -555,6 +558,12 @@ __git_ps1 () local z="${GIT_PS1_STATESEPARATOR-" "}" + b=${b##refs/heads/} + if [ $pcmode = yes ] && [ $ps1_expanded = yes ]; then + __git_ps1_branch_name=$b + b="\${__git_ps1_branch_name}" + fi + # NO color option unless in PROMPT_COMMAND mode or it's Zsh if [ -n "${GIT_PS1_SHOWCOLORHINTS-}" ]; then if [ $pcmode = yes ] || [ -n "${ZSH_VERSION-}" ]; then @@ -562,14 +571,8 @@ __git_ps1 () fi fi - b=${b##refs/heads/} - if [ $pcmode = yes ] && [ $ps1_expanded = yes ]; then - __git_ps1_branch_name=$b - b="\${__git_ps1_branch_name}" - fi - - local f="$h$w$i$s$u" - local gitstring="$c$b${f:+$z$f}${sparse}$r$p" + local f="$h$w$i$s$u$p" + local gitstring="$c$b${f:+$z$f}${sparse}$r${upstream}" if [ $pcmode = yes ]; then if [ "${__git_printf_supports_v-}" != yes ]; then diff --git a/plugins/gitfast/update b/plugins/gitfast/update index 5ebaaef3d..feb13ff7e 100755 --- a/plugins/gitfast/update +++ b/plugins/gitfast/update @@ -1,7 +1,7 @@ #!/bin/sh url="https://raw.githubusercontent.com/felipec/git-completion" -version="1.3.6" +version="1.3.7" curl -s -o _git "${url}/v${version}/git-completion.zsh" && curl -s -o git-completion.bash "${url}/v${version}/git-completion.bash" && From 3668ec2a82250020ca0c285ef8b277f1385a8085 Mon Sep 17 00:00:00 2001 From: Zik <48577114+zikaeroh@users.noreply.github.com> Date: Sun, 14 Aug 2022 08:01:31 -0700 Subject: [PATCH 020/672] refactor(gb)!: remove obsolete `gb` plugin (#11115) --- plugins/gb/README.md | 21 -------- plugins/gb/_gb | 111 ------------------------------------------- 2 files changed, 132 deletions(-) delete mode 100644 plugins/gb/README.md delete mode 100644 plugins/gb/_gb diff --git a/plugins/gb/README.md b/plugins/gb/README.md deleted file mode 100644 index 822c29aaa..000000000 --- a/plugins/gb/README.md +++ /dev/null @@ -1,21 +0,0 @@ -# `gb` plugin - -> A project based build tool for the Go programming language. - -See https://getgb.io for the full `gb` documentation - -* * * * - -- Adds completion support for all `gb` commands. -- Also supports completion for the [`gb-vendor` plugin](https://godoc.org/github.com/constabulary/gb/cmd/gb-vendor). - -To use it, add `gb` to your plugins array: -```sh -plugins=(... gb) -``` - -## Caveats - -The `git` plugin defines an alias `gb` that usually conflicts with the `gb` program. -If you're having trouble with it, remove it by adding `unalias gb` at the end of your -zshrc file. diff --git a/plugins/gb/_gb b/plugins/gb/_gb deleted file mode 100644 index 8148adf16..000000000 --- a/plugins/gb/_gb +++ /dev/null @@ -1,111 +0,0 @@ -#compdef gb -#autoload - -_gb () { - local ret=1 state - _arguments -C ':command:->command' '*::options:->options' && ret=0 - - case $state in - (command) - local -a subcommands - subcommands=( - "build:build a package" - "doc:show documentation for a package or symbol" - "env:print project environment variables" - "generate:generate Go files by processing source" - "help:displays the help" - "info:info returns information about this project" - "list:list the packages named by the importpaths" - "test:test packages" - "vendor:manage your vendored dependencies" - ) - _describe -t subcommands 'gb subcommands' subcommands && ret=0 - ;; - (options) - case $line[1] in - (build) - _arguments \ - -f'[ignore cached packages]' \ - -F'[do not cache packages]' \ - -q'[decreases verbosity]' \ - -P'[the number of build jobs to run in parallel]' \ - -R'[sets the base of the project root search path]' \ - -dotfile'[output a dot formatted file of the build steps]' \ - -ldflags'["flag list" arguments to pass to the linker]' \ - -gcflags'["arg list" arguments to pass to the compiler]' \ - -race'[enable data race detection]' \ - -tags'["tag list" additional build tags]' - ;; - (list) - _arguments \ - -f'[alternate format for the list, using the syntax of package template]' \ - -s'[read format template from STDIN]' \ - -json'[prints output in structured JSON format]' - ;; - (test) - _arguments \ - -v'[print output from test subprocess]' \ - -ldflags'["flag list" arguments to pass to the linker]' \ - -gcflags'["arg list" arguments to pass to the compiler]' \ - -race'[enable data race detection]' \ - -tags'["tag list" additional build tags]' - ;; - (vendor) - _gb-vendor - esac - ;; - esac - - return ret -} - -_gb-vendor () { - local curcontext="$curcontext" state line - _arguments -C ':command:->command' '*::options:->options' - - case $state in - (command) - local -a subcommands - subcommands=( - 'delete:deletes a local dependency' - 'fetch:fetch a remote dependency' - 'list:lists dependencies, one per line' - 'purge:remove all unreferenced dependencies' - 'restore:restore dependencies from the manifest' - 'update:update a local dependency' - ) - _describe -t subcommands 'gb vendor subcommands' subcommands && ret=0 - ;; - (options) - case $line[1] in - (delete) - _arguments \ - -all'[remove all dependencies]' - ;; - (fetch) - _arguments \ - -branch'[fetch from a particular branch]' \ - -no-recurse'[do not fetch recursively]' \ - -tag'[fetch the specified tag]' \ - -revision'[fetch the specific revision from the branch (if supplied)]' \ - -precaire'[allow the use of insecure protocols]' \ - ;; - (list) - _arguments \ - -f'[controls the template used for printing each manifest entry]' - ;; - (restore) - _arguments \ - -precaire'[allow the use of insecure protocols]' - ;; - (update) - _arguments \ - -all'[update all dependencies in the manifest or supply a given dependency]' \ - -precaire'[allow the use of insecure protocols]' - ;; - esac - ;; - esac -} - -_gb From b05d8c3be65091153b4d37cbde9d2ee46f9cba2e Mon Sep 17 00:00:00 2001 From: Roman Danyk <17525890+RomanDanyk@users.noreply.github.com> Date: Tue, 23 Aug 2022 20:23:42 +0300 Subject: [PATCH 021/672] fix(common-aliases): don't overshadow `duf` if installed (#11112) --- plugins/common-aliases/README.md | 7 ++++++- plugins/common-aliases/common-aliases.plugin.zsh | 2 +- 2 files changed, 7 insertions(+), 2 deletions(-) diff --git a/plugins/common-aliases/README.md b/plugins/common-aliases/README.md index 0354c7a3f..1417c3056 100644 --- a/plugins/common-aliases/README.md +++ b/plugins/common-aliases/README.md @@ -35,9 +35,11 @@ plugins=(... common-aliases) | mv | `mv -i` | Move a file | | zshrc | `${=EDITOR} ~/.zshrc` | Quickly access the ~/.zshrc file | | dud | `du -d 1 -h` | Display the size of files at depth 1 in current location in human-readable form | -| duf | `du -sh` | Display the size of files in current location in human-readable form | +| duf\* | `du -sh` | Display the size of files in current location in human-readable form | | t | `tail -f` | Shorthand for tail which outputs the last part of a file | +\* Only if the [`duf`](https://github.com/muesli/duf) command isn't installed. + ### find and grep | Alias | Command | Description | @@ -66,12 +68,15 @@ These aliases are expanded in any position in the command line, meaning you can end of the command you've typed. Examples: Quickly pipe to less: + ```zsh $ ls -l /var/log L # will run $ ls -l /var/log | less ``` + Silences stderr output: + ```zsh $ find . -type f NE # will run diff --git a/plugins/common-aliases/common-aliases.plugin.zsh b/plugins/common-aliases/common-aliases.plugin.zsh index 8b58b6310..3139b821a 100644 --- a/plugins/common-aliases/common-aliases.plugin.zsh +++ b/plugins/common-aliases/common-aliases.plugin.zsh @@ -35,7 +35,7 @@ alias -g NUL="> /dev/null 2>&1" alias -g P="2>&1| pygmentize -l pytb" alias dud='du -d 1 -h' -alias duf='du -sh *' +(( $+commands[duf] )) || alias duf='du -sh *' (( $+commands[fd] )) || alias fd='find . -type d -name' alias ff='find . -type f -name' From 6d48309cd7da1b91038cf08be7865fb5bb9bc5ea Mon Sep 17 00:00:00 2001 From: Erik Thorelli Date: Tue, 23 Aug 2022 10:26:46 -0700 Subject: [PATCH 022/672] chore(react-native): add maintainer for `react-native` plugin (#11109) --- .github/CODEOWNERS | 1 + 1 file changed, 1 insertion(+) diff --git a/.github/CODEOWNERS b/.github/CODEOWNERS index 0cb9410fc..c6b3e8ce9 100644 --- a/.github/CODEOWNERS +++ b/.github/CODEOWNERS @@ -4,6 +4,7 @@ plugins/aws/ @maksyms plugins/genpass/ @atoponce plugins/git-lfs/ @hellovietduc plugins/gitfast/ @felipec +plugins/react-native @esthor plugins/sdk/ @rgoldberg plugins/shell-proxy/ @septs plugins/universalarchive/ @Konfekt From 875a4553204679cc1e3023a7d0e0bf2cf7d60800 Mon Sep 17 00:00:00 2001 From: Monson Shao Date: Thu, 8 Sep 2022 01:03:45 +0800 Subject: [PATCH 023/672] perf: `zrecompile` the compdump file to speed up startup (#8802) --- oh-my-zsh.sh | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/oh-my-zsh.sh b/oh-my-zsh.sh index 925ee46aa..d6ef97a07 100644 --- a/oh-my-zsh.sh +++ b/oh-my-zsh.sh @@ -67,7 +67,7 @@ fi fpath=("$ZSH/functions" "$ZSH/completions" $fpath) # Load all stock functions (from $fpath files) called below. -autoload -U compaudit compinit +autoload -U compaudit compinit zrecompile # Set ZSH_CUSTOM to the path where your custom config files # and plugins exists, or else we will use the default custom/ @@ -142,6 +142,9 @@ EOF fi unset zcompdump_revision zcompdump_fpath zcompdump_refresh +# zcompile the completion dump file if the .zwc is older or missing. +zrecompile -q -p "$ZSH_COMPDUMP" && rm -f "$ZSH_COMPDUMP.zwc.old" + # Load all of the config files in ~/oh-my-zsh that end in .zsh # TIP: Add files you don't want in git to .gitignore for config_file ("$ZSH"/lib/*.zsh); do From 18d2152798e15898f3c11a2fd3d8a59a62b4ac33 Mon Sep 17 00:00:00 2001 From: James Yeoman Date: Tue, 26 Apr 2022 11:37:42 +0100 Subject: [PATCH 024/672] feat(gcloud): support for official apt repo (#10889) Fixes #10888 Closes #10889 --- plugins/gcloud/gcloud.plugin.zsh | 20 +++++++++++++++++--- 1 file changed, 17 insertions(+), 3 deletions(-) diff --git a/plugins/gcloud/gcloud.plugin.zsh b/plugins/gcloud/gcloud.plugin.zsh index 7368eb3a6..d43c62178 100644 --- a/plugins/gcloud/gcloud.plugin.zsh +++ b/plugins/gcloud/gcloud.plugin.zsh @@ -10,7 +10,8 @@ if [[ -z "${CLOUDSDK_HOME}" ]]; then "/opt/homebrew/Caskroom/google-cloud-sdk/latest/google-cloud-sdk" "/usr/share/google-cloud-sdk" "/snap/google-cloud-sdk/current" - "/usr/lib64/google-cloud-sdk/" + "/usr/lib/google-cloud-sdk" + "/usr/lib64/google-cloud-sdk" "/opt/google-cloud-sdk" ) @@ -20,15 +21,28 @@ if [[ -z "${CLOUDSDK_HOME}" ]]; then break fi done + unset search_locations gcloud_sdk_location fi if (( ${+CLOUDSDK_HOME} )); then + # Only source this if gcloud isn't already on the path if (( ! $+commands[gcloud] )); then - # Only source this if GCloud isn't already on the path if [[ -f "${CLOUDSDK_HOME}/path.zsh.inc" ]]; then source "${CLOUDSDK_HOME}/path.zsh.inc" fi fi - source "${CLOUDSDK_HOME}/completion.zsh.inc" + + # Look for completion file in different paths + for comp_file ( + "${CLOUDSDK_HOME}/completion.zsh.inc" # default location + "/usr/share/google-cloud-sdk/completion.zsh.inc" # apt-based location + ); do + if [[ -f "${comp_file}" ]]; then + source "${comp_file}" + break + fi + done + unset comp_file + export CLOUDSDK_HOME fi From dfa88b4d369f6afc7205af0b399a0ef05a4bef2e Mon Sep 17 00:00:00 2001 From: ajilty Date: Thu, 25 Aug 2022 22:02:35 -0400 Subject: [PATCH 025/672] feat(gcloud): support macports installation path (#11133) Closes #11133 --- plugins/gcloud/gcloud.plugin.zsh | 1 + 1 file changed, 1 insertion(+) diff --git a/plugins/gcloud/gcloud.plugin.zsh b/plugins/gcloud/gcloud.plugin.zsh index d43c62178..9be9d68aa 100644 --- a/plugins/gcloud/gcloud.plugin.zsh +++ b/plugins/gcloud/gcloud.plugin.zsh @@ -13,6 +13,7 @@ if [[ -z "${CLOUDSDK_HOME}" ]]; then "/usr/lib/google-cloud-sdk" "/usr/lib64/google-cloud-sdk" "/opt/google-cloud-sdk" + "/opt/local/libexec/google-cloud-sdk" ) for gcloud_sdk_location in $search_locations; do From 7dcabbe6826073ef6069c8a4b6f9a943f00d2df0 Mon Sep 17 00:00:00 2001 From: Giovanni Squillero Date: Sat, 10 Sep 2022 16:57:23 +0200 Subject: [PATCH 026/672] chore(init): ignore any aliases when running `rm` (#11156) --- oh-my-zsh.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/oh-my-zsh.sh b/oh-my-zsh.sh index d6ef97a07..29d39ca23 100644 --- a/oh-my-zsh.sh +++ b/oh-my-zsh.sh @@ -143,7 +143,7 @@ fi unset zcompdump_revision zcompdump_fpath zcompdump_refresh # zcompile the completion dump file if the .zwc is older or missing. -zrecompile -q -p "$ZSH_COMPDUMP" && rm -f "$ZSH_COMPDUMP.zwc.old" +zrecompile -q -p "$ZSH_COMPDUMP" && command rm -f "$ZSH_COMPDUMP.zwc.old" # Load all of the config files in ~/oh-my-zsh that end in .zsh # TIP: Add files you don't want in git to .gitignore From 74235e8aea0c3447871791ed56e7d0131586a057 Mon Sep 17 00:00:00 2001 From: Preet Patel Date: Tue, 4 Oct 2022 03:22:18 +1300 Subject: [PATCH 027/672] feat(react-native): add aliases for 2021 and 2022 iOS devices (#11191) --- plugins/react-native/README.md | 139 ++++++++++--------- plugins/react-native/react-native.plugin.zsh | 10 +- 2 files changed, 85 insertions(+), 64 deletions(-) diff --git a/plugins/react-native/README.md b/plugins/react-native/README.md index d0a53b8d7..88fa233b7 100644 --- a/plugins/react-native/README.md +++ b/plugins/react-native/README.md @@ -11,66 +11,79 @@ plugins=(... react-native) ## Aliases -| Alias | React Native command | -| :------------ | :------------------------------------------------- | -| **rn** | `react-native` | -| **rns** | `react-native start` | -| **rnlink** | `react-native link` | -| _Logging_ | | -| **rnland** | `react-native log-android` | -| **rnlios** | `react-native log-ios` | -| _App Testing_ | | -| **rnand** | `react-native run-android` | -| **rnios** | `react-native run-ios` | -| _iPhone_ | | -| **rnios4s** | `react-native run-ios --simulator "iPhone 4s"` | -| **rnios5** | `react-native run-ios --simulator "iPhone 5"` | -| **rnios5s** | `react-native run-ios --simulator "iPhone 5s"` | -| **rnios6** | `react-native run-ios --simulator "iPhone 6"` | -| **rnios6s** | `react-native run-ios --simulator "iPhone 6s"` | -| **rnios6p** | `react-native run-ios --simulator "iPhone 6 Plus"` | -| **rnios6sp** | `react-native run-ios --simulator "iPhone 6s Plus"` | -| **rnios7** | `react-native run-ios --simulator "iPhone 7"` | -| **rnios7p** | `react-native run-ios --simulator "iPhone 7 Plus"` | -| **rnios8** | `react-native run-ios --simulator "iPhone 8"` | -| **rnios8p** | `react-native run-ios --simulator "iPhone 8 Plus"` | -| **rniosse** | `react-native run-ios --simulator "iPhone SE"` | -| **rniosx** | `react-native run-ios --simulator "iPhone X"` | -| **rniosxs** | `react-native run-ios --simulator "iPhone Xs"` | -| **rniosxsm** | `react-native run-ios --simulator "iPhone Xs Max"` | -| **rniosxr** | `react-native run-ios --simulator "iPhone Xʀ"` | -| **rnios11** | `react-native run-ios --simulator "iPhone 11"` | -| **rnios11p** | `react-native run-ios --simulator "iPhone 11 Pro"` | -| **rnios11pm** | `react-native run-ios --simulator "iPhone 11 Pro Max"` | -| _iPad_ | | -| **rnipad2** | `react-native run-ios --simulator "iPad 2"` | -| **rnipad5** | `react-native run-ios --simulator "iPad (5th generation)"` | -| **rnipad6** | `react-native run-ios --simulator "iPad (6th generation)"` | -| **rnipadr** | `react-native run-ios --simulator "iPad Retina"` | -| **rnipada** | `react-native run-ios --simulator "iPad Air"` | -| **rnipada2** | `react-native run-ios --simulator "iPad Air 2"` | -| **rnipada3** | `react-native run-ios --simulator "iPad Air (3rd generation)"` | -| **rnipadm2** | `react-native run-ios --simulator "iPad mini 2"` | -| **rnipadm3** | `react-native run-ios --simulator "iPad mini 3"` | -| **rnipadm4** | `react-native run-ios --simulator "iPad mini 4"` | -| **rnipadm5** | `react-native run-ios --simulator "iPad mini (5th generation)"` | -| **rnipadp9** | `react-native run-ios --simulator "iPad Pro (9.7-inch)"` | -| **rnipadp12** | `react-native run-ios --simulator "iPad Pro (12.9-inch)"` | -| **rnipadp122** | `react-native run-ios --simulator "iPad Pro (12.9-inch) (2nd generation)"` | -| **rnipadp10** | `react-native run-ios --simulator "iPad Pro (10.5-inch)"` | -| **rnipad11** | `react-native run-ios --simulator "iPad Pro (11-inch)"` | -| **rnipad123** | `react-native run-ios --simulator "iPad Pro (12.9-inch) (3rd generation)"` | -| _Apple TV_ | | -| **rnatv** | `react-native run-ios --simulator "Apple TV"` | -| **rnatv4k** | `react-native run-ios --simulator "Apple TV 4K"` | -| **rnatv4k1080**| `react-native run-ios --simulator "Apple TV 4K (at 1080p)"` | -| **rnipad123** | `react-native run-ios --simulator "iPad Pro (12.9-inch) (3rd generation)"` | -| _Apple Watch_ | | -| **rnaw38** | `react-native run-ios --simulator "Apple Watch - 38mm"` | -| **rnaw42** | `react-native run-ios --simulator "Apple Watch - 42mm"` | -| **rnaws238** | `react-native run-ios --simulator "Apple Watch Series 2 - 38mm"` | -| **rnaws242** | `react-native run-ios --simulator "Apple Watch Series 2 - 42mm"` | -| **rnaws338** | `react-native run-ios --simulator "Apple Watch Series 3 - 38mm"` | -| **rnaws342** | `react-native run-ios --simulator "Apple Watch Series 3 - 42mm"` | -| **rnaws440** | `react-native run-ios --simulator "Apple Watch Series 4 - 40mm"` | -| **rnaws444** | `react-native run-ios --simulator "Apple Watch Series 4 - 44mm"` | +| Alias | React Native command | +| :------------ | :----------------------------------------------------- | +| **rn** | `react-native` | +| **rns** | `react-native start` | +| **rnlink** | `react-native link` | +| _Logging_ | | +| **rnland** | `react-native log-android` | +| **rnlios** | `react-native log-ios` | +| _App Testing_ | | +| **rnand** | `react-native run-android` | +| **rnios** | `react-native run-ios` | +| _iPhone_ | | +| **rnios4s** | `react-native run-ios --simulator "iPhone 4s"` | +| **rnios5** | `react-native run-ios --simulator "iPhone 5"` | +| **rnios5s** | `react-native run-ios --simulator "iPhone 5s"` | +| **rnios6** | `react-native run-ios --simulator "iPhone 6"` | +| **rnios6s** | `react-native run-ios --simulator "iPhone 6s"` | +| **rnios6p** | `react-native run-ios --simulator "iPhone 6 Plus"` | +| **rnios6sp** | `react-native run-ios --simulator "iPhone 6s Plus"` | +| **rnios7** | `react-native run-ios --simulator "iPhone 7"` | +| **rnios7p** | `react-native run-ios --simulator "iPhone 7 Plus"` | +| **rnios8** | `react-native run-ios --simulator "iPhone 8"` | +| **rnios8p** | `react-native run-ios --simulator "iPhone 8 Plus"` | +| **rniosse** | `react-native run-ios --simulator "iPhone SE"` | +| **rniosx** | `react-native run-ios --simulator "iPhone X"` | +| **rniosxs** | `react-native run-ios --simulator "iPhone Xs"` | +| **rniosxsm** | `react-native run-ios --simulator "iPhone Xs Max"` | +| **rniosxr** | `react-native run-ios --simulator "iPhone Xʀ"` | +| **rnios11** | `react-native run-ios --simulator "iPhone 11"` | +| **rnios11p** | `react-native run-ios --simulator "iPhone 11 Pro"` | +| **rnios11pm** | `react-native run-ios --simulator "iPhone 11 Pro Max"` | +| **rnios12** | `react-native run-ios --simulator "iPhone 12"` | +| **rnios12m** | `react-native run-ios --simulator "iPhone 12 mini"` | +| **rnios12p** | `react-native run-ios --simulator "iPhone 12 Pro"` | +| **rnios12pm** | `react-native run-ios --simulator "iPhone 12 Pro Max"` | +| **rnios13** | `react-native run-ios --simulator "iPhone 13"` | +| **rnios13m** | `react-native run-ios --simulator "iPhone 13 mini"` | +| **rnios13p** | `react-native run-ios --simulator "iPhone 13 Pro"` | +| **rnios13pm** | `react-native run-ios --simulator "iPhone 13 Pro Max"` | +| **rnios14** | `react-native run-ios --simulator "iPhone 14"` | +| **rnios14pl** | `react-native run-ios --simulator "iPhone 14 Plus"` | +| **rnios14p** | `react-native run-ios --simulator "iPhone 14 Pro"` | +| **rnios14pm** | `react-native run-ios --simulator "iPhone 14 Pro Max"` | + +| _iPad_ | | +| **rnipad2** | `react-native run-ios --simulator "iPad 2"` | +| **rnipad5** | `react-native run-ios --simulator "iPad (5th generation)"` | +| **rnipad6** | `react-native run-ios --simulator "iPad (6th generation)"` | +| **rnipadr** | `react-native run-ios --simulator "iPad Retina"` | +| **rnipada** | `react-native run-ios --simulator "iPad Air"` | +| **rnipada2** | `react-native run-ios --simulator "iPad Air 2"` | +| **rnipada3** | `react-native run-ios --simulator "iPad Air (3rd generation)"` | +| **rnipadm2** | `react-native run-ios --simulator "iPad mini 2"` | +| **rnipadm3** | `react-native run-ios --simulator "iPad mini 3"` | +| **rnipadm4** | `react-native run-ios --simulator "iPad mini 4"` | +| **rnipadm5** | `react-native run-ios --simulator "iPad mini (5th generation)"` | +| **rnipadp9** | `react-native run-ios --simulator "iPad Pro (9.7-inch)"` | +| **rnipadp12** | `react-native run-ios --simulator "iPad Pro (12.9-inch)"` | +| **rnipadp122** | `react-native run-ios --simulator "iPad Pro (12.9-inch) (2nd generation)"` | +| **rnipadp10** | `react-native run-ios --simulator "iPad Pro (10.5-inch)"` | +| **rnipad11** | `react-native run-ios --simulator "iPad Pro (11-inch)"` | +| **rnipad123** | `react-native run-ios --simulator "iPad Pro (12.9-inch) (3rd generation)"` | +| _Apple TV_ | | +| **rnatv** | `react-native run-ios --simulator "Apple TV"` | +| **rnatv4k** | `react-native run-ios --simulator "Apple TV 4K"` | +| **rnatv4k1080**| `react-native run-ios --simulator "Apple TV 4K (at 1080p)"` | +| **rnipad123** | `react-native run-ios --simulator "iPad Pro (12.9-inch) (3rd generation)"` | +| _Apple Watch_ | | +| **rnaw38** | `react-native run-ios --simulator "Apple Watch - 38mm"` | +| **rnaw42** | `react-native run-ios --simulator "Apple Watch - 42mm"` | +| **rnaws238** | `react-native run-ios --simulator "Apple Watch Series 2 - 38mm"` | +| **rnaws242** | `react-native run-ios --simulator "Apple Watch Series 2 - 42mm"` | +| **rnaws338** | `react-native run-ios --simulator "Apple Watch Series 3 - 38mm"` | +| **rnaws342** | `react-native run-ios --simulator "Apple Watch Series 3 - 42mm"` | +| **rnaws440** | `react-native run-ios --simulator "Apple Watch Series 4 - 40mm"` | +| **rnaws444** | `react-native run-ios --simulator "Apple Watch Series 4 - 44mm"` | diff --git a/plugins/react-native/react-native.plugin.zsh b/plugins/react-native/react-native.plugin.zsh index 8323c27bd..afeaab4fd 100644 --- a/plugins/react-native/react-native.plugin.zsh +++ b/plugins/react-native/react-native.plugin.zsh @@ -28,9 +28,17 @@ alias rnios11='react-native run-ios --simulator "iPhone 11"' alias rnios11p='react-native run-ios --simulator "iPhone 11 Pro"' alias rnios11pm='react-native run-ios --simulator "iPhone 11 Pro Max"' alias rnios12='react-native run-ios --simulator "iPhone 12"' +alias rnios12m='react-native run-ios --simulator "iPhone 12 mini"' alias rnios12p='react-native run-ios --simulator "iPhone 12 Pro"' alias rnios12pm='react-native run-ios --simulator "iPhone 12 Pro Max"' - +alias rnios13='react-native run-ios --simulator "iPhone 13"' +alias rnios13m='react-native run-ios --simulator "iPhone 13 mini"' +alias rnios13p='react-native run-ios --simulator "iPhone 13 Pro"' +alias rnios13pm='react-native run-ios --simulator "iPhone 13 Pro Max"' +alias rnios14='react-native run-ios --simulator "iPhone 14"' +alias rnios14pl='react-native run-ios --simulator "iPhone 14 Plus"' +alias rnios14p='react-native run-ios --simulator "iPhone 14 Pro"' +alias rnios14pm='react-native run-ios --simulator "iPhone 14 Pro Max"' # iPad alias rnipad2='react-native run-ios --simulator "iPad 2"' From 23f3ded92d07184b3611d08c62d7b474a76c956f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Mon, 3 Oct 2022 16:24:15 +0200 Subject: [PATCH 028/672] chore(react-native): fix README table alignment --- plugins/react-native/README.md | 151 ++++++++++++++++----------------- 1 file changed, 75 insertions(+), 76 deletions(-) diff --git a/plugins/react-native/README.md b/plugins/react-native/README.md index 88fa233b7..807c063a5 100644 --- a/plugins/react-native/README.md +++ b/plugins/react-native/README.md @@ -11,79 +11,78 @@ plugins=(... react-native) ## Aliases -| Alias | React Native command | -| :------------ | :----------------------------------------------------- | -| **rn** | `react-native` | -| **rns** | `react-native start` | -| **rnlink** | `react-native link` | -| _Logging_ | | -| **rnland** | `react-native log-android` | -| **rnlios** | `react-native log-ios` | -| _App Testing_ | | -| **rnand** | `react-native run-android` | -| **rnios** | `react-native run-ios` | -| _iPhone_ | | -| **rnios4s** | `react-native run-ios --simulator "iPhone 4s"` | -| **rnios5** | `react-native run-ios --simulator "iPhone 5"` | -| **rnios5s** | `react-native run-ios --simulator "iPhone 5s"` | -| **rnios6** | `react-native run-ios --simulator "iPhone 6"` | -| **rnios6s** | `react-native run-ios --simulator "iPhone 6s"` | -| **rnios6p** | `react-native run-ios --simulator "iPhone 6 Plus"` | -| **rnios6sp** | `react-native run-ios --simulator "iPhone 6s Plus"` | -| **rnios7** | `react-native run-ios --simulator "iPhone 7"` | -| **rnios7p** | `react-native run-ios --simulator "iPhone 7 Plus"` | -| **rnios8** | `react-native run-ios --simulator "iPhone 8"` | -| **rnios8p** | `react-native run-ios --simulator "iPhone 8 Plus"` | -| **rniosse** | `react-native run-ios --simulator "iPhone SE"` | -| **rniosx** | `react-native run-ios --simulator "iPhone X"` | -| **rniosxs** | `react-native run-ios --simulator "iPhone Xs"` | -| **rniosxsm** | `react-native run-ios --simulator "iPhone Xs Max"` | -| **rniosxr** | `react-native run-ios --simulator "iPhone Xʀ"` | -| **rnios11** | `react-native run-ios --simulator "iPhone 11"` | -| **rnios11p** | `react-native run-ios --simulator "iPhone 11 Pro"` | -| **rnios11pm** | `react-native run-ios --simulator "iPhone 11 Pro Max"` | -| **rnios12** | `react-native run-ios --simulator "iPhone 12"` | -| **rnios12m** | `react-native run-ios --simulator "iPhone 12 mini"` | -| **rnios12p** | `react-native run-ios --simulator "iPhone 12 Pro"` | -| **rnios12pm** | `react-native run-ios --simulator "iPhone 12 Pro Max"` | -| **rnios13** | `react-native run-ios --simulator "iPhone 13"` | -| **rnios13m** | `react-native run-ios --simulator "iPhone 13 mini"` | -| **rnios13p** | `react-native run-ios --simulator "iPhone 13 Pro"` | -| **rnios13pm** | `react-native run-ios --simulator "iPhone 13 Pro Max"` | -| **rnios14** | `react-native run-ios --simulator "iPhone 14"` | -| **rnios14pl** | `react-native run-ios --simulator "iPhone 14 Plus"` | -| **rnios14p** | `react-native run-ios --simulator "iPhone 14 Pro"` | -| **rnios14pm** | `react-native run-ios --simulator "iPhone 14 Pro Max"` | - -| _iPad_ | | -| **rnipad2** | `react-native run-ios --simulator "iPad 2"` | -| **rnipad5** | `react-native run-ios --simulator "iPad (5th generation)"` | -| **rnipad6** | `react-native run-ios --simulator "iPad (6th generation)"` | -| **rnipadr** | `react-native run-ios --simulator "iPad Retina"` | -| **rnipada** | `react-native run-ios --simulator "iPad Air"` | -| **rnipada2** | `react-native run-ios --simulator "iPad Air 2"` | -| **rnipada3** | `react-native run-ios --simulator "iPad Air (3rd generation)"` | -| **rnipadm2** | `react-native run-ios --simulator "iPad mini 2"` | -| **rnipadm3** | `react-native run-ios --simulator "iPad mini 3"` | -| **rnipadm4** | `react-native run-ios --simulator "iPad mini 4"` | -| **rnipadm5** | `react-native run-ios --simulator "iPad mini (5th generation)"` | -| **rnipadp9** | `react-native run-ios --simulator "iPad Pro (9.7-inch)"` | -| **rnipadp12** | `react-native run-ios --simulator "iPad Pro (12.9-inch)"` | -| **rnipadp122** | `react-native run-ios --simulator "iPad Pro (12.9-inch) (2nd generation)"` | -| **rnipadp10** | `react-native run-ios --simulator "iPad Pro (10.5-inch)"` | -| **rnipad11** | `react-native run-ios --simulator "iPad Pro (11-inch)"` | -| **rnipad123** | `react-native run-ios --simulator "iPad Pro (12.9-inch) (3rd generation)"` | -| _Apple TV_ | | -| **rnatv** | `react-native run-ios --simulator "Apple TV"` | -| **rnatv4k** | `react-native run-ios --simulator "Apple TV 4K"` | -| **rnatv4k1080**| `react-native run-ios --simulator "Apple TV 4K (at 1080p)"` | -| **rnipad123** | `react-native run-ios --simulator "iPad Pro (12.9-inch) (3rd generation)"` | -| _Apple Watch_ | | -| **rnaw38** | `react-native run-ios --simulator "Apple Watch - 38mm"` | -| **rnaw42** | `react-native run-ios --simulator "Apple Watch - 42mm"` | -| **rnaws238** | `react-native run-ios --simulator "Apple Watch Series 2 - 38mm"` | -| **rnaws242** | `react-native run-ios --simulator "Apple Watch Series 2 - 42mm"` | -| **rnaws338** | `react-native run-ios --simulator "Apple Watch Series 3 - 38mm"` | -| **rnaws342** | `react-native run-ios --simulator "Apple Watch Series 3 - 42mm"` | -| **rnaws440** | `react-native run-ios --simulator "Apple Watch Series 4 - 40mm"` | -| **rnaws444** | `react-native run-ios --simulator "Apple Watch Series 4 - 44mm"` | +| Alias | React Native command | +| :-------------- | :------------------------------------------------------------------------- | +| **rn** | `react-native` | +| **rns** | `react-native start` | +| **rnlink** | `react-native link` | +| _Logging_ | | +| **rnland** | `react-native log-android` | +| **rnlios** | `react-native log-ios` | +| _App Testing_ | | +| **rnand** | `react-native run-android` | +| **rnios** | `react-native run-ios` | +| _iPhone_ | | +| **rnios4s** | `react-native run-ios --simulator "iPhone 4s"` | +| **rnios5** | `react-native run-ios --simulator "iPhone 5"` | +| **rnios5s** | `react-native run-ios --simulator "iPhone 5s"` | +| **rnios6** | `react-native run-ios --simulator "iPhone 6"` | +| **rnios6s** | `react-native run-ios --simulator "iPhone 6s"` | +| **rnios6p** | `react-native run-ios --simulator "iPhone 6 Plus"` | +| **rnios6sp** | `react-native run-ios --simulator "iPhone 6s Plus"` | +| **rnios7** | `react-native run-ios --simulator "iPhone 7"` | +| **rnios7p** | `react-native run-ios --simulator "iPhone 7 Plus"` | +| **rnios8** | `react-native run-ios --simulator "iPhone 8"` | +| **rnios8p** | `react-native run-ios --simulator "iPhone 8 Plus"` | +| **rniosse** | `react-native run-ios --simulator "iPhone SE"` | +| **rniosx** | `react-native run-ios --simulator "iPhone X"` | +| **rniosxs** | `react-native run-ios --simulator "iPhone Xs"` | +| **rniosxsm** | `react-native run-ios --simulator "iPhone Xs Max"` | +| **rniosxr** | `react-native run-ios --simulator "iPhone Xʀ"` | +| **rnios11** | `react-native run-ios --simulator "iPhone 11"` | +| **rnios11p** | `react-native run-ios --simulator "iPhone 11 Pro"` | +| **rnios11pm** | `react-native run-ios --simulator "iPhone 11 Pro Max"` | +| **rnios12** | `react-native run-ios --simulator "iPhone 12"` | +| **rnios12m** | `react-native run-ios --simulator "iPhone 12 mini"` | +| **rnios12p** | `react-native run-ios --simulator "iPhone 12 Pro"` | +| **rnios12pm** | `react-native run-ios --simulator "iPhone 12 Pro Max"` | +| **rnios13** | `react-native run-ios --simulator "iPhone 13"` | +| **rnios13m** | `react-native run-ios --simulator "iPhone 13 mini"` | +| **rnios13p** | `react-native run-ios --simulator "iPhone 13 Pro"` | +| **rnios13pm** | `react-native run-ios --simulator "iPhone 13 Pro Max"` | +| **rnios14** | `react-native run-ios --simulator "iPhone 14"` | +| **rnios14pl** | `react-native run-ios --simulator "iPhone 14 Plus"` | +| **rnios14p** | `react-native run-ios --simulator "iPhone 14 Pro"` | +| **rnios14pm** | `react-native run-ios --simulator "iPhone 14 Pro Max"` | +| _iPad_ | | +| **rnipad2** | `react-native run-ios --simulator "iPad 2"` | +| **rnipad5** | `react-native run-ios --simulator "iPad (5th generation)"` | +| **rnipad6** | `react-native run-ios --simulator "iPad (6th generation)"` | +| **rnipadr** | `react-native run-ios --simulator "iPad Retina"` | +| **rnipada** | `react-native run-ios --simulator "iPad Air"` | +| **rnipada2** | `react-native run-ios --simulator "iPad Air 2"` | +| **rnipada3** | `react-native run-ios --simulator "iPad Air (3rd generation)"` | +| **rnipadm2** | `react-native run-ios --simulator "iPad mini 2"` | +| **rnipadm3** | `react-native run-ios --simulator "iPad mini 3"` | +| **rnipadm4** | `react-native run-ios --simulator "iPad mini 4"` | +| **rnipadm5** | `react-native run-ios --simulator "iPad mini (5th generation)"` | +| **rnipadp9** | `react-native run-ios --simulator "iPad Pro (9.7-inch)"` | +| **rnipadp12** | `react-native run-ios --simulator "iPad Pro (12.9-inch)"` | +| **rnipadp122** | `react-native run-ios --simulator "iPad Pro (12.9-inch) (2nd generation)"` | +| **rnipadp10** | `react-native run-ios --simulator "iPad Pro (10.5-inch)"` | +| **rnipad11** | `react-native run-ios --simulator "iPad Pro (11-inch)"` | +| **rnipad123** | `react-native run-ios --simulator "iPad Pro (12.9-inch) (3rd generation)"` | +| _Apple TV_ | | +| **rnatv** | `react-native run-ios --simulator "Apple TV"` | +| **rnatv4k** | `react-native run-ios --simulator "Apple TV 4K"` | +| **rnatv4k1080** | `react-native run-ios --simulator "Apple TV 4K (at 1080p)"` | +| **rnipad123** | `react-native run-ios --simulator "iPad Pro (12.9-inch) (3rd generation)"` | +| _Apple Watch_ | | +| **rnaw38** | `react-native run-ios --simulator "Apple Watch - 38mm"` | +| **rnaw42** | `react-native run-ios --simulator "Apple Watch - 42mm"` | +| **rnaws238** | `react-native run-ios --simulator "Apple Watch Series 2 - 38mm"` | +| **rnaws242** | `react-native run-ios --simulator "Apple Watch Series 2 - 42mm"` | +| **rnaws338** | `react-native run-ios --simulator "Apple Watch Series 3 - 38mm"` | +| **rnaws342** | `react-native run-ios --simulator "Apple Watch Series 3 - 42mm"` | +| **rnaws440** | `react-native run-ios --simulator "Apple Watch Series 4 - 40mm"` | +| **rnaws444** | `react-native run-ios --simulator "Apple Watch Series 4 - 44mm"` | From 1c879f67b4380f0705ee1bc578d5aab53bf192a4 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Mon, 3 Oct 2022 16:58:42 +0200 Subject: [PATCH 029/672] fix(ssh-agent): silence `ssh-add` if quiet mode is enabled (#11201) Fixes #11201 --- plugins/ssh-agent/ssh-agent.plugin.zsh | 3 +++ 1 file changed, 3 insertions(+) diff --git a/plugins/ssh-agent/ssh-agent.plugin.zsh b/plugins/ssh-agent/ssh-agent.plugin.zsh index 0d6a35b35..78ac46b13 100644 --- a/plugins/ssh-agent/ssh-agent.plugin.zsh +++ b/plugins/ssh-agent/ssh-agent.plugin.zsh @@ -72,6 +72,9 @@ function _add_identities() { local args zstyle -a :omz:plugins:ssh-agent ssh-add-args args + # if ssh-agent quiet mode, pass -q to ssh-add + zstyle -t :omz:plugins:ssh-agent quiet && args=(-q $args) + # use user specified helper to ask for password (ksshaskpass, etc) local helper zstyle -s :omz:plugins:ssh-agent helper helper From e0e22d112013aee22635b6afe4c2c9d1bf88cbf0 Mon Sep 17 00:00:00 2001 From: George Rodrigues Date: Mon, 3 Oct 2022 12:03:53 -0300 Subject: [PATCH 030/672] chore(docs): fix some typos (#11211) --- plugins/emoji/update_emoji.py | 4 ++-- plugins/lpass/_lpass | 2 +- plugins/ng/_ng | 2 +- plugins/pm2/_pm2 | 2 +- plugins/salt/_salt | 2 +- plugins/swiftpm/_swift | 2 +- plugins/systemadmin/README.md | 2 +- plugins/terraform/_terraform | 2 +- tools/require_tool.sh | 2 +- 9 files changed, 10 insertions(+), 10 deletions(-) diff --git a/plugins/emoji/update_emoji.py b/plugins/emoji/update_emoji.py index eb945b9ef..18b3c060d 100644 --- a/plugins/emoji/update_emoji.py +++ b/plugins/emoji/update_emoji.py @@ -56,7 +56,7 @@ typeset -gAH emoji_groups # def country_iso(_all_names, _omz_name): # """ Using the external library country_converter, -# this funciton can detect the ISO2 and ISO3 codes +# this function can detect the ISO2 and ISO3 codes # of the country. It takes as argument the array # with all the names of the emoji, and returns that array.""" # omz_no_underscore = re.sub(r'_', r' ', _omz_name) @@ -96,7 +96,7 @@ def name_to_omz(_name, _group, _subgroup, _status): # Special treatment by status # Enables us to have every emoji combination, # even the one that are not officially sanctionned - # and are implemeted by, say, only one vendor + # and are implemented by, say, only one vendor if _status == "unqualified": shortname += "_unqualified" elif _status == "minimally-qualified": diff --git a/plugins/lpass/_lpass b/plugins/lpass/_lpass index e6193a22d..621a7bcd7 100644 --- a/plugins/lpass/_lpass +++ b/plugins/lpass/_lpass @@ -106,7 +106,7 @@ _lpass() { generic_options+=('--color=[Color: auto | never | always]') fi if [ "$has_interactive" -eq 1 ]; then - generic_options+=("--non-interactive[Use stardard input instead of $EDITOR]") + generic_options+=("--non-interactive[Use standard input instead of $EDITOR]") fi _arguments $generic_options fi diff --git a/plugins/ng/_ng b/plugins/ng/_ng index 9c96cf7e3..86c6ce187 100644 --- a/plugins/ng/_ng +++ b/plugins/ng/_ng @@ -46,7 +46,7 @@ elif (( CURRENT == 3 )); then # ... # } # } - # In abscence of a proper JSON parser, just grab the lines with + # In absence of a proper JSON parser, just grab the lines with # a 2-space indentation and only the stuff inside quotes local -a projects projects=(${(@f)"$(ng config projects 2>/dev/null | sed -n 's/^ "\([^"]\+\)".*$/\1/p')"}) diff --git a/plugins/pm2/_pm2 b/plugins/pm2/_pm2 index 86412aef1..faa6a3404 100644 --- a/plugins/pm2/_pm2 +++ b/plugins/pm2/_pm2 @@ -118,7 +118,7 @@ start_options=( ) logs_options=( '--json[json log output]' - '--format[formated log output]' + '--format[formatted log output]' '--raw[raw output]' '--err[only shows error output]' '--out[only shows standard output]' diff --git a/plugins/salt/_salt b/plugins/salt/_salt index a1c55f350..589d21d8b 100644 --- a/plugins/salt/_salt +++ b/plugins/salt/_salt @@ -9,7 +9,7 @@ # zstyle ':completion::complete:salt(|-call):modules:' use-cache true # zstyle ':completion::complete:salt(|-cp|-call|-run|-key):salt_dir:' use-cache true # -# cache validation can be controled with the style cache-ttl. +# cache validation can be controlled with the style cache-ttl. # it expects two arguments: number (days|hours|weeks|months) # to invalidate the minion cache after four days: # zstyle ':completion::complete:salt(|-cp|-call):minions:' cache-ttl 4 days diff --git a/plugins/swiftpm/_swift b/plugins/swiftpm/_swift index fe6f1c9aa..3a923226d 100644 --- a/plugins/swiftpm/_swift +++ b/plugins/swiftpm/_swift @@ -301,7 +301,7 @@ _swift_package_init() { _swift_package_unedit() { arguments=( ":The name of the package to unedit:_swift_dependency" - "--force[Unedit the package even if it has uncommited and unpushed changes.]" + "--force[Unedit the package even if it has uncommitted and unpushed changes.]" ) _arguments $arguments && return } diff --git a/plugins/systemadmin/README.md b/plugins/systemadmin/README.md index 146b58605..3a9d9de66 100644 --- a/plugins/systemadmin/README.md +++ b/plugins/systemadmin/README.md @@ -41,7 +41,7 @@ plugins=(... systemadmin) | accessip10 | List the top 10 accesses to the ip address in the nginx/access.log file or another log file if specified | | visitpage20 | List the top 20 most visited files or pages in the nginx/access.log file or another log file if specified | | consume100 | List the 100 most time-consuming Page lists (more than 60 seconds) as well as the corresponding number of occurrences | -| webtraffic | List website traffic statistics in GB from tne nginx/access.log file or another log file if specified | +| webtraffic | List website traffic statistics in GB from the nginx/access.log file or another log file if specified | | c404 | List statistics on 404 connections in the nginx/access.log file or another log file if specified | | httpstatus | List statistics based on http status in the nginx/access.log file or another log file if specified | | d0 | Delete 0 byte files recursively in the current directory or another if specified | diff --git a/plugins/terraform/_terraform b/plugins/terraform/_terraform index a19e50670..625834563 100644 --- a/plugins/terraform/_terraform +++ b/plugins/terraform/_terraform @@ -47,7 +47,7 @@ __apply() { '-lock=[(true) Lock the state file when locking is supported.]:lock:(true false)' \ '-lock-timeout=[(0s) Duration to retry a state lock.]' \ '-input=[(true) Ask for input for variables if not directly set.]' \ - '-no-color[If specified, output wil be colorless.]' \ + '-no-color[If specified, output will be colorless.]' \ '-parallelism=[(10) Limit the number of parallel resource operations.]' \ '-refresh=[(true) Update state prior to checking for differences. This has no effect if a plan file is given to apply.]' \ '-state=[(terraform.tfstate) Path to read and save state (unless state-out is specified).]:statefile:_files -g "*.tfstate"' \ diff --git a/tools/require_tool.sh b/tools/require_tool.sh index 1fa77f77a..19c5f6fa9 100755 --- a/tools/require_tool.sh +++ b/tools/require_tool.sh @@ -107,7 +107,7 @@ usage() { NAME require_tool.sh - Ensure version of a tool is greater than the one expected -SYNOPSYS +SYNOPSIS require_tool.sh [ -h ] [ --help ] [ TOOL MIN_VERSION ] From b93b67b84490d45eb2544b1741e64dc16103207d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Mon, 3 Oct 2022 17:11:52 +0200 Subject: [PATCH 031/672] fix(gradle): remove deprecated use of `egrep` (#11160) --- plugins/gradle/_gradle | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/gradle/_gradle b/plugins/gradle/_gradle index e77b23cdb..770723d85 100644 --- a/plugins/gradle/_gradle +++ b/plugins/gradle/_gradle @@ -96,7 +96,7 @@ __gradle-generate-script-cache() { zle -R "Generating Gradle build script cache" # Cache all Gradle scripts local -a gradle_build_scripts - gradle_build_scripts=( $(find $project_root_dir -type f -name "*.gradle" -o -name "*.gradle.kts" 2>/dev/null | egrep -v "$script_exclude_pattern") ) + gradle_build_scripts=( $(find $project_root_dir -type f -name "*.gradle" -o -name "*.gradle.kts" 2>/dev/null | grep -E -v "$script_exclude_pattern") ) printf "%s\n" "${gradle_build_scripts[@]}" >| $cache_dir/$cache_name fi } From 570158e464c9f57ab03c4162b4e6853b2c7c650d Mon Sep 17 00:00:00 2001 From: Nadhem Date: Mon, 3 Oct 2022 16:59:49 +0100 Subject: [PATCH 032/672] chore(lib): update deprecated grep aliases (#11161) --- lib/grep.zsh | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/lib/grep.zsh b/lib/grep.zsh index a725e0f26..54e0f694e 100644 --- a/lib/grep.zsh +++ b/lib/grep.zsh @@ -24,8 +24,8 @@ else if [[ -n "$GREP_OPTIONS" ]]; then # export grep, egrep and fgrep settings alias grep="grep $GREP_OPTIONS" - alias egrep="egrep $GREP_OPTIONS" - alias fgrep="fgrep $GREP_OPTIONS" + alias egrep="grep -E $GREP_OPTIONS" + alias fgrep="grep -F $GREP_OPTIONS" # write to cache file if cache directory is writable if [[ -w "$ZSH_CACHE_DIR" ]]; then From 78e85c7d78edeca7f06d6a54ad7f03f10dacde62 Mon Sep 17 00:00:00 2001 From: Carlo Date: Thu, 6 Oct 2022 20:01:56 +0100 Subject: [PATCH 033/672] fix(nvm): source nvm script only when used (#11205) closes #11042 --- plugins/nvm/README.md | 6 +++--- plugins/nvm/nvm.plugin.zsh | 38 ++++++++++++++++---------------------- 2 files changed, 19 insertions(+), 25 deletions(-) diff --git a/plugins/nvm/README.md b/plugins/nvm/README.md index a8bc34ae7..1acf12050 100644 --- a/plugins/nvm/README.md +++ b/plugins/nvm/README.md @@ -22,9 +22,9 @@ These settings should go in your zshrc file, before Oh My Zsh is sourced: nvm has been installed, regardless of chip architecture, use `NVM_HOMEBREW=$(brew --prefix nvm)`. - **`NVM_LAZY`**: if you want the plugin to defer the load of nvm to speed-up the start of your zsh session, - set `NVM_LAZY` to `1`. This will use the `--no-use` parameter when loading nvm, and will create a function - for `node`, `npm`, `yarn`, and the command(s) specified by `NVM_LAZY_CMD`, so when you call either of them, - nvm will load with `nvm use default`. + set `NVM_LAZY` to `1`. This will source nvm script only when using it, and will create a function for `node`, + `npm`, `pnpm`, `yarn`, and the command(s) specified by `NVM_LAZY_CMD`, so when you call either of them, + nvm will be loaded and run with default version. - **`NVM_LAZY_CMD`**: if you want additional command(s) to trigger lazy loading of nvm, set `NVM_LAZY_CMD` to the command or an array of the commands. diff --git a/plugins/nvm/nvm.plugin.zsh b/plugins/nvm/nvm.plugin.zsh index 630854a71..1fb4d238b 100644 --- a/plugins/nvm/nvm.plugin.zsh +++ b/plugins/nvm/nvm.plugin.zsh @@ -4,39 +4,33 @@ if [[ -z "$NVM_DIR" ]]; then export NVM_DIR="$HOME/.nvm" elif [[ -d "${XDG_CONFIG_HOME:-$HOME/.config}/nvm" ]]; then export NVM_DIR="${XDG_CONFIG_HOME:-$HOME/.config}/nvm" + elif (( $+commands[brew] )); then + NVM_HOMEBREW="${NVM_HOMEBREW:-${HOMEBREW_PREFIX:-$(brew --prefix)}/opt/nvm}" + if [[ -d "$NVM_HOMEBREW" ]]; then + export NVM_DIR="$NVM_HOMEBREW" + fi fi fi # Don't try to load nvm if command already available # Note: nvm is a function so we need to use `which` -! which nvm &>/dev/null || return +which nvm &>/dev/null && return -if [[ -f "$NVM_DIR/nvm.sh" ]]; then +if (( $+NVM_LAZY )); then + # Call nvm when first using nvm, node, npm, pnpm, yarn or $NVM_LAZY_CMD + function nvm node npm pnpm yarn $NVM_LAZY_CMD { + unfunction nvm node npm pnpm yarn $NVM_LAZY_CMD + # Load nvm if it exists in $NVM_DIR + [[ -f "$NVM_DIR/nvm.sh" ]] && source "$NVM_DIR/nvm.sh" + "$0" "$@" + } +elif [[ -f "$NVM_DIR/nvm.sh" ]]; then # Load nvm if it exists in $NVM_DIR - source "$NVM_DIR/nvm.sh" ${NVM_LAZY+"--no-use"} -elif (( $+commands[brew] )); then - # Otherwise try to load nvm installed via Homebrew - # User can set this if they have an unusual Homebrew setup - NVM_HOMEBREW="${NVM_HOMEBREW:-${HOMEBREW_PREFIX:-$(brew --prefix)}/opt/nvm}" - # Load nvm from Homebrew location if it exists - if [[ -f "$NVM_HOMEBREW/nvm.sh" ]]; then - source "$NVM_HOMEBREW/nvm.sh" ${NVM_LAZY+"--no-use"} - else - return - fi + source "$NVM_DIR/nvm.sh" else return fi -# Call nvm when first using node, npm or yarn -if (( $+NVM_LAZY )); then - function node npm yarn $NVM_LAZY_CMD { - unfunction node npm yarn $NVM_LAZY_CMD - nvm use default - command "$0" "$@" - } -fi - # Autoload nvm when finding a .nvmrc file in the current directory # Adapted from: https://github.com/nvm-sh/nvm#zsh if (( $+NVM_AUTOLOAD )); then From f52b3c6716b632a439355510d559c9d5522edc7e Mon Sep 17 00:00:00 2001 From: Eddie <36518273+0xEddie@users.noreply.github.com> Date: Fri, 7 Oct 2022 06:31:01 -0600 Subject: [PATCH 034/672] chore(dnote): fix incorrect link (#11237) --- plugins/dnote/README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/dnote/README.md b/plugins/dnote/README.md index e1b9b7044..7b41b9027 100644 --- a/plugins/dnote/README.md +++ b/plugins/dnote/README.md @@ -1,6 +1,6 @@ # Dnote Plugin -This plugin adds auto-completion for [Dnote](https://dnote.io) project. +This plugin adds auto-completion for [Dnote](https://www.getdnote.com/), a simple command line notebook. To use it, add `dnote` to the plugins array in your zshrc file: From 065f5ffc5ae107f752b908d1c81e4c4f3e26e7b7 Mon Sep 17 00:00:00 2001 From: Alex Date: Fri, 7 Oct 2022 15:39:00 +0300 Subject: [PATCH 035/672] ci: harden permissions for GitHub Workflows (#11174) * build: harden main.yml permissions Signed-off-by: Alex * build: harden project.yml permissions Signed-off-by: Alex * Update project.yml The permissions are not necessary, because a separate token is used `GITHUB_TOKEN: ${{ secrets.PROJECT_TOKEN }}` --- .github/workflows/main.yml | 3 +++ .github/workflows/project.yml | 1 + 2 files changed, 4 insertions(+) diff --git a/.github/workflows/main.yml b/.github/workflows/main.yml index 50e00f9c9..57a1e3833 100644 --- a/.github/workflows/main.yml +++ b/.github/workflows/main.yml @@ -14,6 +14,9 @@ concurrency: group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }} cancel-in-progress: true +permissions: + contents: read # to fetch code (actions/checkout) + jobs: tests: name: Run tests diff --git a/.github/workflows/project.yml b/.github/workflows/project.yml index b2219893d..999cc08e2 100644 --- a/.github/workflows/project.yml +++ b/.github/workflows/project.yml @@ -9,6 +9,7 @@ concurrency: group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }} cancel-in-progress: true +permissions: {} jobs: add-to-project: name: Add to project From 11daa7dd5f22acadef1135000e92cc899e22c134 Mon Sep 17 00:00:00 2001 From: Erik Thorelli Date: Fri, 7 Oct 2022 05:40:13 -0700 Subject: [PATCH 036/672] chore: add vscode workspace settings to gitignore (#11108) There are workspace settings for vscode plugins that make contributing to ohmyzsh easier. However, these would be noisy for users, especially for those that don't use vscode. --- .gitignore | 3 +++ 1 file changed, 3 insertions(+) diff --git a/.gitignore b/.gitignore index ec24a19bb..71ae444e5 100644 --- a/.gitignore +++ b/.gitignore @@ -6,3 +6,6 @@ cache/ log/ *.swp .DS_Store + +# editor configs +.vscode \ No newline at end of file From f80cf12092edb1bed8b7972bc1b9d63c836a9be7 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Wed, 12 Oct 2022 10:49:44 +0200 Subject: [PATCH 037/672] fix: fix OSC 8 hyperlink escape sequences --- tools/install.sh | 2 +- tools/upgrade.sh | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/tools/install.sh b/tools/install.sh index 495ad2c11..bc3723050 100755 --- a/tools/install.sh +++ b/tools/install.sh @@ -185,7 +185,7 @@ supports_truecolor() { fmt_link() { # $1: text, $2: url, $3: fallback mode if supports_hyperlinks; then - printf '\033]8;;%s\a%s\033]8;;\a\n' "$2" "$1" + printf '\033]8;;%s\033\\%s\033]8;;\033\\\n' "$2" "$1" return fi diff --git a/tools/upgrade.sh b/tools/upgrade.sh index afc6a98dd..2f3b4dae3 100755 --- a/tools/upgrade.sh +++ b/tools/upgrade.sh @@ -107,7 +107,7 @@ supports_truecolor() { fmt_link() { # $1: text, $2: url, $3: fallback mode if supports_hyperlinks; then - printf '\033]8;;%s\a%s\033]8;;\a\n' "$2" "$1" + printf '\033]8;;%s\033\\%s\033]8;;\033\\\n' "$2" "$1" return fi From ee4910e3b36dc5556cad567c3760ee500297cc8e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Wed, 12 Oct 2022 10:55:02 +0200 Subject: [PATCH 038/672] fix: show full hyperlinks in Konsole (#10964) Fixes #10964 --- tools/install.sh | 10 ++++++++-- tools/upgrade.sh | 10 ++++++++-- 2 files changed, 16 insertions(+), 4 deletions(-) diff --git a/tools/install.sh b/tools/install.sh index bc3723050..fb6973dbc 100755 --- a/tools/install.sh +++ b/tools/install.sh @@ -156,11 +156,17 @@ supports_hyperlinks() { return 0 fi - # Windows Terminal or Konsole also support hyperlinks - if [ -n "$WT_SESSION" ] || [ -n "$KONSOLE_VERSION" ]; then + # Windows Terminal also supports hyperlinks + if [ -n "$WT_SESSION" ]; then return 0 fi + # Konsole supports hyperlinks, but it's an opt-in setting that can't be detected + # https://github.com/ohmyzsh/ohmyzsh/issues/10964 + # if [ -n "$KONSOLE_VERSION" ]; then + # return 0 + # fi + return 1 } diff --git a/tools/upgrade.sh b/tools/upgrade.sh index 2f3b4dae3..596a59302 100755 --- a/tools/upgrade.sh +++ b/tools/upgrade.sh @@ -78,11 +78,17 @@ supports_hyperlinks() { return 0 fi - # Windows Terminal or Konsole also support hyperlinks - if [ -n "$WT_SESSION" ] || [ -n "$KONSOLE_VERSION" ]; then + # Windows Terminal also supports hyperlinks + if [ -n "$WT_SESSION" ]; then return 0 fi + # Konsole supports hyperlinks, but it's an opt-in setting that can't be detected + # https://github.com/ohmyzsh/ohmyzsh/issues/10964 + # if [ -n "$KONSOLE_VERSION" ]; then + # return 0 + # fi + return 1 } From b9be3a43b4da579299b4426b1ba9121f746e2555 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Mon, 3 Oct 2022 18:52:50 +0200 Subject: [PATCH 039/672] fix(cli): change unrecognized `\s` in BSD awk (#11146) In BSD awk, \s is not a valid sequence interchangeable with "space or tab characters" as it is in GNU awk. This fix uses [ \t] instead, which is all the possibilities that we need to contemplate when reading the .zshrc file. Fixes #11146 --- lib/cli.zsh | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/lib/cli.zsh b/lib/cli.zsh index db659c11f..f15bd6d63 100644 --- a/lib/cli.zsh +++ b/lib/cli.zsh @@ -241,21 +241,21 @@ function _omz::plugin::disable { # Remove plugins substitution awk script local awk_subst_plugins="\ - gsub(/\s+(${(j:|:)dis_plugins})/, \"\") # with spaces before - gsub(/(${(j:|:)dis_plugins})\s+/, \"\") # with spaces after + gsub(/[ \t]+(${(j:|:)dis_plugins})/, \"\") # with spaces before + gsub(/(${(j:|:)dis_plugins})[ \t]+/, \"\") # with spaces after gsub(/\((${(j:|:)dis_plugins})\)/, \"\") # without spaces (only plugin) " # Disable plugins awk script local awk_script=" # if plugins=() is in oneline form, substitute disabled plugins and go to next line -/^\s*plugins=\([^#]+\).*\$/ { +/^[ \t]*plugins=\([^#]+\).*\$/ { $awk_subst_plugins print \$0 next } # if plugins=() is in multiline form, enable multi flag and disable plugins if they're there -/^\s*plugins=\(/ { +/^[ \t]*plugins=\(/ { multi=1 $awk_subst_plugins print \$0 @@ -330,14 +330,14 @@ function _omz::plugin::enable { # Enable plugins awk script local awk_script=" # if plugins=() is in oneline form, substitute ) with new plugins and go to the next line -/^\s*plugins=\([^#]+\).*\$/ { +/^[ \t]*plugins=\([^#]+\).*\$/ { sub(/\)/, \" $add_plugins&\") print \$0 next } # if plugins=() is in multiline form, enable multi flag -/^\s*plugins=\(/ { +/^[ \t]*plugins=\(/ { multi=1 } @@ -699,9 +699,9 @@ function _omz::theme::set { # Enable theme in .zshrc local awk_script=' -!set && /^\s*ZSH_THEME=[^#]+.*$/ { +!set && /^[ \t]*ZSH_THEME=[^#]+.*$/ { set=1 - sub(/^\s*ZSH_THEME=[^#]+.*$/, "ZSH_THEME=\"'$1'\" # set by `omz`") + sub(/^[ \t]*ZSH_THEME=[^#]+.*$/, "ZSH_THEME=\"'$1'\" # set by `omz`") print $0 next } From 52e848ce8f8d7370a202e0bee07ce2c32858932e Mon Sep 17 00:00:00 2001 From: Sibs <68712272+Bryan-netizen@users.noreply.github.com> Date: Fri, 14 Oct 2022 20:07:26 +0300 Subject: [PATCH 040/672] feat(web-search): add support for Brave search engine (#11106) --- plugins/web-search/README.md | 3 ++- plugins/web-search/web-search.plugin.zsh | 34 +++++++++++++----------- 2 files changed, 20 insertions(+), 17 deletions(-) diff --git a/plugins/web-search/README.md b/plugins/web-search/README.md index da90f90a0..54232a910 100644 --- a/plugins/web-search/README.md +++ b/plugins/web-search/README.md @@ -25,9 +25,10 @@ $ google oh-my-zsh Available search contexts are: | Context | URL | -|-----------------------|------------------------------------------| +| --------------------- | ---------------------------------------- | | `bing` | `https://www.bing.com/search?q=` | | `google` | `https://www.google.com/search?q=` | +| `brs` or `brave` | `https://search.brave.com/search?q=` | | `yahoo` | `https://search.yahoo.com/search?p=` | | `ddg` or `duckduckgo` | `https://www.duckduckgo.com/?q=` | | `sp` or `startpage` | `https://www.startpage.com/do/search?q=` | diff --git a/plugins/web-search/web-search.plugin.zsh b/plugins/web-search/web-search.plugin.zsh index 229948894..d8b4a7f8b 100644 --- a/plugins/web-search/web-search.plugin.zsh +++ b/plugins/web-search/web-search.plugin.zsh @@ -7,22 +7,23 @@ function web_search() { typeset -A urls urls=( $ZSH_WEB_SEARCH_ENGINES - google "https://www.google.com/search?q=" - bing "https://www.bing.com/search?q=" - yahoo "https://search.yahoo.com/search?p=" - duckduckgo "https://www.duckduckgo.com/?q=" - startpage "https://www.startpage.com/do/search?q=" - yandex "https://yandex.ru/yandsearch?text=" - github "https://github.com/search?q=" - baidu "https://www.baidu.com/s?wd=" - ecosia "https://www.ecosia.org/search?q=" - goodreads "https://www.goodreads.com/search?q=" - qwant "https://www.qwant.com/?q=" - givero "https://www.givero.com/search?q=" - stackoverflow "https://stackoverflow.com/search?q=" - wolframalpha "https://www.wolframalpha.com/input/?i=" - archive "https://web.archive.org/web/*/" - scholar "https://scholar.google.com/scholar?q=" + google "https://www.google.com/search?q=" + bing "https://www.bing.com/search?q=" + brave "https://search.brave.com/search?q=" + yahoo "https://search.yahoo.com/search?p=" + duckduckgo "https://www.duckduckgo.com/?q=" + startpage "https://www.startpage.com/do/search?q=" + yandex "https://yandex.ru/yandsearch?text=" + github "https://github.com/search?q=" + baidu "https://www.baidu.com/s?wd=" + ecosia "https://www.ecosia.org/search?q=" + goodreads "https://www.goodreads.com/search?q=" + qwant "https://www.qwant.com/?q=" + givero "https://www.givero.com/search?q=" + stackoverflow "https://stackoverflow.com/search?q=" + wolframalpha "https://www.wolframalpha.com/input/?i=" + archive "https://web.archive.org/web/*/" + scholar "https://scholar.google.com/scholar?q=" ) # check whether the search engine is supported @@ -47,6 +48,7 @@ function web_search() { alias bing='web_search bing' +alias brs='web_search brave' alias google='web_search google' alias yahoo='web_search yahoo' alias ddg='web_search duckduckgo' From 08d5c936c670bd7e37902f64a065ba9f74452cb9 Mon Sep 17 00:00:00 2001 From: Syphdias Date: Fri, 14 Oct 2022 19:12:04 +0200 Subject: [PATCH 041/672] fix(git-auto-fetch): avoid password prompt with `GIT_TERMINAL_PROMPT=0` (#11234) --- plugins/git-auto-fetch/git-auto-fetch.plugin.zsh | 1 + 1 file changed, 1 insertion(+) diff --git a/plugins/git-auto-fetch/git-auto-fetch.plugin.zsh b/plugins/git-auto-fetch/git-auto-fetch.plugin.zsh index 2e029639c..2df34bb7b 100644 --- a/plugins/git-auto-fetch/git-auto-fetch.plugin.zsh +++ b/plugins/git-auto-fetch/git-auto-fetch.plugin.zsh @@ -28,6 +28,7 @@ function git-fetch-all { # Fetch all remotes (avoid ssh passphrase prompt) date -R &>! "$gitdir/FETCH_LOG" GIT_SSH_COMMAND="command ssh -o BatchMode=yes" \ + GIT_TERMINAL_PROMPT=0 \ command git fetch --all 2>/dev/null &>> "$gitdir/FETCH_LOG" ) &| } From 34cd8fbd4afce7b2beb3292f4f90ca57142f442c Mon Sep 17 00:00:00 2001 From: Warren Young Date: Mon, 29 Aug 2022 21:49:12 -0600 Subject: [PATCH 042/672] refactor(fossil): use `fossil branch current` supported since v2.7 (#11138) Using the automation-friendly "fossil branch current" feature added in Fossil 2.7 instead of ad hoc parsing of human-readable "fossil branch" output. Not only does this fix a stray space in the output, it's more robust against changes in command output in general. Closes #11138 --- plugins/fossil/fossil.plugin.zsh | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/plugins/fossil/fossil.plugin.zsh b/plugins/fossil/fossil.plugin.zsh index a2123f415..fadf6095d 100644 --- a/plugins/fossil/fossil.plugin.zsh +++ b/plugins/fossil/fossil.plugin.zsh @@ -13,12 +13,11 @@ ZSH_THEME_FOSSIL_PROMPT_DIRTY=" %{$fg_bold[red]%}✖" ZSH_THEME_FOSSIL_PROMPT_CLEAN=" %{$fg_bold[green]%}✔" function fossil_prompt_info() { - local info=$(fossil branch 2>&1) + local branch=$(fossil branch current 2>&1) # if we're not in a fossil repo, don't show anything - ! command grep -q "use --repo" <<< "$info" || return + ! command grep -q "use --repo" <<< "$branch" || return - local branch=$(echo $info | grep "* " | sed 's/* //g') local changes=$(fossil changes) local dirty="$ZSH_THEME_FOSSIL_PROMPT_CLEAN" From c7c0a8917b8ded7511c07105c82bd7417b92f7a3 Mon Sep 17 00:00:00 2001 From: tmoschou <5567550+tmoschou@users.noreply.github.com> Date: Sat, 15 Oct 2022 04:57:42 +1030 Subject: [PATCH 043/672] fix(brew): do not source `brew shellenv` if already on path (#11167) --- plugins/brew/README.md | 5 ++++- plugins/brew/brew.plugin.zsh | 17 ++++++++++------- 2 files changed, 14 insertions(+), 8 deletions(-) diff --git a/plugins/brew/README.md b/plugins/brew/README.md index 64e0e1153..9ce2c5bb0 100644 --- a/plugins/brew/README.md +++ b/plugins/brew/README.md @@ -10,7 +10,10 @@ plugins=(... brew) ## Shellenv -This plugin also executes `brew shellenv` at plugin load to set up many useful variables, such as `HOMEBREW_PREFIX` or `HOMEBREW_REPOSITORY`. +If `brew` is not found in the PATH, this plugin will attempt to find it in common +locations, and execute `brew shellenv` to set the environment appropriately. +This plugin will also export `HOMEBREW_PREFIX="$(brew --prefix)"` if not previously +defined for convenience. ## Aliases diff --git a/plugins/brew/brew.plugin.zsh b/plugins/brew/brew.plugin.zsh index 4a2322216..41420b5b7 100644 --- a/plugins/brew/brew.plugin.zsh +++ b/plugins/brew/brew.plugin.zsh @@ -10,18 +10,21 @@ if (( ! $+commands[brew] )); then else return fi + + # Only add Homebrew installation to PATH, MANPATH, and INFOPATH if brew is + # not already on the path, to prevent duplicate entries. This aligns with + # the behavior of the brew installer.sh post-install steps. + eval "$("$BREW_LOCATION" shellenv)" + unset BREW_LOCATION fi if [[ -z "$HOMEBREW_PREFIX" ]]; then - if [[ -z $BREW_LOCATION ]]; then - eval "$(brew shellenv)" - else - eval "$("$BREW_LOCATION" shellenv)" - fi + # Maintain compatability with potential custom user profiles, where we had + # previously relied on always sourcing shellenv. OMZ plugins should not rely + # on this to be defined due to out of order processing. + export HOMEBREW_PREFIX="$(brew --prefix)" fi -unset BREW_LOCATION - alias bcubc='brew upgrade --cask && brew cleanup' alias bcubo='brew update && brew outdated --cask' alias brewp='brew pin' From 65a1e4edbe678cdac37ad96ca4bc4f6d77e27adf Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Fri, 14 Oct 2022 20:31:33 +0200 Subject: [PATCH 044/672] fix(installer): detect newer Git for Windows version errors (#11157) Fixes #11157 --- tools/install.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tools/install.sh b/tools/install.sh index fb6973dbc..a6538f9d7 100755 --- a/tools/install.sh +++ b/tools/install.sh @@ -273,7 +273,7 @@ setup_ohmyzsh() { } ostype=$(uname) - if [ -z "${ostype%CYGWIN*}" ] && git --version | grep -q msysgit; then + if [ -z "${ostype%CYGWIN*}" ] && git --version | grep -Eq 'msysgit|windows'; then fmt_error "Windows/MSYS Git is not supported on Cygwin" fmt_error "Make sure the Cygwin git package is installed and is first on the \$PATH" exit 1 From 818f3de1fa6588a94bf207766a811992e301acf1 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Sat, 1 Oct 2022 11:21:19 +0200 Subject: [PATCH 045/672] fix(debian)!: remove ar alias BREAKING CHANGE: This alias needs to be removed because is shadowing `ar` archiver. Closes #9304 --- plugins/debian/README.md | 39 ++++++++++++++++---------------- plugins/debian/debian.plugin.zsh | 7 ------ 2 files changed, 19 insertions(+), 27 deletions(-) diff --git a/plugins/debian/README.md b/plugins/debian/README.md index 2ce206cfb..1db534f13 100644 --- a/plugins/debian/README.md +++ b/plugins/debian/README.md @@ -30,26 +30,25 @@ Set `$apt_pref` and `$apt_upgr` to whatever command you want (before sourcing Oh ## Superuser Operations Aliases -| Alias | Command | Description | -| -------- | -------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------- | -| `aac` | `sudo $apt_pref autoclean` | Clears out the local repository of retrieved package files | -| `aar` | `sudo $apt_pref autoremove` | Removes packages installed automatically that are no longer needed | -| `abd` | `sudo $apt_pref build-dep` | Installs all dependencies for building packages | -| `ac` | `sudo $apt_pref clean` | Clears out the local repository of retrieved package files except lock files | -| `ad` | `sudo $apt_pref update` | Updates the package lists for upgrades for packages | -| `adg` | `sudo $apt_pref update && sudo $apt_pref $apt_upgr` | Update and upgrade packages | -| `ads` | `sudo apt-get dselect-upgrade` | Installs packages from list and removes all not in the list | -| `adu` | `sudo $apt_pref update && sudo $apt_pref dist-upgrade` | Smart upgrade that handles dependencies | -| `afu` | `sudo apt-file update` | Update the files in packages | -| `ai` | `sudo $apt_pref install` | Command-line tool to install package | -| `ail` | `sed -e 's/ */ /g' -e 's/ *//' \| cut -s -d ' ' -f 1 \| xargs sudo $apt_pref install` | Install all packages given on the command line while using only the first word of each line | -| `alu` | `sudo apt update && apt list -u && sudo apt upgrade` | Update, list and upgrade packages | -| `ap` | `sudo $apt_pref purge` | Removes packages along with configuration files | -| `ar` | `sudo $apt_pref remove` | Removes packages, keeps the configuration files | -| `au` | `sudo $apt_pref $apt_upgr` | Install package upgrades | -| `di` | `sudo dpkg -i` | Install all .deb files in the current directory | -| `dia` | `sudo dpkg -i ./*.deb` | Install all .deb files in the current directory | -| `kclean` | `sudo aptitude remove -P ?and(~i~nlinux-(ima\|hea) ?not(~n$(uname -r)))` | Remove ALL kernel images and headers EXCEPT the one in use | +| Alias | Command | Description | +| -------- | ------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------- | +| `aac` | `sudo $apt_pref autoclean` | Clears out the local repository of retrieved package files | +| `aar` | `sudo $apt_pref autoremove` | Removes packages installed automatically that are no longer needed | +| `abd` | `sudo $apt_pref build-dep` | Installs all dependencies for building packages | +| `ac` | `sudo $apt_pref clean` | Clears out the local repository of retrieved package files except lock files | +| `ad` | `sudo $apt_pref update` | Updates the package lists for upgrades for packages | +| `adg` | `sudo $apt_pref update && sudo $apt_pref $apt_upgr` | Update and upgrade packages | +| `ads` | `sudo apt-get dselect-upgrade` | Installs packages from list and removes all not in the list | +| `adu` | `sudo $apt_pref update && sudo $apt_pref dist-upgrade` | Smart upgrade that handles dependencies | +| `afu` | `sudo apt-file update` | Update the files in packages | +| `ai` | `sudo $apt_pref install` | Command-line tool to install package | +| `ail` | `sed -e 's/ */ /g' -e 's/ *//' \| cut -s -d ' ' -f 1 \| xargs sudo $apt_pref install` | Install all packages given on the command line while using only the first word of each line | +| `alu` | `sudo apt update && apt list -u && sudo apt upgrade` | Update, list and upgrade packages | +| `ap` | `sudo $apt_pref purge` | Removes packages along with configuration files | +| `au` | `sudo $apt_pref $apt_upgr` | Install package upgrades | +| `di` | `sudo dpkg -i` | Install all .deb files in the current directory | +| `dia` | `sudo dpkg -i ./*.deb` | Install all .deb files in the current directory | +| `kclean` | `sudo aptitude remove -P ?and(~i~nlinux-(ima\|hea) ?not(~n$(uname -r)))` | Remove ALL kernel images and headers EXCEPT the one in use | ## Aliases - Commands using `su` diff --git a/plugins/debian/debian.plugin.zsh b/plugins/debian/debian.plugin.zsh index f649a5b16..2d8c4666e 100644 --- a/plugins/debian/debian.plugin.zsh +++ b/plugins/debian/debian.plugin.zsh @@ -55,7 +55,6 @@ if [[ $use_sudo -eq 1 ]]; then alias ail="sed -e 's/ */ /g' -e 's/ *//' | cut -s -d ' ' -f 1 | xargs sudo $apt_pref install" alias ap="sudo $apt_pref purge" - alias ar="sudo $apt_pref remove" alias aar="sudo $apt_pref autoremove" # apt-get only @@ -98,11 +97,6 @@ else print "$cmd" eval "$cmd" } - function ar() { - cmd="su -lc '$apt_pref remove $@' root" - print "$cmd" - eval "$cmd" - } function aar() { cmd="su -lc '$apt_pref autoremove $@' root" print "$cmd" @@ -147,7 +141,6 @@ apt_pref_compdef au "$apt_upgr" apt_pref_compdef ai "install" apt_pref_compdef ail "install" apt_pref_compdef ap "purge" -apt_pref_compdef ar "remove" apt_pref_compdef aar "autoremove" apt_pref_compdef ads "dselect-upgrade" From 7e3231b846dec87fcf6537f6e45c9c1be9f718fe Mon Sep 17 00:00:00 2001 From: Carlo Date: Tue, 18 Oct 2022 19:10:55 +0200 Subject: [PATCH 046/672] feat(z): replace `rupa/z` with `agkozak/zsh-z` (#11236) --- plugins/z/LICENSE | 21 + plugins/z/MANUAL.md | 343 +++++++++++++++ plugins/z/Makefile | 4 - plugins/z/README | 148 ------- plugins/z/README.md | 7 +- plugins/z/_z | 82 ++++ plugins/z/z.1 | 173 -------- plugins/z/z.plugin.zsh | 972 ++++++++++++++++++++++++++++++++++++++++- plugins/z/z.sh | 267 ----------- 9 files changed, 1417 insertions(+), 600 deletions(-) create mode 100644 plugins/z/LICENSE create mode 100644 plugins/z/MANUAL.md delete mode 100644 plugins/z/Makefile delete mode 100644 plugins/z/README create mode 100644 plugins/z/_z delete mode 100644 plugins/z/z.1 delete mode 100644 plugins/z/z.sh diff --git a/plugins/z/LICENSE b/plugins/z/LICENSE new file mode 100644 index 000000000..d1cca7ae5 --- /dev/null +++ b/plugins/z/LICENSE @@ -0,0 +1,21 @@ +MIT License + +Copyright (c) 2018-2022 Alexandros Kozak + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/plugins/z/MANUAL.md b/plugins/z/MANUAL.md new file mode 100644 index 000000000..dcca3c452 --- /dev/null +++ b/plugins/z/MANUAL.md @@ -0,0 +1,343 @@ +# Zsh-z + +Zsh-z is a command line tool that allows you to jump quickly to directories that you have visited frequently in the past, or recently -- but most often a combination of the two (a concept known as ["frecency"](https://en.wikipedia.org/wiki/Frecency)). It works by keeping track of when you go to directories and how much time you spend in them. It is then in the position to guess where you want to go when you type a partial string, e.g., `z src` might take you to `~/src/zsh`. `z zsh` might also get you there, and `z c/z` might prove to be even more specific -- it all depends on your habits and how much time you have been using Zsh-z to build up a database. After using Zsh-z for a little while, you will get to where you want to be by typing considerably less than you would need if you were using `cd`. + +Zsh-z is a native Zsh port of [rupa/z](https://github.com/rupa/z), a tool written for `bash` and Zsh that uses embedded `awk` scripts to do the heavy lifting. It was quite possibly my most used command line tool for a couple of years. I decided to translate it, `awk` parts and all, into pure Zsh script, to see if by eliminating calls to external tools (`awk`, `sort`, `date`, `sed`, `mv`, `rm`, and `chown`) and reducing forking through subshells I could make it faster. The performance increase is impressive, particularly on systems where forking is slow, such as Cygwin, MSYS2, and WSL. I have found that, in those environments, switching directories using Zsh-z can be over 100% faster than it is using `rupa/z`. + +There is a noteworthy stability increase as well. Race conditions have always been a problem with `rupa/z`, and users of that utility will occasionally lose their `.z` databases. By having Zsh-z only use Zsh (`rupa/z` uses a hybrid shell code that works on `bash` as well), I have been able to implement a `zsh/system`-based file-locking mechanism similar to [the one @mafredri once proposed for `rupa/z`](https://github.com/rupa/z/pull/199). It is now nearly impossible to crash the database, even through extreme testing. + +There are other, smaller improvements which I try to document in [Improvements and Fixes](#improvements-and-fixes). These include the new default behavior of sorting your tab completions by frecency rather than just letting Zsh sort the raw results alphabetically (a behavior which can be restored if you like it -- [see below](#settings)). + +Zsh-z is a drop-in replacement for `rupa/z` and will, by default, use the same database (`~/.z`), so you can go on using `rupa/z` when you launch `bash`. + +## Table of Contents +- [News](#news) +- [Installation](#installation) +- [Command Line Options](#command-line-options) +- [Settings](#settings) +- [Case Sensitivity](#case-sensitivity) +- [`ZSHZ_UNCOMMON`](#zshz_uncommon) +- [Making `--add` work for you](#making---add-work-for-you) +- [Other Improvements and Fixes](#other-improvements-and-fixes) +- [Migrating from Other Tools](#migrating-from-other-tools) +- [`COMPLETE_ALIASES`](#complete_aliases) +- [Known Bugs](#known-bugs) + +## News + +
+ Here are the latest features and updates. + +- June 29, 2022 + + Zsh-z is less likely to leave temporary files sitting around (props @mafredri). +- June 27, 2022 + + A bug was fixed which was preventing paths with spaces in them from being updated ([#61](https://github.com/agkozak/zsh-z/issues/61)). + + If writing to the temporary database file fails, the database will not be clobbered (props @mafredri). +- December 19, 2021 + + ZSH-z will now display tildes for `HOME` during completion when `ZSHZ_TILDE=1` has been set. +- November 11, 2021 + + A bug was fixed which was preventing ranks from being incremented. + + `--add` has been made to work with relative paths and has been documented for the user. +- October 14, 2021 + + Completions were being sorted alphabetically, rather than by rank; this error has been fixed. +- September 25, 2021 + + Orthographical change: "Zsh," not "ZSH." +- September 23, 2021 + + `z -xR` will now remove a directory *and its subdirectories* from the database. + + `z -x` and `z -xR` can now take an argument; without one, `PWD` is assumed. +- September 7, 2021 + + Fixed the unload function so that it removes the `$ZSHZ_CMD` alias (default: `z`). +- August 27, 2021 + + Using `print -v ... -f` instead of `print -v` to work around longstanding bug in Zsh involving `print -v` and multibyte strings. +- August 13, 2021 + + Fixed the explanation string printed during completion so that it may be formatted with `zstyle`. + + Zsh-z now declares `ZSHZ_EXCLUDE_DIRS` as an array with unique elements so that you do not have to. +- July 29, 2021 + + Temporarily disabling use of `print -v`, which seems to be mangling CJK multibyte strings. +- July 27, 2021 + + Internal escaping of path names now works with older versions of ZSH. + + Zsh-z now detects and discards any incomplete or incorrectly formattted database entries. +- July 10, 2021 + + Setting `ZSHZ_TRAILING_SLASH=1` makes it so that a search pattern ending in `/` can match the end of a path; e.g. `z foo/` can match `/path/to/foo`. +- June 25, 2021 + + Setting `ZSHZ_TILDE=1` displays the `HOME` directory as `~`. +- May 7, 2021 + + Setting `ZSHZ_ECHO=1` will cause Zsh-z to display the new path when you change directories. + + Better escaping of path names to deal paths containing the characters ``\`()[]``. +- February 15, 2021 + + Ranks are displayed the way `rupa/z` now displays them, i.e. as large integers. This should help Zsh-z to integrate with other tools. +- January 31, 2021 + + Zsh-z is now efficient enough that, on MSYS2 and Cygwin, it is faster to run it in the foreground than it is to fork a subshell for it. + + `_zshz_precmd` simply returns if `PWD` is `HOME` or in `ZSH_EXCLUDE_DIRS`, rather than waiting for `zshz` to do that. +- January 17, 2021 + + Made sure that the `PUSHD_IGNORE_DUPS` option is respected. +- January 14, 2021 + + The `z -h` help text now breaks at spaces. + + `z -l` was not working for Zsh version < 5. +- January 11, 2021 + + Major refactoring of the code. + + `z -lr` and `z -lt` work as expected. + + `EXTENDED_GLOB` has been disabled within the plugin to accomodate old-fashioned Windows directories with names such as `Progra~1`. + + Removed `zshelldoc` documentation. +- January 6, 2021 + + I have corrected the frecency routine so that it matches `rupa/z`'s math, but for the present, Zsh-z will continue to display ranks as 1/10000th of what they are in `rupa/z` -- [they had to multiply theirs by 10000](https://github.com/rupa/z/commit/f1f113d9bae9effaef6b1e15853b5eeb445e0712) to work around `bash`'s inadequacies at dealing with decimal fractions. +- January 5, 2021 + + If you try `z foo`, and `foo` is not in the database but `${PWD}/foo` is a valid directory, Zsh-z will `cd` to it. +- December 22, 2020 + + `ZSHZ_CASE`: when set to `ignore`, pattern matching is case-insensitive; when set to `smart`, patterns are matched case-insensitively when they are all lowercase and case-sensitively when they have uppercase characters in them (a behavior very much like Vim's `smartcase` setting). + + `ZSHZ_KEEP_DIRS` is an array of directory names that should not be removed from the database, even if they are not currently available (useful when a drive is not always mounted). + + Symlinked datafiles were having their symlinks overwritten; this bug has been fixed. + +
+ +## Installation + +### General observations + +This script can be installed simply by downloading it and sourcing it from your `.zshrc`: + + source /path/to/zsh-z.plugin.zsh + +For tab completion to work, you will want to have loaded `compinit`. The frameworks handle this themselves. If you are not using a framework, put + + autoload -U compinit && compinit + +in your .zshrc somewhere below where you source `zsh-z.plugin.zsh`. + +If you add + + zstyle ':completion:*' menu select + +to your `.zshrc`, your completion menus will look very nice. This `zstyle` invocation should work with any of the frameworks below as well. + +### For [antigen](https://github.com/zsh-users/antigen) users + +Add the line + + antigen bundle agkozak/zsh-z + +to your `.zshrc`, somewhere above the line that says `antigen apply`. + +### For [oh-my-zsh](http://ohmyz.sh/) users + +Execute the following command: + + git clone https://github.com/agkozak/zsh-z ${ZSH_CUSTOM:-~/.oh-my-zsh/custom}/plugins/zsh-z + +and add `zsh-z` to the line of your `.zshrc` that specifies `plugins=()`, e.g., `plugins=( git zsh-z )`. + +### For [prezto](https://github.com/sorin-ionescu/prezto) users + +Execute the following command: + + git clone https://github.com/agkozak/zsh-z.git ~/.zprezto-contrib/zsh-z + +Then edit your `~/.zpreztorc` file. Make sure the line that says + + zstyle ':prezto:load' pmodule-dirs $HOME/.zprezto-contrib + +is uncommented. Then find the section that specifies which modules are to be loaded; it should look something like this: + + zstyle ':prezto:load' pmodule \ + 'environment' \ + 'terminal' \ + 'editor' \ + 'history' \ + 'directory' \ + 'spectrum' \ + 'utility' \ + 'completion' \ + 'prompt' + +Add a backslash to the end of the last line add `'zsh-z'` to the list, e.g., + + zstyle ':prezto:load' pmodule \ + 'environment' \ + 'terminal' \ + 'editor' \ + 'history' \ + 'directory' \ + 'spectrum' \ + 'utility' \ + 'completion' \ + 'prompt' \ + 'zsh-z' + +Then relaunch `zsh`. + +### For [zcomet](https://github.com/agkozak/zcomet) users + +Simply add + + zcomet load agkozak/zsh-z + +to your `.zshrc` (below where you source `zcomet.zsh` and above where you run `zcomet compinit`). + +### For [zgen](https://github.com/tarjoilija/zgen) users + +Add the line + + zgen load agkozak/zsh-z + +somewhere above the line that says `zgen save`. Then run + + zgen reset + zsh + +to refresh your init script. + +### For [Zim](https://github.com/zimfw/zimfw) + +Add the following line to your `.zimrc`: + + zmodule https://github.com/agkozak/zsh-z + +Then run + + zimfw install + +and restart your shell. + +### For [Zinit](https://github.com/zdharma-continuum/zinit) users + +Add the line + + zinit load agkozak/zsh-z + +to your `.zshrc`. + +`zsh-z` supports `zinit`'s `unload` feature; just run `zinit unload agkozak/zshz` to restore the shell to its state before `zsh-z` was loaded. + +### For [Znap](https://github.com/marlonrichert/zsh-snap) users + +Add the line + + znap source agkozak/zsh-z + +somewhere below the line where you `source` Znap itself. + +### For [zplug](https://github.com/zplug/zplug) users + +Add the line + + zplug "agkozak/zsh-z" + +somewhere above the line that says `zplug load`. Then run + + zplug install + zplug load + +to install `zsh-z`. + +## Command Line Options + +- `--add` Add a directory to the database +- `-c` Only match subdirectories of the current directory +- `-e` Echo the best match without going to it +- `-h` Display help +- `-l` List all matches without going to them +- `-r` Match by rank (i.e. how much time you spend in directories) +- `-t` Time -- match by how recently you have been to directories +- `-x` Remove a directory (by default, the current directory) from the database +- `-xR` Remove a directory (by default, the current directory) and its subdirectories from the database + +# Settings + +Zsh-z has environment variables (they all begin with `ZSHZ_`) that change its behavior if you set them; you can also keep your old ones if you have been using `rupa/z` (they begin with `_Z_`). + +* `ZSHZ_CMD` changes the command name (default: `z`) +* `ZSHZ_COMPLETION` can be `'frecent'` (default) or `'legacy'`, depending on whether you want your completion results sorted according to frecency or simply sorted alphabetically +* `ZSHZ_DATA` changes the database file (default: `~/.z`) +* `ZSHZ_ECHO` displays the new path name when changing directories (default: `0`) +* `ZSHZ_EXCLUDE_DIRS` is an array of directories to keep out of the database (default: empty) +* `ZSHZ_KEEP_DIRS` is an array of directories that should not be removed from the database, even if they are not currently available (useful when a drive is not always mounted) (default: empty) +* `ZSHZ_MAX_SCORE` is the maximum combined score the database entries can have before they begin to age and potentially drop out of the database (default: 9000) +* `ZSHZ_NO_RESOLVE_SYMLINKS` prevents symlink resolution (default: `0`) +* `ZSHZ_OWNER` allows usage when in `sudo -s` mode (default: empty) +* `ZSHZ_TILDE` displays the name of the `HOME` directory as a `~` (default: `0`) +* `ZSHZ_TRAILING_SLASH` makes it so that a search pattern ending in `/` can match the final element in a path; e.g., `z foo/` can match `/path/to/foo` (default: `0`) +* `ZSHZ_UNCOMMON` changes the logic used to calculate the directory jumped to; [see below](#zshz_uncommon`) (default: `0`) + +## Case sensitivity + +The default behavior of Zsh-z is to try to find a case-sensitive match. If there is none, then Zsh-z tries to find a case-insensitive match. + +Some users prefer simple case-insensitivity; this behavior can be enabled by setting + + ZSHZ_CASE=ignore + +If you like Vim's `smartcase` setting, where lowercase patterns are case-insensitive while patterns with any uppercase characters are treated case-sensitively, try setting + + ZSHZ_CASE=smart + +## `ZSHZ_UNCOMMON` + +A common complaint about the default behavior of `rupa/z` and Zsh-z involves "common prefixes." If you type `z code` and the best matches, in increasing order, are + + /home/me/code/foo + /home/me/code/bar + /home/me/code/bat + +Zsh-z will see that all possible matches share a common prefix and will send you to that directory -- `/home/me/code` -- which is often a desirable result. But if the possible matches are + + /home/me/.vscode/foo + /home/me/code/foo + /home/me/code/bar + /home/me/code/bat + +then there is no common prefix. In this case, `z code` will simply send you to the highest-ranking match, `/home/me/code/bat`. + +You may enable an alternate, experimental behavior by setting `ZSHZ_UNCOMMON=1`. If you do that, Zsh-z will not jump to a common prefix, even if one exists. Instead, it chooses the highest-ranking match -- but it drops any subdirectories that do not include the search term. So if you type `z bat` and `/home/me/code/bat` is the best match, that is exactly where you will end up. If, however, you had typed `z code` and the best match was also `/home/me/code/bat`, you would have ended up in `/home/me/code` (because `code` was what you had searched for). This feature is still in development, and feedback is welcome. + +## Making `--add` Work for You + +Zsh-z internally uses the `--add` option to add paths to its database. @zachriggle pointed out to me that users might want to use `--add` themselves, so I have altered it a little to make it more user-friendly. + +A good example might involve a directory tree that has Git repositories within it. The working directories could be added to the Zsh-z database as a batch with + + for i in $(find $PWD -maxdepth 3 -name .git -type d); do + z --add ${i:h} + done + +(As a Zsh user, I tend to use `**` instead of `find`, but it is good to see how deep your directory trees go before doing that.) + + +## Other Improvements and Fixes + +* `z -x` works, with the help of `chpwd_functions`. +* Zsh-z works on Solaris. +* Zsh-z uses the "new" `zshcompsys` completion system instead of the old `compctl` one. +* There is no error message when the database file has not yet been created. +* There is support for special characters (e.g., `[`) in directory names. +* If `z -l` only returns one match, a common root is not printed. +* Exit status codes increasingly make sense. +* Completions work with options `-c`, `-r`, and `-t`. +* If `~/foo` and `~/foob` are matches, `~/foo` is *not* the common root. Only a common parent directory can be a common root. +* `z -x` and the new, recursive `z -xR` can take an argument so that you can remove directories other than `PWD` from the database. + +## Migrating from Other Tools + +Zsh-z's database format is identical to that of `rupa/z`. You may switch freely between the two tools (I still use `rupa/z` for `bash`). `fasd` also uses that database format, but it stores it by default in `~/.fasd`, so you will have to `cp ~/.fasd ~/.z` if you want to use your old directory history. + +If you are coming to Zsh-z (or even to the original `rupa/z`, for that matter) from `autojump`, try using my [`jumpstart-z`](https://github.com/agkozak/jumpstart-z/blob/master/jumpstart-z) tool to convert your old database to the Zsh-z format, or simply run + + awk -F "\t" '{printf("%s|%0.f|%s\n", $2, $1, '"$(date +%s)"')}' < /path/to/autojump.txt > ~/.z + +## `COMPLETE_ALIASES` + +`z`, or any alternative you set up using `$ZSH_CMD` or `$_Z_CMD`, is an alias. `setopt COMPLETE_ALIASES` divorces the tab completion for aliases from the underlying commands they invoke, so if you enable `COMPLETE_ALIASES`, tab completion for Zsh-z will be broken. You can get it working again, however, by adding under + + setopt COMPLETE_ALIASES + +the line + + compdef _zshz ${ZSHZ_CMD:-${_Z_CMD:-z}} + +That will re-bind `z` or the command of your choice to the underlying Zsh-z function. + +## Known Bugs +It is possible to run a completion on a string with spaces in it, e.g., `z us bi` might take you to `/usr/local/bin`. This works, but as things stand, after the completion the command line reads + + z us /usr/local/bin. + +You get where you want to go, but the detritus on the command line is annoying. This is also a problem in `rupa/z`, but I am keen on eventually eliminating this glitch. Advice is welcome. diff --git a/plugins/z/Makefile b/plugins/z/Makefile deleted file mode 100644 index dcf433d40..000000000 --- a/plugins/z/Makefile +++ /dev/null @@ -1,4 +0,0 @@ -readme: - @groff -man -Tascii z.1 | col -bx - -.PHONY: readme diff --git a/plugins/z/README b/plugins/z/README deleted file mode 100644 index 47e54c57a..000000000 --- a/plugins/z/README +++ /dev/null @@ -1,148 +0,0 @@ -Z(1) User Commands Z(1) - - - -NAME - z - jump around - -SYNOPSIS - z [-chlrtx] [regex1 regex2 ... regexn] - -AVAILABILITY - bash, zsh - -DESCRIPTION - Tracks your most used directories, based on 'frecency'. - - After a short learning phase, z will take you to the most 'frecent' - directory that matches ALL of the regexes given on the command line, in - order. - - For example, z foo bar would match /foo/bar but not /bar/foo. - -OPTIONS - -c restrict matches to subdirectories of the current directory - - -e echo the best match, don't cd - - -h show a brief help message - - -l list only - - -r match by rank only - - -t match by recent access only - - -x remove the current directory from the datafile - -EXAMPLES - z foo cd to most frecent dir matching foo - - z foo bar cd to most frecent dir matching foo, then bar - - z -r foo cd to highest ranked dir matching foo - - z -t foo cd to most recently accessed dir matching foo - - z -l foo list all dirs matching foo (by frecency) - -NOTES - Installation: - Put something like this in your $HOME/.bashrc or $HOME/.zshrc: - - . /path/to/z.sh - - cd around for a while to build up the db. - - PROFIT!! - - Optionally: - Set $_Z_CMD to change the command name (default z). - Set $_Z_DATA to change the datafile (default $HOME/.z). - Set $_Z_MAX_SCORE lower to age entries out faster (default - 9000). - Set $_Z_NO_RESOLVE_SYMLINKS to prevent symlink resolution. - Set $_Z_NO_PROMPT_COMMAND to handle PROMPT_COMMAND/precmd your- - self. - Set $_Z_EXCLUDE_DIRS to an array of directory trees to exclude. - Set $_Z_OWNER to allow usage when in 'sudo -s' mode. - (These settings should go in .bashrc/.zshrc before the line - added above.) - Install the provided man page z.1 somewhere in your MANPATH, - like /usr/local/man/man1. - - Aging: - The rank of directories maintained by z undergoes aging based on a sim- - ple formula. The rank of each entry is incremented every time it is - accessed. When the sum of ranks is over 9000, all ranks are multiplied - by 0.99. Entries with a rank lower than 1 are forgotten. - - Frecency: - Frecency is a portmanteau of 'recent' and 'frequency'. It is a weighted - rank that depends on how often and how recently something occurred. As - far as I know, Mozilla came up with the term. - - To z, a directory that has low ranking but has been accessed recently - will quickly have higher rank than a directory accessed frequently a - long time ago. - - Frecency is determined at runtime. - - Common: - When multiple directories match all queries, and they all have a common - prefix, z will cd to the shortest matching directory, without regard to - priority. This has been in effect, if undocumented, for quite some - time, but should probably be configurable or reconsidered. - - Tab Completion: - z supports tab completion. After any number of arguments, press TAB to - complete on directories that match each argument. Due to limitations of - the completion implementations, only the last argument will be com- - pleted in the shell. - - Internally, z decides you've requested a completion if the last argu- - ment passed is an absolute path to an existing directory. This may - cause unexpected behavior if the last argument to z begins with /. - -ENVIRONMENT - A function _z() is defined. - - The contents of the variable $_Z_CMD is aliased to _z 2>&1. If not set, - $_Z_CMD defaults to z. - - The environment variable $_Z_DATA can be used to control the datafile - location. If it is not defined, the location defaults to $HOME/.z. - - The environment variable $_Z_NO_RESOLVE_SYMLINKS can be set to prevent - resolving of symlinks. If it is not set, symbolic links will be - resolved when added to the datafile. - - In bash, z appends a command to the PROMPT_COMMAND environment variable - to maintain its database. In zsh, z appends a function _z_precmd to the - precmd_functions array. - - The environment variable $_Z_NO_PROMPT_COMMAND can be set if you want - to handle PROMPT_COMMAND or precmd yourself. - - The environment variable $_Z_EXCLUDE_DIRS can be set to an array of - directory trees to exclude from tracking. $HOME is always excluded. - Directories must be full paths without trailing slashes. - - The environment variable $_Z_OWNER can be set to your username, to - allow usage of z when your sudo environment keeps $HOME set. - -FILES - Data is stored in $HOME/.z. This can be overridden by setting the - $_Z_DATA environment variable. When initialized, z will raise an error - if this path is a directory, and not function correctly. - - A man page (z.1) is provided. - -SEE ALSO - regex(7), pushd, popd, autojump, cdargs - - Please file bugs at https://github.com/rupa/z/ - - - -z January 2013 Z(1) diff --git a/plugins/z/README.md b/plugins/z/README.md index ea8d4610a..5b7d6f649 100644 --- a/plugins/z/README.md +++ b/plugins/z/README.md @@ -1,8 +1,9 @@ # z - jump around -This plugin defines the [z command](https://github.com/rupa/z) that tracks your most visited directories and allows you to access them with very few keystrokes. +This plugin defines the [z command](https://github.com/agkozak/zsh-z) that tracks your most visited directories and allows you to access them with very few keystrokes. ### Example + Assume that you have previously visited directory `~/.oh-my-zsh/plugins`. From any folder in your command line, you can quickly access it by using a regex match to this folder: ```bash @@ -11,6 +12,7 @@ Assume that you have previously visited directory `~/.oh-my-zsh/plugins`. From a ``` ### Setup + To enable z, add `z` to your `plugins` array in your zshrc file: ```zsh @@ -19,5 +21,4 @@ plugins=(... z) ### Further reading -For advanced usage and details of z, see [README](./README) (in man page format, copied from [rupa/z](https://github.com/rupa/z)). - +For advanced usage and details of z, see [MANUAL](./MANUAL.md) (copied from [agkozak/zsh-z](https://github.com/agkozak/zsh-z)). diff --git a/plugins/z/_z b/plugins/z/_z new file mode 100644 index 000000000..9891a52ed --- /dev/null +++ b/plugins/z/_z @@ -0,0 +1,82 @@ +#compdef zshz ${ZSHZ_CMD:-${_Z_CMD:-z}} +# +# Zsh-z - jump around with Zsh - A native Zsh version of z without awk, sort, +# date, or sed +# +# https://github.com/agkozak/zsh-z +# +# Copyright (c) 2018-2022 Alexandros Kozak +# +# Permission is hereby granted, free of charge, to any person obtaining a copy +# of this software and associated documentation files (the "Software"), to deal +# in the Software without restriction, including without limitation the rights +# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +# copies of the Software, and to permit persons to whom the Software is +# furnished to do so, subject to the following conditions: +# +# The above copyright notice and this permission notice shall be included in all +# copies or substantial portions of the Software. +# +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +# SOFTWARE. +# +# z (https://github.com/rupa/z) is copyright (c) 2009 rupa deadwyler and +# licensed under the WTFPL license, Version 2.a +# +# shellcheck shell=ksh + +############################################################ +# Zsh-z COMPLETIONS +############################################################ +emulate -L zsh +(( ZSHZ_DEBUG )) && + setopt LOCAL_OPTIONS WARN_CREATE_GLOBAL NO_WARN_NESTED_VAR 2> /dev/null + +# TODO: This routine currently reproduces z's feature of allowing spaces to be +# used as wildcards in completions, so that +# +# z us lo bi +# +# can expand to +# +# z /usr/local/bin +# +# but it also reproduces z's buggy display on the commandline, viz. +# +# z us lo /usr/local/bin +# +# Address. + +local completions expl completion +local -a completion_list + +completions=$(zshz --complete ${(@)words:1}) +[[ -z $completions ]] && return 1 + +for completion in ${(f)completions[@]}; do + if (( ZSHZ_TILDE )) && [[ $completion == ${HOME}* ]]; then + completion="~${(q)${completion#${HOME}}}" + else + completion="${(q)completion}" + fi + completion_list+=( $completion ) +done + +_description -V completion_list expl 'directories' + +if [[ $ZSHZ_COMPLETION == 'legacy' ]]; then + compadd "${expl[@]}" -QU -- "${completion_list[@]}" +else + compadd "${expl[@]}" -QU -V zsh-z -- "${completion_list[@]}" +fi + +compstate[insert]=menu + +return 0 + +# vim: ft=zsh:fdm=indent:ts=2:et:sts=2:sw=2: diff --git a/plugins/z/z.1 b/plugins/z/z.1 deleted file mode 100644 index 182f98176..000000000 --- a/plugins/z/z.1 +++ /dev/null @@ -1,173 +0,0 @@ -.TH "Z" "1" "January 2013" "z" "User Commands" -.SH -NAME -z \- jump around -.SH -SYNOPSIS -z [\-chlrtx] [regex1 regex2 ... regexn] -.SH -AVAILABILITY -bash, zsh -.SH -DESCRIPTION -Tracks your most used directories, based on 'frecency'. -.P -After a short learning phase, \fBz\fR will take you to the most 'frecent' -directory that matches ALL of the regexes given on the command line, in order. - -For example, \fBz foo bar\fR would match \fB/foo/bar\fR but not \fB/bar/foo\fR. -.SH -OPTIONS -.TP -\fB\-c\fR -restrict matches to subdirectories of the current directory -.TP -\fB\-e\fR -echo the best match, don't cd -.TP -\fB\-h\fR -show a brief help message -.TP -\fB\-l\fR -list only -.TP -\fB\-r\fR -match by rank only -.TP -\fB\-t\fR -match by recent access only -.TP -\fB\-x\fR -remove the current directory from the datafile -.SH EXAMPLES -.TP 14 -\fBz foo\fR -cd to most frecent dir matching foo -.TP 14 -\fBz foo bar\fR -cd to most frecent dir matching foo, then bar -.TP 14 -\fBz -r foo\fR -cd to highest ranked dir matching foo -.TP 14 -\fBz -t foo\fR -cd to most recently accessed dir matching foo -.TP 14 -\fBz -l foo\fR -list all dirs matching foo (by frecency) -.SH -NOTES -.SS -Installation: -.P -Put something like this in your \fB$HOME/.bashrc\fR or \fB$HOME/.zshrc\fR: -.RS -.P -\fB. /path/to/z.sh\fR -.RE -.P -\fBcd\fR around for a while to build up the db. -.P -PROFIT!! -.P -Optionally: -.RS -Set \fB$_Z_CMD\fR to change the command name (default \fBz\fR). -.RE -.RS -Set \fB$_Z_DATA\fR to change the datafile (default \fB$HOME/.z\fR). -.RE -.RS -Set \fB$_Z_MAX_SCORE\fR lower to age entries out faster (default \fB9000\fR). -.RE -.RS -Set \fB$_Z_NO_RESOLVE_SYMLINKS\fR to prevent symlink resolution. -.RE -.RS -Set \fB$_Z_NO_PROMPT_COMMAND\fR to handle \fBPROMPT_COMMAND/precmd\fR yourself. -.RE -.RS -Set \fB$_Z_EXCLUDE_DIRS\fR to an array of directory trees to exclude. -.RE -.RS -Set \fB$_Z_OWNER\fR to allow usage when in 'sudo -s' mode. -.RE -.RS -(These settings should go in .bashrc/.zshrc before the line added above.) -.RE -.RS -Install the provided man page \fBz.1\fR somewhere in your \f$MANPATH, like -\fB/usr/local/man/man1\fR. -.RE -.SS -Aging: -The rank of directories maintained by \fBz\fR undergoes aging based on a simple -formula. The rank of each entry is incremented every time it is accessed. When -the sum of ranks is over 9000, all ranks are multiplied by 0.99. Entries with a -rank lower than 1 are forgotten. -.SS -Frecency: -Frecency is a portmanteau of 'recent' and 'frequency'. It is a weighted rank -that depends on how often and how recently something occurred. As far as I -know, Mozilla came up with the term. -.P -To \fBz\fR, a directory that has low ranking but has been accessed recently -will quickly have higher rank than a directory accessed frequently a long time -ago. -.P -Frecency is determined at runtime. -.SS -Common: -When multiple directories match all queries, and they all have a common prefix, -\fBz\fR will cd to the shortest matching directory, without regard to priority. -This has been in effect, if undocumented, for quite some time, but should -probably be configurable or reconsidered. -.SS -Tab Completion: -\fBz\fR supports tab completion. After any number of arguments, press TAB to -complete on directories that match each argument. Due to limitations of the -completion implementations, only the last argument will be completed in the -shell. -.P -Internally, \fBz\fR decides you've requested a completion if the last argument -passed is an absolute path to an existing directory. This may cause unexpected -behavior if the last argument to \fBz\fR begins with \fB/\fR. -.SH -ENVIRONMENT -A function \fB_z()\fR is defined. -.P -The contents of the variable \fB$_Z_CMD\fR is aliased to \fB_z 2>&1\fR. If not -set, \fB$_Z_CMD\fR defaults to \fBz\fR. -.P -The environment variable \fB$_Z_DATA\fR can be used to control the datafile -location. If it is not defined, the location defaults to \fB$HOME/.z\fR. -.P -The environment variable \fB$_Z_NO_RESOLVE_SYMLINKS\fR can be set to prevent -resolving of symlinks. If it is not set, symbolic links will be resolved when -added to the datafile. -.P -In bash, \fBz\fR appends a command to the \fBPROMPT_COMMAND\fR environment -variable to maintain its database. In zsh, \fBz\fR appends a function -\fB_z_precmd\fR to the \fBprecmd_functions\fR array. -.P -The environment variable \fB$_Z_NO_PROMPT_COMMAND\fR can be set if you want to -handle \fBPROMPT_COMMAND\fR or \fBprecmd\fR yourself. -.P -The environment variable \fB$_Z_EXCLUDE_DIRS\fR can be set to an array of -directory trees to exclude from tracking. \fB$HOME\fR is always excluded. -Directories must be full paths without trailing slashes. -.P -The environment variable \fB$_Z_OWNER\fR can be set to your username, to -allow usage of \fBz\fR when your sudo environment keeps \fB$HOME\fR set. -.SH -FILES -Data is stored in \fB$HOME/.z\fR. This can be overridden by setting the -\fB$_Z_DATA\fR environment variable. When initialized, \fBz\fR will raise an -error if this path is a directory, and not function correctly. -.P -A man page (\fBz.1\fR) is provided. -.SH -SEE ALSO -regex(7), pushd, popd, autojump, cdargs -.P -Please file bugs at https://github.com/rupa/z/ diff --git a/plugins/z/z.plugin.zsh b/plugins/z/z.plugin.zsh index 7d3eacac0..209edfea7 100644 --- a/plugins/z/z.plugin.zsh +++ b/plugins/z/z.plugin.zsh @@ -1,6 +1,968 @@ -# Handle $0 according to the standard: -# https://zdharma-continuum.github.io/Zsh-100-Commits-Club/Zsh-Plugin-Standard.html -0="${${ZERO:-${0:#$ZSH_ARGZERO}}:-${(%):-%N}}" -0="${${(M)0:#/*}:-$PWD/$0}" +################################################################################ +# Zsh-z - jump around with Zsh - A native Zsh version of z without awk, sort, +# date, or sed +# +# https://github.com/agkozak/zsh-z +# +# Copyright (c) 2018-2022 Alexandros Kozak +# +# Permission is hereby granted, free of charge, to any person obtaining a copy +# of this software and associated documentation files (the "Software"), to deal +# in the Software without restriction, including without limitation the rights +# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +# copies of the Software, and to permit persons to whom the Software is +# furnished to do so, subject to the following conditions: +# +# The above copyright notice and this permission notice shall be included in all +# copies or substantial portions of the Software. +# +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +# SOFTWARE. +# +# z (https://github.com/rupa/z) is copyright (c) 2009 rupa deadwyler and +# licensed under the WTFPL license, Version 2. +# +# Zsh-z maintains a jump-list of the directories you actually use. +# +# INSTALL: +# * put something like this in your .zshrc: +# source /path/to/zsh-z.plugin.zsh +# * cd around for a while to build up the database +# +# USAGE: +# * z foo cd to the most frecent directory matching foo +# * z foo bar cd to the most frecent directory matching both foo and bar +# (e.g. /foo/bat/bar/quux) +# * z -r foo cd to the highest ranked directory matching foo +# * z -t foo cd to most recently accessed directory matching foo +# * z -l foo List matches instead of changing directories +# * z -e foo Echo the best match without changing directories +# * z -c foo Restrict matches to subdirectories of PWD +# * z -x Remove a directory (default: PWD) from the database +# * z -xR Remove a directory (default: PWD) and its subdirectories from +# the database +# +# ENVIRONMENT VARIABLES: +# +# ZSHZ_CASE -> if `ignore', pattern matching is case-insensitive; if `smart', +# pattern matching is case-insensitive only when the pattern is all +# lowercase +# ZSHZ_CMD -> name of command (default: z) +# ZSHZ_COMPLETION -> completion method (default: 'frecent'; 'legacy' for +# alphabetic sorting) +# ZSHZ_DATA -> name of datafile (default: ~/.z) +# ZSHZ_EXCLUDE_DIRS -> array of directories to exclude from your database +# (default: empty) +# ZSHZ_KEEP_DIRS -> array of directories that should not be removed from the +# database, even if they are not currently available (default: empty) +# ZSHZ_MAX_SCORE -> maximum combined score the database entries can have +# before beginning to age (default: 9000) +# ZSHZ_NO_RESOLVE_SYMLINKS -> '1' prevents symlink resolution +# ZSHZ_OWNER -> your username (if you want use Zsh-z while using sudo -s) +# ZSHZ_UNCOMMON -> if 1, do not jump to "common directories," but rather drop +# subdirectories based on what the search string was (default: 0) +################################################################################ -source "${0:h}/z.sh" +autoload -U is-at-least + +if ! is-at-least 4.3.11; then + print "Zsh-z requires Zsh v4.3.11 or higher." >&2 && exit +fi + +############################################################ +# The help message +# +# Globals: +# ZSHZ_CMD +############################################################ +_zshz_usage() { + print "Usage: ${ZSHZ_CMD:-${_Z_CMD:-z}} [OPTION]... [ARGUMENT] +Jump to a directory that you have visited frequently or recently, or a bit of both, based on the partial string ARGUMENT. + +With no ARGUMENT, list the directory history in ascending rank. + + --add Add a directory to the database + -c Only match subdirectories of the current directory + -e Echo the best match without going to it + -h Display this help and exit + -l List all matches without going to them + -r Match by rank + -t Match by recent access + -x Remove a directory from the database (by default, the current directory) + -xR Remove a directory and its subdirectories from the database (by default, the current directory)" | + fold -s -w $COLUMNS >&2 +} + +# Load zsh/datetime module, if necessary +(( $+EPOCHSECONDS )) || zmodload zsh/datetime + +# Load zsh/files, if necessary +[[ ${builtins[zf_chown]} == 'defined' && + ${builtins[zf_mv]} == 'defined' && + ${builtins[zf_rm]} == 'defined' ]] || + zmodload -F zsh/files b:zf_chown b:zf_mv b:zf_rm + +# Load zsh/system, if necessary +[[ ${modules[zsh/system]} == 'loaded' ]] || zmodload zsh/system &> /dev/null + +# Global associative array for internal use +typeset -gA ZSHZ + +# Make sure ZSHZ_EXCLUDE_DIRS has been declared so that other scripts can +# simply append to it +(( ${+ZSHZ_EXCLUDE_DIRS} )) || typeset -gUa ZSHZ_EXCLUDE_DIRS + +# Determine if zsystem flock is available +zsystem supports flock &> /dev/null && ZSHZ[USE_FLOCK]=1 + +# Determine if `print -v' is supported +is-at-least 5.3.0 && ZSHZ[PRINTV]=1 + +############################################################ +# The Zsh-z Command +# +# Globals: +# ZSHZ +# ZSHZ_CASE +# ZSHZ_COMPLETION +# ZSHZ_DATA +# ZSHZ_DEBUG +# ZSHZ_EXCLUDE_DIRS +# ZSHZ_KEEP_DIRS +# ZSHZ_MAX_SCORE +# ZSHZ_OWNER +# +# Arguments: +# $* Command options and arguments +############################################################ +zshz() { + + # Don't use `emulate -L zsh' - it breaks PUSHD_IGNORE_DUPS + setopt LOCAL_OPTIONS NO_KSH_ARRAYS NO_SH_WORD_SPLIT EXTENDED_GLOB + (( ZSHZ_DEBUG )) && setopt LOCAL_OPTIONS WARN_CREATE_GLOBAL + + local REPLY + local -a lines + + # Allow the user to specify the datafile name in $ZSHZ_DATA (default: ~/.z) + # If the datafile is a symlink, it gets dereferenced + local datafile=${${ZSHZ_DATA:-${_Z_DATA:-${HOME}/.z}}:A} + + # If the datafile is a directory, print a warning and exit + if [[ -d $datafile ]]; then + print "ERROR: Zsh-z's datafile (${datafile}) is a directory." >&2 + exit + fi + + # Make sure that the datafile exists before attempting to read it or lock it + # for writing + [[ -f $datafile ]] || touch "$datafile" + + # Bail if we don't own the datafile and $ZSHZ_OWNER is not set + [[ -z ${ZSHZ_OWNER:-${_Z_OWNER}} && -f $datafile && ! -O $datafile ]] && + return + + # Load the datafile into an array and parse it + lines=( ${(f)"$(< $datafile)"} ) + # Discard entries that are incomplete or incorrectly formatted + lines=( ${(M)lines:#/*\|[[:digit:]]##[.,]#[[:digit:]]#\|[[:digit:]]##} ) + + ############################################################ + # Add a path to or remove one from the datafile + # + # Globals: + # ZSHZ + # ZSHZ_EXCLUDE_DIRS + # ZSHZ_OWNER + # + # Arguments: + # $1 Which action to perform (--add/--remove) + # $2 The path to add + ############################################################ + _zshz_add_or_remove_path() { + local action=${1} + shift + + if [[ $action == '--add' ]]; then + + # TODO: The following tasks are now handled by _agkozak_precmd. Dead code? + + # Don't add $HOME + [[ $* == $HOME ]] && return + + # Don't track directory trees excluded in ZSHZ_EXCLUDE_DIRS + local exclude + for exclude in ${(@)ZSHZ_EXCLUDE_DIRS:-${(@)_Z_EXCLUDE_DIRS}}; do + case $* in + ${exclude}|${exclude}/*) return ;; + esac + done + fi + + # A temporary file that gets copied over the datafile if all goes well + local tempfile="${datafile}.${RANDOM}" + + # See https://github.com/rupa/z/pull/199/commits/ed6eeed9b70d27c1582e3dd050e72ebfe246341c + if (( ZSHZ[USE_FLOCK] )); then + + local lockfd + + # Grab exclusive lock (released when function exits) + zsystem flock -f lockfd "$datafile" 2> /dev/null || return + + fi + + integer tmpfd + case $action in + --add) + exec {tmpfd}>|"$tempfile" # Open up tempfile for writing + _zshz_update_datafile $tmpfd "$*" + local ret=$? + ;; + --remove) + local xdir # Directory to be removed + + if (( ${ZSHZ_NO_RESOLVE_SYMLINKS:-${_Z_NO_RESOLVE_SYMLINKS}} )); then + [[ -d ${${*:-${PWD}}:a} ]] && xdir=${${*:-${PWD}}:a} + else + [[ -d ${${*:-${PWD}}:A} ]] && xdir=${${*:-${PWD}}:a} + fi + + local -a lines_to_keep + if (( ${+opts[-R]} )); then + # Prompt user before deleting entire database + if [[ $xdir == '/' ]] && ! read -q "?Delete entire Zsh-z database? "; then + print && return 1 + fi + # All of the lines that don't match the directory to be deleted + lines_to_keep=( ${lines:#${xdir}\|*} ) + # Or its subdirectories + lines_to_keep=( ${lines_to_keep:#${xdir%/}/**} ) + else + # All of the lines that don't match the directory to be deleted + lines_to_keep=( ${lines:#${xdir}\|*} ) + fi + if [[ $lines != "$lines_to_keep" ]]; then + lines=( $lines_to_keep ) + else + return 1 # The $PWD isn't in the datafile + fi + exec {tmpfd}>|"$tempfile" # Open up tempfile for writing + print -u $tmpfd -l -- $lines + local ret=$? + ;; + esac + + if (( tmpfd != 0 )); then + # Close tempfile + exec {tmpfd}>&- + fi + + if (( ret != 0 )); then + # Avoid clobbering the datafile if the write to tempfile failed + zf_rm -f "$tempfile" + return $ret + fi + + local owner + owner=${ZSHZ_OWNER:-${_Z_OWNER}} + + if (( ZSHZ[USE_FLOCK] )); then + zf_mv "$tempfile" "$datafile" 2> /dev/null || zf_rm -f "$tempfile" + + if [[ -n $owner ]]; then + zf_chown ${owner}:"$(id -ng ${owner})" "$datafile" + fi + else + if [[ -n $owner ]]; then + zf_chown "${owner}":"$(id -ng "${owner}")" "$tempfile" + fi + zf_mv -f "$tempfile" "$datafile" 2> /dev/null || zf_rm -f "$tempfile" + fi + + # In order to make z -x work, we have to disable zsh-z's adding + # to the database until the user changes directory and the + # chpwd_functions are run + if [[ $action == '--remove' ]]; then + ZSHZ[DIRECTORY_REMOVED]=1 + fi + } + + ############################################################ + # Read the curent datafile contents, update them, "age" them + # when the total rank gets high enough, and print the new + # contents to STDOUT. + # + # Globals: + # ZSHZ_KEEP_DIRS + # ZSHZ_MAX_SCORE + # + # Arguments: + # $1 File descriptor linked to tempfile + # $2 Path to be added to datafile + ############################################################ + _zshz_update_datafile() { + + integer fd=$1 + local -A rank time + + # Characters special to the shell (such as '[]') are quoted with backslashes + # See https://github.com/rupa/z/issues/246 + local add_path=${(q)2} + + local -a existing_paths + local now=$EPOCHSECONDS line dir + local path_field rank_field time_field count x + + rank[$add_path]=1 + time[$add_path]=$now + + # Remove paths from database if they no longer exist + for line in $lines; do + if [[ ! -d ${line%%\|*} ]]; then + for dir in ${(@)ZSHZ_KEEP_DIRS}; do + if [[ ${line%%\|*} == ${dir}/* || + ${line%%\|*} == $dir || + $dir == '/' ]]; then + existing_paths+=( $line ) + fi + done + else + existing_paths+=( $line ) + fi + done + lines=( $existing_paths ) + + for line in $lines; do + path_field=${(q)line%%\|*} + rank_field=${${line%\|*}#*\|} + time_field=${line##*\|} + + # When a rank drops below 1, drop the path from the database + (( rank_field < 1 )) && continue + + if [[ $path_field == $add_path ]]; then + rank[$path_field]=$rank_field + (( rank[$path_field]++ )) + time[$path_field]=$now + else + rank[$path_field]=$rank_field + time[$path_field]=$time_field + fi + (( count += rank_field )) + done + if (( count > ${ZSHZ_MAX_SCORE:-${_Z_MAX_SCORE:-9000}} )); then + # Aging + for x in ${(k)rank}; do + print -u $fd -- "$x|$(( 0.99 * rank[$x] ))|${time[$x]}" || return 1 + done + else + for x in ${(k)rank}; do + print -u $fd -- "$x|${rank[$x]}|${time[$x]}" || return 1 + done + fi + } + + ############################################################ + # The original tab completion method + # + # String processing is smartcase -- case-insensitive if the + # search string is lowercase, case-sensitive if there are + # any uppercase letters. Spaces in the search string are + # treated as *'s in globbing. Read the contents of the + # datafile and print matches to STDOUT. + # + # Arguments: + # $1 The string to be completed + ############################################################ + _zshz_legacy_complete() { + + local line path_field path_field_normalized + + # Replace spaces in the search string with asterisks for globbing + 1=${1//[[:space:]]/*} + + for line in $lines; do + + path_field=${line%%\|*} + + path_field_normalized=$path_field + if (( ZSHZ_TRAILING_SLASH )); then + path_field_normalized=${path_field%/}/ + fi + + # If the search string is all lowercase, the search will be case-insensitive + if [[ $1 == "${1:l}" && ${path_field_normalized:l} == *${~1}* ]]; then + print -- $path_field + # Otherwise, case-sensitive + elif [[ $path_field_normalized == *${~1}* ]]; then + print -- $path_field + fi + + done + # TODO: Search strings with spaces in them are currently treated case- + # insensitively. + } + + ############################################################ + # `print' or `printf' to REPLY + # + # Variable assignment through command substitution, of the + # form + # + # foo=$( bar ) + # + # requires forking a subshell; on Cygwin/MSYS2/WSL1 that can + # be surprisingly slow. Zsh-z avoids doing that by printing + # values to the variable REPLY. Since Zsh v5.3.0 that has + # been possible with `print -v'; for earlier versions of the + # shell, the values are placed on the editing buffer stack + # and then `read' into REPLY. + # + # Globals: + # ZSHZ + # + # Arguments: + # Options and parameters for `print' + ############################################################ + _zshz_printv() { + # NOTE: For a long time, ZSH's `print -v' had a tendency + # to mangle multibyte strings: + # + # https://www.zsh.org/mla/workers/2020/msg00307.html + # + # The bug was fixed in late 2020: + # + # https://github.com/zsh-users/zsh/commit/b6ba74cd4eaec2b6cb515748cf1b74a19133d4a4#diff-32bbef18e126b837c87b06f11bfc61fafdaa0ed99fcb009ec53f4767e246b129 + # + # In order to support shells with the bug, we must use a form of `printf`, + # which does not exhibit the undesired behavior. See + # + # https://www.zsh.org/mla/workers/2020/msg00308.html + + if (( ZSHZ[PRINTV] )); then + builtin print -v REPLY -f %s $@ + else + builtin print -z $@ + builtin read -rz REPLY + fi + } + + ############################################################ + # If matches share a common root, find it, and put it in + # REPLY for _zshz_output to use. + # + # Arguments: + # $1 Name of associative array of matches and ranks + ############################################################ + _zshz_find_common_root() { + local -a common_matches + local x short + + common_matches=( ${(@Pk)1} ) + + for x in ${(@)common_matches}; do + if [[ -z $short ]] || (( $#x < $#short )) || [[ $x != ${short}/* ]]; then + short=$x + fi + done + + [[ $short == '/' ]] && return + + for x in ${(@)common_matches}; do + [[ $x != $short* ]] && return + done + + _zshz_printv -- $short + } + + ############################################################ + # Calculate a common root, if there is one. Then do one of + # the following: + # + # 1) Print a list of completions in frecent order; + # 2) List them (z -l) to STDOUT; or + # 3) Put a common root or best match into REPLY + # + # Globals: + # ZSHZ_UNCOMMON + # + # Arguments: + # $1 Name of an associative array of matches and ranks + # $2 The best match or best case-insensitive match + # $3 Whether to produce a completion, a list, or a root or + # match + ############################################################ + _zshz_output() { + + local match_array=$1 match=$2 format=$3 + local common k x + local -a descending_list output + local -A output_matches + + output_matches=( ${(Pkv)match_array} ) + + _zshz_find_common_root $match_array + common=$REPLY + + case $format in + + completion) + for k in ${(@k)output_matches}; do + _zshz_printv -f "%.2f|%s" ${output_matches[$k]} $k + descending_list+=( ${(f)REPLY} ) + REPLY='' + done + descending_list=( ${${(@On)descending_list}#*\|} ) + print -l $descending_list + ;; + + list) + local path_to_display + for x in ${(k)output_matches}; do + if (( ${output_matches[$x]} )); then + path_to_display=$x + (( ZSHZ_TILDE )) && + path_to_display=${path_to_display/#${HOME}/\~} + _zshz_printv -f "%-10d %s\n" ${output_matches[$x]} $path_to_display + output+=( ${(f)REPLY} ) + REPLY='' + fi + done + if [[ -n $common ]]; then + (( ZSHZ_TILDE )) && common=${common/#${HOME}/\~} + (( $#output > 1 )) && printf "%-10s %s\n" 'common:' $common + fi + # -lt + if (( $+opts[-t] )); then + for x in ${(@On)output}; do + print -- $x + done + # -lr + elif (( $+opts[-r] )); then + for x in ${(@on)output}; do + print -- $x + done + # -l + else + for x in ${(@on)output}; do + print $x + done + fi + ;; + + *) + if (( ! ZSHZ_UNCOMMON )) && [[ -n $common ]]; then + _zshz_printv -- $common + else + _zshz_printv -- ${(P)match} + fi + ;; + esac + } + + ############################################################ + # Match a pattern by rank, time, or a combination of the + # two, and output the results as completions, a list, or a + # best match. + # + # Globals: + # ZSHZ + # ZSHZ_CASE + # ZSHZ_KEEP_DIRS + # ZSHZ_OWNER + # + # Arguments: + # #1 Pattern to match + # $2 Matching method (rank, time, or [default] frecency) + # $3 Output format (completion, list, or [default] store + # in REPLY + ############################################################ + _zshz_find_matches() { + setopt LOCAL_OPTIONS NO_EXTENDED_GLOB + + local fnd=$1 method=$2 format=$3 + + local -a existing_paths + local line dir path_field rank_field time_field rank dx escaped_path_field + local -A matches imatches + local best_match ibest_match hi_rank=-9999999999 ihi_rank=-9999999999 + + # Remove paths from database if they no longer exist + for line in $lines; do + if [[ ! -d ${line%%\|*} ]]; then + for dir in ${(@)ZSHZ_KEEP_DIRS}; do + if [[ ${line%%\|*} == ${dir}/* || + ${line%%\|*} == $dir || + $dir == '/' ]]; then + existing_paths+=( $line ) + fi + done + else + existing_paths+=( $line ) + fi + done + lines=( $existing_paths ) + + for line in $lines; do + path_field=${line%%\|*} + rank_field=${${line%\|*}#*\|} + time_field=${line##*\|} + + case $method in + rank) rank=$rank_field ;; + time) (( rank = time_field - EPOCHSECONDS )) ;; + *) + # Frecency routine + (( dx = EPOCHSECONDS - time_field )) + rank=$(( 10000 * rank_field * (3.75/((0.0001 * dx + 1) + 0.25)) )) + ;; + esac + + # Use spaces as wildcards + local q=${fnd//[[:space:]]/\*} + + # If $ZSHZ_TRAILING_SLASH is set, use path_field with a trailing slash for matching. + local path_field_normalized=$path_field + if (( ZSHZ_TRAILING_SLASH )); then + path_field_normalized=${path_field%/}/ + fi + + # If $ZSHZ_CASE is 'ignore', be case-insensitive. + # + # If it's 'smart', be case-insensitive unless the string to be matched + # includes capital letters. + # + # Otherwise, the default behavior of Zsh-z is to match case-sensitively if + # possible, then to fall back on a case-insensitive match if possible. + if [[ $ZSHZ_CASE == 'smart' && ${1:l} == $1 && + ${path_field_normalized:l} == ${~q:l} ]]; then + imatches[$path_field]=$rank + elif [[ $ZSHZ_CASE != 'ignore' && $path_field_normalized == ${~q} ]]; then + matches[$path_field]=$rank + elif [[ $ZSHZ_CASE != 'smart' && ${path_field_normalized:l} == ${~q:l} ]]; then + imatches[$path_field]=$rank + fi + + # Escape characters that would cause "invalid subscript" errors + # when accessing the associative array. + escaped_path_field=${path_field//'\'/'\\'} + escaped_path_field=${escaped_path_field//'`'/'\`'} + escaped_path_field=${escaped_path_field//'('/'\('} + escaped_path_field=${escaped_path_field//')'/'\)'} + escaped_path_field=${escaped_path_field//'['/'\['} + escaped_path_field=${escaped_path_field//']'/'\]'} + + if (( matches[$escaped_path_field] )) && + (( matches[$escaped_path_field] > hi_rank )); then + best_match=$path_field + hi_rank=${matches[$escaped_path_field]} + elif (( imatches[$escaped_path_field] )) && + (( imatches[$escaped_path_field] > ihi_rank )); then + ibest_match=$path_field + ihi_rank=${imatches[$escaped_path_field]} + ZSHZ[CASE_INSENSITIVE]=1 + fi + done + + # Return 1 when there are no matches + [[ -z $best_match && -z $ibest_match ]] && return 1 + + if [[ -n $best_match ]]; then + _zshz_output matches best_match $format + elif [[ -n $ibest_match ]]; then + _zshz_output imatches ibest_match $format + fi + } + + # THE MAIN ROUTINE + + local -A opts + + zparseopts -E -D -A opts -- \ + -add \ + -complete \ + c \ + e \ + h \ + -help \ + l \ + r \ + R \ + t \ + x + + if [[ $1 == '--' ]]; then + shift + elif [[ -n ${(M)@:#-*} && -z $compstate ]]; then + print "Improper option(s) given." + _zshz_usage + return 1 + fi + + local opt output_format method='frecency' fnd prefix req + + for opt in ${(k)opts}; do + case $opt in + --add) + [[ ! -d $* ]] && return 1 + local dir + # Cygwin and MSYS2 have a hard time with relative paths expressed from / + if [[ $OSTYPE == (cygwin|msys) && $PWD == '/' && $* != /* ]]; then + set -- "/$*" + fi + if (( ${ZSHZ_NO_RESOLVE_SYMLINKS:-${_Z_NO_RESOLVE_SYMLINKS}} )); then + dir=${*:a} + else + dir=${*:A} + fi + _zshz_add_or_remove_path --add "$dir" + return + ;; + --complete) + if [[ -s $datafile && ${ZSHZ_COMPLETION:-frecent} == 'legacy' ]]; then + _zshz_legacy_complete "$1" + return + fi + output_format='completion' + ;; + -c) [[ $* == ${PWD}/* || $PWD == '/' ]] || prefix="$PWD " ;; + -h|--help) + _zshz_usage + return + ;; + -l) output_format='list' ;; + -r) method='rank' ;; + -t) method='time' ;; + -x) + # Cygwin and MSYS2 have a hard time with relative paths expressed from / + if [[ $OSTYPE == (cygwin|msys) && $PWD == '/' && $* != /* ]]; then + set -- "/$*" + fi + _zshz_add_or_remove_path --remove $* + return + ;; + esac + done + req="$*" + fnd="$prefix$*" + + [[ -n $fnd && $fnd != "$PWD " ]] || { + [[ $output_format != 'completion' ]] && output_format='list' + } + + ######################################################### + # If $ZSHZ_ECHO == 1, display paths as you jump to them. + # If it is also the case that $ZSHZ_TILDE == 1, display + # the home directory as a tilde. + ######################################################### + _zshz_echo() { + if (( ZSHZ_ECHO )); then + if (( ZSHZ_TILDE )); then + print ${PWD/#${HOME}/\~} + else + print $PWD + fi + fi + } + + if [[ ${@: -1} == /* ]] && (( ! $+opts[-e] && ! $+opts[-l] )); then + # cd if possible; echo the new path if $ZSHZ_ECHO == 1 + [[ -d ${@: -1} ]] && builtin cd ${@: -1} && _zshz_echo && return + fi + + # With option -c, make sure query string matches beginning of matches; + # otherwise look for matches anywhere in paths + + # zpm-zsh/colors has a global $c, so we'll avoid math expressions here + if [[ ! -z ${(tP)opts[-c]} ]]; then + _zshz_find_matches "$fnd*" $method $output_format + else + _zshz_find_matches "*$fnd*" $method $output_format + fi + + local ret2=$? + + local cd + cd=$REPLY + + # New experimental "uncommon" behavior + # + # If the best choice at this point is something like /foo/bar/foo/bar, and the # search pattern is `bar', go to /foo/bar/foo/bar; but if the search pattern + # is `foo', go to /foo/bar/foo + if (( ZSHZ_UNCOMMON )) && [[ -n $cd ]]; then + if [[ -n $cd ]]; then + + # In the search pattern, replace spaces with * + local q=${fnd//[[:space:]]/\*} + q=${q%/} # Trailing slash has to be removed + + # As long as the best match is not case-insensitive + if (( ! ZSHZ[CASE_INSENSITIVE] )); then + # Count the number of characters in $cd that $q matches + local q_chars=$(( ${#cd} - ${#${cd//${~q}/}} )) + # Try dropping directory elements from the right; stop when it affects + # how many times the search pattern appears + until (( ( ${#cd:h} - ${#${${cd:h}//${~q}/}} ) != q_chars )); do + cd=${cd:h} + done + + # If the best match is case-insensitive + else + local q_chars=$(( ${#cd} - ${#${${cd:l}//${~${q:l}}/}} )) + until (( ( ${#cd:h} - ${#${${${cd:h}:l}//${~${q:l}}/}} ) != q_chars )); do + cd=${cd:h} + done + fi + + ZSHZ[CASE_INSENSITIVE]=0 + fi + fi + + if (( ret2 == 0 )) && [[ -n $cd ]]; then + if (( $+opts[-e] )); then # echo + (( ZSHZ_TILDE )) && cd=${cd/#${HOME}/\~} + print -- "$cd" + else + # cd if possible; echo the new path if $ZSHZ_ECHO == 1 + [[ -d $cd ]] && builtin cd "$cd" && _zshz_echo + fi + else + # if $req is a valid path, cd to it; echo the new path if $ZSHZ_ECHO == 1 + if ! (( $+opts[-e] || $+opts[-l] )) && [[ -d $req ]]; then + builtin cd "$req" && _zshz_echo + else + return $ret2 + fi + fi +} + +alias ${ZSHZ_CMD:-${_Z_CMD:-z}}='zshz 2>&1' + +############################################################ +# precmd - add path to datafile unless `z -x' has just been +# run +# +# Globals: +# ZSHZ +############################################################ +_zshz_precmd() { + # Do not add PWD to datafile when in HOME directory, or + # if `z -x' has just been run + [[ $PWD == "$HOME" ]] || (( ZSHZ[DIRECTORY_REMOVED] )) && return + + # Don't track directory trees excluded in ZSHZ_EXCLUDE_DIRS + local exclude + for exclude in ${(@)ZSHZ_EXCLUDE_DIRS:-${(@)_Z_EXCLUDE_DIRS}}; do + case $PWD in + ${exclude}|${exclude}/*) return ;; + esac + done + + # It appears that forking a subshell is so slow in Windows that it is better + # just to add the PWD to the datafile in the foreground + if [[ $OSTYPE == (cygwin|msys) ]]; then + zshz --add "$PWD" + else + (zshz --add "$PWD" &) + fi + + # See https://github.com/rupa/z/pull/247/commits/081406117ea42ccb8d159f7630cfc7658db054b6 + : $RANDOM +} + +############################################################ +# chpwd +# +# When the $PWD is removed from the datafile with `z -x', +# Zsh-z refrains from adding it again until the user has +# left the directory. +# +# Globals: +# ZSHZ +############################################################ +_zshz_chpwd() { + ZSHZ[DIRECTORY_REMOVED]=0 +} + +autoload -Uz add-zsh-hook + +add-zsh-hook precmd _zshz_precmd +add-zsh-hook chpwd _zshz_chpwd + +############################################################ +# Completion +############################################################ + +# Standarized $0 handling +# (See https://github.com/agkozak/Zsh-100-Commits-Club/blob/master/Zsh-Plugin-Standard.adoc) +0=${${ZERO:-${0:#$ZSH_ARGZERO}}:-${(%):-%N}} +0=${${(M)0:#/*}:-$PWD/$0} + +(( ${fpath[(ie)${0:A:h}]} <= ${#fpath} )) || fpath=( "${0:A:h}" "${fpath[@]}" ) + +############################################################ +# zsh-z functions +############################################################ +ZSHZ[FUNCTIONS]='_zshz_usage + _zshz_add_or_remove_path + _zshz_update_datafile + _zshz_legacy_complete + _zshz_printv + _zshz_find_common_root + _zshz_output + _zshz_find_matches + zshz + _zshz_precmd + _zshz_chpwd + _zshz' + +############################################################ +# Enable WARN_NESTED_VAR for functions listed in +# ZSHZ[FUNCTIONS] +############################################################ +(( ZSHZ_DEBUG )) && () { + if is-at-least 5.4.0; then + local x + for x in ${=ZSHZ[FUNCTIONS]}; do + functions -W $x + done + fi +} + +############################################################ +# Unload function +# +# See https://github.com/agkozak/Zsh-100-Commits-Club/blob/master/Zsh-Plugin-Standard.adoc#unload-fun +# +# Globals: +# ZSHZ +# ZSHZ_CMD +############################################################ +zsh-z_plugin_unload() { + emulate -L zsh + + add-zsh-hook -D precmd _zshz_precmd + add-zsh-hook -d chpwd _zshz_chpwd + + local x + for x in ${=ZSHZ[FUNCTIONS]}; do + (( ${+functions[$x]} )) && unfunction $x + done + + unset ZSHZ + + fpath=( "${(@)fpath:#${0:A:h}}" ) + + (( ${+aliases[${ZSHZ_CMD:-${_Z_CMD:-z}}]} )) && + unalias ${ZSHZ_CMD:-${_Z_CMD:-z}} + + unfunction $0 +} + +# vim: fdm=indent:ts=2:et:sts=2:sw=2: diff --git a/plugins/z/z.sh b/plugins/z/z.sh deleted file mode 100644 index 67f504e27..000000000 --- a/plugins/z/z.sh +++ /dev/null @@ -1,267 +0,0 @@ -# Copyright (c) 2009 rupa deadwyler. Licensed under the WTFPL license, Version 2 - -# maintains a jump-list of the directories you actually use -# -# INSTALL: -# * put something like this in your .bashrc/.zshrc: -# . /path/to/z.sh -# * cd around for a while to build up the db -# * PROFIT!! -# * optionally: -# set $_Z_CMD in .bashrc/.zshrc to change the command (default z). -# set $_Z_DATA in .bashrc/.zshrc to change the datafile (default ~/.z). -# set $_Z_MAX_SCORE lower to age entries out faster (default 9000). -# set $_Z_NO_RESOLVE_SYMLINKS to prevent symlink resolution. -# set $_Z_NO_PROMPT_COMMAND if you're handling PROMPT_COMMAND yourself. -# set $_Z_EXCLUDE_DIRS to an array of directories to exclude. -# set $_Z_OWNER to your username if you want use z while sudo with $HOME kept -# -# USE: -# * z foo # cd to most frecent dir matching foo -# * z foo bar # cd to most frecent dir matching foo and bar -# * z -r foo # cd to highest ranked dir matching foo -# * z -t foo # cd to most recently accessed dir matching foo -# * z -l foo # list matches instead of cd -# * z -e foo # echo the best match, don't cd -# * z -c foo # restrict matches to subdirs of $PWD -# * z -x # remove the current directory from the datafile -# * z -h # show a brief help message - -[ -d "${_Z_DATA:-$HOME/.z}" ] && { - echo "ERROR: z.sh's datafile (${_Z_DATA:-$HOME/.z}) is a directory." -} - -_z() { - - local datafile="${_Z_DATA:-$HOME/.z}" - - # if symlink, dereference - [ -h "$datafile" ] && datafile=$(readlink "$datafile") - - # bail if we don't own ~/.z and $_Z_OWNER not set - [ -z "$_Z_OWNER" -a -f "$datafile" -a ! -O "$datafile" ] && return - - _z_dirs () { - [ -f "$datafile" ] || return - - local line - while read line; do - # only count directories - [ -d "${line%%\|*}" ] && echo "$line" - done < "$datafile" - return 0 - } - - # add entries - if [ "$1" = "--add" ]; then - shift - - # $HOME and / aren't worth matching - [ "$*" = "$HOME" -o "$*" = '/' ] && return - - # don't track excluded directory trees - if [ ${#_Z_EXCLUDE_DIRS[@]} -gt 0 ]; then - local exclude - for exclude in "${_Z_EXCLUDE_DIRS[@]}"; do - case "$*" in "$exclude"*) return;; esac - done - fi - - # maintain the data file - local tempfile="$datafile.$RANDOM" - local score=${_Z_MAX_SCORE:-9000} - _z_dirs | awk -v path="$*" -v now="$(date +%s)" -v score=$score -F"|" ' - BEGIN { - rank[path] = 1 - time[path] = now - } - $2 >= 1 { - # drop ranks below 1 - if( $1 == path ) { - rank[$1] = $2 + 1 - time[$1] = now - } else { - rank[$1] = $2 - time[$1] = $3 - } - count += $2 - } - END { - if( count > score ) { - # aging - for( x in rank ) print x "|" 0.99*rank[x] "|" time[x] - } else for( x in rank ) print x "|" rank[x] "|" time[x] - } - ' 2>/dev/null >| "$tempfile" - # do our best to avoid clobbering the datafile in a race condition. - if [ $? -ne 0 -a -f "$datafile" ]; then - env rm -f "$tempfile" - else - [ "$_Z_OWNER" ] && chown $_Z_OWNER:"$(id -ng $_Z_OWNER)" "$tempfile" - env mv -f "$tempfile" "$datafile" || env rm -f "$tempfile" - fi - - # tab completion - elif [ "$1" = "--complete" -a -s "$datafile" ]; then - _z_dirs | awk -v q="$2" -F"|" ' - BEGIN { - q = substr(q, 3) - if( q == tolower(q) ) imatch = 1 - gsub(/ /, ".*", q) - } - { - if( imatch ) { - if( tolower($1) ~ q ) print $1 - } else if( $1 ~ q ) print $1 - } - ' 2>/dev/null - - else - # list/go - local echo fnd last list opt typ - while [ "$1" ]; do case "$1" in - --) while [ "$1" ]; do shift; fnd="$fnd${fnd:+ }$1";done;; - -*) opt=${1:1}; while [ "$opt" ]; do case ${opt:0:1} in - c) fnd="^$PWD $fnd";; - e) echo=1;; - h) echo "${_Z_CMD:-z} [-cehlrtx] args" >&2; return;; - l) list=1;; - r) typ="rank";; - t) typ="recent";; - x) sed -i -e "\:^${PWD}|.*:d" "$datafile";; - esac; opt=${opt:1}; done;; - *) fnd="$fnd${fnd:+ }$1";; - esac; last=$1; [ "$#" -gt 0 ] && shift; done - [ "$fnd" -a "$fnd" != "^$PWD " ] || list=1 - - # if we hit enter on a completion just go there - case "$last" in - # completions will always start with / - /*) [ -z "$list" -a -d "$last" ] && builtin cd "$last" && return;; - esac - - # no file yet - [ -f "$datafile" ] || return - - local cd - cd="$( < <( _z_dirs ) awk -v t="$(date +%s)" -v list="$list" -v typ="$typ" -v q="$fnd" -F"|" ' - function frecent(rank, time) { - # relate frequency and time - dx = t - time - return int(10000 * rank * (3.75/((0.0001 * dx + 1) + 0.25))) - } - function output(matches, best_match, common) { - # list or return the desired directory - if( list ) { - if( common ) { - printf "%-10s %s\n", "common:", common > "/dev/stderr" - } - cmd = "sort -n >&2" - for( x in matches ) { - if( matches[x] ) { - printf "%-10s %s\n", matches[x], x | cmd - } - } - } else { - if( common && !typ ) best_match = common - print best_match - } - } - function common(matches) { - # find the common root of a list of matches, if it exists - for( x in matches ) { - if( matches[x] && (!short || length(x) < length(short)) ) { - short = x - } - } - if( short == "/" ) return - for( x in matches ) if( matches[x] && index(x, short) != 1 ) { - return - } - return short - } - BEGIN { - gsub(" ", ".*", q) - hi_rank = ihi_rank = -9999999999 - } - { - if( typ == "rank" ) { - rank = $2 - } else if( typ == "recent" ) { - rank = $3 - t - } else rank = frecent($2, $3) - if( $1 ~ q ) { - matches[$1] = rank - } else if( tolower($1) ~ tolower(q) ) imatches[$1] = rank - if( matches[$1] && matches[$1] > hi_rank ) { - best_match = $1 - hi_rank = matches[$1] - } else if( imatches[$1] && imatches[$1] > ihi_rank ) { - ibest_match = $1 - ihi_rank = imatches[$1] - } - } - END { - # prefer case sensitive - if( best_match ) { - output(matches, best_match, common(matches)) - exit - } else if( ibest_match ) { - output(imatches, ibest_match, common(imatches)) - exit - } - exit(1) - } - ')" - - if [ "$?" -eq 0 ]; then - if [ "$cd" ]; then - if [ "$echo" ]; then echo "$cd"; else builtin cd "$cd"; fi - fi - else - return $? - fi - fi -} - -alias ${_Z_CMD:-z}='_z 2>&1' - -[ "$_Z_NO_RESOLVE_SYMLINKS" ] || _Z_RESOLVE_SYMLINKS="-P" - -if type compctl >/dev/null 2>&1; then - # zsh - [ "$_Z_NO_PROMPT_COMMAND" ] || { - # populate directory list, avoid clobbering any other precmds. - if [ "$_Z_NO_RESOLVE_SYMLINKS" ]; then - _z_precmd() { - (_z --add "${PWD:a}" &) - : $RANDOM - } - else - _z_precmd() { - (_z --add "${PWD:A}" &) - : $RANDOM - } - fi - [[ -n "${precmd_functions[(r)_z_precmd]}" ]] || { - precmd_functions[$(($#precmd_functions+1))]=_z_precmd - } - } - _z_zsh_tab_completion() { - # tab completion - local compl - read -l compl - reply=(${(f)"$(_z --complete "$compl")"}) - } - compctl -U -K _z_zsh_tab_completion _z -elif type complete >/dev/null 2>&1; then - # bash - # tab completion - complete -o filenames -C '_z --complete "$COMP_LINE"' ${_Z_CMD:-z} - [ "$_Z_NO_PROMPT_COMMAND" ] || { - # populate directory list. avoid clobbering other PROMPT_COMMANDs. - grep "_z --add" <<< "$PROMPT_COMMAND" >/dev/null || { - PROMPT_COMMAND="$PROMPT_COMMAND"$'\n''(_z --add "$(command pwd '$_Z_RESOLVE_SYMLINKS' 2>/dev/null)" 2>/dev/null &);' - } - } -fi From 8487a5536d247927216dd22041c1c32bcd100256 Mon Sep 17 00:00:00 2001 From: Carlo Date: Tue, 18 Oct 2022 19:38:47 +0200 Subject: [PATCH 047/672] fix(cli): avoid using `column` (#11271) --- lib/cli.zsh | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/lib/cli.zsh b/lib/cli.zsh index f15bd6d63..fed00d21d 100644 --- a/lib/cli.zsh +++ b/lib/cli.zsh @@ -416,14 +416,14 @@ function _omz::plugin::list { if (( ${#custom_plugins} )); then print -P "%U%BCustom plugins%b%u:" - print -l ${(q-)custom_plugins} | column -x + print -lac ${(q-)custom_plugins} fi if (( ${#builtin_plugins} )); then (( ${#custom_plugins} )) && echo # add a line of separation print -P "%U%BBuilt-in plugins%b%u:" - print -l ${(q-)builtin_plugins} | column -x + print -lac ${(q-)builtin_plugins} fi } @@ -674,13 +674,13 @@ function _omz::theme::list { # Print custom themes if there are any if (( ${#custom_themes} )); then print -P "%U%BCustom themes%b%u:" - print -l ${(q-)custom_themes} | column -x + print -lac ${(q-)custom_themes} echo fi # Print built-in themes print -P "%U%BBuilt-in themes%b%u:" - print -l ${(q-)builtin_themes} | column -x + print -lac ${(q-)builtin_themes} } function _omz::theme::set { From 4e4961e60c6e4bb6a3bd30bc70576f00ea519930 Mon Sep 17 00:00:00 2001 From: Yuval Date: Tue, 18 Oct 2022 19:40:02 +0200 Subject: [PATCH 048/672] feat(aliases): add basic argument parsing (#10710) --- plugins/aliases/README.md | 6 ++++++ plugins/aliases/cheatsheet.py | 25 +++++++++++++++++++------ 2 files changed, 25 insertions(+), 6 deletions(-) diff --git a/plugins/aliases/README.md b/plugins/aliases/README.md index bfb6ab8c4..66fd84584 100644 --- a/plugins/aliases/README.md +++ b/plugins/aliases/README.md @@ -17,6 +17,12 @@ Requirements: Python needs to be installed. - `acs`: show all aliases by group. +- `acs -h/--help`: print help mesage. + - `acs `: filter aliases by `` and highlight. +- `acs -g /--group `. Multiple uses of the flag show all groups, + +- `acs --groups-only`: show only group names + ![screenshot](https://cloud.githubusercontent.com/assets/3602957/11581913/cb54fb8a-9a82-11e5-846b-5a67f67ad9ad.png) diff --git a/plugins/aliases/cheatsheet.py b/plugins/aliases/cheatsheet.py index a7e3968b0..3362a6ab6 100644 --- a/plugins/aliases/cheatsheet.py +++ b/plugins/aliases/cheatsheet.py @@ -2,6 +2,7 @@ import sys import itertools import termcolor +import argparse def parse(line): left = line[0:line.find('=')].strip() @@ -26,7 +27,7 @@ def cheatsheet(lines): target_aliases.extend(group_list) return cheatsheet -def pretty_print_group(key, aliases, highlight=None): +def pretty_print_group(key, aliases, highlight=None, only_groupname=False): if len(aliases) == 0: return group_hl_formatter = lambda g, hl: termcolor.colored(hl, 'yellow').join([termcolor.colored(part, 'red') for part in ('[%s]' % g).split(hl)]) @@ -35,21 +36,33 @@ def pretty_print_group(key, aliases, highlight=None): alias_formatter = lambda alias: termcolor.colored('\t%s = %s' % alias[0:2], 'green') if highlight and len(highlight)>0: print (group_hl_formatter(key, highlight)) - print ('\n'.join([alias_hl_formatter(alias, highlight) for alias in aliases])) + if not only_groupname: + print ('\n'.join([alias_hl_formatter(alias, highlight) for alias in aliases])) else: print (group_formatter(key)) - print ('\n'.join([alias_formatter(alias) for alias in aliases])) + if not only_groupname: + print ('\n'.join([alias_formatter(alias) for alias in aliases])) print ('') -def pretty_print(cheatsheet, wfilter): +def pretty_print(cheatsheet, wfilter, group_list=None, groups_only=False): sorted_key = sorted(cheatsheet.keys()) for key in sorted_key: + if group_list and key not in group_list: + continue aliases = cheatsheet.get(key) if not wfilter: - pretty_print_group(key, aliases, wfilter) + pretty_print_group(key, aliases, wfilter, groups_only) else: pretty_print_group(key, [ alias for alias in aliases if alias[0].find(wfilter)>-1 or alias[1].find(wfilter)>-1], wfilter) if __name__ == '__main__': + parser = argparse.ArgumentParser(description="Pretty print aliases.") + parser.add_argument('filter', nargs="*", help="search aliases matching string") + parser.add_argument('-g', '--group', dest="group_list", action='append', help="only print aliases in given groups") + parser.add_argument('--groups', dest='groups_only', action='store_true', help="only print alias groups") + args = parser.parse_args() + lines = sys.stdin.readlines() - pretty_print(cheatsheet(lines), sys.argv[1] if len(sys.argv)>1 else None) + group_list = args.group_list or None + wfilter = " ".join(args.filter) or None + pretty_print(cheatsheet(lines), wfilter, group_list, args.groups_only) From a7d910c3a61d8599f748a8ddae59ecdd9424022a Mon Sep 17 00:00:00 2001 From: Shreem Asati <96364929+shreem-123@users.noreply.github.com> Date: Wed, 19 Oct 2022 11:57:54 +0530 Subject: [PATCH 049/672] chore: fix typo in CONTRIBUTING.md (#11273) --- CONTRIBUTING.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index 59cf96012..e78bd8192 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -233,7 +233,7 @@ type(scope)!: subject Try to keep the first commit line short. This is harder to do using this commit style but try to be concise and if you need more space, you can use the commit body. Try to make sure that the commit -subject is clear and precise enough that users will know what change by just looking at the changelog. +subject is clear and precise enough that users will know what changed by just looking at the changelog. ---- From 0066280c3e971e1e45a9037f6d0b993dabcc3576 Mon Sep 17 00:00:00 2001 From: pomatory Date: Sun, 23 Oct 2022 02:52:26 +0800 Subject: [PATCH 050/672] fix(pip): fix `pipupall` error with `freeze` format (#11280) --- plugins/pip/pip.plugin.zsh | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/plugins/pip/pip.plugin.zsh b/plugins/pip/pip.plugin.zsh index 7eb2d2a35..90e39e118 100644 --- a/plugins/pip/pip.plugin.zsh +++ b/plugins/pip/pip.plugin.zsh @@ -94,12 +94,12 @@ alias pipreq="pip freeze > requirements.txt" # Install packages from requirements file alias pipir="pip install -r requirements.txt" -# Update all installed packages +# Upgrade all installed packages function pipupall { # non-GNU xargs does not support nor need `--no-run-if-empty` local xargs="xargs --no-run-if-empty" xargs --version 2>/dev/null | grep -q GNU || xargs="xargs" - pip list --outdated --format freeze | cut -d= -f1 | ${=xargs} pip install --upgrade + pip list --outdated | awk 'NR > 2 { print $1 }' | ${=xargs} pip install --upgrade } # Uninstalled all installed packages From bb8a0aa2c1c54c3aeb3e703397ab050fd62e36e6 Mon Sep 17 00:00:00 2001 From: Zhong Ruoyu Date: Mon, 24 Oct 2022 18:07:12 +0800 Subject: [PATCH 051/672] fix(npm): ignore `rm` alias (#11222) --- plugins/npm/npm.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/npm/npm.plugin.zsh b/plugins/npm/npm.plugin.zsh index 6c768d614..e0dcbf142 100644 --- a/plugins/npm/npm.plugin.zsh +++ b/plugins/npm/npm.plugin.zsh @@ -1,5 +1,5 @@ (( $+commands[npm] )) && { - rm -f "${ZSH_CACHE_DIR:-$ZSH/cache}/npm_completion" + command rm -f "${ZSH_CACHE_DIR:-$ZSH/cache}/npm_completion" _npm_completion() { local si=$IFS From 820b8bd40f19867d7811766f967d66faa5e5a818 Mon Sep 17 00:00:00 2001 From: Eric Hsieh Date: Wed, 26 Oct 2022 03:35:30 +0800 Subject: [PATCH 052/672] docs(autojump): fix outdated links and update description (#11289) --- plugins/asdf/README.md | 21 ++++++++++++--------- 1 file changed, 12 insertions(+), 9 deletions(-) diff --git a/plugins/asdf/README.md b/plugins/asdf/README.md index e8aa976bc..f047860e2 100644 --- a/plugins/asdf/README.md +++ b/plugins/asdf/README.md @@ -6,22 +6,25 @@ Adds integration with [asdf](https://github.com/asdf-vm/asdf), the extendable ve ### Installation -1. Enable the plugin by adding it to your `plugins` definition in `~/.zshrc`. +1. [Download asdf](https://asdf-vm.com/guide/getting-started.html#_2-download-asdf) by running the following: + + ``` + git clone https://github.com/asdf-vm/asdf.git ~/.asdf + ``` + +2. [Enable asdf](https://asdf-vm.com/guide/getting-started.html#_3-install-asdf) by adding it to your `plugins` definition in `~/.zshrc`. ``` plugins=(asdf) ``` -2. [Install asdf](https://github.com/asdf-vm/asdf#setup) by running the following: - ``` - git clone https://github.com/asdf-vm/asdf.git ~/.asdf - ``` - ### Usage -See the [asdf usage documentation](https://github.com/asdf-vm/asdf#usage) for information on how to use asdf: +See the [asdf documentation](https://asdf-vm.com/guide/getting-started.html#_4-install-a-plugin) for information on how to use asdf: ``` -asdf plugin-add nodejs git@github.com:asdf-vm/asdf-nodejs.git -asdf install nodejs 5.9.1 +asdf plugin add nodejs https://github.com/asdf-vm/asdf-nodejs.git +asdf install nodejs latest +asdf global nodejs latest +asdf local nodejs latest ``` From 49691b58b3c1fbe64b927ec88d5e9697f76e2a80 Mon Sep 17 00:00:00 2001 From: Paul S Date: Tue, 25 Oct 2022 20:39:58 +0100 Subject: [PATCH 053/672] feat(autojump): add support for macOS and nix (#11291) --- plugins/autojump/autojump.plugin.zsh | 1 + 1 file changed, 1 insertion(+) diff --git a/plugins/autojump/autojump.plugin.zsh b/plugins/autojump/autojump.plugin.zsh index 8593353b2..e11f231b6 100644 --- a/plugins/autojump/autojump.plugin.zsh +++ b/plugins/autojump/autojump.plugin.zsh @@ -12,6 +12,7 @@ autojump_paths=( /opt/local/etc/profile.d/autojump.sh # macOS with MacPorts /usr/local/etc/profile.d/autojump.sh # macOS with Homebrew (default) /opt/homebrew/etc/profile.d/autojump.sh # macOS with Homebrew (default on M1 macs) + /etc/profiles/per-user/$USER/bin/autojump # macOS Nix, Home Manager and flakes ) for file in $autojump_paths; do From 50a526f209a182add8a47e362e1c9a3bfd7c5af4 Mon Sep 17 00:00:00 2001 From: Pandey-utkarsh <91661580+Pandey-utkarsh@users.noreply.github.com> Date: Sun, 30 Oct 2022 17:51:35 +0530 Subject: [PATCH 054/672] chore: correct style in CONTRIBUTING.md (#11306) Corrected grammatically incorrect sentences, punctuations and typos for better readability. --- CONTRIBUTING.md | 18 +++++++++--------- 1 file changed, 9 insertions(+), 9 deletions(-) diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index e78bd8192..6c8b8446e 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -35,13 +35,13 @@ you would make is not already covered. Please be so kind as to [search](#use-the-search-luke) for any open issue already covering your problem. -If you find one, comment on it so we can know there are more people experiencing it. +If you find one, comment on it, so we know more people are experiencing it. If not, look at the [Troubleshooting](https://github.com/ohmyzsh/ohmyzsh/wiki/Troubleshooting) page for instructions on how to gather data to better debug your problem. Then, you can go ahead and create an issue with as much detail as you can provide. -It should include the data gathered as indicated above, along with: +It should include the data gathered as indicated above, along with the following: 1. How to reproduce the problem 2. What the correct behavior should be @@ -57,7 +57,7 @@ We will do our very best to help you. Please be so kind as to [search](#use-the-search-luke) for any open issue already covering your suggestion. -If you find one, comment on it so we can know there are more people supporting it. +If you find one, comment on it, so we know more people are supporting it. If not, you can go ahead and create an issue. Please copy to anyone relevant (e.g. plugin maintainers) by mentioning their GitHub handle (starting with `@`) in your message. @@ -84,7 +84,7 @@ your [problem](#you-have-a-problem), and any pending/merged/rejected PR covering If the solution is already reported, try it out and +1 the pull request if the solution works ok. On the other hand, if you think your solution is better, post -it with a reference to the other one so we can have both solutions to compare. +it with reference to the other one so we can have both solutions to compare. If not, then go ahead and submit a PR. Please copy to anyone relevant (e.g. plugin maintainers) by mentioning their GitHub handle (starting with `@`) in your message. @@ -113,14 +113,14 @@ This has become an issue for two opposing reasons: - Some users want to have their personal aliases in Oh My Zsh. - Some users don't want any aliases at all and feel that there are too many. -Because of this, from now on we're requiring that new aliases follow these conditions: +Because of this, from now on, we require that new aliases follow these conditions: 1. They will be used by many people, not just a few. 2. The aliases will be used many times and for common tasks. 3. Prefer one generic alias over many specific ones. 4. When justifying the need for an alias, talk about workflows where you'll use it, preferably in combination with other aliases. -5. If there exists a command with the same name, look for a different alias name. +5. If a command with the same name exists, look for a different alias name. This list is not exhaustive! Please remember that your alias will be in the machines of many people, so it should be justified why they should have it. @@ -214,7 +214,7 @@ type(scope)!: subject ``` - `subject`: a brief description of the changes. This will be displayed in the changelog. If you need - to specify other details you can use the commit body but it won't be visible. + to specify other details, you can use the commit body, but it won't be visible. Formatting tricks: the commit subject may contain: @@ -231,8 +231,8 @@ type(scope)!: subject ### Style -Try to keep the first commit line short. This is harder to do using this commit style but try to be -concise and if you need more space, you can use the commit body. Try to make sure that the commit +Try to keep the first commit line short. It's harder to do using this commit style but try to be +concise, and if you need more space, you can use the commit body. Try to make sure that the commit subject is clear and precise enough that users will know what changed by just looking at the changelog. ---- From 239e2f9fcd3a3d469a2d6edfc33b57bf5c39c6a2 Mon Sep 17 00:00:00 2001 From: Lennart Ochel Date: Thu, 3 Nov 2022 18:30:30 +0100 Subject: [PATCH 055/672] ci: migrate to ProjectV2 GraphQL API (#11311) --- .github/workflows/project.yml | 32 ++++++++++++++++---------------- 1 file changed, 16 insertions(+), 16 deletions(-) diff --git a/.github/workflows/project.yml b/.github/workflows/project.yml index 999cc08e2..1aa69c279 100644 --- a/.github/workflows/project.yml +++ b/.github/workflows/project.yml @@ -27,24 +27,25 @@ jobs: gh api graphql -f query=' query($org: String!, $number: Int!) { organization(login: $org){ - projectNext(number: $number) { + projectV2(number: $number) { id fields(first:20) { nodes { - id - name + ... on ProjectV2Field { + id + name + } } } } } - } - ' -f org=$ORGANIZATION -F number=$PROJECT_NUMBER > project_data.json + }' -f org=$ORGANIZATION -F number=$PROJECT_NUMBER > project_data.json # Parse project data cat >> $GITHUB_ENV <> $GITHUB_ENV @@ -108,23 +109,23 @@ jobs: $theme_field: ID! $theme_value: String! ) { - set_plugin: updateProjectNextItemField(input: { + set_plugin: updateProjectV2ItemFieldValue(input: { projectId: $project itemId: $item fieldId: $plugin_field value: $plugin_value }) { - projectNextItem { + projectV2Item { id } } - set_theme: updateProjectNextItemField(input: { + set_theme: updateProjectV2ItemFieldValue(input: { projectId: $project itemId: $item fieldId: $theme_field value: $theme_value }) { - projectNextItem { + projectV2Item { id } } @@ -133,4 +134,3 @@ jobs: -f plugin_field=$PLUGIN_FIELD_ID -f plugin_value=$PLUGIN \ -f theme_field=$THEME_FIELD_ID -f theme_value=$THEME \ --silent - From 5ddb5890118f577ac67bd9101ef66bcdd520c8d9 Mon Sep 17 00:00:00 2001 From: Qin Li <30631553+liblaf@users.noreply.github.com> Date: Fri, 4 Nov 2022 01:32:01 +0800 Subject: [PATCH 056/672] fix(brew): suppress error message of brew cask on Linux (#11302) --- plugins/brew/brew.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/brew/brew.plugin.zsh b/plugins/brew/brew.plugin.zsh index 41420b5b7..ea8900823 100644 --- a/plugins/brew/brew.plugin.zsh +++ b/plugins/brew/brew.plugin.zsh @@ -36,7 +36,7 @@ alias buf='brew upgrade --formula' function brews() { local formulae="$(brew leaves | xargs brew deps --installed --for-each)" - local casks="$(brew list --cask)" + local casks="$(brew list --cask 2>/dev/null)" local blue="$(tput setaf 4)" local bold="$(tput bold)" From 02972f801b4865c68a1045ce2455b3ac4a9d59ad Mon Sep 17 00:00:00 2001 From: Marco Eidinger Date: Thu, 3 Nov 2022 10:32:54 -0700 Subject: [PATCH 057/672] feat(swiftpm): update completion for Swift 5.7 (#11299) * feat(swiftpm): update completion for Swift 5.7 * chore(docs): fix typo --- plugins/swiftpm/README.md | 2 +- plugins/swiftpm/_swift | 1114 +++++++++++++++++++++++++------------ 2 files changed, 759 insertions(+), 357 deletions(-) diff --git a/plugins/swiftpm/README.md b/plugins/swiftpm/README.md index a722c03e4..223a607c1 100644 --- a/plugins/swiftpm/README.md +++ b/plugins/swiftpm/README.md @@ -2,7 +2,7 @@ ## Description -This plugin provides a few utilities that make you faster on your daily work with the [Swift Package Manager](https://github.com/apple/swift-package-manager), as well as autocompletion for Swift 5.1. +This plugin provides a few utilities that make you faster on your daily work with the [Swift Package Manager](https://github.com/apple/swift-package-manager), as well as autocompletion for Swift 5.7. To start using it, add the `swiftpm` plugin to your `plugins` array in `~/.zshrc`: diff --git a/plugins/swiftpm/_swift b/plugins/swiftpm/_swift index 3a923226d..51c9fffa0 100644 --- a/plugins/swiftpm/_swift +++ b/plugins/swiftpm/_swift @@ -1,474 +1,876 @@ #compdef swift local context state state_descr line +_swift_commandname=$words[1] typeset -A opt_args _swift() { - _arguments -C \ - '(- :)--help[prints the synopsis and a list of the most commonly used commands]: :->arg' \ - '(-): :->command' \ - '(-)*:: :->arg' && return - + integer ret=1 + local -a args + args+=( + '(-h --help)'{-h,--help}'[Show help information.]' + '(-): :->command' + '(-)*:: :->arg' + ) + _arguments -w -s -S $args[@] && ret=0 case $state in (command) - local tools - tools=( - 'build:build sources into binary products' - 'run:build and run an executable product' - 'package:perform operations on Swift packages' - 'test:build and run tests' + local subcommands + subcommands=( + 'run:Build and run an executable product' + 'build:Build sources into binary products' + 'test:Build and run tests' + 'package:Perform operations on Swift packages' + 'help:Show subcommand help information.' ) - _alternative \ - 'tools:common:{_describe "tool" tools }' \ - 'compiler: :_swift_compiler' && _ret=0 + _describe "subcommand" subcommands ;; (arg) case ${words[1]} in - (build) - _swift_build - ;; (run) _swift_run ;; - (package) - _swift_package + (build) + _swift_build ;; (test) _swift_test ;; - (*) - _swift_compiler + (package) + _swift_package + ;; + (help) + _swift_help ;; esac ;; esac + + return ret } -_swift_dependency() { - local dependencies - dependencies=( $(swift package completion-tool list-dependencies) ) - _describe '' dependencies -} - -_swift_executable() { - local executables - executables=( $(swift package completion-tool list-executables) ) - _describe '' executables -} - -# Generates completions for swift build -# -# In the final compdef file, set the following file header: -# -# #compdef _swift_build -# local context state state_descr line -# typeset -A opt_args -_swift_build() { - arguments=( - "-Xcc[Pass flag through to all C compiler invocations]:Pass flag through to all C compiler invocations: " - "-Xswiftc[Pass flag through to all Swift compiler invocations]:Pass flag through to all Swift compiler invocations: " - "-Xlinker[Pass flag through to all linker invocations]:Pass flag through to all linker invocations: " - "-Xcxx[Pass flag through to all C++ compiler invocations]:Pass flag through to all C++ compiler invocations: " - "(--configuration -c)"{--configuration,-c}"[Build with configuration (debug|release) ]: :{_values '' 'debug[build with DEBUG configuration]' 'release[build with RELEASE configuration]'}" - "--build-path[Specify build/cache directory ]:Specify build/cache directory :_files" - "(--chdir -C)"{--chdir,-C}"[]: :_files" - "--package-path[Change working directory before any other operation]:Change working directory before any other operation:_files" - "--sanitize[Turn on runtime checks for erroneous behavior]: :{_values '' 'address[enable Address sanitizer]' 'thread[enable Thread sanitizer]' 'undefined[enable Undefined Behavior sanitizer]'}" - "--disable-prefetching[]" - "--skip-update[Skip updating dependencies from their remote during a resolution]" - "--disable-sandbox[Disable using the sandbox when executing subprocesses]" - "--disable-package-manifest-caching[Disable caching Package.swift manifests]" - "--version[]" - "--destination[]: :_files" - "(--verbose -v)"{--verbose,-v}"[Increase verbosity of informational output]" - "--no-static-swift-stdlib[Do not link Swift stdlib statically \[default\]]" - "--static-swift-stdlib[Link Swift stdlib statically]" - "--force-resolved-versions[]" - "--disable-automatic-resolution[Disable automatic resolution if Package.resolved file is out-of-date]" - "--enable-index-store[Enable indexing-while-building feature]" - "--disable-index-store[Disable indexing-while-building feature]" - "--enable-pubgrub-resolver[\[Experimental\] Enable the new Pubgrub dependency resolver]" - "--enable-parseable-module-interfaces[]" - "--trace-resolver[]" - "(--jobs -j)"{--jobs,-j}"[The number of jobs to spawn in parallel during the build process]:The number of jobs to spawn in parallel during the build process: " - "--enable-test-discovery[Enable test discovery on platforms without Objective-C runtime]" - "--build-tests[Build both source and test targets]" - "--product[Build the specified product]:Build the specified product: " - "--target[Build the specified target]:Build the specified target: " - "--show-bin-path[Print the binary output path]" - ) - _arguments $arguments && return -} - -# Generates completions for swift run -# -# In the final compdef file, set the following file header: -# -# #compdef _swift_run -# local context state state_descr line -# typeset -A opt_args _swift_run() { - arguments=( - ":The executable to run:_swift_executable" - "-Xcc[Pass flag through to all C compiler invocations]:Pass flag through to all C compiler invocations: " - "-Xswiftc[Pass flag through to all Swift compiler invocations]:Pass flag through to all Swift compiler invocations: " - "-Xlinker[Pass flag through to all linker invocations]:Pass flag through to all linker invocations: " - "-Xcxx[Pass flag through to all C++ compiler invocations]:Pass flag through to all C++ compiler invocations: " - "(--configuration -c)"{--configuration,-c}"[Build with configuration (debug|release) ]: :{_values '' 'debug[build with DEBUG configuration]' 'release[build with RELEASE configuration]'}" - "--build-path[Specify build/cache directory ]:Specify build/cache directory :_files" - "(--chdir -C)"{--chdir,-C}"[]: :_files" - "--package-path[Change working directory before any other operation]:Change working directory before any other operation:_files" - "--sanitize[Turn on runtime checks for erroneous behavior]: :{_values '' 'address[enable Address sanitizer]' 'thread[enable Thread sanitizer]' 'undefined[enable Undefined Behavior sanitizer]'}" - "--disable-prefetching[]" - "--skip-update[Skip updating dependencies from their remote during a resolution]" - "--disable-sandbox[Disable using the sandbox when executing subprocesses]" - "--disable-package-manifest-caching[Disable caching Package.swift manifests]" - "--version[]" - "--destination[]: :_files" - "(--verbose -v)"{--verbose,-v}"[Increase verbosity of informational output]" - "--no-static-swift-stdlib[Do not link Swift stdlib statically \[default\]]" - "--static-swift-stdlib[Link Swift stdlib statically]" - "--force-resolved-versions[]" - "--disable-automatic-resolution[Disable automatic resolution if Package.resolved file is out-of-date]" - "--enable-index-store[Enable indexing-while-building feature]" - "--disable-index-store[Disable indexing-while-building feature]" - "--enable-pubgrub-resolver[\[Experimental\] Enable the new Pubgrub dependency resolver]" - "--enable-parseable-module-interfaces[]" - "--trace-resolver[]" - "(--jobs -j)"{--jobs,-j}"[The number of jobs to spawn in parallel during the build process]:The number of jobs to spawn in parallel during the build process: " - "--enable-test-discovery[Enable test discovery on platforms without Objective-C runtime]" - "--skip-build[Skip building the executable product]" - "--build-tests[Build both source and test targets]" - "--repl[Launch Swift REPL for the package]" + integer ret=1 + local -a args + args+=( + '--package-path[Specify the package path to operate on (default current directory). This changes the working directory before any other operation]:package-path:_files -/' + '--cache-path[Specify the shared cache directory path]:cache-path:_files -/' + '--config-path[Specify the shared configuration directory path]:config-path:_files -/' + '--security-path[Specify the shared security directory path]:security-path:_files -/' + '--scratch-path[Specify a custom scratch directory path (default .build)]:scratch-path:_files -/' + '--enable-dependency-cache[Use a shared cache when fetching dependencies]' + '--disable-dependency-cache[Use a shared cache when fetching dependencies]' + '--enable-build-manifest-caching' + '--disable-build-manifest-caching' + '--manifest-cache[Caching mode of Package.swift manifests (shared: shared cache, local: package'"'"'s build directory, none: disabled]:manifest-cache:' + '(--verbose -v)'{--verbose,-v}'[Increase verbosity to include informational output]' + '(--very-verbose --vv)'{--very-verbose,--vv}'[Increase verbosity to include debug output]' + '--disable-sandbox[Disable using the sandbox when executing subprocesses]' + '--enable-netrc[Load credentials from a .netrc file]' + '--disable-netrc[Load credentials from a .netrc file]' + '--netrc-file[Specify the .netrc file path.]:netrc-file:_files' + '--enable-keychain[Search credentials in macOS keychain]' + '--disable-keychain[Search credentials in macOS keychain]' + '--resolver-fingerprint-checking:resolver-fingerprint-checking:' + '--enable-prefetching' + '--disable-prefetching' + '(--force-resolved-versions --disable-automatic-resolution --only-use-versions-from-resolved-file)'{--force-resolved-versions,--disable-automatic-resolution,--only-use-versions-from-resolved-file}'[Only use versions from the Package.resolved file and fail resolution if it is out-of-date]' + '--skip-update[Skip updating dependencies from their remote during a resolution]' + '--disable-scm-to-registry-transformation[disable source control to registry transformation]' + '--use-registry-identity-for-scm[look up source control dependencies in the registry and use their registry identity when possible to help deduplicate across the two origins]' + '--replace-scm-with-registry[look up source control dependencies in the registry and use the registry to retrieve them instead of source control when possible]' + '(--configuration -c)'{--configuration,-c}'[Build with configuration]:configuration:(debug release)' + '-Xcc[Pass flag through to all C compiler invocations]:Xcc:' + '-Xswiftc[Pass flag through to all Swift compiler invocations]:Xswiftc:' + '-Xlinker[Pass flag through to all linker invocations]:Xlinker:' + '-Xcxx[Pass flag through to all C++ compiler invocations]:Xcxx:' + '--triple:triple:' + '--sdk:sdk:_files -/' + '--toolchain:toolchain:_files -/' + '--sanitize[Turn on runtime checks for erroneous behavior, possible values: address, thread, undefined, scudo]:sanitize:' + '--auto-index-store[Enable or disable indexing-while-building feature]' + '--enable-index-store[Enable or disable indexing-while-building feature]' + '--disable-index-store[Enable or disable indexing-while-building feature]' + '--enable-parseable-module-interfaces' + '(--jobs -j)'{--jobs,-j}'[The number of jobs to spawn in parallel during the build process]:jobs:' + '--emit-swift-module-separately' + '--use-integrated-swift-driver' + '--experimental-explicit-module-build' + '--print-manifest-job-graph[Write the command graph for the build manifest as a graphviz file]' + '--build-system:build-system:(native xcode)' + '--enable-dead-strip[Disable/enable dead code stripping by the linker]' + '--disable-dead-strip[Disable/enable dead code stripping by the linker]' + '--static-swift-stdlib[Link Swift stdlib statically]' + '--no-static-swift-stdlib[Link Swift stdlib statically]' + '--repl[Launch Swift REPL for the package]' + '--debugger[Launch the executable in a debugger session]' + '--run[Launch the executable with the provided arguments]' + '--skip-build[Skip building the executable product]' + '--build-tests[Build both source and test targets]' + ':executable:{local -a list; list=(${(f)"$(swift package completion-tool list-executables)"}); _describe '''' list}' + ':arguments:' + '--version[Show the version.]' + '(-help -h --help)'{-help,-h,--help}'[Show help information.]' ) - _arguments $arguments && return + _arguments -w -s -S $args[@] && ret=0 + + return ret +} + +_swift_build() { + integer ret=1 + local -a args + args+=( + '--package-path[Specify the package path to operate on (default current directory). This changes the working directory before any other operation]:package-path:_files -/' + '--cache-path[Specify the shared cache directory path]:cache-path:_files -/' + '--config-path[Specify the shared configuration directory path]:config-path:_files -/' + '--security-path[Specify the shared security directory path]:security-path:_files -/' + '--scratch-path[Specify a custom scratch directory path (default .build)]:scratch-path:_files -/' + '--enable-dependency-cache[Use a shared cache when fetching dependencies]' + '--disable-dependency-cache[Use a shared cache when fetching dependencies]' + '--enable-build-manifest-caching' + '--disable-build-manifest-caching' + '--manifest-cache[Caching mode of Package.swift manifests (shared: shared cache, local: package'"'"'s build directory, none: disabled]:manifest-cache:' + '(--verbose -v)'{--verbose,-v}'[Increase verbosity to include informational output]' + '(--very-verbose --vv)'{--very-verbose,--vv}'[Increase verbosity to include debug output]' + '--disable-sandbox[Disable using the sandbox when executing subprocesses]' + '--enable-netrc[Load credentials from a .netrc file]' + '--disable-netrc[Load credentials from a .netrc file]' + '--netrc-file[Specify the .netrc file path.]:netrc-file:_files' + '--enable-keychain[Search credentials in macOS keychain]' + '--disable-keychain[Search credentials in macOS keychain]' + '--resolver-fingerprint-checking:resolver-fingerprint-checking:' + '--enable-prefetching' + '--disable-prefetching' + '(--force-resolved-versions --disable-automatic-resolution --only-use-versions-from-resolved-file)'{--force-resolved-versions,--disable-automatic-resolution,--only-use-versions-from-resolved-file}'[Only use versions from the Package.resolved file and fail resolution if it is out-of-date]' + '--skip-update[Skip updating dependencies from their remote during a resolution]' + '--disable-scm-to-registry-transformation[disable source control to registry transformation]' + '--use-registry-identity-for-scm[look up source control dependencies in the registry and use their registry identity when possible to help deduplicate across the two origins]' + '--replace-scm-with-registry[look up source control dependencies in the registry and use the registry to retrieve them instead of source control when possible]' + '(--configuration -c)'{--configuration,-c}'[Build with configuration]:configuration:(debug release)' + '-Xcc[Pass flag through to all C compiler invocations]:Xcc:' + '-Xswiftc[Pass flag through to all Swift compiler invocations]:Xswiftc:' + '-Xlinker[Pass flag through to all linker invocations]:Xlinker:' + '-Xcxx[Pass flag through to all C++ compiler invocations]:Xcxx:' + '--triple:triple:' + '--sdk:sdk:_files -/' + '--toolchain:toolchain:_files -/' + '--sanitize[Turn on runtime checks for erroneous behavior, possible values: address, thread, undefined, scudo]:sanitize:' + '--auto-index-store[Enable or disable indexing-while-building feature]' + '--enable-index-store[Enable or disable indexing-while-building feature]' + '--disable-index-store[Enable or disable indexing-while-building feature]' + '--enable-parseable-module-interfaces' + '(--jobs -j)'{--jobs,-j}'[The number of jobs to spawn in parallel during the build process]:jobs:' + '--emit-swift-module-separately' + '--use-integrated-swift-driver' + '--experimental-explicit-module-build' + '--print-manifest-job-graph[Write the command graph for the build manifest as a graphviz file]' + '--build-system:build-system:(native xcode)' + '--enable-dead-strip[Disable/enable dead code stripping by the linker]' + '--disable-dead-strip[Disable/enable dead code stripping by the linker]' + '--static-swift-stdlib[Link Swift stdlib statically]' + '--no-static-swift-stdlib[Link Swift stdlib statically]' + '--build-tests[Build both source and test targets]' + '--show-bin-path[Print the binary output path]' + '--target[Build the specified target]:target:' + '--product[Build the specified product]:product:' + '--version[Show the version.]' + '(-help -h --help)'{-help,-h,--help}'[Show help information.]' + ) + _arguments -w -s -S $args[@] && ret=0 + + return ret +} + +_swift_test() { + integer ret=1 + local -a args + args+=( + '--package-path[Specify the package path to operate on (default current directory). This changes the working directory before any other operation]:package-path:_files -/' + '--cache-path[Specify the shared cache directory path]:cache-path:_files -/' + '--config-path[Specify the shared configuration directory path]:config-path:_files -/' + '--security-path[Specify the shared security directory path]:security-path:_files -/' + '--scratch-path[Specify a custom scratch directory path (default .build)]:scratch-path:_files -/' + '--enable-dependency-cache[Use a shared cache when fetching dependencies]' + '--disable-dependency-cache[Use a shared cache when fetching dependencies]' + '--enable-build-manifest-caching' + '--disable-build-manifest-caching' + '--manifest-cache[Caching mode of Package.swift manifests (shared: shared cache, local: package'"'"'s build directory, none: disabled]:manifest-cache:' + '(--verbose -v)'{--verbose,-v}'[Increase verbosity to include informational output]' + '(--very-verbose --vv)'{--very-verbose,--vv}'[Increase verbosity to include debug output]' + '--disable-sandbox[Disable using the sandbox when executing subprocesses]' + '--enable-netrc[Load credentials from a .netrc file]' + '--disable-netrc[Load credentials from a .netrc file]' + '--netrc-file[Specify the .netrc file path.]:netrc-file:_files' + '--enable-keychain[Search credentials in macOS keychain]' + '--disable-keychain[Search credentials in macOS keychain]' + '--resolver-fingerprint-checking:resolver-fingerprint-checking:' + '--enable-prefetching' + '--disable-prefetching' + '(--force-resolved-versions --disable-automatic-resolution --only-use-versions-from-resolved-file)'{--force-resolved-versions,--disable-automatic-resolution,--only-use-versions-from-resolved-file}'[Only use versions from the Package.resolved file and fail resolution if it is out-of-date]' + '--skip-update[Skip updating dependencies from their remote during a resolution]' + '--disable-scm-to-registry-transformation[disable source control to registry transformation]' + '--use-registry-identity-for-scm[look up source control dependencies in the registry and use their registry identity when possible to help deduplicate across the two origins]' + '--replace-scm-with-registry[look up source control dependencies in the registry and use the registry to retrieve them instead of source control when possible]' + '(--configuration -c)'{--configuration,-c}'[Build with configuration]:configuration:(debug release)' + '-Xcc[Pass flag through to all C compiler invocations]:Xcc:' + '-Xswiftc[Pass flag through to all Swift compiler invocations]:Xswiftc:' + '-Xlinker[Pass flag through to all linker invocations]:Xlinker:' + '-Xcxx[Pass flag through to all C++ compiler invocations]:Xcxx:' + '--triple:triple:' + '--sdk:sdk:_files -/' + '--toolchain:toolchain:_files -/' + '--sanitize[Turn on runtime checks for erroneous behavior, possible values: address, thread, undefined, scudo]:sanitize:' + '--auto-index-store[Enable or disable indexing-while-building feature]' + '--enable-index-store[Enable or disable indexing-while-building feature]' + '--disable-index-store[Enable or disable indexing-while-building feature]' + '--enable-parseable-module-interfaces' + '(--jobs -j)'{--jobs,-j}'[The number of jobs to spawn in parallel during the build process]:jobs:' + '--emit-swift-module-separately' + '--use-integrated-swift-driver' + '--experimental-explicit-module-build' + '--print-manifest-job-graph[Write the command graph for the build manifest as a graphviz file]' + '--build-system:build-system:(native xcode)' + '--enable-dead-strip[Disable/enable dead code stripping by the linker]' + '--disable-dead-strip[Disable/enable dead code stripping by the linker]' + '--static-swift-stdlib[Link Swift stdlib statically]' + '--no-static-swift-stdlib[Link Swift stdlib statically]' + '--skip-build[Skip building the test target]' + '--parallel[Run the tests in parallel.]' + '--num-workers[Number of tests to execute in parallel.]:num-workers:' + '(--list-tests -l)'{--list-tests,-l}'[Lists test methods in specifier format]' + '--show-codecov-path[Print the path of the exported code coverage JSON file]' + '(-s --specifier)'{-s,--specifier}':specifier:' + '--filter[Run test cases matching regular expression, Format: . or ./]:filter:' + '--skip[Skip test cases matching regular expression, Example: --skip PerformanceTests]:skip:' + '--xunit-output[Path where the xUnit xml file should be generated.]:xunit-output:_files -/' + '--test-product[Test the specified product.]:test-product:' + '--enable-testable-imports[Enable or disable testable imports. Enabled by default.]' + '--disable-testable-imports[Enable or disable testable imports. Enabled by default.]' + '--enable-code-coverage[Enable code coverage]' + '--disable-code-coverage[Enable code coverage]' + '--version[Show the version.]' + '(-help -h --help)'{-help,-h,--help}'[Show help information.]' + ) + _arguments -w -s -S $args[@] && ret=0 + + return ret } -# Generates completions for swift package -# -# In the final compdef file, set the following file header: -# -# #compdef _swift_package -# local context state state_descr line -# typeset -A opt_args _swift_package() { - arguments=( - "-Xcc[Pass flag through to all C compiler invocations]:Pass flag through to all C compiler invocations: " - "-Xswiftc[Pass flag through to all Swift compiler invocations]:Pass flag through to all Swift compiler invocations: " - "-Xlinker[Pass flag through to all linker invocations]:Pass flag through to all linker invocations: " - "-Xcxx[Pass flag through to all C++ compiler invocations]:Pass flag through to all C++ compiler invocations: " - "(--configuration -c)"{--configuration,-c}"[Build with configuration (debug|release) ]: :{_values '' 'debug[build with DEBUG configuration]' 'release[build with RELEASE configuration]'}" - "--build-path[Specify build/cache directory ]:Specify build/cache directory :_files" - "(--chdir -C)"{--chdir,-C}"[]: :_files" - "--package-path[Change working directory before any other operation]:Change working directory before any other operation:_files" - "--sanitize[Turn on runtime checks for erroneous behavior]: :{_values '' 'address[enable Address sanitizer]' 'thread[enable Thread sanitizer]' 'undefined[enable Undefined Behavior sanitizer]'}" - "--disable-prefetching[]" - "--skip-update[Skip updating dependencies from their remote during a resolution]" - "--disable-sandbox[Disable using the sandbox when executing subprocesses]" - "--disable-package-manifest-caching[Disable caching Package.swift manifests]" - "--version[]" - "--destination[]: :_files" - "(--verbose -v)"{--verbose,-v}"[Increase verbosity of informational output]" - "--no-static-swift-stdlib[Do not link Swift stdlib statically \[default\]]" - "--static-swift-stdlib[Link Swift stdlib statically]" - "--force-resolved-versions[]" - "--disable-automatic-resolution[Disable automatic resolution if Package.resolved file is out-of-date]" - "--enable-index-store[Enable indexing-while-building feature]" - "--disable-index-store[Disable indexing-while-building feature]" - "--enable-pubgrub-resolver[\[Experimental\] Enable the new Pubgrub dependency resolver]" - "--enable-parseable-module-interfaces[]" - "--trace-resolver[]" - "(--jobs -j)"{--jobs,-j}"[The number of jobs to spawn in parallel during the build process]:The number of jobs to spawn in parallel during the build process: " - "--enable-test-discovery[Enable test discovery on platforms without Objective-C runtime]" + integer ret=1 + local -a args + args+=( + '--package-path[Specify the package path to operate on (default current directory). This changes the working directory before any other operation]:package-path:_files -/' + '--cache-path[Specify the shared cache directory path]:cache-path:_files -/' + '--config-path[Specify the shared configuration directory path]:config-path:_files -/' + '--security-path[Specify the shared security directory path]:security-path:_files -/' + '--scratch-path[Specify a custom scratch directory path (default .build)]:scratch-path:_files -/' + '--enable-dependency-cache[Use a shared cache when fetching dependencies]' + '--disable-dependency-cache[Use a shared cache when fetching dependencies]' + '--enable-build-manifest-caching' + '--disable-build-manifest-caching' + '--manifest-cache[Caching mode of Package.swift manifests (shared: shared cache, local: package'"'"'s build directory, none: disabled]:manifest-cache:' + '(--verbose -v)'{--verbose,-v}'[Increase verbosity to include informational output]' + '(--very-verbose --vv)'{--very-verbose,--vv}'[Increase verbosity to include debug output]' + '--disable-sandbox[Disable using the sandbox when executing subprocesses]' + '--enable-netrc[Load credentials from a .netrc file]' + '--disable-netrc[Load credentials from a .netrc file]' + '--netrc-file[Specify the .netrc file path.]:netrc-file:_files' + '--enable-keychain[Search credentials in macOS keychain]' + '--disable-keychain[Search credentials in macOS keychain]' + '--resolver-fingerprint-checking:resolver-fingerprint-checking:' + '--enable-prefetching' + '--disable-prefetching' + '(--force-resolved-versions --disable-automatic-resolution --only-use-versions-from-resolved-file)'{--force-resolved-versions,--disable-automatic-resolution,--only-use-versions-from-resolved-file}'[Only use versions from the Package.resolved file and fail resolution if it is out-of-date]' + '--skip-update[Skip updating dependencies from their remote during a resolution]' + '--disable-scm-to-registry-transformation[disable source control to registry transformation]' + '--use-registry-identity-for-scm[look up source control dependencies in the registry and use their registry identity when possible to help deduplicate across the two origins]' + '--replace-scm-with-registry[look up source control dependencies in the registry and use the registry to retrieve them instead of source control when possible]' + '(--configuration -c)'{--configuration,-c}'[Build with configuration]:configuration:(debug release)' + '-Xcc[Pass flag through to all C compiler invocations]:Xcc:' + '-Xswiftc[Pass flag through to all Swift compiler invocations]:Xswiftc:' + '-Xlinker[Pass flag through to all linker invocations]:Xlinker:' + '-Xcxx[Pass flag through to all C++ compiler invocations]:Xcxx:' + '--triple:triple:' + '--sdk:sdk:_files -/' + '--toolchain:toolchain:_files -/' + '--sanitize[Turn on runtime checks for erroneous behavior, possible values: address, thread, undefined, scudo]:sanitize:' + '--auto-index-store[Enable or disable indexing-while-building feature]' + '--enable-index-store[Enable or disable indexing-while-building feature]' + '--disable-index-store[Enable or disable indexing-while-building feature]' + '--enable-parseable-module-interfaces' + '(--jobs -j)'{--jobs,-j}'[The number of jobs to spawn in parallel during the build process]:jobs:' + '--emit-swift-module-separately' + '--use-integrated-swift-driver' + '--experimental-explicit-module-build' + '--print-manifest-job-graph[Write the command graph for the build manifest as a graphviz file]' + '--build-system:build-system:(native xcode)' + '--enable-dead-strip[Disable/enable dead code stripping by the linker]' + '--disable-dead-strip[Disable/enable dead code stripping by the linker]' + '--static-swift-stdlib[Link Swift stdlib statically]' + '--no-static-swift-stdlib[Link Swift stdlib statically]' + '--version[Show the version.]' + '(-help -h --help)'{-help,-h,--help}'[Show help information.]' '(-): :->command' '(-)*:: :->arg' ) - _arguments $arguments && return + _arguments -w -s -S $args[@] && ret=0 case $state in (command) - local modes - modes=( - 'completion-tool:Completion tool (for shell completions)' - 'dump-package:Print parsed Package.swift as JSON' - 'describe:Describe the current package' + local subcommands + subcommands=( 'clean:Delete build artifacts' - 'show-dependencies:Print the resolved dependency graph' - 'init:Initialize a new package' - 'unedit:Remove a package from editable mode' - 'tools-version:Manipulate tools version of the current package' - 'fetch:' - 'resolve:Resolve package dependencies' + 'purge-cache:Purge the global repository cache.' 'reset:Reset the complete cache/build directory' - 'generate-xcodeproj:Generates an Xcode project' - 'edit:Put a package in editable mode' - 'config:Manipulate configuration of the package' 'update:Update package dependencies' + 'describe:Describe the current package' + 'init:Initialize a new package' + '_format:' + 'diagnose-api-breaking-changes:Diagnose API-breaking changes to Swift modules in a package' + 'experimental-api-diff:Deprecated - use `swift package diagnose-api-breaking-changes` instead' + 'dump-symbol-graph:Dump Symbol Graph' + 'dump-pif:' + 'dump-package:Print parsed Package.swift as JSON' + 'edit:Put a package in editable mode' + 'unedit:Remove a package from editable mode' + 'config:Manipulate configuration of the package' + 'resolve:Resolve package dependencies' + 'fetch:' + 'show-dependencies:Print the resolved dependency graph' + 'tools-version:Manipulate tools version of the current package' + 'generate-xcodeproj:Generates an Xcode project. This command will be deprecated soon.' + 'compute-checksum:Compute the checksum for a binary artifact.' + 'archive-source:Create a source archive for the package' + 'completion-tool:Completion tool (for shell completions)' + 'plugin:Invoke a command plugin or perform other actions on command plugins' + 'default-command:' ) - _describe "mode" modes + _describe "subcommand" subcommands ;; (arg) case ${words[1]} in - (completion-tool) - _swift_package_completion-tool - ;; - (dump-package) - _swift_package_dump-package - ;; - (describe) - _swift_package_describe - ;; (clean) _swift_package_clean ;; - (show-dependencies) - _swift_package_show-dependencies - ;; - (init) - _swift_package_init - ;; - (unedit) - _swift_package_unedit - ;; - (tools-version) - _swift_package_tools-version - ;; - (fetch) - _swift_package_fetch - ;; - (resolve) - _swift_package_resolve + (purge-cache) + _swift_package_purge-cache ;; (reset) _swift_package_reset ;; - (generate-xcodeproj) - _swift_package_generate-xcodeproj + (update) + _swift_package_update + ;; + (describe) + _swift_package_describe + ;; + (init) + _swift_package_init + ;; + (_format) + _swift_package__format + ;; + (diagnose-api-breaking-changes) + _swift_package_diagnose-api-breaking-changes + ;; + (experimental-api-diff) + _swift_package_experimental-api-diff + ;; + (dump-symbol-graph) + _swift_package_dump-symbol-graph + ;; + (dump-pif) + _swift_package_dump-pif + ;; + (dump-package) + _swift_package_dump-package ;; (edit) _swift_package_edit ;; + (unedit) + _swift_package_unedit + ;; (config) _swift_package_config ;; - (update) - _swift_package_update + (resolve) + _swift_package_resolve + ;; + (fetch) + _swift_package_fetch + ;; + (show-dependencies) + _swift_package_show-dependencies + ;; + (tools-version) + _swift_package_tools-version + ;; + (generate-xcodeproj) + _swift_package_generate-xcodeproj + ;; + (compute-checksum) + _swift_package_compute-checksum + ;; + (archive-source) + _swift_package_archive-source + ;; + (completion-tool) + _swift_package_completion-tool + ;; + (plugin) + _swift_package_plugin + ;; + (default-command) + _swift_package_default-command ;; esac ;; esac -} -_swift_package_completion-tool() { - arguments=( - ": :{_values '' 'generate-bash-script[generate Bash completion script]' 'generate-zsh-script[generate Bash completion script]' 'list-dependencies[list all dependencies' names]' 'list-executables[list all executables' names]'}" - ) - _arguments $arguments && return -} - -_swift_package_dump-package() { - arguments=( - ) - _arguments $arguments && return -} - -_swift_package_describe() { - arguments=( - "--type[json|text]: :{_values '' 'text[describe using text format]' 'json[describe using JSON format]'}" - ) - _arguments $arguments && return + return ret } _swift_package_clean() { - arguments=( + integer ret=1 + local -a args + args+=( + '--version[Show the version.]' + '(-help -h --help)'{-help,-h,--help}'[Show help information.]' ) - _arguments $arguments && return + _arguments -w -s -S $args[@] && ret=0 + + return ret } -_swift_package_show-dependencies() { - arguments=( - "--format[text|dot|json|flatlist]: :{_values '' 'text[list dependencies using text format]' 'dot[list dependencies using dot format]' 'json[list dependencies using JSON format]'}" +_swift_package_purge-cache() { + integer ret=1 + local -a args + args+=( + '--version[Show the version.]' + '(-help -h --help)'{-help,-h,--help}'[Show help information.]' ) - _arguments $arguments && return -} + _arguments -w -s -S $args[@] && ret=0 -_swift_package_init() { - arguments=( - "--type[empty|library|executable|system-module|manifest]: :{_values '' 'empty[generates an empty project]' 'library[generates project for a dynamic library]' 'executable[generates a project for a cli executable]' 'system-module[generates a project for a system module]'}" - "--name[Provide custom package name]:Provide custom package name: " - ) - _arguments $arguments && return -} - -_swift_package_unedit() { - arguments=( - ":The name of the package to unedit:_swift_dependency" - "--force[Unedit the package even if it has uncommitted and unpushed changes.]" - ) - _arguments $arguments && return -} - -_swift_package_tools-version() { - arguments=( - "--set[Set tools version of package to the given value]:Set tools version of package to the given value: " - "--set-current[Set tools version of package to the current tools version in use]" - ) - _arguments $arguments && return -} - -_swift_package_fetch() { - arguments=( - ) - _arguments $arguments && return -} - -_swift_package_resolve() { - arguments=( - ":The name of the package to resolve:_swift_dependency" - "--version[The version to resolve at]:The version to resolve at: " - "--branch[The branch to resolve at]:The branch to resolve at: " - "--revision[The revision to resolve at]:The revision to resolve at: " - ) - _arguments $arguments && return + return ret } _swift_package_reset() { - arguments=( + integer ret=1 + local -a args + args+=( + '--version[Show the version.]' + '(-help -h --help)'{-help,-h,--help}'[Show help information.]' ) - _arguments $arguments && return + _arguments -w -s -S $args[@] && ret=0 + + return ret } -_swift_package_generate-xcodeproj() { - arguments=( - "--xcconfig-overrides[Path to xcconfig file]:Path to xcconfig file:_files" - "--enable-code-coverage[Enable code coverage in the generated project]" - "--output[Path where the Xcode project should be generated]:Path where the Xcode project should be generated:_files" - "--legacy-scheme-generator[Use the legacy scheme generator]" - "--watch[Watch for changes to the Package manifest to regenerate the Xcode project]" - "--skip-extra-files[Do not add file references for extra files to the generated Xcode project]" +_swift_package_update() { + integer ret=1 + local -a args + args+=( + '(--dry-run -n)'{--dry-run,-n}'[Display the list of dependencies that can be updated]' + ':packages:' + '--version[Show the version.]' + '(-help -h --help)'{-help,-h,--help}'[Show help information.]' ) - _arguments $arguments && return + _arguments -w -s -S $args[@] && ret=0 + + return ret +} + +_swift_package_describe() { + integer ret=1 + local -a args + args+=( + '--type[json | text]:type:' + '--version[Show the version.]' + '(-help -h --help)'{-help,-h,--help}'[Show help information.]' + ) + _arguments -w -s -S $args[@] && ret=0 + + return ret +} + +_swift_package_init() { + integer ret=1 + local -a args + args+=( + '--type[Package type: empty | library | executable | system-module | manifest]:type:' + '--name[Provide custom package name]:name:' + '--version[Show the version.]' + '(-help -h --help)'{-help,-h,--help}'[Show help information.]' + ) + _arguments -w -s -S $args[@] && ret=0 + + return ret +} + +_swift_package__format() { + integer ret=1 + local -a args + args+=( + ':swift-format-flags:' + '--version[Show the version.]' + '(-help -h --help)'{-help,-h,--help}'[Show help information.]' + ) + _arguments -w -s -S $args[@] && ret=0 + + return ret +} + +_swift_package_diagnose-api-breaking-changes() { + integer ret=1 + local -a args + args+=( + '--breakage-allowlist-path[The path to a text file containing breaking changes which should be ignored by the API comparison. Each ignored breaking change in the file should appear on its own line and contain the exact message to be ignored (e.g. '"'"'API breakage: func foo() has been removed'"'"').]:breakage-allowlist-path:_files -/' + ':treeish:' + '--products[One or more products to include in the API comparison. If present, only the specified products (and any targets specified using `--targets`) will be compared.]:products:' + '--targets[One or more targets to include in the API comparison. If present, only the specified targets (and any products specified using `--products`) will be compared.]:targets:' + '--baseline-dir[The path to a directory used to store API baseline files. If unspecified, a temporary directory will be used.]:baseline-dir:_files -/' + '--regenerate-baseline[Regenerate the API baseline, even if an existing one is available.]' + '--version[Show the version.]' + '(-help -h --help)'{-help,-h,--help}'[Show help information.]' + ) + _arguments -w -s -S $args[@] && ret=0 + + return ret +} + +_swift_package_experimental-api-diff() { + integer ret=1 + local -a args + args+=( + ':args:' + '--version[Show the version.]' + '(-help -h --help)'{-help,-h,--help}'[Show help information.]' + ) + _arguments -w -s -S $args[@] && ret=0 + + return ret +} + +_swift_package_dump-symbol-graph() { + integer ret=1 + local -a args + args+=( + '--pretty-print[Pretty-print the output JSON.]' + '--skip-synthesized-members[Skip members inherited through classes or default implementations.]' + '--minimum-access-level[Include symbols with this access level or more. Possible values: private | fileprivate | internal | public | open]:minimum-access-level:(private fileprivate internal public open)' + '--skip-inherited-docs[Skip emitting doc comments for members inherited through classes or default implementations.]' + '--include-spi-symbols[Add symbols with SPI information to the symbol graph.]' + '--version[Show the version.]' + '(-help -h --help)'{-help,-h,--help}'[Show help information.]' + ) + _arguments -w -s -S $args[@] && ret=0 + + return ret +} + +_swift_package_dump-pif() { + integer ret=1 + local -a args + args+=( + '--preserve-structure[Preserve the internal structure of PIF]' + '--version[Show the version.]' + '(-help -h --help)'{-help,-h,--help}'[Show help information.]' + ) + _arguments -w -s -S $args[@] && ret=0 + + return ret +} + +_swift_package_dump-package() { + integer ret=1 + local -a args + args+=( + '--version[Show the version.]' + '(-help -h --help)'{-help,-h,--help}'[Show help information.]' + ) + _arguments -w -s -S $args[@] && ret=0 + + return ret } _swift_package_edit() { - arguments=( - ":The name of the package to edit:_swift_dependency" - "--revision[The revision to edit]:The revision to edit: " - "--branch[The branch to create]:The branch to create: " - "--path[Create or use the checkout at this path]:Create or use the checkout at this path:_files" + integer ret=1 + local -a args + args+=( + '--revision[The revision to edit]:revision:' + '--branch[The branch to create]:branch:' + '--path[Create or use the checkout at this path]:path:_files -/' + ':package-name:' + '--version[Show the version.]' + '(-help -h --help)'{-help,-h,--help}'[Show help information.]' ) - _arguments $arguments && return + _arguments -w -s -S $args[@] && ret=0 + + return ret +} + +_swift_package_unedit() { + integer ret=1 + local -a args + args+=( + '--force[Unedit the package even if it has uncommitted and unpushed changes]' + ':package-name:' + '--version[Show the version.]' + '(-help -h --help)'{-help,-h,--help}'[Show help information.]' + ) + _arguments -w -s -S $args[@] && ret=0 + + return ret } _swift_package_config() { - arguments=( + integer ret=1 + local -a args + args+=( + '--version[Show the version.]' + '(-help -h --help)'{-help,-h,--help}'[Show help information.]' '(-): :->command' '(-)*:: :->arg' ) - _arguments $arguments && return + _arguments -w -s -S $args[@] && ret=0 case $state in (command) - local modes - modes=( + local subcommands + subcommands=( + 'set-mirror:Set a mirror for a dependency' 'unset-mirror:Remove an existing mirror' 'get-mirror:Print mirror configuration for the given package dependency' - 'set-mirror:Set a mirror for a dependency' ) - _describe "mode" modes + _describe "subcommand" subcommands ;; (arg) case ${words[1]} in + (set-mirror) + _swift_package_config_set-mirror + ;; (unset-mirror) _swift_package_config_unset-mirror ;; (get-mirror) _swift_package_config_get-mirror ;; - (set-mirror) - _swift_package_config_set-mirror - ;; esac ;; esac -} -_swift_package_config_unset-mirror() { - arguments=( - "--package-url[The package dependency url]:The package dependency url: " - "--mirror-url[The mirror url]:The mirror url: " - ) - _arguments $arguments && return -} - -_swift_package_config_get-mirror() { - arguments=( - "--package-url[The package dependency url]:The package dependency url: " - ) - _arguments $arguments && return + return ret } _swift_package_config_set-mirror() { - arguments=( - "--package-url[The package dependency url]:The package dependency url: " - "--mirror-url[The mirror url]:The mirror url: " + integer ret=1 + local -a args + args+=( + '--package-url[The package dependency url]:package-url:' + '--original-url[The original url]:original-url:' + '--mirror-url[The mirror url]:mirror-url:' + '--version[Show the version.]' + '(-help -h --help)'{-help,-h,--help}'[Show help information.]' ) - _arguments $arguments && return + _arguments -w -s -S $args[@] && ret=0 + + return ret } -_swift_package_update() { - arguments=( +_swift_package_config_unset-mirror() { + integer ret=1 + local -a args + args+=( + '--package-url[The package dependency url]:package-url:' + '--original-url[The original url]:original-url:' + '--mirror-url[The mirror url]:mirror-url:' + '--version[Show the version.]' + '(-help -h --help)'{-help,-h,--help}'[Show help information.]' ) - _arguments $arguments && return + _arguments -w -s -S $args[@] && ret=0 + + return ret } -# Generates completions for swift test -# -# In the final compdef file, set the following file header: -# -# #compdef _swift_test -# local context state state_descr line -# typeset -A opt_args -_swift_test() { - arguments=( - "-Xcc[Pass flag through to all C compiler invocations]:Pass flag through to all C compiler invocations: " - "-Xswiftc[Pass flag through to all Swift compiler invocations]:Pass flag through to all Swift compiler invocations: " - "-Xlinker[Pass flag through to all linker invocations]:Pass flag through to all linker invocations: " - "-Xcxx[Pass flag through to all C++ compiler invocations]:Pass flag through to all C++ compiler invocations: " - "(--configuration -c)"{--configuration,-c}"[Build with configuration (debug|release) ]: :{_values '' 'debug[build with DEBUG configuration]' 'release[build with RELEASE configuration]'}" - "--build-path[Specify build/cache directory ]:Specify build/cache directory :_files" - "(--chdir -C)"{--chdir,-C}"[]: :_files" - "--package-path[Change working directory before any other operation]:Change working directory before any other operation:_files" - "--sanitize[Turn on runtime checks for erroneous behavior]: :{_values '' 'address[enable Address sanitizer]' 'thread[enable Thread sanitizer]' 'undefined[enable Undefined Behavior sanitizer]'}" - "--disable-prefetching[]" - "--skip-update[Skip updating dependencies from their remote during a resolution]" - "--disable-sandbox[Disable using the sandbox when executing subprocesses]" - "--disable-package-manifest-caching[Disable caching Package.swift manifests]" - "--version[]" - "--destination[]: :_files" - "(--verbose -v)"{--verbose,-v}"[Increase verbosity of informational output]" - "--no-static-swift-stdlib[Do not link Swift stdlib statically \[default\]]" - "--static-swift-stdlib[Link Swift stdlib statically]" - "--force-resolved-versions[]" - "--disable-automatic-resolution[Disable automatic resolution if Package.resolved file is out-of-date]" - "--enable-index-store[Enable indexing-while-building feature]" - "--disable-index-store[Disable indexing-while-building feature]" - "--enable-pubgrub-resolver[\[Experimental\] Enable the new Pubgrub dependency resolver]" - "--enable-parseable-module-interfaces[]" - "--trace-resolver[]" - "(--jobs -j)"{--jobs,-j}"[The number of jobs to spawn in parallel during the build process]:The number of jobs to spawn in parallel during the build process: " - "--enable-test-discovery[Enable test discovery on platforms without Objective-C runtime]" - "--skip-build[Skip building the test target]" - "(--list-tests -l)"{--list-tests,-l}"[Lists test methods in specifier format]" - "--generate-linuxmain[Generate LinuxMain.swift entries for the package]" - "--parallel[Run the tests in parallel.]" - "--num-workers[Number of tests to execute in parallel.]:Number of tests to execute in parallel.: " - "(--specifier -s)"{--specifier,-s}"[]: : " - "--xunit-output[]: :_files" - "--filter[Run test cases matching regular expression, Format: . or ./]:Run test cases matching regular expression, Format: . or ./: " - "--enable-code-coverage[Test with code coverage enabled]" +_swift_package_config_get-mirror() { + integer ret=1 + local -a args + args+=( + '--package-url[The package dependency url]:package-url:' + '--original-url[The original url]:original-url:' + '--version[Show the version.]' + '(-help -h --help)'{-help,-h,--help}'[Show help information.]' ) - _arguments $arguments && return + _arguments -w -s -S $args[@] && ret=0 + + return ret } -_swift_compiler() { +_swift_package_resolve() { + integer ret=1 + local -a args + args+=( + '--version[The version to resolve at]:version:' + '--branch[The branch to resolve at]:branch:' + '--revision[The revision to resolve at]:revision:' + ':package-name:' + '--version[Show the version.]' + '(-help -h --help)'{-help,-h,--help}'[Show help information.]' + ) + _arguments -w -s -S $args[@] && ret=0 + + return ret +} + +_swift_package_fetch() { + integer ret=1 + local -a args + args+=( + '--version[The version to resolve at]:version:' + '--branch[The branch to resolve at]:branch:' + '--revision[The revision to resolve at]:revision:' + ':package-name:' + '--version[Show the version.]' + '(-help -h --help)'{-help,-h,--help}'[Show help information.]' + ) + _arguments -w -s -S $args[@] && ret=0 + + return ret +} + +_swift_package_show-dependencies() { + integer ret=1 + local -a args + args+=( + '--format[text | dot | json | flatlist]:format:' + '(--output-path -o)'{--output-path,-o}'[The absolute or relative path to output the resolved dependency graph.]:output-path:_files -/' + '--version[Show the version.]' + '(-help -h --help)'{-help,-h,--help}'[Show help information.]' + ) + _arguments -w -s -S $args[@] && ret=0 + + return ret +} + +_swift_package_tools-version() { + integer ret=1 + local -a args + args+=( + '--set-current[Set tools version of package to the current tools version in use]' + '--set[Set tools version of package to the given value]:set:' + '--version[Show the version.]' + '(-help -h --help)'{-help,-h,--help}'[Show help information.]' + ) + _arguments -w -s -S $args[@] && ret=0 + + return ret +} + +_swift_package_generate-xcodeproj() { + integer ret=1 + local -a args + args+=( + '--xcconfig-overrides[Path to xcconfig file]:xcconfig-overrides:_files' + '--output[Path where the Xcode project should be generated]:output:_files -/' + '--legacy-scheme-generator[Use the legacy scheme generator]' + '--watch[Watch for changes to the Package manifest to regenerate the Xcode project]' + '--skip-extra-files[Do not add file references for extra files to the generated Xcode project]' + '--enable-code-coverage[Enable code coverage]' + '--disable-code-coverage[Enable code coverage]' + '--version[Show the version.]' + '(-help -h --help)'{-help,-h,--help}'[Show help information.]' + ) + _arguments -w -s -S $args[@] && ret=0 + + return ret +} + +_swift_package_compute-checksum() { + integer ret=1 + local -a args + args+=( + ':path:_files -/' + '--version[Show the version.]' + '(-help -h --help)'{-help,-h,--help}'[Show help information.]' + ) + _arguments -w -s -S $args[@] && ret=0 + + return ret +} + +_swift_package_archive-source() { + integer ret=1 + local -a args + args+=( + '(-o --output)'{-o,--output}'[The absolute or relative path for the generated source archive]:output:_files -/' + '--version[Show the version.]' + '(-help -h --help)'{-help,-h,--help}'[Show help information.]' + ) + _arguments -w -s -S $args[@] && ret=0 + + return ret +} + +_swift_package_completion-tool() { + integer ret=1 + local -a args + args+=( + ':mode:(generate-bash-script generate-zsh-script generate-fish-script list-dependencies list-executables list-snippets)' + '--version[Show the version.]' + '(-help -h --help)'{-help,-h,--help}'[Show help information.]' + ) + _arguments -w -s -S $args[@] && ret=0 + + return ret +} + +_swift_package_plugin() { + integer ret=1 + local -a args + args+=( + '--list[List the available command plugins]' + '--allow-writing-to-package-directory[Allow the plugin to write to the package directory]' + '--allow-writing-to-directory[Allow the plugin to write to an additional directory]:allow-writing-to-directory:' + ':command:' + ':arguments:' + '--version[Show the version.]' + '(-help -h --help)'{-help,-h,--help}'[Show help information.]' + ) + _arguments -w -s -S $args[@] && ret=0 + + return ret +} + +_swift_package_default-command() { + integer ret=1 + local -a args + args+=( + '--allow-writing-to-package-directory[Allow the plugin to write to the package directory]' + '--allow-writing-to-directory[Allow the plugin to write to an additional directory]:allow-writing-to-directory:' + ':remaining:' + '--version[Show the version.]' + '(-help -h --help)'{-help,-h,--help}'[Show help information.]' + ) + _arguments -w -s -S $args[@] && ret=0 + + return ret +} + +_swift_help() { + integer ret=1 + local -a args + args+=( + ':subcommands:' + ) + _arguments -w -s -S $args[@] && ret=0 + + return ret +} + + +_custom_completion() { + local completions=("${(@f)$($*)}") + _describe '' completions } _swift From b3b336b0f95644ceda7758871191cdf040b897b2 Mon Sep 17 00:00:00 2001 From: Andrew Wu Date: Fri, 4 Nov 2022 01:34:28 +0800 Subject: [PATCH 058/672] feat(fzf): fix MacPorts auto-completion file location. (#11305) --- plugins/fzf/fzf.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/fzf/fzf.plugin.zsh b/plugins/fzf/fzf.plugin.zsh index a946cf762..60ae0c765 100644 --- a/plugins/fzf/fzf.plugin.zsh +++ b/plugins/fzf/fzf.plugin.zsh @@ -178,7 +178,7 @@ function fzf_setup_using_macports() { (( $+commands[fzf] )) || return 1 # The fzf-zsh-completion package installs the auto-completion in - local completions="/opt/local/share/zsh/site-functions/fzf" + local completions="/opt/local/share/fzf/shell/completion.zsh" # The fzf-zsh-completion package installs the key-bindings file in local key_bindings="/opt/local/share/fzf/shell/key-bindings.zsh" From 1342459b153576429382aed34ee5753f85bf3420 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Fri, 4 Nov 2022 19:16:54 +0100 Subject: [PATCH 059/672] ci: fix update of plugin or theme fields See [1] for the reference of value field (ProjectV2FieldValue type), and [2] for sample application code. [1] https://docs.github.com/en/graphql/reference/input-objects#projectv2fieldvalue [2] https://docs.github.com/en/enterprise-cloud@latest/issues/planning-and-tracking-with-projects/automating-your-project/automating-projects-using-actions#example-workflow-authenticating-with-a-github-app --- .github/workflows/project.yml | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/.github/workflows/project.yml b/.github/workflows/project.yml index 1aa69c279..1d961d8c0 100644 --- a/.github/workflows/project.yml +++ b/.github/workflows/project.yml @@ -113,7 +113,9 @@ jobs: projectId: $project itemId: $item fieldId: $plugin_field - value: $plugin_value + value: { + text: $plugin_value + } }) { projectV2Item { id @@ -123,7 +125,9 @@ jobs: projectId: $project itemId: $item fieldId: $theme_field - value: $theme_value + value: { + text: $theme_value + } }) { projectV2Item { id From 9f2bbebdf78322ab11a4cc57e2932fcbf6fb3fa8 Mon Sep 17 00:00:00 2001 From: Frieder Bluemle Date: Fri, 4 Nov 2022 11:34:02 -0700 Subject: [PATCH 060/672] docs: fix some capitalization typos(#11293) --- plugins/coffee/_coffee | 2 +- plugins/docker-machine/_docker-machine | 4 ++-- plugins/frontend-search/_frontend | 2 +- plugins/httpie/_httpie | 2 +- plugins/kitchen/_kitchen | 2 +- plugins/pod/_pod | 2 +- plugins/rails/_rails | 2 +- plugins/ripgrep/_ripgrep | 2 +- plugins/scala/_scala | 2 +- plugins/xcode/xcode.plugin.zsh | 2 +- themes/refined.zsh-theme | 4 ++-- 11 files changed, 13 insertions(+), 13 deletions(-) diff --git a/plugins/coffee/_coffee b/plugins/coffee/_coffee index e2814f7ba..a771f5204 100644 --- a/plugins/coffee/_coffee +++ b/plugins/coffee/_coffee @@ -1,6 +1,6 @@ #compdef coffee # ------------------------------------------------------------------------------ -# Copyright (c) 2011 Github zsh-users - https://github.com/zsh-users +# Copyright (c) 2011 GitHub zsh-users - https://github.com/zsh-users # All rights reserved. # # Redistribution and use in source and binary forms, with or without diff --git a/plugins/docker-machine/_docker-machine b/plugins/docker-machine/_docker-machine index fbd36d7c6..17bcd3598 100644 --- a/plugins/docker-machine/_docker-machine +++ b/plugins/docker-machine/_docker-machine @@ -335,9 +335,9 @@ _docker-machine() { '--tls-ca-key[Private key to generate certificates]:file:_files' \ '--tls-client-cert[Client cert to use for TLS]:file:_files' \ '--tls-client-key[Private key used in client TLS auth]:file:_files' \ - '--github-api-token[Token to use for requests to the Github API]' \ + '--github-api-token[Token to use for requests to the GitHub API]' \ '--native-ssh[Use the native (Go-based) SSH implementation.]' \ - '--bugsnag-api-token[BugSnag API token for crash reporting]' \ + '--bugsnag-api-token[Bugsnag API token for crash reporting]' \ '(- :)'{-v,--version}'[Print the version]' \ "(-): :->command" \ "(-)*:: :->option-or-argument" && ret=0 diff --git a/plugins/frontend-search/_frontend b/plugins/frontend-search/_frontend index 15f8d239d..aca4920d7 100644 --- a/plugins/frontend-search/_frontend +++ b/plugins/frontend-search/_frontend @@ -37,7 +37,7 @@ function _frontend() { 'lodash: Search in Lo-Dash website' 'mdn: Search in MDN website' 'nodejs: Search in NodeJS website' - 'npmjs: Search in NPMJS website' + 'npmjs: Search in npmjs website' 'packagephobia: Search in Packagephobia website' 'qunit: Search in Qunit website' 'reactjs: Search in React website' diff --git a/plugins/httpie/_httpie b/plugins/httpie/_httpie index 4d702ef60..11bc8e1f8 100644 --- a/plugins/httpie/_httpie +++ b/plugins/httpie/_httpie @@ -1,6 +1,6 @@ #compdef http # ------------------------------------------------------------------------------ -# Copyright (c) 2015 Github zsh-users - http://github.com/zsh-users +# Copyright (c) 2015 GitHub zsh-users - http://github.com/zsh-users # All rights reserved. # # Redistribution and use in source and binary forms, with or without diff --git a/plugins/kitchen/_kitchen b/plugins/kitchen/_kitchen index d93d93d78..64c01e395 100644 --- a/plugins/kitchen/_kitchen +++ b/plugins/kitchen/_kitchen @@ -1,6 +1,6 @@ #compdef kitchen # ------------------------------------------------------------------------------ -# Copyright (c) 2014 Github zsh-users - https://github.com/zsh-users +# Copyright (c) 2014 GitHub zsh-users - https://github.com/zsh-users # All rights reserved. # # Redistribution and use in source and binary forms, with or without diff --git a/plugins/pod/_pod b/plugins/pod/_pod index 80d23daad..d560129db 100644 --- a/plugins/pod/_pod +++ b/plugins/pod/_pod @@ -6,7 +6,7 @@ # ----------------------------------------------------------------------------- # FILE: _pod -# DESCRIPTION: Cocoapods (0.33.1) autocomplete plugin for Oh-My-Zsh +# DESCRIPTION: CocoaPods (0.33.1) autocomplete plugin for Oh-My-Zsh # https://cocoapods.org # Generated with `pod --completion-script # AUTHOR: Alexandre Joly (alexandre.joly@mekanics.ch) diff --git a/plugins/rails/_rails b/plugins/rails/_rails index 6dc85d458..ac90d45cc 100644 --- a/plugins/rails/_rails +++ b/plugins/rails/_rails @@ -1,6 +1,6 @@ #compdef rails # ------------------------------------------------------------------------------ -# Copyright (c) 2016 Github zsh-users - http://github.com/zsh-users +# Copyright (c) 2016 GitHub zsh-users - http://github.com/zsh-users # All rights reserved. # # Redistribution and use in source and binary forms, with or without diff --git a/plugins/ripgrep/_ripgrep b/plugins/ripgrep/_ripgrep index 31bc697c7..a93a8b8eb 100644 --- a/plugins/ripgrep/_ripgrep +++ b/plugins/ripgrep/_ripgrep @@ -591,7 +591,7 @@ _rg "$@" ################################################################################ # ------------------------------------------------------------------------------ -# Copyright (c) 2011 Github zsh-users - http://github.com/zsh-users +# Copyright (c) 2011 GitHub zsh-users - http://github.com/zsh-users # All rights reserved. # # Redistribution and use in source and binary forms, with or without diff --git a/plugins/scala/_scala b/plugins/scala/_scala index ba7ac3874..b4e834e2f 100644 --- a/plugins/scala/_scala +++ b/plugins/scala/_scala @@ -1,6 +1,6 @@ #compdef scala scalac # ------------------------------------------------------------------------------ -# Copyright (c) 2012 Github zsh-users - https://github.com/zsh-users +# Copyright (c) 2012 GitHub zsh-users - https://github.com/zsh-users # All rights reserved. # # Redistribution and use in source and binary forms, with or without diff --git a/plugins/xcode/xcode.plugin.zsh b/plugins/xcode/xcode.plugin.zsh index 3bd12cdec..5d1f901a3 100644 --- a/plugins/xcode/xcode.plugin.zsh +++ b/plugins/xcode/xcode.plugin.zsh @@ -31,7 +31,7 @@ function xx { open -a "Xcode.app" "$@" } -# "XCode-SELect by Version" - select Xcode by just version number +# "Xcode-Select by Version" - select Xcode by just version number # Uses naming convention: # - different versions of Xcode are named Xcode-.app or stored # in a folder named Xcode- diff --git a/themes/refined.zsh-theme b/themes/refined.zsh-theme index 5e2de7a87..2b55cfb0c 100644 --- a/themes/refined.zsh-theme +++ b/themes/refined.zsh-theme @@ -11,11 +11,11 @@ # more about both of these fantastic two people here: # # Sindre Sorhus -# Github: https://github.com/sindresorhus +# GitHub: https://github.com/sindresorhus # Twitter: https://twitter.com/sindresorhus # # Julien Nicoulaud -# Github: https://github.com/nicoulaj +# GitHub: https://github.com/nicoulaj # Twitter: https://twitter.com/nicoulaj # # ------------------------------------------------------------------------------ From 15014db8d58892488f6a270148279e053a472bfb Mon Sep 17 00:00:00 2001 From: Tanmay Patil <92677342+TanmayPatil105@users.noreply.github.com> Date: Sat, 5 Nov 2022 00:12:05 +0530 Subject: [PATCH 061/672] feat(web-search): add ask.com (#11292) --- plugins/web-search/README.md | 1 + plugins/web-search/web-search.plugin.zsh | 2 ++ 2 files changed, 3 insertions(+) diff --git a/plugins/web-search/README.md b/plugins/web-search/README.md index 54232a910..0bf9f26ad 100644 --- a/plugins/web-search/README.md +++ b/plugins/web-search/README.md @@ -43,6 +43,7 @@ Available search contexts are: | `wolframalpha` | `https://wolframalpha.com/input?i=` | | `archive` | `https://web.archive.org/web/*/` | | `scholar` | `https://scholar.google.com/scholar?q=` | +| `ask` | `https://www.ask.com/web?q=` | Also there are aliases for bang-searching DuckDuckGo: diff --git a/plugins/web-search/web-search.plugin.zsh b/plugins/web-search/web-search.plugin.zsh index d8b4a7f8b..ec176dd68 100644 --- a/plugins/web-search/web-search.plugin.zsh +++ b/plugins/web-search/web-search.plugin.zsh @@ -24,6 +24,7 @@ function web_search() { wolframalpha "https://www.wolframalpha.com/input/?i=" archive "https://web.archive.org/web/*/" scholar "https://scholar.google.com/scholar?q=" + ask "https://www.ask.com/web?q=" ) # check whether the search engine is supported @@ -64,6 +65,7 @@ alias stackoverflow='web_search stackoverflow' alias wolframalpha='web_search wolframalpha' alias archive='web_search archive' alias scholar='web_search scholar' +alias ask='web_search ask' #add your own !bang searches here alias wiki='web_search duckduckgo \!w' From 80fdbc9b91a9acca42fb90065b5e64a9722978a7 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Fri, 4 Nov 2022 19:45:17 +0100 Subject: [PATCH 062/672] fix(git): remove unused escape chars Closes #11176 --- plugins/git/git.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/git/git.plugin.zsh b/plugins/git/git.plugin.zsh index f25453bc1..5c0e6db2c 100644 --- a/plugins/git/git.plugin.zsh +++ b/plugins/git/git.plugin.zsh @@ -302,7 +302,7 @@ alias gtv='git tag | sort -V' alias gtl='gtl(){ git tag --sort=-v:refname -n -l "${1}*" }; noglob gtl' alias gunignore='git update-index --no-assume-unchanged' -alias gunwip='git log -n 1 | grep -q -c "\-\-wip\-\-" && git reset HEAD~1' +alias gunwip='git log -n 1 | grep -q -c "--wip--" && git reset HEAD~1' alias gup='git pull --rebase' alias gupv='git pull --rebase -v' alias gupa='git pull --rebase --autostash' From 3eda3e5650c72c5f71336fcc2c8dfa5b861acb6d Mon Sep 17 00:00:00 2001 From: Jeremy Combs Date: Sun, 6 Nov 2022 14:50:39 -0500 Subject: [PATCH 063/672] feat(encode64): add `encodefile64` function (#10813) Co-authored-by: Jeremy Combs --- plugins/encode64/README.md | 23 +++++++++++++++++++---- plugins/encode64/encode64.plugin.zsh | 10 ++++++++++ 2 files changed, 29 insertions(+), 4 deletions(-) diff --git a/plugins/encode64/README.md b/plugins/encode64/README.md index 86320cffb..7cdf8c3f3 100644 --- a/plugins/encode64/README.md +++ b/plugins/encode64/README.md @@ -10,10 +10,11 @@ plugins=(... encode64) ## Functions and Aliases -| Function | Alias | Description | -| ---------- | ----- | ------------------------------ | -| `encode64` | `e64` | Encodes given data to base64 | -| `decode64` | `d64` | Decodes given data from base64 | +| Function | Alias | Description | +| -------------- | ------ | -------------------------------------- | +| `encode64` | `e64` | Encodes given data to base64 | +| `encodefile64` | `ef64` | Encodes given file's content to base64 | +| `decode64` | `d64` | Decodes given data from base64 | ## Usage and examples @@ -37,6 +38,20 @@ plugins=(... encode64) b2gtbXktenNo== ``` +### Encoding a file + +Encode a file's contents to base64 and save output to text file. +**NOTE:** Takes provided file and saves encoded content as new file with `.txt` extension + +- From parameter + + ```console + $ encodefile64 ohmyzsh.icn + ohmyzsh.icn's content encoded in base64 and saved as ohmyzsh.icn.txt + $ ef64 "oh-my-zsh" + ohmyzsh.icn's content encoded in base64 and saved as ohmyzsh.icn.txt + ``` + ### Decoding - From parameter diff --git a/plugins/encode64/encode64.plugin.zsh b/plugins/encode64/encode64.plugin.zsh index 979e06742..6927f5216 100644 --- a/plugins/encode64/encode64.plugin.zsh +++ b/plugins/encode64/encode64.plugin.zsh @@ -6,6 +6,15 @@ encode64() { fi } +encodefile64() { + if [[ $# -eq 0 ]]; then + echo "You must provide a filename" + else + base64 -i $1 -o $1.txt + echo "${1}'s content encoded in base64 and saved as ${1}.txt" + fi +} + decode64() { if [[ $# -eq 0 ]]; then cat | base64 --decode @@ -14,4 +23,5 @@ decode64() { fi } alias e64=encode64 +alias ef64=encodefile64 alias d64=decode64 From 4806f755694d160f20e3fb8ae0a1d009d56d966b Mon Sep 17 00:00:00 2001 From: Atk Date: Sun, 6 Nov 2022 19:52:53 +0000 Subject: [PATCH 064/672] feat(wd): update to latest upstream release (#11235) Based on https://github.com/mfaerevaag/wd/releases/tag/v0.5.2 --- plugins/wd/README.md | 8 ++++++-- plugins/wd/wd.sh | 18 +++++++++++++++--- 2 files changed, 21 insertions(+), 5 deletions(-) diff --git a/plugins/wd/README.md b/plugins/wd/README.md index 8791f9f0e..1d1980632 100644 --- a/plugins/wd/README.md +++ b/plugins/wd/README.md @@ -1,12 +1,12 @@ # wd -[![Build Status](https://travis-ci.org/mfaerevaag/wd.png?branch=master)](https://travis-ci.org/mfaerevaag/wd) +[![Build Status](https://github.com/mfaerevaag/wd/actions/workflows/test.yml/badge.svg)](https://github.com/mfaerevaag/wd/actions) `wd` (*warp directory*) lets you jump to custom directories in zsh, without using `cd`. Why? Because `cd` seems inefficient when the folder is frequently visited or has a long path. -![tty.gif](https://raw.githubusercontent.com/mfaerevaag/wd/master/tty.gif) +![Demo](https://raw.githubusercontent.com/mfaerevaag/wd/master/tty.gif) ## Setup @@ -36,6 +36,10 @@ In your `.zshrc`: antibody bundle mfaerevaag/wd ``` +### [Fig](https://fig.io) + +Install `wd` here: [![Fig plugin store](https://fig.io/badges/install-with-fig.svg)](https://fig.io/plugins/other/wd_mfaerevaag) + ### Arch ([AUR](https://aur.archlinux.org/packages/zsh-plugin-wd-git/)) 1. Install from the AUR diff --git a/plugins/wd/wd.sh b/plugins/wd/wd.sh index 9085c5b7b..e51cf906a 100644 --- a/plugins/wd/wd.sh +++ b/plugins/wd/wd.sh @@ -163,6 +163,7 @@ wd_add() { local point=$1 local force=$2 + cmdnames=(add rm show list ls path clean help) if [[ $point == "" ]] then @@ -178,6 +179,9 @@ wd_add() elif [[ $point =~ : ]] || [[ $point =~ / ]] then wd_exit_fail "Warp point contains illegal character (:/)" + elif (($cmdnames[(Ie)$point])) + then + wd_exit_fail "Warp point name cannot be a wd command (see wd -h for a full list)" elif [[ ${points[$point]} == "" ]] || [ ! -z "$force" ] then wd_remove "$point" > /dev/null @@ -185,7 +189,7 @@ wd_add() if (whence sort >/dev/null); then local config_tmp=$(mktemp "${TMPDIR:-/tmp}/wd.XXXXXXXXXX") # use 'cat' below to ensure we respect $WD_CONFIG as a symlink - command sort -o "${config_tmp}" "$WD_CONFIG" && command cat "${config_tmp}" > "$WD_CONFIG" && command rm "${config_tmp}" + command sort -o "${config_tmp}" "$WD_CONFIG" && command cat "${config_tmp}" >| "$WD_CONFIG" && command rm "${config_tmp}" fi wd_export_static_named_directories @@ -214,7 +218,7 @@ wd_remove() then local config_tmp=$(mktemp "${TMPDIR:-/tmp}/wd.XXXXXXXXXX") # Copy and delete in two steps in order to preserve symlinks - if sed -n "/^${point_name}:.*$/!p" "$WD_CONFIG" > "$config_tmp" && command cp "$config_tmp" "$WD_CONFIG" && command rm "$config_tmp" + if sed -n "/^${point_name}:.*$/!p" "$WD_CONFIG" >| "$config_tmp" && command cp "$config_tmp" "$WD_CONFIG" && command rm "$config_tmp" then wd_print_msg "$WD_GREEN" "Warp point removed" else @@ -251,7 +255,7 @@ wd_list_all() then arr=(${(s,:,)line}) key=${arr[1]} - val=${arr[2]} + val=${line#"${arr[1]}:"} if [[ -z $wd_quiet_mode ]] then @@ -389,6 +393,11 @@ else wd_export_static_named_directories fi +# disable extendedglob for the complete wd execution time +setopt | grep -q extendedglob +wd_extglob_is_set=$? +[[ $wd_extglob_is_set ]] && setopt noextendedglob + # load warp points typeset -A points while read -r line @@ -475,6 +484,9 @@ fi # if not, next time warp will pick up variables from this run # remember, there's no sub shell +[[ $wd_extglob_is_set ]] && setopt extendedglob + +unset wd_extglob_is_set unset wd_warp unset wd_add unset wd_remove From 4e2317c757674af8264bbcc4edd79b2d42f6d781 Mon Sep 17 00:00:00 2001 From: Julian <62412964+julianadler@users.noreply.github.com> Date: Mon, 7 Nov 2022 21:46:48 +1300 Subject: [PATCH 065/672] fix(lol): use https for `yolo` calls (#11320) --- plugins/lol/README.md | 4 ++-- plugins/lol/lol.plugin.zsh | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/plugins/lol/README.md b/plugins/lol/README.md index ea6b0c3b8..b45513b35 100644 --- a/plugins/lol/README.md +++ b/plugins/lol/README.md @@ -49,7 +49,7 @@ plugins=(... lol) | `violenz` | `git rebase` | | `visible` | `echo` | | `wtf` | `dmesg` | -| `yolo` | `git commit -m "$(curl -s http://whatthecommit.com/index.txt)"` | +| `yolo` | `git commit -m "$(curl -s https://whatthecommit.com/index.txt)"` | ## Usage Examples @@ -66,6 +66,6 @@ nowai u=r,go= some.file # ssh root@catserver.org pwned root@catserver.org -# git commit -m "$(curl -s http://whatthecommit.com/index.txt)" +# git commit -m "$(curl -s https://whatthecommit.com/index.txt)" yolo ``` diff --git a/plugins/lol/lol.plugin.zsh b/plugins/lol/lol.plugin.zsh index 3c30259a1..585f96e4f 100644 --- a/plugins/lol/lol.plugin.zsh +++ b/plugins/lol/lol.plugin.zsh @@ -45,7 +45,7 @@ alias bringz='git pull' alias chicken='git add' alias oanward='git commit -m' alias ooanward='git commit -am' -alias yolo='git commit -m "$(curl -s http://whatthecommit.com/index.txt)"' +alias yolo='git commit -m "$(curl -s https://whatthecommit.com/index.txt)"' alias letcat='git checkout' alias violenz='git rebase' From ac0924930d48217e127523809dc5d386fb3403a4 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ho=C3=A0ng?= <10150902+hoang-himself@users.noreply.github.com> Date: Mon, 7 Nov 2022 15:47:59 +0700 Subject: [PATCH 066/672] feat(git): add aliases for `worktree` (#10079) --- plugins/git/README.md | 11 ++++++++--- plugins/git/git.plugin.zsh | 6 ++++++ 2 files changed, 14 insertions(+), 3 deletions(-) diff --git a/plugins/git/README.md b/plugins/git/README.md index 050c13d81..f1c8b81c4 100644 --- a/plugins/git/README.md +++ b/plugins/git/README.md @@ -91,8 +91,8 @@ plugins=(... git) | gignore | git update-index --assume-unchanged | | gignored | git ls-files -v \| grep "^[[:lower:]]" | | git-svn-dcommit-push | git svn dcommit && git push github $(git_main_branch):svntrunk | -| gk | gitk --all --branches &! | -| gke | gitk --all $(git log -g --pretty=%h) &! | +| gk | gitk --all --branches &! | +| gke | gitk --all $(git log -g --pretty=%h) &! | | gl | git pull | | glg | git log --stat | | glgp | git log --stat -p | @@ -184,7 +184,7 @@ plugins=(... git) | gupom | git pull --rebase origin $(git_main_branch) | | gupomi | git pull --rebase=interactive origin $(git_main_branch) | | glum | git pull upstream $(git_main_branch) | -| gluc | git pull upstream $(git_current_branch) | +| gluc | git pull upstream $(git_current_branch) | | gwch | git whatchanged -p --abbrev-commit --pretty=medium | | gwip | git add -A; git rm $(git ls-files --deleted) 2> /dev/null; git commit --no-verify --no-gpg-sign -m "--wip-- [skip ci]" | | gam | git am | @@ -192,6 +192,11 @@ plugins=(... git) | gams | git am --skip | | gama | git am --abort | | gamscp | git am --show-current-patch | +| gwt | git worktree | +| gwta | git worktree add | +| gwtls | git worktree list | +| gwtmv | git worktree move | +| gwtrm | git worktree remove | ### Main branch preference diff --git a/plugins/git/git.plugin.zsh b/plugins/git/git.plugin.zsh index 5c0e6db2c..fc7699237 100644 --- a/plugins/git/git.plugin.zsh +++ b/plugins/git/git.plugin.zsh @@ -315,6 +315,12 @@ alias gluc='git pull upstream $(git_current_branch)' alias gwch='git whatchanged -p --abbrev-commit --pretty=medium' alias gwip='git add -A; git rm $(git ls-files --deleted) 2> /dev/null; git commit --no-verify --no-gpg-sign -m "--wip-- [skip ci]"' +alias gwt='git worktree' +alias gwta='git worktree add' +alias gwtls='git worktree list' +alias gwtmv='git worktree move' +alias gwtrm='git worktree remove' + alias gam='git am' alias gamc='git am --continue' alias gams='git am --skip' From 0145d744a9c4c11f00992f7f3ad9555bc8ac6177 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Mon, 7 Nov 2022 12:59:12 +0100 Subject: [PATCH 067/672] fix(git): escape first hyphen in `gunwip` --- plugins/git/git.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/git/git.plugin.zsh b/plugins/git/git.plugin.zsh index fc7699237..26f4beeb3 100644 --- a/plugins/git/git.plugin.zsh +++ b/plugins/git/git.plugin.zsh @@ -302,7 +302,7 @@ alias gtv='git tag | sort -V' alias gtl='gtl(){ git tag --sort=-v:refname -n -l "${1}*" }; noglob gtl' alias gunignore='git update-index --no-assume-unchanged' -alias gunwip='git log -n 1 | grep -q -c "--wip--" && git reset HEAD~1' +alias gunwip='git log -n 1 | grep -q -c "\--wip--" && git reset HEAD~1' alias gup='git pull --rebase' alias gupv='git pull --rebase -v' alias gupa='git pull --rebase --autostash' From 6df14641ac48b380c56e1c72aa86b57861fbfb70 Mon Sep 17 00:00:00 2001 From: Gheritarish Date: Mon, 7 Nov 2022 19:53:36 +0100 Subject: [PATCH 068/672] feat(1password): add username copy to `opswd` (#10812) --- plugins/1password/README.md | 16 +++++++++------- plugins/1password/opswd | 18 +++++++++++++++--- 2 files changed, 24 insertions(+), 10 deletions(-) diff --git a/plugins/1password/README.md b/plugins/1password/README.md index f6854da53..ace6da8e1 100644 --- a/plugins/1password/README.md +++ b/plugins/1password/README.md @@ -14,16 +14,18 @@ clipboard. ## `opswd` The `opswd` command is a wrapper around the `op` command. It takes a service -name as an argument and copies the password for that service to the clipboard. +name as an argument and copies the username, then the password for that service +to the clipboard, after confirmation on the user part. -If the service also contains a TOTP, it is copied to the clipboard after 10 seconds. -Finally, after 20 seconds, the clipboard is cleared. +If the service also contains a TOTP, it is copied to the clipboard after confirmation +on the user part. Finally, after 20 seconds, the clipboard is cleared. -The function has completion support, so you can use tab completion to select -which service you want to get. +For example, `opswd github.com` will put your GitHub username into your clipboard. Then, +it will ask for confirmation to continue, and copy the password to your clipboard. Finally, +if a TOTP is available, it will be copied to the clipboard after your confirmation. -For example, `opswd github.com` will put your GitHub password into your clipboard, and if -a TOTP is available, it will be copied to the clipboard after 10 seconds. +This function has completion support, so you can use tab completion to select which +service you want to get. > NOTE: you need to be signed in for `opswd` to work. If you are using biometric unlock, > 1Password CLI will automatically prompt you to sign in. See: diff --git a/plugins/1password/opswd b/plugins/1password/opswd index 57672807e..0f667d2ff 100644 --- a/plugins/1password/opswd +++ b/plugins/1password/opswd @@ -14,6 +14,17 @@ function opswd() { # If not logged in, print error and return op user list > /dev/null || return + local username + # Copy the username to the clipboard + if ! username=$(op item get "$service" --fields username 2>/dev/null); then + echo "error: could not obtain username for $service" + return 1 + fi + + echo -n "$username" | clipcopy + echo "✔ username for service $service copied to the clipboard. Press Enter to continue" + read + local password # Copy the password to the clipboard if ! password=$(op item get "$service" --fields password 2>/dev/null); then @@ -22,12 +33,13 @@ function opswd() { fi echo -n "$password" | clipcopy - echo "✔ password for $service copied to clipboard" + echo "✔ password for $service copied to clipboard. Press Enter to continue" + read - # If there's a one time password, copy it to the clipboard after 10 seconds + # If there's a one time password, copy it to the clipboard local totp if totp=$(op item get --otp "$service" 2>/dev/null) && [[ -n "$totp" ]]; then - sleep 10 && echo -n "$totp" | clipcopy + echo -n "$totp" | clipcopy echo "✔ TOTP for $service copied to clipboard" fi From 6dfc9b960f023f30d6c55a22fa8402d91beb8d1f Mon Sep 17 00:00:00 2001 From: Banst Date: Tue, 8 Nov 2022 09:34:13 +0100 Subject: [PATCH 069/672] feat(git): display tag in git-prompt when possible (#11318) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Co-authored-by: Marc Cornellà --- lib/git.zsh | 1 + 1 file changed, 1 insertion(+) diff --git a/lib/git.zsh b/lib/git.zsh index be9fa7e67..f049f73c2 100644 --- a/lib/git.zsh +++ b/lib/git.zsh @@ -19,6 +19,7 @@ function git_prompt_info() { local ref ref=$(__git_prompt_git symbolic-ref --short HEAD 2> /dev/null) \ + || ref=$(__git_prompt_git describe --tags --exact-match HEAD 2> /dev/null) \ || ref=$(__git_prompt_git rev-parse --short HEAD 2> /dev/null) \ || return 0 From 1f30c1a079cd10030578e38f8562dc5be53d0fd3 Mon Sep 17 00:00:00 2001 From: Sandeep Tailor Date: Tue, 8 Nov 2022 13:45:42 +0000 Subject: [PATCH 070/672] feat(hasura): add completion plugin (#11278) --- plugins/hasura/README.md | 9 +++++++++ plugins/hasura/hasura.plugin.zsh | 13 +++++++++++++ 2 files changed, 22 insertions(+) create mode 100644 plugins/hasura/README.md create mode 100644 plugins/hasura/hasura.plugin.zsh diff --git a/plugins/hasura/README.md b/plugins/hasura/README.md new file mode 100644 index 000000000..d7db9ed92 --- /dev/null +++ b/plugins/hasura/README.md @@ -0,0 +1,9 @@ +# Hasura plugin + +This plugin adds completion for [the Hasura CLI](https://hasura.io/docs/latest/hasura-cli/index/). + +To use it, add `hasura` to the plugins array in your zshrc file: + +```zsh +plugins=(... hasura) +``` diff --git a/plugins/hasura/hasura.plugin.zsh b/plugins/hasura/hasura.plugin.zsh new file mode 100644 index 000000000..18254c43b --- /dev/null +++ b/plugins/hasura/hasura.plugin.zsh @@ -0,0 +1,13 @@ +if (( ! $+commands[hasura] )); then + return +fi + +# 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/_hasura" ]]; then + hasura completion zsh --file "$ZSH_CACHE_DIR/completions/_hasura" >/dev/null + source "$ZSH_CACHE_DIR/completions/_hasura" +else + source "$ZSH_CACHE_DIR/completions/_hasura" + hasura completion zsh --file "$ZSH_CACHE_DIR/completions/_hasura" >/dev/null &| +fi From 9f77cb29d7557ec6ce453a7372b053931a7d034d Mon Sep 17 00:00:00 2001 From: Marco Franssen Date: Fri, 15 Apr 2022 20:43:43 +0200 Subject: [PATCH 071/672] feat(sigstore): add completion plugin Closes #10862 Signed-off-by: Marco Franssen Co-authored-by: Carlo Sala --- plugins/sigstore/README.md | 13 +++++++++++++ plugins/sigstore/sigstore.plugin.zsh | 22 ++++++++++++++++++++++ 2 files changed, 35 insertions(+) create mode 100644 plugins/sigstore/README.md create mode 100644 plugins/sigstore/sigstore.plugin.zsh diff --git a/plugins/sigstore/README.md b/plugins/sigstore/README.md new file mode 100644 index 000000000..00e83c8c2 --- /dev/null +++ b/plugins/sigstore/README.md @@ -0,0 +1,13 @@ +# Sigstore plugin + +This plugin sets up completion for the following [Sigstore](https://sigstore.dev/) CLI tools. + +- [Cosign](https://docs.sigstore.dev/cosign/overview) +- [Sget](https://docs.sigstore.dev/cosign/installation#alpine-linux) +- [Rekor](https://docs.sigstore.dev/rekor/overview) + +To use it, add `sigstore` to the plugins array in your zshrc file: + +```zsh +plugins=(... sigstore) +``` diff --git a/plugins/sigstore/sigstore.plugin.zsh b/plugins/sigstore/sigstore.plugin.zsh new file mode 100644 index 000000000..1f9d77c11 --- /dev/null +++ b/plugins/sigstore/sigstore.plugin.zsh @@ -0,0 +1,22 @@ +function install_autocompletion { + if (( ! $+commands[$1] )); then + return + fi + + # If the completion file doesn't exist yet, we need to autoload it and + # bind it to `$1` (cosign, sget, rekor-cli). Otherwise, compinit will + # have already done that + if [[ ! -f "$ZSH_CACHE_DIR/completions/_$1" ]]; then + autoload -Uz _$1 + typeset -g -A _comps + _comps[$1]=_$1 + fi + + $1 completion zsh >| "$ZSH_CACHE_DIR/completions/_$1" &| +} + +install_autocompletion cosign +install_autocompletion sget +install_autocompletion rekor-cli + +unfunction install_autocompletion From 23de5d95285a6b119d7c99f777051d9c5ec69ef8 Mon Sep 17 00:00:00 2001 From: cxy004 Date: Thu, 10 Nov 2022 06:04:55 +0800 Subject: [PATCH 072/672] fix(colorize): check if $ZSH_COLORIZE_TOOL exists (#11325) --- plugins/colorize/colorize.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/colorize/colorize.plugin.zsh b/plugins/colorize/colorize.plugin.zsh index a9da6cf83..12841e0ee 100644 --- a/plugins/colorize/colorize.plugin.zsh +++ b/plugins/colorize/colorize.plugin.zsh @@ -23,7 +23,7 @@ colorize_check_requirements() { if [[ ${available_tools[(Ie)$ZSH_COLORIZE_TOOL]} -eq 0 ]]; then echo "ZSH_COLORIZE_TOOL '$ZSH_COLORIZE_TOOL' not recognized. Available options are 'pygmentize' and 'chroma'." >&2 return 1 - elif (( $+commands["$ZSH_COLORIZE_TOOL"] )); then + elif ! (( $+commands[$ZSH_COLORIZE_TOOL] )); then echo "Package '$ZSH_COLORIZE_TOOL' is not installed!" >&2 return 1 fi From fcbfdf42de702d55174fe2b19142ba232289671e Mon Sep 17 00:00:00 2001 From: Marcos Alano Date: Thu, 10 Nov 2022 18:36:51 +0100 Subject: [PATCH 073/672] feat(terraform): load completion from bash Closes #11328 Closes #11330 --- plugins/terraform/_terraform | 411 ------------------------- plugins/terraform/terraform.plugin.zsh | 5 + 2 files changed, 5 insertions(+), 411 deletions(-) delete mode 100644 plugins/terraform/_terraform diff --git a/plugins/terraform/_terraform b/plugins/terraform/_terraform deleted file mode 100644 index 625834563..000000000 --- a/plugins/terraform/_terraform +++ /dev/null @@ -1,411 +0,0 @@ -#compdef terraform - -local -a _terraform_cmds opt_args -_terraform_cmds=( - 'apply:Builds or changes infrastructure' - 'console:Interactive console for Terraform interpolations' - 'destroy:Destroy Terraform-managed infrastructure' - 'fmt:Rewrites config files to canonical format' - 'force-unlock:Manually unlock the terraform state' - 'get:Download and install modules for the configuration' - 'graph:Create a visual graph of Terraform resources' - 'import:Import existing infrastructure into Terraform' - 'init:Initialize a Terraform working directory' - 'login:Obtain and save credentials for a remote host' - 'logout:Remove locally-stored credentials for a remote host' - 'output:Read an output from a state file' - 'plan:Generate and show an execution plan' - 'providers:Prints a tree of the providers used in the configuration' - 'refresh:Update local state file against real resources' - 'show:Inspect Terraform state or plan' - 'state:Advanced state management' - 'taint:Manually mark a resource for recreation' - 'untaint:Manually unmark a resource as tainted' - 'validate:Validates the Terraform files' - 'version:Prints the Terraform version' - 'workspace:Workspace management' - '0.12upgrade:Rewrites pre-0.12 module source code for v0.12' - '0.13upgrade:Rewrites pre-0.13 module source code for v0.13' -) - -__012upgrade() { - _arguments \ - '-yes[Skip the initial introduction messages and interactive confirmation. This can be used to run this command in batch from a script.]' \ - '-force[ Override the heuristic that attempts to detect if a configuration is already written for v0.12 or later. Some of the transformations made by this command are not idempotent, so re-running against the same module may change the meanings expressions in the module.]' -} - -__013upgrade() { - _arguments \ - '-yes[Skip the initial introduction messages and interactive confirmation. This can be used to run this command in batch from a script.]' -} - -__apply() { - _arguments \ - '-auto-approve[Skip interactive approval of plan before applying.]' \ - '-backup=[(path) Path to backup the existing state file before modifying. Defaults to the "-state-out" path with ".backup" extension. Set to "-" to disable backup.]:backupfile:_files -g "*.backup"' \ - '-compact-warnings[If Terraform produces any warnings that are not accompanied by errors, show them in a more compact form that includes only the summary messages.]' \ - '-lock=[(true) Lock the state file when locking is supported.]:lock:(true false)' \ - '-lock-timeout=[(0s) Duration to retry a state lock.]' \ - '-input=[(true) Ask for input for variables if not directly set.]' \ - '-no-color[If specified, output will be colorless.]' \ - '-parallelism=[(10) Limit the number of parallel resource operations.]' \ - '-refresh=[(true) Update state prior to checking for differences. This has no effect if a plan file is given to apply.]' \ - '-state=[(terraform.tfstate) Path to read and save state (unless state-out is specified).]:statefile:_files -g "*.tfstate"' \ - '-state-out=[(path) Path to write state to that is different than "-state". This can be used to preserve the old state.]:statefile:_files -g "*.tfstate"' \ - '*-target=[(resource) Resource to target. Operation will be limited to this resource and its dependencies. This flag can be used multiple times.]:target:__statelist' \ - '*-var[("foo=bar") Set a variable in the Terraform configuration. This flag can be set multiple times.]' \ - '*-var-file=[(foo) Set variables in the Terraform configuration from a file. If "terraform.tfvars" or any ".auto.tfvars" files are present, they will be automatically loaded.]:file:_files -g "*.tfvars{,.json}"' -} - -__console() { - _arguments \ - '-state=[(terraform.tfstate) Path to read state.]' \ - '*-var[("foo=bar") Set a variable in the Terraform configuration. This flag can be set multiple times.]' \ - '*-var-file=[(foo) Set variables in the Terraform configuration from a file. If "terraform.tfvars" or any ".auto.tfvars" files are present, they will be automatically loaded.]:file:_files -g "*.tfvars{,.json}"' -} - -__destroy() { - _arguments \ - '-backup=[(path) Path to backup the existing state file before modifying. Defaults to the "-state-out" path with ".backup" extension. Set to "-" to disable backup.]:backupfile:_files -g "*.backup"' \ - '-auto-approve[Skip interactive approval before destroying.]' \ - '-force[Deprecated: same as auto-approve.]' \ - '-lock=[(true) Lock the state file when locking is supported.]:lock:(true false)' \ - '-lock-timeout=[(0s) Duration to retry a state lock.]' \ - '-no-color[If specified, output will contain no color.]' \ - '-parallelism=[(10) Limit the number of concurrent operations.]' \ - '-refresh=[(true) Update state prior to checking for differences. This has no effect if a plan file is given to apply.]' \ - '-state=[(terraform.tfstate) Path to read and save state (unless state-out is specified).]:statefile:_files -g "*.tfstate"' \ - '-state-out=[(path) Path to write state to that is different than "-state". This can be used to preserve the old state.]:statefile:_files -g "*.tfstate"' \ - '*-target=[(resource) Resource to target. Operation will be limited to this resource and its dependencies. This flag can be used multiple times.]:target:__statelist' \ - '*-var[("foo=bar") Set a variable in the Terraform configuration. This flag can be set multiple times.]' \ - '*-var-file=[(foo) Set variables in the Terraform configuration from a file. If "terraform.tfvars" or any ".auto.tfvars" files are present, they will be automatically loaded.]:file:_files -g "*.tfvars{,.json}"' -} - -__fmt() { - _arguments \ - '-list=[(true) List files whose formatting differs (always false if using STDIN)]' \ - '-write=[(true) Write result to source file instead of STDOUT (always false if using STDIN or -check)]' \ - '-diff=[(false) Display diffs of formatting changes]' \ - '-check=[(false) Check if the input is formatted. Exit status will be 0 if all input is properly formatted and non-zero otherwise.]' \ - '-recursive=[(false) Also process files in subdirectories. By default, only the given directory (or current directory) is processed.]' -} - -__force_unlock() { - _arguments \ - "-force[Don't ask for input for unlock confirmation.]" -} - -__get() { - _arguments \ - '-update=[(false) If true, modules already downloaded will be checked for updates and updated if necessary.]' \ - '-no-color[Disable text coloring in the output.]' -} - -__graph() { - _arguments \ - '-draw-cycles[Highlight any cycles in the graph with colored edges. This helps when diagnosing cycle errors.]' \ - '-type=[(plan) Type of graph to output. Can be: plan, plan-destroy, apply, validate, input, refresh.]' -} - -__import() { - _arguments \ - '-backup=[(path) Path to backup the existing state file before modifying. Defaults to the "-state-out" path with ".backup" extension. Set to "-" to disable backup.]:backupfile:_files -g "*.backup"' \ - '-config=[(path) Path to a directory of Terraform configuration files to use to configure the provider. Defaults to pwd. If no config files are present, they must be provided via the input prompts or env vars.]' \ - '-allow-missing-config[Allow import when no resource configuration block exists.]' \ - '-input=[(true) Ask for input for variables if not directly set.]' \ - '-lock=[(true) Lock the state file when locking is supported.]:lock:(true false)' \ - '-lock-timeout=[(0s) Duration to retry a state lock.]' \ - '-no-color[If specified, output will contain no color.]' \ - '-state=[(PATH) Path to the source state file. Defaults to the configured backend, or "terraform.tfstate"]:statefile:_files -g "*.tfstate"' \ - '-state-out=[(PATH) Path to the destination state file to write to. If this is not specified, the source state file will be used. This can be a new or existing path.]:statefile:_files -g "*.tfstate"' \ - '*-var[("foo=bar") Set a variable in the Terraform configuration. This flag can be set multiple times. This is only useful with the "-config" flag.]' \ - '*-var-file=[(foo) Set variables in the Terraform configuration from a file. If "terraform.tfvars" or any ".auto.tfvars" files are present, they will be automatically loaded.]:file:_files -g "*.tfvars{,.json}"' -} - -__init() { - _arguments \ - '-backend=[(true) Configure the backend for this configuration.]' \ - '-backend-config=[This can be either a path to an HCL file with key/value assignments (same format as terraform.tfvars) or a 'key=value' format. This is merged with what is in the configuration file. This can be specified multiple times. The backend type must be in the configuration itself.]' \ - '-force-copy[Suppress prompts about copying state data. This is equivalent to providing a "yes" to all confirmation prompts.]' \ - '-from-module=[(SOURCE) Copy the contents of the given module into the target directory before initialization.]' \ - '-get=[(true) Download any modules for this configuration.]' \ - '-get-plugins=[(true) Download any missing plugins for this configuration.]' \ - '-input=[(true) Ask for input if necessary. If false, will error if input was required.]' \ - '-lock=[(true) Lock the state file when locking is supported.]:lock:(true false)' \ - '-lock-timeout=[(0s) Duration to retry a state lock.]' \ - '-no-color[If specified, output will contain no color.]' \ - '-plugin-dir[Directory containing plugin binaries. This overrides all default search paths for plugins, and prevents the automatic installation of plugins. This flag can be used multiple times.]:plugin_dir:_files -/' \ - '-reconfigure[Reconfigure the backend, ignoring any saved configuration.]' \ - '-upgrade=[(false) If installing modules (-get) or plugins (-get-plugins), ignore previously-downloaded objects and install the latest version allowed within configured constraints.]' \ - '-verify-plugins=[(true) Verify the authenticity and integrity of automatically downloaded plugins.]' -} - -__login() { - _arguments \ - -} - -__logout() { - _arguments \ - -} - -__output() { - _arguments \ - '-state=[(path) Path to the state file to read. Defaults to "terraform.tfstate".]:statefile:_files -g "*.tfstate"' \ - '-no-color[If specified, output will contain no color.]' \ - '-json[If specified, machine readable output will be printed in JSON format]' -} - -__plan() { - _arguments \ - '-compact-warnings[If Terraform produces any warnings that are not accompanied by errors, show them in a more compact form that includes only the summary messages.]' \ - '-destroy[If set, a plan will be generated to destroy all resources managed by the given configuration and state.]' \ - '-detailed-exitcode[() Return detailed exit codes when the command exits. This will change the meaning of exit codes to: 0 - Succeeded, diff is empty (no changes); 1 - Errored, 2 - Succeeded; there is a diff]' \ - '-input=[(true) Ask for input for variables if not directly set.]' \ - '-lock=[(true) Lock the state file when locking is supported.]:lock:(true false)' \ - '-lock-timeout=[(0s) Duration to retry a state lock.]' \ - '-no-color[() If specified, output will contain no color.]' \ - '-out=[(path) Write a plan file to the given path. This can be used as input to the "apply" command.]' \ - '-parallelism=[(10) Limit the number of concurrent operations.]' \ - '-refresh=[(true) Update state prior to checking for differences.]' \ - '-state=[(statefile) Path to a Terraform state file to use to look up Terraform-managed resources. By default it will use the state "terraform.tfstate" if it exists.]:statefile:_files -g "*.tfstate"' \ - '*-target=[(resource) Resource to target. Operation will be limited to this resource and its dependencies. This flag can be used multiple times.]:target:__statelist' \ - '*-var[("foo=bar") Set a variable in the Terraform configuration. This flag can be set multiple times.]' \ - '*-var-file=[(foo) Set variables in the Terraform configuration from a file. If "terraform.tfvars" or any ".auto.tfvars" files are present, they will be automatically loaded.]:file:_files -g "*.tfvars{,.json}"' -} - -__providers() { - local -a __providers_cmds - __providers_cmds=( - 'mirror:Mirrors the provider plugins needed for the current configuration' - 'schema:Prints the schemas of the providers used in the configuration' - ) - _describe -t providers "providers commands" __providers_cmds - -} - -__providers_mirror() { - _arguments \ - '-platform=[(os_arch) Choose which target platform to build a mirror for.]' \ - "*:target_dir:_files -/" -} - -__providers_schema() { - _arguments \ - '-json[]' \ - '::' -} - -__refresh() { - _arguments \ - '-backup=[(path) Path to backup the existing state file before modifying. Defaults to the "-state-out" path with ".backup" extension. Set to "-" to disable backup.]::backupfile:_files -g "*.backup"' \ - '-compact-warnings[If Terraform produces any warnings that are not accompanied by errors, show them in a more compact form that includes only the summary messages.]' \ - '-input=[(true) Ask for input for variables if not directly set.]' \ - '-lock=[(true) Lock the state file when locking is supported.]:lock:(true false)' \ - '-lock-timeout=[(0s) Duration to retry a state lock.]' \ - '-no-color[If specified, output will not contain any color.]' \ - '-state=[(path) Path to read and save state (unless state-out is specified). Defaults to "terraform.tfstate".]:statefile:_files -g "*.tfstate"' \ - '-state-out=[(path) Path to write state to that is different than "-state". This can be used to preserve the old state.]:statefile:_files -g "*.tfstate"' \ - '*-target=[(resource) A Resource Address to target. Operation will be limited to this resource and its dependencies. This flag can be used multiple times.]:target:__statelist' \ - '*-var[("foo=bar") Set a variable in the Terraform configuration. This flag can be set multiple times.]' \ - '*-var-file=[(foo) Set variables in the Terraform configuration from a file. If "terraform.tfvars" or any ".auto.tfvars" files are present, they will be automatically loaded.]:file:_files -g "*.tfvars{,.json}"' -} - -__show() { - _arguments \ - '-json[If specified, output the Terraform plan or state in a machine-readable form.]' \ - '-no-color[If specified, output will not contain any color.]' -} - -__state() { - local -a __state_cmds - __state_cmds=( - 'list:List resources in the state' - 'mv:Move an item in the state' - 'pull:Pull current state and output to stdout' - 'push:Update remote state from a local state file' - 'replace-provider:Replace provider for resources in the Terraform state' - 'rm:Remove instances from the state' - 'show:Show a resource in the state' - ) - _describe -t state "state commands" __state_cmds -} - -__state_list() { - _arguments \ - '-state=[(statefile) Path to a Terraform state file to use to look up Terraform-managed resources. By default, Terraform will consult the state of the currently-selected workspace.]' \ - '-id=[(id) Filters the results to include only instances whose resource types have an attribute named id whose value equals the given id string.]' \ - "*:address:__statelist" -} - -__state_mv() { - _arguments \ - "-dry-run[If set, prints out what would've been moved but doesn't actually move anything.]" \ - '-backup=[(PATH) Path where Terraform should write the backup for the original state. This can"t be disabled. If not set, Terraform will write it to the same path as the statefile with a ".backup" extension.]:backupfile:_files -g "*.backup"' \ - '-backup-out=[(PATH) Path where Terraform should write the backup for the destination state. This can"t be disabled. If not set, Terraform will write it to the same path as the destination state file with a backup extension. This only needs to be specified if -state-out is set to a different path than -state.]:backupfile:_files -g "*.backup"' \ - "-lock=[(true) Lock the state files when locking is supported.]:lock:(true false)" \ - "-lock-timeout=[(0s) Duration to retry a state lock.]" \ - '-state=[(path) Path to the source state file. Defaults to the configured backend, or "terraform.tfstate"]:statefile:_files -g "*.tfstate"' \ - '-state-out=[(path) Path to the destination state file to write to. If this isn"t specified, the source state file will be used. This can be a new or existing path.]:statefile:_files -g "*.tfstate"' \ - "::" \ - ":source:__statelist" \ - ":destination: " -} - -__state_push() { - _arguments \ - "-force[Write the state even if lineages don't match or the remote serial is higher.]" \ - '-lock=[(true) Lock the state file when locking is supported.]:lock:(true false)' \ - "-lock-timeout=[(0s) Duration to retry a state lock.]" \ - "::" \ - ":destination:_files" -} - -__state_replace_provider() { - _arguments \ - '-auto-approve[Skip interactive approval.]' \ - '-backup=[(PATH) Path where Terraform should write the backup for the state file. This can"t be disabled. If not set, Terraform will write it to the same path as the state file with a ".backup" extension.]:backupfile:_files -g "*.backup"' \ - "-lock=[(true) Lock the state files when locking is supported.]:lock:(true false)" \ - "-lock-timeout=[(0s) Duration to retry a state lock.]" \ - '-state=[(PATH) Path to the source state file. Defaults to the configured backend, or "terraform.tfstate"]:statefile:_files -g "*.tfstate"' \ - ":from_provider_fqn:" \ - ":to_provider_fqn:" -} - -__state_rm() { - _arguments \ - "-dry-run[If set, prints out what would've been removed but doesn't actually remove anything.]" \ - '-backup=[(PATH) Path where Terraform should write the backup for the original state.]::backupfile:_files -g "*.backup"' \ - "-lock=[(true) Lock the state file when locking is supported.]:lock:(true false)" \ - "-lock-timeout=[(0s) Duration to retry a state lock.]" \ - '-state=[(PATH) Path to the state file to update. Defaults to the current workspace state.]:statefile:_files -g "*.tfstate"' \ - "*:address:__statelist" -} - - -__state_show() { - _arguments \ - '-state=[(statefile) Path to a Terraform state file to use to look up Terraform-managed resources. By default it will use the state "terraform.tfstate" if it exists.]:statefile:_files -g "*.tfstate"' \ - "*:address:__statelist" -} - -__statelist() { - compadd $(terraform state list $opt_args[-state]) -} - -__taint() { - _arguments \ - '-allow-missing[If specified, the command will succeed (exit code 0) even if the resource is missing.]' \ - '-backup=[(path) Path to backup the existing state file before modifying. Defaults to the "-state-out" path with ".backup" extension. Set to "-" to disable backup.]:backupfile:_files -g "*.backup"' \ - '-lock=[(true) Lock the state file when locking is supported.]:lock:(true false)' \ - '-lock-timeout=[(0s) Duration to retry a state lock.]' \ - '-module=[(path) The module path where the resource lives. By default this will be root. Child modules can be specified by names. Ex. "consul" or "consul.vpc" (nested modules).]' \ - '-state=[(path) Path to read and save state (unless state-out is specified). Defaults to "terraform.tfstate".]:statefile:_files -g "*.tfstate"' \ - '-state-out=[(path) Path to write updated state file. By default, the "-state" path will be used.]:statefile:_files -g "*.tfstate"' \ - "*:address:__statelist" -} - -__untaint() { - _arguments \ - '-allow-missing[If specified, the command will succeed (exit code 0) even if the resource is missing.]' \ - '-backup=[(path) Path to backup the existing state file before modifying. Defaults to the "-state-out" path with ".backup" extension. Set to "-" to disable backup.]:backupfile:_files -g "*.backup"' \ - '-lock=[(true) Lock the state file when locking is supported.]:lock:(true false)' \ - '-lock-timeout=[(0s) Duration to retry a state lock.]' \ - '-module=[(path) The module path where the resource lives. By default this will be root. Child modules can be specified by names. Ex. "consul" or "consul.vpc" (nested modules).]' \ - '-state=[(path) Path to read and save state (unless state-out is specified). Defaults to "terraform.tfstate".]:statefile:_files -g "*.tfstate"' \ - '-state-out=[(path) Path to write updated state file. By default, the "-state" path will be used.]:statefile:_files -g "*.tfstate"' -} - -__validate() { - _arguments \ - '-no-color[If specified, output will not contain any color.]' \ - '-json[Produce output in a machine-readable JSON format, suitable for use in text editor integrations and other automated systems.]' \ - ':dir:_files -/' -} - -__version() { - _arguments \ - '-json[Output the version information as a JSON object.]' -} - -__workspace() { - local -a __workspace_cmds - __workspace_cmds=( - 'delete:Delete a workspace' - 'list:List Workspaces' - 'new:Create a new workspace' - 'select:Select a workspace' - 'show:Show the name of the current workspace' - ) - _describe -t workspace "workspace commands" __workspace_cmds -} - -_arguments '*:: :->command' - -if (( CURRENT == 1 )); then - _describe -t commands "terraform command" _terraform_cmds - return -fi - -local -a _command_args -case "$words[1]" in - 0.12upgrade) - __012upgrade ;; - 0.13upgrade) - __013upgrade ;; - apply) - __apply ;; - console) - __console;; - destroy) - __destroy ;; - fmt) - __fmt;; - force-unlock) - __force_unlock;; - get) - __get ;; - graph) - __graph ;; - import) - __import;; - init) - __init ;; - login) - __login ;; - logout) - __logout ;; - output) - __output ;; - plan) - __plan ;; - providers) - test $CURRENT -lt 3 && __providers - [[ $words[2] = "mirror" ]] && __providers_mirror - [[ $words[2] = "schema" ]] && __providers_schema - ;; - refresh) - __refresh ;; - show) - __show ;; - state) - test $CURRENT -lt 3 && __state - [[ $words[2] = "list" ]] && __state_list - [[ $words[2] = "mv" ]] && __state_mv - [[ $words[2] = "push" ]] && __state_push - [[ $words[2] = "replace-provider" ]] && __state_replace_provider - [[ $words[2] = "rm" ]] && __state_rm - [[ $words[2] = "show" ]] && __state_show - ;; - taint) - __taint ;; - untaint) - __untaint ;; - validate) - __validate ;; - version) - __version ;; - workspace) - test $CURRENT -lt 3 && __workspace ;; -esac diff --git a/plugins/terraform/terraform.plugin.zsh b/plugins/terraform/terraform.plugin.zsh index d9e39e6ac..eaa1e2e81 100644 --- a/plugins/terraform/terraform.plugin.zsh +++ b/plugins/terraform/terraform.plugin.zsh @@ -16,3 +16,8 @@ alias tfi='terraform init' alias tfo='terraform output' alias tfp='terraform plan' alias tfv='terraform validate' + +if (( $+commands[terraform] )); then + autoload -U +X bashcompinit && bashcompinit + complete -o nospace -C terraform terraform +fi From 5bfdd0356b46dc711a8f0866eeb9b717c033d5b2 Mon Sep 17 00:00:00 2001 From: Haltarys <45515869+Haltarys@users.noreply.github.com> Date: Fri, 11 Nov 2022 09:49:41 +0100 Subject: [PATCH 074/672] fix(ubuntu)!: rename `acs` alias to `acse (#11334) BREAKING CHANGE: `acs` alias, present in both `ubuntu` and `debian` plugins conflicts with `acs` function in aliases plugin. Change it to prevent ghosting of one of them. --- plugins/debian/README.md | 2 +- plugins/debian/debian.plugin.zsh | 4 ++-- plugins/ubuntu/README.md | 2 +- plugins/ubuntu/ubuntu.plugin.zsh | 2 +- 4 files changed, 5 insertions(+), 5 deletions(-) diff --git a/plugins/debian/README.md b/plugins/debian/README.md index 1db534f13..c1ebe1c50 100644 --- a/plugins/debian/README.md +++ b/plugins/debian/README.md @@ -21,7 +21,7 @@ Set `$apt_pref` and `$apt_upgr` to whatever command you want (before sourcing Oh | ------ | ---------------------------------------------------------------------- | ---------------------------------------------------------- | | `age` | `apt-get` | Command line tool for handling packages | | `api` | `aptitude` | Same functionality as `apt-get`, provides extra options | -| `acs` | `apt-cache search` | Command line tool for searching apt software package cache | +| `acse` | `apt-cache search` | Command line tool for searching apt software package cache | | `aps` | `aptitude search` | Searches installed packages using aptitude | | `as` | `aptitude -F '* %p -> %d \n(%v/%V)' --no-gui --disable-columns search` | Print searched packages using a custom format | | `afs` | `apt-file search --regexp` | Search file in packages | diff --git a/plugins/debian/debian.plugin.zsh b/plugins/debian/debian.plugin.zsh index 2d8c4666e..bab1ae1c6 100644 --- a/plugins/debian/debian.plugin.zsh +++ b/plugins/debian/debian.plugin.zsh @@ -26,7 +26,7 @@ alias age='apt-get' alias api='aptitude' # Some self-explanatory aliases -alias acs="apt-cache search" +alias acse="apt-cache search" alias aps='aptitude search' alias as="aptitude -F '* %p -> %d \n(%v/%V)' --no-gui --disable-columns search" @@ -51,7 +51,7 @@ if [[ $use_sudo -eq 1 ]]; then alias au="sudo $apt_pref $apt_upgr" alias ai="sudo $apt_pref install" # Install all packages given on the command line while using only the first word of each line: - # acs ... | ail + # acse ... | ail alias ail="sed -e 's/ */ /g' -e 's/ *//' | cut -s -d ' ' -f 1 | xargs sudo $apt_pref install" alias ap="sudo $apt_pref purge" diff --git a/plugins/ubuntu/README.md b/plugins/ubuntu/README.md index 20f5c65ee..2401c102b 100644 --- a/plugins/ubuntu/README.md +++ b/plugins/ubuntu/README.md @@ -15,7 +15,7 @@ Commands that use `$APT` will use `apt` if installed or defer to `apt-get` other | Alias | Command | Description | |---------|--------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------| | age | `sudo $APT` | Run apt-get with sudo | -| acs | `apt-cache search` | Search the apt-cache with the specified criteria | +| acse | `apt-cache search` | Search the apt-cache with the specified criteria | | acsp | `apt-cache showpkg` | Shows information about the listed packages | | acp | `apt-cache policy` | Display the package source priorities | | afs | `apt-file search --regexp` | Perform a regular expression apt-file search | diff --git a/plugins/ubuntu/ubuntu.plugin.zsh b/plugins/ubuntu/ubuntu.plugin.zsh index 7b765a406..4d35da2ac 100644 --- a/plugins/ubuntu/ubuntu.plugin.zsh +++ b/plugins/ubuntu/ubuntu.plugin.zsh @@ -1,6 +1,6 @@ (( $+commands[apt] )) && APT=apt || APT=apt-get -alias acs='apt-cache search' +alias acse='apt-cache search' alias afs='apt-file search --regexp' From 5b2d0a3f06a743cf9d33783276f29ea683db81c3 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Fri, 14 Oct 2022 18:07:18 +0200 Subject: [PATCH 075/672] perf(bgnotify): cache terminal app ID computation Fixes #10971 --- plugins/bgnotify/bgnotify.plugin.zsh | 30 +++++++++++++--------------- 1 file changed, 14 insertions(+), 16 deletions(-) diff --git a/plugins/bgnotify/bgnotify.plugin.zsh b/plugins/bgnotify/bgnotify.plugin.zsh index 479796dbe..9c4a62cd7 100644 --- a/plugins/bgnotify/bgnotify.plugin.zsh +++ b/plugins/bgnotify/bgnotify.plugin.zsh @@ -20,25 +20,25 @@ if ! (type bgnotify_formatted | grep -q 'function'); then ## allow custom functi } fi -currentAppId () { - if (( $+commands[osascript] )); then - osascript -e 'tell application (path to frontmost application as text) to id' 2>/dev/null +} + +function currentAppId { + if (( ${+commands[osascript]} )); then + # output: com.googlecode.iterm2, 116 + osascript -e 'tell application (path to frontmost application as text) to get the {id, id of front window}' 2>/dev/null + elif (( ${+commands[notify-send]} || ${+commands[kdialog]} )); then + xprop -root 2> /dev/null | awk '/NET_ACTIVE_WINDOW/{print $5;exit} END{exit !$5}' || echo "0" + else + echo $EPOCHSECONDS fi } -currentWindowId () { - if hash osascript 2>/dev/null; then #osx - osascript -e 'tell application (path to frontmost application as text) to id of front window' 2&> /dev/null || echo "0" - elif (hash notify-send 2>/dev/null || hash kdialog 2>/dev/null); then #ubuntu! - xprop -root 2> /dev/null | awk '/NET_ACTIVE_WINDOW/{print $5;exit} END{exit !$5}' || echo "0" - else - echo $EPOCHSECONDS #fallback for windows - fi -} +# currentAppId is expensive (more on macOS!) and it will remain the same until the shell is close +bgnotify_termid=$(currentAppId) bgnotify () { ## args: (title, subtitle) if hash terminal-notifier 2>/dev/null; then #osx - local term_id="$bgnotify_appid" + local term_id="${bgnotify_termid%%,*}" # remove window id if [[ -z "$term_id" ]]; then case "$TERM_PROGRAM" in iTerm.app) term_id='com.googlecode.iterm2' ;; @@ -69,8 +69,6 @@ bgnotify () { ## args: (title, subtitle) bgnotify_begin() { bgnotify_timestamp=$EPOCHSECONDS bgnotify_lastcmd="${1:-$2}" - bgnotify_appid="$(currentAppId)" - bgnotify_windowid=$(currentWindowId) } bgnotify_end() { @@ -78,7 +76,7 @@ bgnotify_end() { elapsed=$(( EPOCHSECONDS - bgnotify_timestamp )) past_threshold=$(( elapsed >= bgnotify_threshold )) if (( bgnotify_timestamp > 0 )) && (( past_threshold )); then - if [[ $(currentAppId) != "$bgnotify_appid" || $(currentWindowId) != "$bgnotify_windowid" ]]; then + if [[ $(currentAppId) != "$bgnotify_termid" ]]; then print -n "\a" bgnotify_formatted "$didexit" "$bgnotify_lastcmd" "$elapsed" fi From a04cf078801db637c2ecdcc95c491fa9fb217ceb Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Fri, 14 Oct 2022 18:36:48 +0200 Subject: [PATCH 076/672] refactor(bgnotify): clean up and reorganize code MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit 🗸 Standardize code style 🗸 Organize code sections 🗸 Optimize calls for window ID --- plugins/bgnotify/bgnotify.plugin.zsh | 125 +++++++++++++++------------ 1 file changed, 70 insertions(+), 55 deletions(-) diff --git a/plugins/bgnotify/bgnotify.plugin.zsh b/plugins/bgnotify/bgnotify.plugin.zsh index 9c4a62cd7..ed2653aa8 100644 --- a/plugins/bgnotify/bgnotify.plugin.zsh +++ b/plugins/bgnotify/bgnotify.plugin.zsh @@ -1,43 +1,78 @@ #!/usr/bin/env zsh -## setup ## +## Setup -[[ -o interactive ]] || return #interactive only! -zmodload zsh/datetime || { print "can't load zsh/datetime"; return } # faster than date() -autoload -Uz add-zsh-hook || { print "can't add zsh hook!"; return } +[[ -o interactive ]] || return # don't load on non-interactive shells +[[ -z "$SSH_CLIENT" && -z "$SSH_TTY" ]] || return # don't load on a SSH connection -(( ${+bgnotify_threshold} )) || bgnotify_threshold=5 #default 10 seconds +zmodload zsh/datetime # faster than `date` -## definitions ## - -if ! (type bgnotify_formatted | grep -q 'function'); then ## allow custom function override - function bgnotify_formatted { ## args: (exit_status, command, elapsed_seconds) - elapsed="$(( $3 % 60 ))s" - (( $3 >= 60 )) && elapsed="$((( $3 % 3600) / 60 ))m $elapsed" - (( $3 >= 3600 )) && elapsed="$(( $3 / 3600 ))h $elapsed" - [ $1 -eq 0 ] && bgnotify "#win (took $elapsed)" "$2" || bgnotify "#fail (took $elapsed)" "$2" - } -fi +## Zsh Hooks +function bgnotify_begin { + bgnotify_timestamp=$EPOCHSECONDS + bgnotify_lastcmd="${1:-$2}" } -function currentAppId { +function bgnotify_end { + { + local exit_status=$? + local elapsed=$(( EPOCHSECONDS - bgnotify_timestamp )) + + # check time elapsed + [[ $bgnotify_timestamp -gt 0 ]] || return + [[ $elapsed -ge $bgnotify_threshold ]] || return + + # check if Terminal app is not active + [[ $(bgnotify_appid) != "$bgnotify_termid" ]] || return + + printf '\a' # beep sound + bgnotify_formatted "$exit_status" "$bgnotify_lastcmd" "$elapsed" + } always { + bgnotify_timestamp=0 + } +} + +autoload -Uz add-zsh-hook +add-zsh-hook preexec bgnotify_begin +add-zsh-hook precmd bgnotify_end + + +## Functions + +# allow custom function override +(( ${+functions[bgnotify_formatted]} )) || \ +function bgnotify_formatted { + local exit_status=$1 + local cmd="$2" + + # humanly readable elapsed time + local elapsed="$(( $3 % 60 ))s" + (( $3 < 60 )) || elapsed="$((( $3 % 3600) / 60 ))m $elapsed" + (( $3 < 3600 )) || elapsed="$(( $3 / 3600 ))h $elapsed" + + if [[ $1 -eq 0 ]]; then + bgnotify "#win (took $elapsed)" "$2" + else + bgnotify "#fail (took $elapsed)" "$2" + fi +} + +# for macOS, output is "app ID, window ID" (com.googlecode.iterm2, 116) +function bgnotify_appid { if (( ${+commands[osascript]} )); then - # output: com.googlecode.iterm2, 116 osascript -e 'tell application (path to frontmost application as text) to get the {id, id of front window}' 2>/dev/null - elif (( ${+commands[notify-send]} || ${+commands[kdialog]} )); then - xprop -root 2> /dev/null | awk '/NET_ACTIVE_WINDOW/{print $5;exit} END{exit !$5}' || echo "0" + elif (( ${+commands[xprop]} )); then + xprop -root _NET_ACTIVE_WINDOW 2>/dev/null | cut -d' ' -f5 else echo $EPOCHSECONDS fi } -# currentAppId is expensive (more on macOS!) and it will remain the same until the shell is close -bgnotify_termid=$(currentAppId) - -bgnotify () { ## args: (title, subtitle) - if hash terminal-notifier 2>/dev/null; then #osx +function bgnotify { + # $1: title, $2: message + if (( ${+commands[terminal-notifier]} )); then # macOS local term_id="${bgnotify_termid%%,*}" # remove window id if [[ -z "$term_id" ]]; then case "$TERM_PROGRAM" in @@ -46,46 +81,26 @@ bgnotify () { ## args: (title, subtitle) esac fi - ## now call terminal-notifier, (hopefully with $term_id!) if [[ -z "$term_id" ]]; then - terminal-notifier -message "$2" -title "$1" >/dev/null + terminal-notifier -message "$2" -title "$1" &>/dev/null else - terminal-notifier -message "$2" -title "$1" -activate "$term_id" -sender "$term_id" >/dev/null + terminal-notifier -message "$2" -title "$1" -activate "$term_id" -sender "$term_id" &>/dev/null fi - elif hash growlnotify 2>/dev/null; then #osx growl + elif (( ${+commands[growlnotify]} )); then # macOS growl growlnotify -m "$1" "$2" - elif hash notify-send 2>/dev/null; then #ubuntu gnome! + elif (( ${+commands[notify-send]} )); then # GNOME notify-send "$1" "$2" - elif hash kdialog 2>/dev/null; then #ubuntu kde! + elif (( ${+commands[kdialog]} )); then # KDE kdialog --title "$1" --passivepopup "$2" 5 - elif hash notifu 2>/dev/null; then #cygwyn support! + elif (( ${+commands[notifu]} )); then # cygwin notifu /m "$2" /p "$1" fi } +## Defaults -## Zsh hooks ## +# notify if command took longer than 5s by default +bgnotify_threshold=${bgnotify_threshold:-5} -bgnotify_begin() { - bgnotify_timestamp=$EPOCHSECONDS - bgnotify_lastcmd="${1:-$2}" -} - -bgnotify_end() { - didexit=$? - elapsed=$(( EPOCHSECONDS - bgnotify_timestamp )) - past_threshold=$(( elapsed >= bgnotify_threshold )) - if (( bgnotify_timestamp > 0 )) && (( past_threshold )); then - if [[ $(currentAppId) != "$bgnotify_termid" ]]; then - print -n "\a" - bgnotify_formatted "$didexit" "$bgnotify_lastcmd" "$elapsed" - fi - fi - bgnotify_timestamp=0 #reset it to 0! -} - -## only enable if a local (non-ssh) connection -if [ -z "$SSH_CLIENT" ] && [ -z "$SSH_TTY" ]; then - add-zsh-hook preexec bgnotify_begin - add-zsh-hook precmd bgnotify_end -fi +# bgnotify_appid is slow in macOS and the terminal ID won't change, so cache it at startup +bgnotify_termid="$(bgnotify_appid)" From 62929263fafd9e3c1da043bc9b40fa97fccfa7a1 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Fri, 11 Feb 2022 15:20:03 +0100 Subject: [PATCH 077/672] fix(perms)!: change function name from `fixperms` to `resetperms` and document caution (#10686) BREAKING CHANGE: function `fixperms` has been renamed to the more accurate `resetperms`. Please read the README carefully before using it as it may badly reset the permissions. Fixes #10648 Closes #10686 --- plugins/perms/README.md | 16 +++++++++++++--- plugins/perms/perms.plugin.zsh | 27 ++++++++++++++++----------- 2 files changed, 29 insertions(+), 14 deletions(-) diff --git a/plugins/perms/README.md b/plugins/perms/README.md index ae7a36b9d..ae10fa659 100644 --- a/plugins/perms/README.md +++ b/plugins/perms/README.md @@ -10,6 +10,16 @@ plugins=(... perms) ## Usage -* `set755` recursively sets all given directories (default to .) to octal 755. -* `set644` recursively sets all given files (default to .) to octal 644. -* `fixperms` is a wrapper around `set755` and `set644` applied to a specified directory or the current directory otherwise. It also prompts prior to execution unlike the other two aliases. +> **CAUTION:** these functions are harmful if you don't know what they do. + +- `set755`: sets the permission to octal 755 for all given directories and their child directories (by default, starting from the current directory). + +- `set644`: sets the permission to octal 644 for all files of the given directory (by default, the current directory), recursively. It will only affect regular files (no symlinks). + +- `resetperms` is a wrapper around `set755` and `set644` applied to a specified directory or the current directory otherwise. + It will set the permissions to 755 for directories, and 644 for files. + +## Reference + +- octal 644: _read and write_ for the owner, _read_ for the group and others users. +- octal 755: _read, write and execute_ permissions for the owner, and _read and execute_ for the group and others users. diff --git a/plugins/perms/perms.plugin.zsh b/plugins/perms/perms.plugin.zsh index 1a7472c1c..353b58411 100644 --- a/plugins/perms/perms.plugin.zsh +++ b/plugins/perms/perms.plugin.zsh @@ -6,25 +6,25 @@ ### Aliases # Set all files' permissions to 644 recursively in a directory -set644() { +function set644 { find "${@:-.}" -type f ! -perm 644 -print0 | xargs -0 chmod 644 } # Set all directories' permissions to 755 recursively in a directory -set755() { +function set755 { find "${@:-.}" -type d ! -perm 755 -print0 | xargs -0 chmod 755 } ### Functions -# fixperms - fix permissions on files and directories, with confirmation +# resetperms - fix permissions on files and directories, with confirmation # Returns 0 on success, nonzero if any errors occurred -fixperms () { +function resetperms { local opts confirm target exit_status chmod_opts use_slow_mode zparseopts -E -D -a opts -help -slow v+=chmod_opts if [[ $# > 1 || -n "${opts[(r)--help]}" ]]; then cat < Date: Sat, 12 Nov 2022 11:46:06 +0100 Subject: [PATCH 078/672] feat(git-prompt): show deleted files (#11245) --- plugins/git-prompt/git-prompt.plugin.zsh | 5 +++++ plugins/git-prompt/gitstatus.py | 9 ++++++--- 2 files changed, 11 insertions(+), 3 deletions(-) diff --git a/plugins/git-prompt/git-prompt.plugin.zsh b/plugins/git-prompt/git-prompt.plugin.zsh index 0485e317c..dcda418cf 100644 --- a/plugins/git-prompt/git-prompt.plugin.zsh +++ b/plugins/git-prompt/git-prompt.plugin.zsh @@ -47,6 +47,7 @@ function update_current_git_vars() { GIT_UNTRACKED=$__CURRENT_GIT_STATUS[7] GIT_STASHED=$__CURRENT_GIT_STATUS[8] GIT_CLEAN=$__CURRENT_GIT_STATUS[9] + GIT_DELETED=$__CURRENT_GIT_STATUS[10] } git_super_status() { @@ -69,6 +70,9 @@ git_super_status() { if [ "$GIT_CHANGED" -ne "0" ]; then STATUS="$STATUS$ZSH_THEME_GIT_PROMPT_CHANGED$GIT_CHANGED%{${reset_color}%}" fi + if [ "$GIT_DELETED" -ne "0" ]; then + STATUS="$STATUS$ZSH_THEME_GIT_PROMPT_DELETED$GIT_DELETED%{${reset_color}%}" + fi if [ "$GIT_UNTRACKED" -ne "0" ]; then STATUS="$STATUS$ZSH_THEME_GIT_PROMPT_UNTRACKED$GIT_UNTRACKED%{${reset_color}%}" fi @@ -91,6 +95,7 @@ ZSH_THEME_GIT_PROMPT_BRANCH="%{$fg_bold[magenta]%}" ZSH_THEME_GIT_PROMPT_STAGED="%{$fg[red]%}%{●%G%}" ZSH_THEME_GIT_PROMPT_CONFLICTS="%{$fg[red]%}%{✖%G%}" ZSH_THEME_GIT_PROMPT_CHANGED="%{$fg[blue]%}%{✚%G%}" +ZSH_THEME_GIT_PROMPT_DELETED="%{$fg[blue]%}%{-%G%}" ZSH_THEME_GIT_PROMPT_BEHIND="%{↓%G%}" ZSH_THEME_GIT_PROMPT_AHEAD="%{↑%G%}" ZSH_THEME_GIT_PROMPT_UNTRACKED="%{$fg[cyan]%}%{…%G%}" diff --git a/plugins/git-prompt/gitstatus.py b/plugins/git-prompt/gitstatus.py index b5c3c9a0c..94774d828 100644 --- a/plugins/git-prompt/gitstatus.py +++ b/plugins/git-prompt/gitstatus.py @@ -44,7 +44,7 @@ if po.returncode != 0: sys.exit(0) # Not a git repository # collect git status information -untracked, staged, changed, conflicts = [], [], [], [] +untracked, staged, changed, deleted, conflicts = [], [], [], [], [] ahead, behind = 0, 0 status = [(line[0], line[1], line[2:]) for line in stdout.decode('utf-8').splitlines()] for st in status: @@ -75,13 +75,15 @@ for st in status: else: if st[1] == 'M': changed.append(st) + if st[1] == 'D': + deleted.append(st) if st[0] == 'U': conflicts.append(st) elif st[0] != ' ': staged.append(st) stashed = get_stash() -if not changed and not staged and not conflicts and not untracked: +if not changed and not deleted and not staged and not conflicts and not untracked: clean = 1 else: clean = 0 @@ -95,6 +97,7 @@ out = ' '.join([ str(len(changed)), str(len(untracked)), str(stashed), - str(clean) + str(clean), + str(len(deleted)) ]) print(out, end='') From b70977b25657c193a3a6c0445b63325a420da646 Mon Sep 17 00:00:00 2001 From: Isaac Levy Date: Mon, 14 Nov 2022 11:36:19 -0500 Subject: [PATCH 079/672] perf(pyenv): do not check if it's disabled (#11338) --- plugins/pyenv/pyenv.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/pyenv/pyenv.plugin.zsh b/plugins/pyenv/pyenv.plugin.zsh index 7fbd1589e..48c8ffaf5 100644 --- a/plugins/pyenv/pyenv.plugin.zsh +++ b/plugins/pyenv/pyenv.plugin.zsh @@ -78,7 +78,7 @@ if [[ $FOUND_PYENV -eq 1 ]]; then eval "$(pyenv init - --no-rehash zsh)" # If pyenv-virtualenv exists, load it - if [[ "$(pyenv commands)" =~ "virtualenv-init" && "$ZSH_PYENV_VIRTUALENV" != false ]]; then + if [[ "$ZSH_PYENV_VIRTUALENV" != false && "$(pyenv commands)" =~ "virtualenv-init" ]]; then eval "$(pyenv virtualenv-init - zsh)" fi From a482a02915f361e56669ee9884ebee0eb6f2d8d5 Mon Sep 17 00:00:00 2001 From: Lennart Ochel Date: Mon, 14 Nov 2022 17:38:44 +0100 Subject: [PATCH 080/672] feat(git-prompt): add option to show upstream branch (#11336) --- plugins/git-prompt/README.md | 2 ++ plugins/git-prompt/git-prompt.plugin.zsh | 9 ++++++++- 2 files changed, 10 insertions(+), 1 deletion(-) diff --git a/plugins/git-prompt/README.md b/plugins/git-prompt/README.md index 8775af893..05208d72f 100644 --- a/plugins/git-prompt/README.md +++ b/plugins/git-prompt/README.md @@ -45,6 +45,7 @@ The symbols are as follows: | ●n | there are `n` staged files | | ✖n | there are `n` unmerged files | | ✚n | there are `n` unstaged files | +| -n | there are `n` deleted files | | ⚑n | there are `n` stashed changes | | … | there are some untracked files | @@ -59,6 +60,7 @@ The symbols are as follows: ## Customisation - Set the variable `ZSH_THEME_GIT_PROMPT_CACHE` to any value in order to enable caching. +- Set the variable `ZSH_THEME_GIT_SHOW_UPSTREAM` to any value to display the upstream branch. - You may also change a number of variables (whose name start with `ZSH_THEME_GIT_PROMPT_`) to change the appearance of the prompt. Take a look at the bottom of the [plugin file](git-prompt.plugin.zsh)` to see what variables are available. diff --git a/plugins/git-prompt/git-prompt.plugin.zsh b/plugins/git-prompt/git-prompt.plugin.zsh index dcda418cf..487332028 100644 --- a/plugins/git-prompt/git-prompt.plugin.zsh +++ b/plugins/git-prompt/git-prompt.plugin.zsh @@ -48,12 +48,18 @@ function update_current_git_vars() { GIT_STASHED=$__CURRENT_GIT_STATUS[8] GIT_CLEAN=$__CURRENT_GIT_STATUS[9] GIT_DELETED=$__CURRENT_GIT_STATUS[10] + + if [ -z ${ZSH_THEME_GIT_SHOW_UPSTREAM+x} ]; then + GIT_UPSTREAM= + else + GIT_UPSTREAM=$(git rev-parse --abbrev-ref --symbolic-full-name "@{upstream}" 2>/dev/null) && GIT_UPSTREAM="${ZSH_THEME_GIT_PROMPT_UPSTREAM_SEPARATOR}${GIT_UPSTREAM}" + fi } git_super_status() { precmd_update_git_vars if [ -n "$__CURRENT_GIT_STATUS" ]; then - STATUS="$ZSH_THEME_GIT_PROMPT_PREFIX$ZSH_THEME_GIT_PROMPT_BRANCH$GIT_BRANCH%{${reset_color}%}" + STATUS="$ZSH_THEME_GIT_PROMPT_PREFIX$ZSH_THEME_GIT_PROMPT_BRANCH$GIT_BRANCH$GIT_UPSTREAM%{${reset_color}%}" if [ "$GIT_BEHIND" -ne "0" ]; then STATUS="$STATUS$ZSH_THEME_GIT_PROMPT_BEHIND$GIT_BEHIND%{${reset_color}%}" fi @@ -101,6 +107,7 @@ ZSH_THEME_GIT_PROMPT_AHEAD="%{↑%G%}" ZSH_THEME_GIT_PROMPT_UNTRACKED="%{$fg[cyan]%}%{…%G%}" ZSH_THEME_GIT_PROMPT_STASHED="%{$fg_bold[blue]%}%{⚑%G%}" ZSH_THEME_GIT_PROMPT_CLEAN="%{$fg_bold[green]%}%{✔%G%}" +ZSH_THEME_GIT_PROMPT_UPSTREAM_SEPARATOR="->" # Set the prompt. RPROMPT='$(git_super_status)' From 37d9e1aee9289025373d3f840ead74897206d73f Mon Sep 17 00:00:00 2001 From: milinches Date: Sat, 7 May 2022 06:12:22 +0100 Subject: [PATCH 081/672] feat(golang): add `goe`, `gove` aliases Closes #10914 --- plugins/golang/README.md | 4 +++- plugins/golang/golang.plugin.zsh | 2 ++ 2 files changed, 5 insertions(+), 1 deletion(-) diff --git a/plugins/golang/README.md b/plugins/golang/README.md index 3b7d1e19f..128cc7fbb 100644 --- a/plugins/golang/README.md +++ b/plugins/golang/README.md @@ -16,11 +16,12 @@ plugins=(... golang) | gob | `go build` | Build your code | | goc | `go clean` | Removes object files from package source directories | | god | `go doc` | Prints documentation comments | +| goe | `go env` | Prints Go environment information | | gof | `go fmt` | Gofmt formats (aligns and indents) Go programs. | | gofa | `go fmt ./...` | Run go fmt for all packages in current directory, recursively | | gofx | `go fix` | Update packages to use a new API | | gog | `go get` | Downloads packages and then installs them to $GOPATH | -| gog | `go get ./...` | Installs all dependencies in current directory, recursively | +| goga | `go get ./...` | Installs all dependencies in current directory, recursively | | goi | `go install` | Compiles and installs packages to $GOPATH | | gol | `go list` | Lists Go packages | | gom | `go mod` | Access to operations on modules | @@ -35,4 +36,5 @@ plugins=(... golang) | gotod | `go tool dist` | Utility to bootstrap, build and test go runtime | | gotofx | `go tool fix` | Fixes an application to use newer features | | gov | `go vet` | Vet examines Go source code and reports suspicious constructs | +| gove | `go version` | Prints Go version | | gow | `go work` | Work provides access to operations on workspaces | diff --git a/plugins/golang/golang.plugin.zsh b/plugins/golang/golang.plugin.zsh index 0dbaab069..45ccd3a1c 100644 --- a/plugins/golang/golang.plugin.zsh +++ b/plugins/golang/golang.plugin.zsh @@ -13,6 +13,7 @@ unset p alias gob='go build' alias goc='go clean' alias god='go doc' +alias goe='go env' alias gof='go fmt' alias gofa='go fmt ./...' alias gofx='go fix' @@ -32,4 +33,5 @@ alias gotoc='go tool compile' alias gotod='go tool dist' alias gotofx='go tool fix' alias gov='go vet' +alias gove='go version' alias gow='go work' From aafc7443f07b841b4c008951087bfad282f3341f Mon Sep 17 00:00:00 2001 From: Steven Conaway Date: Tue, 15 Nov 2022 10:19:37 -0800 Subject: [PATCH 082/672] feat(fzf): support macOS ARM brew install dir (#10944) --- plugins/fzf/fzf.plugin.zsh | 1 + 1 file changed, 1 insertion(+) diff --git a/plugins/fzf/fzf.plugin.zsh b/plugins/fzf/fzf.plugin.zsh index 60ae0c765..9c8dd8648 100644 --- a/plugins/fzf/fzf.plugin.zsh +++ b/plugins/fzf/fzf.plugin.zsh @@ -9,6 +9,7 @@ function fzf_setup_using_base_dir() { "${HOME}/.nix-profile/share/fzf" "${XDG_DATA_HOME:-$HOME/.local/share}/fzf" "/usr/local/opt/fzf" + "/opt/homebrew/bin/fzf" "/usr/share/fzf" "/usr/local/share/examples/fzf" ) From 94584e2a7337e0a7f5af45e2c97ca6d0770e67a1 Mon Sep 17 00:00:00 2001 From: Bill Haofei Gong Date: Wed, 16 Nov 2022 05:25:22 +1100 Subject: [PATCH 083/672] feat(cakephp3): add compatibility with CakePHP 3.7+ (#11080) --- plugins/cakephp3/cakephp3.plugin.zsh | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/plugins/cakephp3/cakephp3.plugin.zsh b/plugins/cakephp3/cakephp3.plugin.zsh index dbfbeba3b..a1a289fd0 100644 --- a/plugins/cakephp3/cakephp3.plugin.zsh +++ b/plugins/cakephp3/cakephp3.plugin.zsh @@ -1,10 +1,10 @@ # CakePHP 3 basic command completion _cakephp3_get_command_list () { - bin/cake Completion commands + bin/cake completion commands } _cakephp3_get_sub_command_list () { - bin/cake Completion subcommands ${words[2]} + bin/cake completion subcommands ${words[2]} } _cakephp3_get_3rd_argument () { @@ -34,5 +34,5 @@ compdef _cakephp3 cake #Alias alias c3='bin/cake' -alias c3cache='bin/cake orm_cache clear' +alias c3cache='bin/cake schema_cache clear' alias c3migrate='bin/cake migrations migrate' From 4392d3a923eddd4e9d0f9b17a1e995cc9aa5cc96 Mon Sep 17 00:00:00 2001 From: Ben Iofel Date: Tue, 15 Nov 2022 18:29:48 +0000 Subject: [PATCH 084/672] feat(systemadmin): color `ip` if shell is interactive (#11107) --- plugins/systemadmin/systemadmin.plugin.zsh | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/plugins/systemadmin/systemadmin.plugin.zsh b/plugins/systemadmin/systemadmin.plugin.zsh index 8e5e0af71..9b5159ff1 100644 --- a/plugins/systemadmin/systemadmin.plugin.zsh +++ b/plugins/systemadmin/systemadmin.plugin.zsh @@ -33,6 +33,14 @@ alias pscpu10='ps -e -o pcpu,cpu,nice,state,cputime,args|sort -k1,1n -nr | head # top10 of the history alias hist10='print -l ${(o)history%% *} | uniq -c | sort -nr | head -n 10' +function ip() { + if [ -t 1 ]; then + command ip -color "$@" + else + command ip "$@" + fi +} + # directory LS function dls() { print -l *(/) From 6d5ba2d6c489d56fb34788ec128f98609e60b7be Mon Sep 17 00:00:00 2001 From: Carlo Date: Tue, 15 Nov 2022 20:23:09 +0100 Subject: [PATCH 085/672] feat(nvm)!: settings now are zstyle-based (#11335) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Co-authored-by: Marc Cornellà --- plugins/nvm/README.md | 40 +++++++++++++++++++++++--------- plugins/nvm/nvm.plugin.zsh | 47 ++++++++++++++++++++++++++++++-------- 2 files changed, 66 insertions(+), 21 deletions(-) diff --git a/plugins/nvm/README.md b/plugins/nvm/README.md index 1acf12050..4c6312e6e 100644 --- a/plugins/nvm/README.md +++ b/plugins/nvm/README.md @@ -1,7 +1,7 @@ # nvm plugin -This plugin adds autocompletions for [nvm](https://github.com/nvm-sh/nvm) — a Node.js version manager. -It also automatically sources nvm, so you don't need to do it manually in your `.zshrc`. +This plugin adds autocompletions for [nvm](https://github.com/nvm-sh/nvm) — a Node.js version manager. It also +automatically sources nvm, so you don't need to do it manually in your `.zshrc`. To use it, add `nvm` to the plugins array of your zshrc file: @@ -21,14 +21,32 @@ These settings should go in your zshrc file, before Oh My Zsh is sourced: [Homebrew is installed in `/opt/homebrew`](https://docs.brew.sh/Installation). To get the directory where nvm has been installed, regardless of chip architecture, use `NVM_HOMEBREW=$(brew --prefix nvm)`. -- **`NVM_LAZY`**: if you want the plugin to defer the load of nvm to speed-up the start of your zsh session, - set `NVM_LAZY` to `1`. This will source nvm script only when using it, and will create a function for `node`, - `npm`, `pnpm`, `yarn`, and the command(s) specified by `NVM_LAZY_CMD`, so when you call either of them, - nvm will be loaded and run with default version. +## Customization -- **`NVM_LAZY_CMD`**: if you want additional command(s) to trigger lazy loading of nvm, set `NVM_LAZY_CMD` to - the command or an array of the commands. +#### Lazy startup -- **`NVM_AUTOLOAD`**: if `NVM_AUTOLOAD` is set to `1`, the plugin will automatically load a node version when - if finds a [`.nvmrc` file](https://github.com/nvm-sh/nvm#nvmrc) in the current working directory indicating - which node version to load. +This option will help you to defer nvm's load until you use it to speed-up your zsh startup. This will source +nvm script only when using it, and will create a function for `node`, `npm`, `pnpm`, `yarn`, and the +command(s) specified by `lazy-cmd` option, so when you call either of them, nvm will be loaded and run with +default version. To enable it, you can add this snippet to your zshrc, before Oh My Zsh is sourced: + +```zsh +zstyle ':omz:plugins:nvm' lazy yes +``` + +Then, to define extra commands that will also trigger nvm load, you can use a similar syntax, adding as many +as you want: + +```zsh +zstyle ':omz:plugins:nvm' lazy-cmd eslint prettier typescript ... +``` + +#### `.nvmrc` autoload + +If set, the plugin will automatically load a node version when if finds a +[`.nvmrc` file](https://github.com/nvm-sh/nvm#nvmrc) in the current working directory indicating which node +version to load. This can be done, similar as previous options, adding: + +```zsh +zstyle ':omz:plugins:nvm' autoload true +``` diff --git a/plugins/nvm/nvm.plugin.zsh b/plugins/nvm/nvm.plugin.zsh index 1fb4d238b..ec583cc2d 100644 --- a/plugins/nvm/nvm.plugin.zsh +++ b/plugins/nvm/nvm.plugin.zsh @@ -16,14 +16,41 @@ fi # Note: nvm is a function so we need to use `which` which nvm &>/dev/null && return -if (( $+NVM_LAZY )); then - # Call nvm when first using nvm, node, npm, pnpm, yarn or $NVM_LAZY_CMD - function nvm node npm pnpm yarn $NVM_LAZY_CMD { - unfunction nvm node npm pnpm yarn $NVM_LAZY_CMD - # Load nvm if it exists in $NVM_DIR - [[ -f "$NVM_DIR/nvm.sh" ]] && source "$NVM_DIR/nvm.sh" - "$0" "$@" - } +# TODO: 2022-11-11: Remove soft-deprecate options +if (( ${+NVM_LAZY} + ${+NVM_LAZY_CMD} + ${+NVM_AUTOLOAD} )); then + # Get list of NVM_* variable settings defined + local -a used_vars + used_vars=(${(o)parameters[(I)NVM_(AUTOLOAD|LAZY|LAZY_CMD)]}) + # Nicely print the list in the style `var1, var2 and var3` + echo "${fg[yellow]}[nvm plugin] Variable-style settings are deprecated. Instead of ${(j:, :)used_vars[1,-2]}${used_vars[-2]+ and }${used_vars[-1]}, use:\n" + if (( $+NVM_AUTOLOAD )); then + echo " zstyle ':omz:plugins:nvm' autoload true" + zstyle ':omz:plugins:nvm' autoload yes + fi + if (( $+NVM_LAZY )); then + echo " zstyle ':omz:plugins:nvm' lazy true" + zstyle ':omz:plugins:nvm' lazy yes + fi + if (( $+NVM_LAZY_CMD )); then + echo " zstyle ':omz:plugins:nvm' lazy-cmd $NVM_LAZY_CMD" + zstyle ':omz:plugins:nvm' lazy-cmd $NVM_LAZY_CMD + fi + echo "$reset_color" + unset used_vars NVM_AUTOLOAD NVM_LAZY NVM_LAZY_CMD +fi + +if zstyle -t ':omz:plugins:nvm' lazy; then + # Call nvm when first using nvm, node, npm, pnpm, yarn or other commands in lazy-cmd + zstyle -a ':omz:plugins:nvm' lazy-cmd nvm_lazy_cmd + eval " + function nvm node npm pnpm yarn $nvm_lazy_cmd { + unfunction nvm node npm pnpm yarn $nvm_lazy_cmd + # Load nvm if it exists in \$NVM_DIR + [[ -f \"\$NVM_DIR/nvm.sh\" ]] && source \"\$NVM_DIR/nvm.sh\" + \"\$0\" \"\$@\" + } + " + unset nvm_lazy_cmd elif [[ -f "$NVM_DIR/nvm.sh" ]]; then # Load nvm if it exists in $NVM_DIR source "$NVM_DIR/nvm.sh" @@ -33,7 +60,7 @@ fi # Autoload nvm when finding a .nvmrc file in the current directory # Adapted from: https://github.com/nvm-sh/nvm#zsh -if (( $+NVM_AUTOLOAD )); then +if zstyle -t ':omz:plugins:nvm' autoload; then load-nvmrc() { local node_version="$(nvm version)" local nvmrc_path="$(nvm_find_nvmrc)" @@ -70,4 +97,4 @@ for nvm_completion in "$NVM_DIR/bash_completion" "$NVM_HOMEBREW/etc/bash_complet fi done -unset NVM_HOMEBREW NVM_LAZY NVM_AUTOLOAD nvm_completion +unset NVM_HOMEBREW nvm_completion From 5bce72ef57255ab1c23d8fb753417859afe6e0f0 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Tue, 15 Nov 2022 20:27:12 +0100 Subject: [PATCH 086/672] docs(yarn): follow omz `zstyle` bools standard --- plugins/yarn/README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/yarn/README.md b/plugins/yarn/README.md index 9c16ff2c3..cdda2026c 100644 --- a/plugins/yarn/README.md +++ b/plugins/yarn/README.md @@ -15,7 +15,7 @@ It also adds `yarn` global scripts dir (commonly `~/.yarn/bin`) to the `$PATH`. To disable this feature, set the following style in your `.zshrc`: ```zsh -zstyle ':omz:plugins:yarn' global-path false +zstyle ':omz:plugins:yarn' global-path no ``` ## Aliases From 5ab517361a4215d2f777023fc1e772fe79496713 Mon Sep 17 00:00:00 2001 From: Ruslan Tursunov Date: Thu, 17 Nov 2022 13:54:01 +0300 Subject: [PATCH 087/672] feat(git): add `gcn` alias (#10836) --- plugins/git/README.md | 1 + plugins/git/git.plugin.zsh | 1 + 2 files changed, 2 insertions(+) diff --git a/plugins/git/README.md b/plugins/git/README.md index f1c8b81c4..3beb0890a 100644 --- a/plugins/git/README.md +++ b/plugins/git/README.md @@ -35,6 +35,7 @@ plugins=(... git) | gbss | git bisect start | | gc | git commit -v | | gc! | git commit -v --amend | +| gcn | git commit -v --no-edit | | gcn! | git commit -v --no-edit --amend | | gca | git commit -v -a | | gca! | git commit -v -a --amend | diff --git a/plugins/git/git.plugin.zsh b/plugins/git/git.plugin.zsh index 26f4beeb3..69745730c 100644 --- a/plugins/git/git.plugin.zsh +++ b/plugins/git/git.plugin.zsh @@ -84,6 +84,7 @@ alias gbss='git bisect start' alias gc='git commit -v' alias gc!='git commit -v --amend' +alias gcn='git commit -v --no-edit' alias gcn!='git commit -v --no-edit --amend' alias gca='git commit -v -a' alias gca!='git commit -v -a --amend' From d93f3174504f8a0c21aef6998714e3b67ba82606 Mon Sep 17 00:00:00 2001 From: Carlo Date: Sun, 20 Nov 2022 08:36:20 +0100 Subject: [PATCH 088/672] fix(init): prevent multiple compdump compilations (#11345) Closes #11341 --- oh-my-zsh.sh | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/oh-my-zsh.sh b/oh-my-zsh.sh index 29d39ca23..e94c2f417 100644 --- a/oh-my-zsh.sh +++ b/oh-my-zsh.sh @@ -143,7 +143,10 @@ fi unset zcompdump_revision zcompdump_fpath zcompdump_refresh # zcompile the completion dump file if the .zwc is older or missing. -zrecompile -q -p "$ZSH_COMPDUMP" && command rm -f "$ZSH_COMPDUMP.zwc.old" +if command mkdir "${ZSH_COMPDUMP}.lock" 2>/dev/null; then + zrecompile -q -p "$ZSH_COMPDUMP" + command rm -rf "$ZSH_COMPDUMP.zwc.old" "${ZSH_COMPDUMP}.lock" +fi # Load all of the config files in ~/oh-my-zsh that end in .zsh # TIP: Add files you don't want in git to .gitignore From 96976736166998a980cc3d9570db4c0b594460e3 Mon Sep 17 00:00:00 2001 From: Brenex Date: Mon, 21 Nov 2022 05:23:16 -0500 Subject: [PATCH 089/672] docs(aliases): fix typos (#11348) Co-authored-by: Carlo Sala --- plugins/aliases/README.md | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/plugins/aliases/README.md b/plugins/aliases/README.md index 66fd84584..4e77f67b3 100644 --- a/plugins/aliases/README.md +++ b/plugins/aliases/README.md @@ -15,14 +15,14 @@ Requirements: Python needs to be installed. ## Usage -- `acs`: show all aliases by group. +- `acs`: show all aliases by group -- `acs -h/--help`: print help mesage. +- `acs -h/--help`: print help mesage -- `acs `: filter aliases by `` and highlight. +- `acs `: filter aliases by `` and highlight -- `acs -g /--group `. Multiple uses of the flag show all groups, +- `acs -g /--group `: show only aliases for group ``. Multiple uses of the flag show all groups -- `acs --groups-only`: show only group names +- `acs --groups`: show only group names ![screenshot](https://cloud.githubusercontent.com/assets/3602957/11581913/cb54fb8a-9a82-11e5-846b-5a67f67ad9ad.png) From fe83581a20ab12010e9168977dc633c9da2924e1 Mon Sep 17 00:00:00 2001 From: Richard Mitchell Date: Mon, 21 Nov 2022 05:24:10 -0500 Subject: [PATCH 090/672] fix(last-working-dir): use builtin `pwd` (#11346) --- plugins/last-working-dir/last-working-dir.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/last-working-dir/last-working-dir.plugin.zsh b/plugins/last-working-dir/last-working-dir.plugin.zsh index 905a02a70..684972cc1 100644 --- a/plugins/last-working-dir/last-working-dir.plugin.zsh +++ b/plugins/last-working-dir/last-working-dir.plugin.zsh @@ -9,7 +9,7 @@ chpwd_last_working_dir() { [[ "$ZSH_SUBSHELL" -eq 0 ]] || return 0 # Add ".$SSH_USER" suffix to cache file if $SSH_USER is set and non-empty local cache_file="$ZSH_CACHE_DIR/last-working-dir${SSH_USER:+.$SSH_USER}" - pwd >| "$cache_file" + builtin pwd >| "$cache_file" } # Changes directory to the last working directory From 8ef9abc9621321c41e89c578bc6f12176696f36c Mon Sep 17 00:00:00 2001 From: Markus Hofbauer Date: Wed, 23 Nov 2022 10:23:11 +0100 Subject: [PATCH 091/672] feat(pre-commit) add aliases (#10707) --- plugins/pre-commit/README.md | 19 +++++++++++++++++++ plugins/pre-commit/pre-commit.plugin.zsh | 8 ++++++++ 2 files changed, 27 insertions(+) create mode 100644 plugins/pre-commit/README.md create mode 100644 plugins/pre-commit/pre-commit.plugin.zsh diff --git a/plugins/pre-commit/README.md b/plugins/pre-commit/README.md new file mode 100644 index 000000000..e6d80d369 --- /dev/null +++ b/plugins/pre-commit/README.md @@ -0,0 +1,19 @@ +# Pre-commit plugin + +This plugin adds aliases for common commands of [pre-commit](https://pre-commit.com/). + +To use this plugin, add it to the plugins array in your zshrc file: + +```zsh +plugins=(... pre-commit) +``` + +## Aliases + +| Alias | Command | Description | +| ------- | -------------------------------------- | ------------------------------------------------------ | +| prc | `pre-commit` | The `pre-commit` command | +| prcau | `pre-commit autoupdate` | Update hooks automatically | +| prcr | `pre-commit run` | The `pre-commit run` command | +| prcra | `pre-commit run --all-files` | Run pre-commit hooks on all files | +| prcrf | `pre-commit run --files` | Run pre-commit hooks on a given list of files | diff --git a/plugins/pre-commit/pre-commit.plugin.zsh b/plugins/pre-commit/pre-commit.plugin.zsh new file mode 100644 index 000000000..c3d0c6290 --- /dev/null +++ b/plugins/pre-commit/pre-commit.plugin.zsh @@ -0,0 +1,8 @@ +# Aliases for pre-commit +alias prc='pre-commit' + +alias prcau='pre-commit autoupdate' + +alias prcr='pre-commit run' +alias prcra='pre-commit run --all-files' +alias prcrf='pre-commit run --files' From 5485d70df2cefa9374c477425d2c1c84646a7d49 Mon Sep 17 00:00:00 2001 From: Luis Serra <74016165+serrovsky@users.noreply.github.com> Date: Wed, 23 Nov 2022 17:24:08 +0000 Subject: [PATCH 092/672] feat(fluxcd): add completion for flux (#11350) --- plugins/fluxcd/README.md | 9 +++++++++ plugins/fluxcd/fluxcd.plugin.zsh | 14 ++++++++++++++ 2 files changed, 23 insertions(+) create mode 100644 plugins/fluxcd/README.md create mode 100644 plugins/fluxcd/fluxcd.plugin.zsh diff --git a/plugins/fluxcd/README.md b/plugins/fluxcd/README.md new file mode 100644 index 000000000..9723fcc6b --- /dev/null +++ b/plugins/fluxcd/README.md @@ -0,0 +1,9 @@ +# FluxCD plugin + +This plugin adds completion for [FluxCD](https://fluxcd.io), an open and extensible continuous delivery solution for Kubernetes. Powered by GitOps Toolkit. + +To use it, add `fluxcd` to the plugins array in your zshrc file: + +```zsh +plugins=(... fluxcd) +``` diff --git a/plugins/fluxcd/fluxcd.plugin.zsh b/plugins/fluxcd/fluxcd.plugin.zsh new file mode 100644 index 000000000..d30866a06 --- /dev/null +++ b/plugins/fluxcd/fluxcd.plugin.zsh @@ -0,0 +1,14 @@ +# Autocompletion for the FluxCD CLI (flux). +if (( ! $+commands[flux] )); then + return +fi + +# If the completion file doesn't exist yet, we need to autoload it and +# bind it to `flux`. Otherwise, compinit will have already done that. +if [[ ! -f "$ZSH_CACHE_DIR/completions/_flux" ]]; then + typeset -g -A _comps + autoload -Uz _flux + _comps[flux]=_flux +fi + +flux completion zsh >| "$ZSH_CACHE_DIR/completions/_flux" &| From a473c0cb4ad325de211f37388b0ff6ae435b6df4 Mon Sep 17 00:00:00 2001 From: Luis Serra <74016165+serrovsky@users.noreply.github.com> Date: Wed, 23 Nov 2022 17:24:46 +0000 Subject: [PATCH 093/672] feat(mongo-atlas): add completion for atlas (#11349) --- plugins/mongo-atlas/README.md | 10 ++++++++++ plugins/mongo-atlas/mongo-atlas.plugin.zsh | 14 ++++++++++++++ 2 files changed, 24 insertions(+) create mode 100644 plugins/mongo-atlas/README.md create mode 100644 plugins/mongo-atlas/mongo-atlas.plugin.zsh diff --git a/plugins/mongo-atlas/README.md b/plugins/mongo-atlas/README.md new file mode 100644 index 000000000..ef1b5e0d2 --- /dev/null +++ b/plugins/mongo-atlas/README.md @@ -0,0 +1,10 @@ +# MongoDB Atlas plugin + +This plugin adds completion for [Atlas](https://www.mongodb.com/docs/atlas/cli/stable/) a command line interface built specifically for +MongoDB Atlas. + +To use it, add `mongo-atlas` to the plugins array in your zshrc file: + +```zsh +plugins=(... mongo-atlas) +``` diff --git a/plugins/mongo-atlas/mongo-atlas.plugin.zsh b/plugins/mongo-atlas/mongo-atlas.plugin.zsh new file mode 100644 index 000000000..6762c909e --- /dev/null +++ b/plugins/mongo-atlas/mongo-atlas.plugin.zsh @@ -0,0 +1,14 @@ +# Autocompletion for the Mongo Atlas CLI (atlas). +if (( ! $+commands[atlas] )); then + return +fi + +# If the completion file doesn't exist yet, we need to autoload it and +# bind it to `atlas`. Otherwise, compinit will have already done that. +if [[ ! -f "$ZSH_CACHE_DIR/completions/_atlas" ]]; then + typeset -g -A _comps + autoload -Uz _atlas + _comps[atlas]=_atlas +fi + +atlas completion zsh >| "$ZSH_CACHE_DIR/completions/atlas" &| From da7ea13ba928a36c0b41cb520b0cc192f6389143 Mon Sep 17 00:00:00 2001 From: Mathieu Fenniak Date: Wed, 23 Nov 2022 10:56:26 -0700 Subject: [PATCH 094/672] fix(avit): replace deprecated GREP_COLOR (#11168) --- themes/avit.zsh-theme | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/themes/avit.zsh-theme b/themes/avit.zsh-theme index f90ba331b..1279ea919 100644 --- a/themes/avit.zsh-theme +++ b/themes/avit.zsh-theme @@ -82,4 +82,4 @@ ZSH_THEME_GIT_TIME_SINCE_COMMIT_NEUTRAL="%{$fg[white]%}" # LS colors, made with https://geoff.greer.fm/lscolors/ export LSCOLORS="exfxcxdxbxegedabagacad" export LS_COLORS='di=34;40:ln=35;40:so=32;40:pi=33;40:ex=31;40:bd=34;46:cd=34;43:su=0;41:sg=0;46:tw=0;42:ow=0;43:' -export GREP_COLOR='1;33' +export GREP_COLORS='mt=1;33' From a4392cfc16ce6f1ddf1fd085819913ee26dc6189 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Tue, 15 Nov 2022 19:40:06 +0100 Subject: [PATCH 095/672] feat(docker): update completion Taken from https://github.com/docker/cli/blob/79dca7a38e9969f9d0694d85adbaf13394d893ac/contrib/completion/zsh/_docker Closes #10826 --- plugins/docker/_docker | 54 +++++++++++++----------------------------- 1 file changed, 17 insertions(+), 37 deletions(-) diff --git a/plugins/docker/_docker b/plugins/docker/_docker index 8ee35abcf..e6a12d774 100644 --- a/plugins/docker/_docker +++ b/plugins/docker/_docker @@ -567,7 +567,7 @@ __docker_container_commands() { "cp:Copy files/folders between a container and the local filesystem" "create:Create a new container" "diff:Inspect changes on a container's filesystem" - "exec:Run a command in a running container" + "exec:Execute a command in a running container" "export:Export a container's filesystem as a tar archive" "inspect:Display detailed information on one or more containers" "kill:Kill one or more running containers" @@ -579,7 +579,7 @@ __docker_container_commands() { "rename:Rename a container" "restart:Restart one or more containers" "rm:Remove one or more containers" - "run:Run a command in a new container" + "run:Create and run a new container from an image" "start:Start one or more stopped containers" "stats:Display a live stream of container(s) resource usage statistics" "stop:Stop one or more running containers" @@ -650,6 +650,7 @@ __docker_container_subcommand() { "($help)*"{-p=,--publish=}"[Expose a container's port to the host]:port:_ports" "($help)--pid=[PID namespace to use]:PID namespace:__docker_complete_pid" "($help)--privileged[Give extended privileges to this container]" + "($help -q --quiet)"{-q,--quiet}"[Suppress the pull output]" "($help)--read-only[Mount the container's root filesystem as read only]" "($help)*--security-opt=[Security options]:security option: " "($help)*--shm-size=[Size of '/dev/shm' (format is '')]:shm size: " @@ -802,7 +803,7 @@ __docker_container_subcommand() { "($help -a --all)"{-a,--all}"[Show all containers]" \ "($help)--before=[Show only container created before...]:containers:__docker_complete_containers" \ "($help)*"{-f=,--filter=}"[Filter values]:filter:__docker_complete_ps_filters" \ - "($help)--format=[Pretty-print containers using a Go template]:template: " \ + "($help)--format=[Format the output using the given Go template]:template: " \ "($help -l --latest)"{-l,--latest}"[Show only the latest created container]" \ "($help -n --last)"{-n=,--last=}"[Show n last created containers (includes all states)]:n:(1 5 10 25 50)" \ "($help)--no-trunc[Do not truncate output]" \ @@ -907,7 +908,7 @@ __docker_container_subcommand() { _arguments $(__docker_arguments) \ $opts_help \ "($help -a --all)"{-a,--all}"[Show all containers (default shows just running)]" \ - "($help)--format=[Pretty-print images using a Go template]:template: " \ + "($help)--format=[Format the output using the given Go template]:template: " \ "($help)--no-stream[Disable streaming stats and only pull the first result]" \ "($help)--no-trunc[Do not truncate output]" \ "($help -)*:containers:__docker_complete_running_containers" && ret=0 @@ -973,8 +974,8 @@ __docker_image_commands() { "load:Load an image from a tar archive or STDIN" "ls:List images" "prune:Remove unused images" - "pull:Pull an image or a repository from a registry" - "push:Push an image or a repository to a registry" + "pull:Download an image from a registry" + "push:Upload an image to a registry" "rm:Remove one or more images" "save:Save one or more images to a tar archive (streamed to STDOUT by default)" "tag:Tag an image into a repository" @@ -1060,7 +1061,7 @@ __docker_image_subcommand() { "($help -a --all)"{-a,--all}"[Show all images]" \ "($help)--digests[Show digests]" \ "($help)*"{-f=,--filter=}"[Filter values]:filter:__docker_complete_images_filters" \ - "($help)--format=[Pretty-print images using a Go template]:template: " \ + "($help)--format=[Format the output using the given Go template]:template: " \ "($help)--no-trunc[Do not truncate output]" \ "($help -q --quiet)"{-q,--quiet}"[Only show image IDs]" \ "($help -): :__docker_complete_repositories" && ret=0 @@ -1082,7 +1083,7 @@ __docker_image_subcommand() { (push) _arguments $(__docker_arguments) \ $opts_help \ - "($help -a --all-tags)"{-a,--all-tags}"[Push all tagged images in the repository]" \ + "($help -a --all-tags)"{-a,--all-tags}"[Push all tags of an image to the repository]" \ "($help)--disable-content-trust[Skip image signing]" \ "($help -): :__docker_complete_images" && ret=0 ;; @@ -1292,7 +1293,7 @@ __docker_network_subcommand() { $opts_help \ "($help)--no-trunc[Do not truncate the output]" \ "($help)*"{-f=,--filter=}"[Provide filter values]:filter:__docker_network_complete_ls_filters" \ - "($help)--format=[Pretty-print networks using a Go template]:template: " \ + "($help)--format=[Format the output using the given Go template]:template: " \ "($help -q --quiet)"{-q,--quiet}"[Only display network IDs]" && ret=0 ;; (prune) @@ -2050,7 +2051,7 @@ __docker_service_subcommand() { _arguments $(__docker_arguments) \ $opts_help \ "($help)*"{-f=,--filter=}"[Filter output based on conditions provided]:filter:__docker_service_complete_ls_filters" \ - "($help)--format=[Pretty-print services using a Go template]:template: " \ + "($help)--format=[Format the output using the given Go template]:template: " \ "($help -q --quiet)"{-q,--quiet}"[Only display IDs]" && ret=0 ;; (rm|remove) @@ -2253,7 +2254,7 @@ __docker_stack_subcommand() { _arguments $(__docker_arguments) \ $opts_help \ "($help)*"{-f=,--filter=}"[Filter output based on conditions provided]:filter:__docker_stack_complete_services_filters" \ - "($help)--format=[Pretty-print services using a Go template]:template: " \ + "($help)--format=[Format the output using the given Go template]:template: " \ "($help -q --quiet)"{-q,--quiet}"[Only display IDs]" \ "($help -):stack:__docker_complete_stacks" && ret=0 ;; @@ -2520,7 +2521,7 @@ __docker_volume_subcommand() { _arguments $(__docker_arguments) \ $opts_help \ "($help)*"{-f=,--filter=}"[Provide filter values]:filter:__docker_volume_complete_ls_filters" \ - "($help)--format=[Pretty-print volumes using a Go template]:template: " \ + "($help)--format=[Format the output using the given Go template]:template: " \ "($help -q --quiet)"{-q,--quiet}"[Only display volume names]" && ret=0 ;; (prune) @@ -2582,10 +2583,8 @@ __docker_context_subcommand() { (create) _arguments $(__docker_arguments) \ $opts_help \ - "($help)--default-stack-orchestrator=[Default orchestrator for stack operations to use with this context]:default-stack-orchestrator:(swarm kubernetes all)" \ "($help)--description=[Description of the context]:description:" \ "($help)--docker=[Set the docker endpoint]:docker:" \ - "($help)--kubernetes=[Set the kubernetes endpoint]:kubernetes:" \ "($help)--from=[Create context from a named context]:from:__docker_complete_contexts" \ "($help -):name: " && ret=0 ;; @@ -2607,10 +2606,8 @@ __docker_context_subcommand() { (update) _arguments $(__docker_arguments) \ $opts_help \ - "($help)--default-stack-orchestrator=[Default orchestrator for stack operations to use with this context]:default-stack-orchestrator:(swarm kubernetes all)" \ "($help)--description=[Description of the context]:description:" \ "($help)--docker=[Set the docker endpoint]:docker:" \ - "($help)--kubernetes=[Set the kubernetes endpoint]:kubernetes:" \ "($help -):name:" && ret=0 ;; esac @@ -2734,9 +2731,6 @@ __docker_subcommand() { "($help -b --bridge)"{-b=,--bridge=}"[Attach containers to a network bridge]:bridge:_net_interfaces" \ "($help)--bip=[Network bridge IP]:IP address: " \ "($help)--cgroup-parent=[Parent cgroup for all containers]:cgroup: " \ - "($help)--cluster-advertise=[Address or interface name to advertise]:Instance to advertise (host\:port): " \ - "($help)--cluster-store=[URL of the distributed storage backend]:Cluster Store:->cluster-store" \ - "($help)*--cluster-store-opt=[Cluster store options]:Cluster options:->cluster-store-options" \ "($help)--config-file=[Path to daemon configuration file]:Config File:_files" \ "($help)--containerd=[Path to containerd socket]:socket:_files -g \"*.sock\"" \ "($help)--containerd-namespace=[Containerd namespace to use]:containerd namespace:" \ @@ -2778,7 +2772,7 @@ __docker_subcommand() { "($help)--oom-score-adjust=[Set the oom_score_adj for the daemon]:oom-score:(-500)" \ "($help -p --pidfile)"{-p=,--pidfile=}"[Path to use for daemon PID file]:PID file:_files" \ "($help)--raw-logs[Full timestamps without ANSI coloring]" \ - "($help)*--registry-mirror=[Preferred Docker registry mirror]:registry mirror: " \ + "($help)*--registry-mirror=[Preferred registry mirror]:registry mirror: " \ "($help)--seccomp-profile=[Path to seccomp profile]:path:_files -g \"*.json\"" \ "($help -s --storage-driver)"{-s=,--storage-driver=}"[Storage driver to use]:driver:(aufs btrfs devicemapper overlay overlay2 vfs zfs)" \ "($help)--selinux-enabled[Enable selinux support]" \ @@ -2795,22 +2789,6 @@ __docker_subcommand() { "($help)--validate[Validate daemon configuration and exit]" && ret=0 case $state in - (cluster-store) - if compset -P '*://'; then - _message 'host:port' && ret=0 - else - store=('consul' 'etcd' 'zk') - _describe -t cluster-store "Cluster Store" store -qS "://" && ret=0 - fi - ;; - (cluster-store-options) - if compset -P '*='; then - _files && ret=0 - else - opts=('discovery.heartbeat' 'discovery.ttl' 'kv.cacertfile' 'kv.certfile' 'kv.keyfile' 'kv.path') - _describe -t cluster-store-opts "Cluster Store Options" opts -qS "=" && ret=0 - fi - ;; (users-groups) if compset -P '*:'; then _groups && ret=0 @@ -3095,6 +3073,7 @@ _docker() { _arguments $(__docker_arguments) -C \ "(: -)"{-h,--help}"[Print usage]" \ "($help)--config[Location of client config files]:path:_directories" \ + "($help -c --context)"{-c=,--context=}"[Execute the command in a docker context]:context:__docker_complete_contexts" \ "($help -D --debug)"{-D,--debug}"[Enable debug mode]" \ "($help -H --host)"{-H=,--host=}"[tcp://host:port to bind/connect to]:host: " \ "($help -l --log-level)"{-l=,--log-level=}"[Logging level]:level:(debug info warn error fatal)" \ @@ -3110,7 +3089,8 @@ _docker() { local host=${opt_args[-H]}${opt_args[--host]} local config=${opt_args[--config]} - local docker_options="${host:+--host $host} ${config:+--config $config}" + local context=${opt_args[-c]}${opt_args[--context]} + local docker_options="${host:+--host $host} ${config:+--config $config} ${context:+--context $context} " case $state in (command) From 1c06ea24fb2176e28facf34b7c2ed2bfb3c79eaa Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Tue, 15 Nov 2022 20:05:13 +0100 Subject: [PATCH 096/672] chore(docker): sort and reorganize aliases --- plugins/docker/README.md | 86 +++++++++++++++----------------- plugins/docker/docker.plugin.zsh | 32 +++++------- 2 files changed, 52 insertions(+), 66 deletions(-) diff --git a/plugins/docker/README.md b/plugins/docker/README.md index 606690f14..b865d53ed 100644 --- a/plugins/docker/README.md +++ b/plugins/docker/README.md @@ -13,18 +13,15 @@ https://github.com/docker/cli/blob/master/contrib/completion/zsh/_docker ## Settings -By default, the completion doesn't allow option-stacking, meaning if you try to -complete `docker run -it ` it won't work, because you're _stacking_ the -`-i` and `-t` options. +By default, the completion doesn't allow option-stacking, meaning if you try to complete +`docker run -it ` it won't work, because you're _stacking_ the `-i` and `-t` options. -[You can enable it](https://github.com/docker/cli/commit/b10fb43048) by **adding -the lines below to your zshrc file**, but be aware of the side effects: +[You can enable it](https://github.com/docker/cli/commit/b10fb43048) by **adding the lines below to your zshrc +file**, but be aware of the side effects: -> This enables Zsh to understand commands like `docker run -it -> ubuntu`. However, by enabling this, this also makes Zsh complete -> `docker run -u` with `docker run -uapprox` which is not valid. The -> users have to put the space or the equal sign themselves before trying -> to complete. +> This enables Zsh to understand commands like `docker run -it ubuntu`. However, by enabling this, this also +> makes Zsh complete `docker run -u` with `docker run -uapprox` which is not valid. The users have to put +> the space or the equal sign themselves before trying to complete. > > Therefore, this behavior is disabled by default. To enable it: > @@ -35,39 +32,36 @@ the lines below to your zshrc file**, but be aware of the side effects: ## Aliases -| Alias | Command | Description | -| :------ | :-------------------------- | :--------------------------------------------------------------------------------------- | -| dbl | `docker build` | Build an image from a Dockerfile | -| dcin | `docker container inspect` | Display detailed information on one or more containers | -| dlo | `docker container logs` | Fetch the logs of a docker container | -| dcls | `docker container ls` | List all the running docker containers | -| dclsa | `docker container ls -a` | List all running and stopped containers | -| dpo | `docker container port` | List port mappings or a specific mapping for the container | -| dpu | `docker pull` | Pull an image or a repository from a registry | -| dr | `docker container run` | Create a new container and start it using the specified command | -| drit | `docker container run -it` | Create a new container and start it in an interactive shell | -| drm | `docker container rm` | Remove the specified container(s) | -| drm! | `docker container rm -f` | Force the removal of a running container (uses SIGKILL) | -| dst | `docker container start` | Start one or more stopped containers | -| dstp | `docker container stop` | Stop one or more running containers | -| dtop | `docker top` | Display the running processes of a container | -| dxc | `docker container exec` | Run a new command in a running container | -| dxcit | `docker container exec -it` | Run a new command in a running container in an interactive shell | -| | | **Docker Images** | -| dib | `docker image build` | Build an image from a Dockerfile (same as docker build) | -| dii | `docker image inspect` | Display detailed information on one or more images | -| dils | `docker image ls` | List docker images | -| dipu | `docker image push` | Push an image or repository to a remote registry | -| dirm | `docker image rm` | Remove one or more images | -| dit | `docker image tag` | Add a name and tag to a particular image | -| | | **Docker Network** | -| dnc | `docker network create` | Create a new network | -| dncn | `docker network connect` | Connect a container to a network | -| dndcn | `docker network disconnect` | Disconnect a container from a network | -| dni | `docker network inspect` | Return information about one or more networks | -| dnls | `docker network ls` | List all networks the engine daemon knows about, including those spanning multiple hosts | -| dnrm | `docker network rm` | Remove one or more networks | -| | | **Docker Volume** | -| dvi | `docker volume inspect` | Display detailed information about one or more volumes | -| dvls | `docker volume ls` | List all the volumes known to docker | -| dvprune | `docker volume prune` | Cleanup dangling volumes | +| Alias | Command | Description | +| :------ | :---------------------------- | :--------------------------------------------------------------------------------------- | +| dbl | `docker build` | Build an image from a Dockerfile | +| dcin | `docker container inspect` | Display detailed information on one or more containers | +| dcls | `docker container ls` | List all the running docker containers | +| dclsa | `docker container ls -a` | List all running and stopped containers | +| dib | `docker image build` | Build an image from a Dockerfile (same as docker build) | +| dii | `docker image inspect` | Display detailed information on one or more images | +| dils | `docker image ls` | List docker images | +| dipu | `docker image push` | Push an image or repository to a remote registry | +| dirm | `docker image rm` | Remove one or more images | +| dit | `docker image tag` | Add a name and tag to a particular image | +| dlo | `docker container logs` | Fetch the logs of a docker container | +| dnc | `docker network create` | Create a new network | +| dncn | `docker network connect` | Connect a container to a network | +| dndcn | `docker network disconnect` | Disconnect a container from a network | +| dni | `docker network inspect` | Return information about one or more networks | +| dnls | `docker network ls` | List all networks the engine daemon knows about, including those spanning multiple hosts | +| dnrm | `docker network rm` | Remove one or more networks | +| dpo | `docker container port` | List port mappings or a specific mapping for the container | +| dpu | `docker pull` | Pull an image or a repository from a registry | +| dr | `docker container run` | Create a new container and start it using the specified command | +| drit | `docker container run -it` | Create a new container and start it in an interactive shell | +| drm | `docker container rm` | Remove the specified container(s) | +| drm! | `docker container rm -f` | Force the removal of a running container (uses SIGKILL) | +| dst | `docker container start` | Start one or more stopped containers | +| dstp | `docker container stop` | Stop one or more running containers | +| dtop | `docker top` | Display the running processes of a container | +| dvi | `docker volume inspect` | Display detailed information about one or more volumes | +| dvls | `docker volume ls` | List all the volumes known to docker | +| dvprune | `docker volume prune` | Cleanup dangling volumes | +| dxc | `docker container exec` | Run a new command in a running container | +| dxcit | `docker container exec -it` | Run a new command in a running container in an interactive shell | diff --git a/plugins/docker/docker.plugin.zsh b/plugins/docker/docker.plugin.zsh index 9c8ad8a28..483b3b97e 100644 --- a/plugins/docker/docker.plugin.zsh +++ b/plugins/docker/docker.plugin.zsh @@ -1,39 +1,31 @@ alias dbl='docker build' -alias dpu='docker pull' -alias dtop='docker top' - -# docker containers alias dcin='docker container inspect' -alias dlo='docker container logs' alias dcls='docker container ls' alias dclsa='docker container ls -a' -alias dpo='docker container port' -alias dr='docker container run' -alias drit='docker container run -it' -alias drm='docker container rm' -alias 'drm!'='docker container rm -f' -alias dst='docker container start' -alias dstp='docker container stop' -alias dxc='docker container exec' -alias dxcit='docker container exec -it' - -# docker images alias dib='docker image build' alias dii='docker image inspect' alias dils='docker image ls' alias dipu='docker image push' alias dirm='docker image rm' alias dit='docker image tag' - -# docker network +alias dlo='docker container logs' alias dnc='docker network create' alias dncn='docker network connect' alias dndcn='docker network disconnect' alias dni='docker network inspect' alias dnls='docker network ls' alias dnrm='docker network rm' - -# docker volume +alias dpo='docker container port' +alias dpu='docker pull' +alias dr='docker container run' +alias drit='docker container run -it' +alias drm='docker container rm' +alias 'drm!'='docker container rm -f' +alias dst='docker container start' +alias dstp='docker container stop' +alias dtop='docker top' alias dvi='docker volume inspect' alias dvls='docker volume ls' alias dvprune='docker volume prune' +alias dxc='docker container exec' +alias dxcit='docker container exec -it' From c35ca17258dd870f1724eeb92e9077177d2e3bed Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Rafael=20Bernard=20Ara=C3=BAjo?= Date: Tue, 15 Nov 2022 20:05:33 +0100 Subject: [PATCH 097/672] feat(docker): add `dsta` alias Closes #11089 --- plugins/docker/README.md | 1 + plugins/docker/docker.plugin.zsh | 1 + 2 files changed, 2 insertions(+) diff --git a/plugins/docker/README.md b/plugins/docker/README.md index b865d53ed..040a168d6 100644 --- a/plugins/docker/README.md +++ b/plugins/docker/README.md @@ -58,6 +58,7 @@ file**, but be aware of the side effects: | drm | `docker container rm` | Remove the specified container(s) | | drm! | `docker container rm -f` | Force the removal of a running container (uses SIGKILL) | | dst | `docker container start` | Start one or more stopped containers | +| dsta | `docker stop $(docker ps -q)` | Stop all running containers | | dstp | `docker container stop` | Stop one or more running containers | | dtop | `docker top` | Display the running processes of a container | | dvi | `docker volume inspect` | Display detailed information about one or more volumes | diff --git a/plugins/docker/docker.plugin.zsh b/plugins/docker/docker.plugin.zsh index 483b3b97e..737803651 100644 --- a/plugins/docker/docker.plugin.zsh +++ b/plugins/docker/docker.plugin.zsh @@ -22,6 +22,7 @@ alias drit='docker container run -it' alias drm='docker container rm' alias 'drm!'='docker container rm -f' alias dst='docker container start' +alias dsta='docker stop $(docker ps -q)' alias dstp='docker container stop' alias dtop='docker top' alias dvi='docker volume inspect' From 1aa58d42a52b8fa39f16ad169fc405f276c36ae5 Mon Sep 17 00:00:00 2001 From: jzhang046 <25826821+jzhang046@users.noreply.github.com> Date: Sun, 27 Nov 2022 17:54:24 +0800 Subject: [PATCH 098/672] fix(changelog): generate correct commit link in markdown (#11356) --- tools/changelog.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tools/changelog.sh b/tools/changelog.sh index 6489a3cb2..a5cc468f2 100755 --- a/tools/changelog.sh +++ b/tools/changelog.sh @@ -209,7 +209,7 @@ function display-release { case "$output" in raw) printf '%s' "$hash" ;; text) printf '\e[33m%s\e[0m' "$hash" ;; # red - md) printf '[`%s`](https://github.com/ohmyzsh/ohmyzsh/commit/%s)' "$hash" ;; + md) printf '[`%s`](https://github.com/ohmyzsh/ohmyzsh/commit/%s)' "$hash" "$hash" ;; esac } From 66addc8b45c93f7661a5d8bba93b7b4afcbc23de Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Andr=C3=A9=20Lopes?= <85288424+agnlopes@users.noreply.github.com> Date: Tue, 29 Nov 2022 13:35:57 +0100 Subject: [PATCH 099/672] feat(skaffold): add completion (#11357) --- plugins/skaffold/README.md | 9 +++++++++ plugins/skaffold/skaffold.plugin.zsh | 14 ++++++++++++++ 2 files changed, 23 insertions(+) create mode 100644 plugins/skaffold/README.md create mode 100644 plugins/skaffold/skaffold.plugin.zsh diff --git a/plugins/skaffold/README.md b/plugins/skaffold/README.md new file mode 100644 index 000000000..4ee12c666 --- /dev/null +++ b/plugins/skaffold/README.md @@ -0,0 +1,9 @@ +# Skaffold plugin (Autocompletion) + +This plugin adds completion for [Skaffold](https://skaffold.dev) + +To use it, add `skaffold` to the plugins array in your zshrc file: + +```zsh +plugins=(... skaffold) +``` diff --git a/plugins/skaffold/skaffold.plugin.zsh b/plugins/skaffold/skaffold.plugin.zsh new file mode 100644 index 000000000..8296c450c --- /dev/null +++ b/plugins/skaffold/skaffold.plugin.zsh @@ -0,0 +1,14 @@ +# Autocompletion for skaffold +if (( ! $+commands[skaffold] )); then + return +fi + +# If the completion file doesn't exist yet, we need to autoload it and +# bind it to `skaffold`. Otherwise, compinit will have already done that. +if [[ ! -f "$ZSH_CACHE_DIR/completions/_skaffold" ]]; then + typeset -g -A _comps + autoload -Uz _skaffold + _comps[skaffold]=_skaffold +fi + +skaffold completion zsh >| "$ZSH_CACHE_DIR/completions/_skaffold" &| From a051eb04b88cb0a876d1f3d68559d228a14dccf0 Mon Sep 17 00:00:00 2001 From: Marco Collovati Date: Thu, 1 Dec 2022 12:34:38 +0100 Subject: [PATCH 100/672] feat(mvn): add completion for Vaadin (#11362) --- plugins/mvn/mvn.plugin.zsh | 2 ++ 1 file changed, 2 insertions(+) diff --git a/plugins/mvn/mvn.plugin.zsh b/plugins/mvn/mvn.plugin.zsh index 1b9141f21..151fbd2a6 100644 --- a/plugins/mvn/mvn.plugin.zsh +++ b/plugins/mvn/mvn.plugin.zsh @@ -283,6 +283,8 @@ function listMavenCompletions { toolchain:toolchain #liberty liberty:clean-server liberty:compile-jsp liberty:configure-arquillian liberty:create-server liberty:debug liberty:debug-server liberty:deploy liberty:dev liberty:display-url liberty:dump-server liberty:install-apps liberty:install-feature liberty:install-server liberty:java-dump-server liberty:package-server liberty:run liberty:run-server liberty:server-status liberty:start liberty:start-server liberty:status liberty:stop liberty:stop-server liberty:test-start-server liberty:test-stop-server liberty:undeploy liberty:uninstall-feature + # vaadin + vaadin:prepare-frontend vaadin:build-frontend vaadin:clean-frontend vaadin:dance # options "-Dmaven.test.skip=true" -DskipTests -DskipITs -Dmaven.surefire.debug -DenableCiProfile "-Dpmd.skip=true" "-Dcheckstyle.skip=true" "-Dtycho.mode=maven" "-Dmaven.test.failure.ignore=true" "-DgroupId=" "-DartifactId=" "-Dversion=" "-Dpackaging=jar" "-Dfile=" From 64bc22aee4d32eb64ee918fc9e63318b68979070 Mon Sep 17 00:00:00 2001 From: Carlo Date: Thu, 1 Dec 2022 19:44:48 +0100 Subject: [PATCH 101/672] feat(nvm): add `silent-autoload` setting (#11363) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Co-authored-by: Michał Regulski Closes #10942 --- plugins/nvm/README.md | 10 +++++++++- plugins/nvm/nvm.plugin.zsh | 12 +++++++----- 2 files changed, 16 insertions(+), 6 deletions(-) diff --git a/plugins/nvm/README.md b/plugins/nvm/README.md index 4c6312e6e..d3fd980be 100644 --- a/plugins/nvm/README.md +++ b/plugins/nvm/README.md @@ -48,5 +48,13 @@ If set, the plugin will automatically load a node version when if finds a version to load. This can be done, similar as previous options, adding: ```zsh -zstyle ':omz:plugins:nvm' autoload true +zstyle ':omz:plugins:nvm' autoload yes ``` + +To remove the output generated by NVM when autoloading, you can set the following option: + +```zsh +zstyle ':omz:plugins:nvm' silent-autoload yes +``` + +Note: _this will not remove regular `nvm` output_ diff --git a/plugins/nvm/nvm.plugin.zsh b/plugins/nvm/nvm.plugin.zsh index ec583cc2d..c5799c88e 100644 --- a/plugins/nvm/nvm.plugin.zsh +++ b/plugins/nvm/nvm.plugin.zsh @@ -24,11 +24,11 @@ if (( ${+NVM_LAZY} + ${+NVM_LAZY_CMD} + ${+NVM_AUTOLOAD} )); then # Nicely print the list in the style `var1, var2 and var3` echo "${fg[yellow]}[nvm plugin] Variable-style settings are deprecated. Instead of ${(j:, :)used_vars[1,-2]}${used_vars[-2]+ and }${used_vars[-1]}, use:\n" if (( $+NVM_AUTOLOAD )); then - echo " zstyle ':omz:plugins:nvm' autoload true" + echo " zstyle ':omz:plugins:nvm' autoload yes" zstyle ':omz:plugins:nvm' autoload yes fi if (( $+NVM_LAZY )); then - echo " zstyle ':omz:plugins:nvm' lazy true" + echo " zstyle ':omz:plugins:nvm' lazy yes" zstyle ':omz:plugins:nvm' lazy yes fi if (( $+NVM_LAZY_CMD )); then @@ -61,9 +61,11 @@ fi # Autoload nvm when finding a .nvmrc file in the current directory # Adapted from: https://github.com/nvm-sh/nvm#zsh if zstyle -t ':omz:plugins:nvm' autoload; then - load-nvmrc() { + function load-nvmrc { local node_version="$(nvm version)" local nvmrc_path="$(nvm_find_nvmrc)" + local nvm_silent="" + zstyle -t ':omz:plugins:nvm' silent-autoload && _nvm_silent="--silent" if [[ -n "$nvmrc_path" ]]; then local nvmrc_node_version=$(nvm version "$(cat "${nvmrc_path}")") @@ -71,11 +73,11 @@ if zstyle -t ':omz:plugins:nvm' autoload; then if [[ "$nvmrc_node_version" = "N/A" ]]; then nvm install elif [[ "$nvmrc_node_version" != "$node_version" ]]; then - nvm use + nvm use $nvm_silent fi elif [[ "$node_version" != "$(nvm version default)" ]]; then echo "Reverting to nvm default version" - nvm use default + nvm use default $nvm_silent fi } From fc44c49cca9d5e499097392d3f42b1375d0253ba Mon Sep 17 00:00:00 2001 From: Zeragamba Date: Thu, 1 Dec 2022 13:49:41 -0500 Subject: [PATCH 102/672] fix(nvm): trim non-printable chars from .nvmrc (#10997) --- plugins/nvm/nvm.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/nvm/nvm.plugin.zsh b/plugins/nvm/nvm.plugin.zsh index c5799c88e..a4ff29cf1 100644 --- a/plugins/nvm/nvm.plugin.zsh +++ b/plugins/nvm/nvm.plugin.zsh @@ -68,7 +68,7 @@ if zstyle -t ':omz:plugins:nvm' autoload; then zstyle -t ':omz:plugins:nvm' silent-autoload && _nvm_silent="--silent" if [[ -n "$nvmrc_path" ]]; then - local nvmrc_node_version=$(nvm version "$(cat "${nvmrc_path}")") + local nvmrc_node_version=$(nvm version $(cat "$nvmrc_path" | tr -dc '[:print:]')) if [[ "$nvmrc_node_version" = "N/A" ]]; then nvm install From 7ea8a93bb8fb04a070960048aa0b5dca639456a8 Mon Sep 17 00:00:00 2001 From: Mohammad Parvin Date: Fri, 2 Dec 2022 16:19:00 +0330 Subject: [PATCH 103/672] feat(helm): add aliases (#11361) Co-authored-by: Carlo Sala --- plugins/helm/README.md | 11 ++++++++++- plugins/helm/helm.plugin.zsh | 5 +++++ 2 files changed, 15 insertions(+), 1 deletion(-) diff --git a/plugins/helm/README.md b/plugins/helm/README.md index 49844c78f..8be024bfb 100644 --- a/plugins/helm/README.md +++ b/plugins/helm/README.md @@ -1,9 +1,18 @@ # Helm plugin -This plugin adds completion for [Helm](https://helm.sh/), the Kubernetes package manager. +This plugin adds completion and aliases for [Helm](https://helm.sh/), the Kubernetes package manager. To use it, add `helm` to the plugins array in your zshrc file: ```zsh plugins=(... helm) ``` + +## Aliases + +| Alias | Full command | +| ----- | ------------ | +| h | helm | +| hin | helm install | +| hse | helm search | +| hup | helm upgrade | diff --git a/plugins/helm/helm.plugin.zsh b/plugins/helm/helm.plugin.zsh index 151c43d88..7fc05be98 100644 --- a/plugins/helm/helm.plugin.zsh +++ b/plugins/helm/helm.plugin.zsh @@ -11,3 +11,8 @@ else source "$ZSH_CACHE_DIR/completions/_helm" helm completion zsh | tee "$ZSH_CACHE_DIR/completions/_helm" >/dev/null &| fi + +alias h='helm' +alias hin='helm install' +alias hse='helm search' +alias hup='helm upgrade' From 3a9322b9a0698a3861277890f791b43e727cccc5 Mon Sep 17 00:00:00 2001 From: Noam Okman Date: Mon, 5 Dec 2022 15:18:18 +0200 Subject: [PATCH 104/672] feat(yarn): add format alias (#11368) --- plugins/yarn/README.md | 1 + plugins/yarn/yarn.plugin.zsh | 1 + 2 files changed, 2 insertions(+) diff --git a/plugins/yarn/README.md b/plugins/yarn/README.md index cdda2026c..270bf6b7f 100644 --- a/plugins/yarn/README.md +++ b/plugins/yarn/README.md @@ -29,6 +29,7 @@ zstyle ':omz:plugins:yarn' global-path no | yb | `yarn build` | Run the build script defined in `package.json` | | ycc | `yarn cache clean` | Clean yarn's global cache of packages | | yd | `yarn dev` | Run the dev script defined in `package.json` | +| yf | `yarn format` | Run the dev script defined in `package.json` | | yga | `yarn global add` | Install packages globally on your operating system | | ygls | `yarn global list` | Lists global installed packages | | ygrm | `yarn global remove` | Remove global installed packages from your OS | diff --git a/plugins/yarn/yarn.plugin.zsh b/plugins/yarn/yarn.plugin.zsh index bcb8661cf..7ba710df7 100644 --- a/plugins/yarn/yarn.plugin.zsh +++ b/plugins/yarn/yarn.plugin.zsh @@ -17,6 +17,7 @@ alias yap="yarn add --peer" alias yb="yarn build" alias ycc="yarn cache clean" alias yd="yarn dev" +alias yf="yarn format" alias yga="yarn global add" alias ygls="yarn global list" alias ygrm="yarn global remove" From 585e7138b556db89715eb2a850f8959fdf527384 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Micha=C5=82=20Regulski?= Date: Tue, 6 Dec 2022 18:22:13 +0100 Subject: [PATCH 105/672] fix(nvm): omit message when silent-autoload is enabled (#11371) --- plugins/nvm/nvm.plugin.zsh | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/plugins/nvm/nvm.plugin.zsh b/plugins/nvm/nvm.plugin.zsh index a4ff29cf1..20697d67d 100644 --- a/plugins/nvm/nvm.plugin.zsh +++ b/plugins/nvm/nvm.plugin.zsh @@ -65,7 +65,7 @@ if zstyle -t ':omz:plugins:nvm' autoload; then local node_version="$(nvm version)" local nvmrc_path="$(nvm_find_nvmrc)" local nvm_silent="" - zstyle -t ':omz:plugins:nvm' silent-autoload && _nvm_silent="--silent" + zstyle -t ':omz:plugins:nvm' silent-autoload && nvm_silent="--silent" if [[ -n "$nvmrc_path" ]]; then local nvmrc_node_version=$(nvm version $(cat "$nvmrc_path" | tr -dc '[:print:]')) @@ -76,7 +76,10 @@ if zstyle -t ':omz:plugins:nvm' autoload; then nvm use $nvm_silent fi elif [[ "$node_version" != "$(nvm version default)" ]]; then - echo "Reverting to nvm default version" + if [[ -z $nvm_silent ]]; then + echo "Reverting to nvm default version" + fi + nvm use default $nvm_silent fi } From 658eb01d82c01d82b4263b3dc59e15232cb4cdaf Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Tue, 6 Dec 2022 22:51:52 +0100 Subject: [PATCH 106/672] refactor(kubectl): standarize completion generation --- plugins/kubectl/kubectl.plugin.zsh | 22 ++++++++++++---------- 1 file 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 From b692ff2e1597816563cbdaeeedf0966ad9babeca Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Wed, 7 Dec 2022 12:18:51 +0100 Subject: [PATCH 107/672] fix(kubectl): redirect stderr in completion generation Fixes #11364 --- plugins/kubectl/kubectl.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/kubectl/kubectl.plugin.zsh b/plugins/kubectl/kubectl.plugin.zsh index b415d1ad8..315d3ce93 100644 --- a/plugins/kubectl/kubectl.plugin.zsh +++ b/plugins/kubectl/kubectl.plugin.zsh @@ -10,7 +10,7 @@ if [[ ! -f "$ZSH_CACHE_DIR/completions/_kubectl" ]]; then _comps[kubectl]=_kubectl fi -kubectl completion zsh >| "$ZSH_CACHE_DIR/completions/_kubectl" &| +kubectl completion zsh 2> /dev/null >| "$ZSH_CACHE_DIR/completions/_kubectl" &| # This command is used a LOT both below and in daily life alias k=kubectl From f4dc8c5be365668810783ced01a86ff8f251bfd7 Mon Sep 17 00:00:00 2001 From: fedor <60283525+izumrudik@users.noreply.github.com> Date: Thu, 8 Dec 2022 14:38:13 +0300 Subject: [PATCH 108/672] fix(tmux): use `$...SESSION_NAME` while attaching (#10946) --- plugins/tmux/tmux.plugin.zsh | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/plugins/tmux/tmux.plugin.zsh b/plugins/tmux/tmux.plugin.zsh index b9bb66d59..311c2e6a9 100644 --- a/plugins/tmux/tmux.plugin.zsh +++ b/plugins/tmux/tmux.plugin.zsh @@ -73,7 +73,11 @@ function _zsh_tmux_plugin_run() { [[ "$ZSH_TMUX_UNICODE" == "true" ]] && tmux_cmd+=(-u) # Try to connect to an existing session. - [[ "$ZSH_TMUX_AUTOCONNECT" == "true" ]] && $tmux_cmd attach + if [[ -n "$ZSH_TMUX_DEFAULT_SESSION_NAME" ]]; then + [[ "$ZSH_TMUX_AUTOCONNECT" == "true" ]] && $tmux_cmd attach -t $ZSH_TMUX_DEFAULT_SESSION_NAME + else + [[ "$ZSH_TMUX_AUTOCONNECT" == "true" ]] && $tmux_cmd attach + fi # If failed, just run tmux, fixing the TERM variable if requested. if [[ $? -ne 0 ]]; then @@ -83,9 +87,9 @@ function _zsh_tmux_plugin_run() { tmux_cmd+=(-f "$ZSH_TMUX_CONFIG") fi if [[ -n "$ZSH_TMUX_DEFAULT_SESSION_NAME" ]]; then - $tmux_cmd new-session -s $ZSH_TMUX_DEFAULT_SESSION_NAME + $tmux_cmd new-session -s $ZSH_TMUX_DEFAULT_SESSION_NAME else - $tmux_cmd new-session + $tmux_cmd new-session fi fi From cc5100d1e9e3d843ab93a12a5b0bac71ae0425f3 Mon Sep 17 00:00:00 2001 From: Neil Girdhar Date: Fri, 9 Dec 2022 04:07:52 -0500 Subject: [PATCH 109/672] feat(pip): add several aliases (#10647) --- plugins/pip/README.md | 8 ++++++++ plugins/pip/pip.plugin.zsh | 26 +++++++++++++++++++++++++- 2 files changed, 33 insertions(+), 1 deletion(-) diff --git a/plugins/pip/README.md b/plugins/pip/README.md index 88d88227e..70d40c79f 100644 --- a/plugins/pip/README.md +++ b/plugins/pip/README.md @@ -22,6 +22,14 @@ the next time you autocomplete `pip install`. | Alias | Description | | :------- | :-------------------------------------------- | +| pipi | Install packages | +| pipig | Install package from GitHub repository | +| pipigb | Install package from GitHub branch | +| pipigp | Install package from GitHub pull request | +| pipu | Upgrade packages | +| pipun | Uninstall packages | +| pipgi | Grep through installed packages | +| piplo | List outdated packages | | pipreq | Create requirements file | | pipir | Install packages from `requirements.txt` file | | pipupall | Update all installed packages | diff --git a/plugins/pip/pip.plugin.zsh b/plugins/pip/pip.plugin.zsh index 90e39e118..bf1aafd4a 100644 --- a/plugins/pip/pip.plugin.zsh +++ b/plugins/pip/pip.plugin.zsh @@ -88,6 +88,12 @@ else alias pip="noglob pip" fi +alias pipi="pip install" +alias pipu="pip install --upgrade" +alias pipun="pip uninstall" +alias pipgi="pip freeze | grep" +alias piplo="pip list -o" + # Create requirements file alias pipreq="pip freeze > requirements.txt" @@ -102,10 +108,28 @@ function pipupall { pip list --outdated | awk 'NR > 2 { print $1 }' | ${=xargs} pip install --upgrade } -# Uninstalled all installed packages +# Uninstall all installed packages function pipunall { # non-GNU xargs does not support nor need `--no-run-if-empty` local xargs="xargs --no-run-if-empty" xargs --version 2>/dev/null | grep -q GNU || xargs="xargs" pip list --format freeze | cut -d= -f1 | ${=xargs} pip uninstall } + +# Install from GitHub repository +function pipig { + pip install "git+https://github.com/$1.git" +} +compdef _pip pipig + +# Install from GitHub branch +function pipigb { + pip install "git+https://github.com/$1.git@$2" +} +compdef _pip pipigb + +# Install from GitHub pull request +function pipigp { + pip install "git+https://github.com/$1.git@refs/pull/$2/head" +} +compdef _pip pipigp From c189e8b40c2a9ed15850d5bb5a68e6789be5fc70 Mon Sep 17 00:00:00 2001 From: Dan Wallis Date: Fri, 9 Dec 2022 18:10:04 +0000 Subject: [PATCH 110/672] feat(agnoster): add remote-tracking status to prompt (#7209) --- themes/agnoster.zsh-theme | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/themes/agnoster.zsh-theme b/themes/agnoster.zsh-theme index 5f4efe813..88854eccd 100644 --- a/themes/agnoster.zsh-theme +++ b/themes/agnoster.zsh-theme @@ -116,6 +116,17 @@ prompt_git() { prompt_segment green $CURRENT_FG fi + local ahead behind + ahead=$(git log --oneline @{upstream}.. 2>/dev/null) + behind=$(git log --oneline ..@{upstream} 2>/dev/null) + if [[ -n "$ahead" ]] && [[ -n "$behind" ]]; then + PL_BRANCH_CHAR=$'\u21c5' + elif [[ -n "$ahead" ]]; then + PL_BRANCH_CHAR=$'\u21b1' + elif [[ -n "$behind" ]]; then + PL_BRANCH_CHAR=$'\u21b0' + fi + if [[ -e "${repo_path}/BISECT_LOG" ]]; then mode=" " elif [[ -e "${repo_path}/MERGE_HEAD" ]]; then From 82c0db41bcfd3fd97d6170dcb7575f98e38fc68d Mon Sep 17 00:00:00 2001 From: Basil Sh Date: Sat, 10 Dec 2022 00:11:16 +0600 Subject: [PATCH 111/672] docs(term_tab): rewrite README in markdown (#11381) --- plugins/term_tab/README | 16 ---------------- plugins/term_tab/README.md | 16 ++++++++++++++++ 2 files changed, 16 insertions(+), 16 deletions(-) delete mode 100644 plugins/term_tab/README create mode 100644 plugins/term_tab/README.md diff --git a/plugins/term_tab/README b/plugins/term_tab/README deleted file mode 100644 index 316062e73..000000000 --- a/plugins/term_tab/README +++ /dev/null @@ -1,16 +0,0 @@ - -term_tab - 'cwd' for all open zsh sessions -****************************************** - -What it does: -************* -This plugin allows to complete the 'cwd' of other Zsh sessions. Sounds -complicated but is rather simple. E.g. if you have three zsh sessions open, in -each session you are in a different folder, you can hit Ctrl+v in one session -to show you the current working directory of the other open zsh sessions. - -How it works: -************* -* It uses 'pidof zsh' to determine all zsh PIDs -* It reads procfs to get the current working directory of this session -* Everything is fed into zsh's completion magic diff --git a/plugins/term_tab/README.md b/plugins/term_tab/README.md new file mode 100644 index 000000000..7548fe6a8 --- /dev/null +++ b/plugins/term_tab/README.md @@ -0,0 +1,16 @@ +# term_tab plugin + +term_tab - `cwd` for all open zsh sessions + +## What it does: + +This plugin allows to complete the `cwd` of other Zsh sessions. Sounds +complicated but is rather simple. E.g. if you have three zsh sessions open, in +each session you are in a different folder, you can hit `Ctrl+V` in one session +to show you the current working directory of the other open zsh sessions. + +## How it works: + +* It uses `pidof zsh` to determine all zsh PIDs +* It reads procfs to get the current working directory of this session +* Everything is fed into zsh's completion magic From 29cf199b5d84eb4897f2e0e421a344174568eb9f Mon Sep 17 00:00:00 2001 From: Richard Mitchell Date: Mon, 12 Dec 2022 03:18:29 -0500 Subject: [PATCH 112/672] docs(term_tab): plugin can only be used with linux and solaris (#11385) --- plugins/term_tab/README.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/plugins/term_tab/README.md b/plugins/term_tab/README.md index 7548fe6a8..59462a825 100644 --- a/plugins/term_tab/README.md +++ b/plugins/term_tab/README.md @@ -1,5 +1,7 @@ # term_tab plugin +This plugin only works for Solaris and linux. + term_tab - `cwd` for all open zsh sessions ## What it does: From 3705edf557922f286a5054523d6d7208e2ed6f5e Mon Sep 17 00:00:00 2001 From: kormosi <53222723+kormosi@users.noreply.github.com> Date: Thu, 15 Dec 2022 11:47:10 +0100 Subject: [PATCH 113/672] feat(docker): add `drs` alias (#11393) --- plugins/docker/README.md | 1 + plugins/docker/docker.plugin.zsh | 1 + 2 files changed, 2 insertions(+) diff --git a/plugins/docker/README.md b/plugins/docker/README.md index 040a168d6..512b5d17c 100644 --- a/plugins/docker/README.md +++ b/plugins/docker/README.md @@ -58,6 +58,7 @@ file**, but be aware of the side effects: | drm | `docker container rm` | Remove the specified container(s) | | drm! | `docker container rm -f` | Force the removal of a running container (uses SIGKILL) | | dst | `docker container start` | Start one or more stopped containers | +| drs | `docker container restart` | Restart one or more containers | dsta | `docker stop $(docker ps -q)` | Stop all running containers | | dstp | `docker container stop` | Stop one or more running containers | | dtop | `docker top` | Display the running processes of a container | diff --git a/plugins/docker/docker.plugin.zsh b/plugins/docker/docker.plugin.zsh index 737803651..8684a9785 100644 --- a/plugins/docker/docker.plugin.zsh +++ b/plugins/docker/docker.plugin.zsh @@ -22,6 +22,7 @@ alias drit='docker container run -it' alias drm='docker container rm' alias 'drm!'='docker container rm -f' alias dst='docker container start' +alias drs='docker container restart' alias dsta='docker stop $(docker ps -q)' alias dstp='docker container stop' alias dtop='docker top' From 13082bb159361d1c0807eb7e5577f4c670cb0f88 Mon Sep 17 00:00:00 2001 From: Till Backhaus Date: Fri, 16 Dec 2022 12:46:34 +0100 Subject: [PATCH 114/672] feat(watson): add completion (#10886) Co-authored-by: Carlo Sala --- plugins/watson/README.md | 9 +++++++++ plugins/watson/_watson | 34 ++++++++++++++++++++++++++++++++++ 2 files changed, 43 insertions(+) create mode 100644 plugins/watson/README.md create mode 100644 plugins/watson/_watson diff --git a/plugins/watson/README.md b/plugins/watson/README.md new file mode 100644 index 000000000..ef734ec63 --- /dev/null +++ b/plugins/watson/README.md @@ -0,0 +1,9 @@ +# Watson + +This plugin provides completion for [Watson](https://tailordev.github.io/Watson/). + +To use it add `watson` to the plugins array in your zshrc file. + +```zsh +plugins=(... watson) +``` diff --git a/plugins/watson/_watson b/plugins/watson/_watson new file mode 100644 index 000000000..0f599bd66 --- /dev/null +++ b/plugins/watson/_watson @@ -0,0 +1,34 @@ +#compdef watson + +_watson_completion() { + local -a completions + local -a completions_with_descriptions + local -a response + (( ! $+commands[watson] )) && return 1 + + response=("${(@f)$(env COMP_WORDS="${words[*]}" COMP_CWORD=$((CURRENT-1)) _WATSON_COMPLETE=zsh_complete watson)}") + + for type key descr in ${response}; do + if [[ "$type" == "plain" ]]; then + if [[ "$descr" == "_" ]]; then + completions+=("$key") + else + completions_with_descriptions+=("$key":"$descr") + fi + elif [[ "$type" == "dir" ]]; then + _path_files -/ + elif [[ "$type" == "file" ]]; then + _path_files -f + fi + done + + if [ -n "$completions_with_descriptions" ]; then + _describe -V unsorted completions_with_descriptions -U + fi + + if [ -n "$completions" ]; then + compadd -U -V unsorted -a completions + fi +} + +compdef _watson_completion watson; From 2bc42d223cfe3e21aef06648fb971bd9fb00828e Mon Sep 17 00:00:00 2001 From: Renjith Date: Sat, 17 Dec 2022 22:23:48 +0530 Subject: [PATCH 115/672] feat(docker-compose): add `dcupdb` alias (#10235) --- plugins/docker-compose/README.md | 39 ++++++++++--------- .../docker-compose/docker-compose.plugin.zsh | 1 + 2 files changed, 21 insertions(+), 19 deletions(-) diff --git a/plugins/docker-compose/README.md b/plugins/docker-compose/README.md index 13f3c2cea..bbcff2e0c 100644 --- a/plugins/docker-compose/README.md +++ b/plugins/docker-compose/README.md @@ -11,22 +11,23 @@ plugins=(... docker-compose) ## Aliases -| Alias | Command | Description | -|-----------|--------------------------------|------------------------------------------------------------------| -| dco | `docker-compose` | Docker-compose main command | -| dcb | `docker-compose build` | Build containers | -| dce | `docker-compose exec` | Execute command inside a container | -| dcps | `docker-compose ps` | List containers | -| dcrestart | `docker-compose restart` | Restart container | -| dcrm | `docker-compose rm` | Remove container | -| dcr | `docker-compose run` | Run a command in container | -| dcstop | `docker-compose stop` | Stop a container | -| dcup | `docker-compose up` | Build, (re)create, start, and attach to containers for a service | -| dcupb | `docker-compose up --build` | Same as `dcup`, but build images before starting containers | -| dcupd | `docker-compose up -d` | Same as `dcup`, but starts as daemon | -| dcdn | `docker-compose down` | Stop and remove containers | -| dcl | `docker-compose logs` | Show logs of container | -| dclf | `docker-compose logs -f` | Show logs and follow output | -| dcpull | `docker-compose pull` | Pull image of a service | -| dcstart | `docker-compose start` | Start a container | -| dck | `docker-compose kill` | Kills containers | +| Alias | Command | Description | +|-----------|--------------------------------|----------------------------------------------------------------------------------| +| dco | `docker-compose` | Docker-compose main command | +| dcb | `docker-compose build` | Build containers | +| dce | `docker-compose exec` | Execute command inside a container | +| dcps | `docker-compose ps` | List containers | +| dcrestart | `docker-compose restart` | Restart container | +| dcrm | `docker-compose rm` | Remove container | +| dcr | `docker-compose run` | Run a command in container | +| dcstop | `docker-compose stop` | Stop a container | +| dcup | `docker-compose up` | Build, (re)create, start, and attach to containers for a service | +| dcupb | `docker-compose up --build` | Same as `dcup`, but build images before starting containers | +| dcupd | `docker-compose up -d` | Same as `dcup`, but starts as daemon | +| dcupdb | `docker-compose up -d --build` | Same as `dcup`, but build images before starting containers and starts as daemon | +| dcdn | `docker-compose down` | Stop and remove containers | +| dcl | `docker-compose logs` | Show logs of container | +| dclf | `docker-compose logs -f` | Show logs and follow output | +| dcpull | `docker-compose pull` | Pull image of a service | +| dcstart | `docker-compose start` | Start a container | +| dck | `docker-compose kill` | Kills containers | diff --git a/plugins/docker-compose/docker-compose.plugin.zsh b/plugins/docker-compose/docker-compose.plugin.zsh index b8a4b067d..7a8bf4a03 100644 --- a/plugins/docker-compose/docker-compose.plugin.zsh +++ b/plugins/docker-compose/docker-compose.plugin.zsh @@ -12,6 +12,7 @@ alias dcstop="$dccmd stop" alias dcup="$dccmd up" alias dcupb="$dccmd up --build" alias dcupd="$dccmd up -d" +alias dcupdb="$dccmd up -d --build" alias dcdn="$dccmd down" alias dcl="$dccmd logs" alias dclf="$dccmd logs -f" From 9c2d1af8afa02b5439e8ccc81a160e62e1e59617 Mon Sep 17 00:00:00 2001 From: Andrew Starr-Bochicchio Date: Tue, 20 Dec 2022 14:56:30 -0500 Subject: [PATCH 116/672] fix(doctl): actually load completions (#11402) --- plugins/doctl/doctl.plugin.zsh | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) diff --git a/plugins/doctl/doctl.plugin.zsh b/plugins/doctl/doctl.plugin.zsh index d23ed085c..7b3a384a9 100644 --- a/plugins/doctl/doctl.plugin.zsh +++ b/plugins/doctl/doctl.plugin.zsh @@ -4,6 +4,14 @@ # # Author: https://github.com/HalisCz -if [ $commands[doctl] ]; then - source <(doctl completion zsh) +if (( ! $+commands[doctl] )); then + return fi + +if [[ ! -f "$ZSH_CACHE_DIR/completions/_doctl" ]]; then + typeset -g -A _comps + autoload -Uz _doctl + _comps[doctl]=_doctl +fi + +doctl completion zsh >| "$ZSH_CACHE_DIR/completions/_doctl" &| From a3c579bf27b34942d4c6ad64e7cfd75788b05ea3 Mon Sep 17 00:00:00 2001 From: Nur Rony <2513341+nurrony@users.noreply.github.com> Date: Mon, 26 Dec 2022 14:41:30 +0600 Subject: [PATCH 117/672] feat(maven): add `quarkus` command support (#11405) --- plugins/mvn/mvn.plugin.zsh | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/plugins/mvn/mvn.plugin.zsh b/plugins/mvn/mvn.plugin.zsh index 151fbd2a6..da51f74df 100644 --- a/plugins/mvn/mvn.plugin.zsh +++ b/plugins/mvn/mvn.plugin.zsh @@ -196,7 +196,7 @@ function listMavenCompletions { # spring-boot spring-boot:run spring-boot:repackage # quarkus - quarkus:dev quarkus:list-extensions quarkus:add-extension quarkus:add-extensions quarkus:generate-config quarkus:help + quarkus:dev quarkus:list-extensions quarkus:add-extension quarkus:add-extensions quarkus:remove-extension quarkus:remove-extensions quarkus:generate-config quarkus:help # exec exec:exec exec:java # versions @@ -287,7 +287,7 @@ function listMavenCompletions { vaadin:prepare-frontend vaadin:build-frontend vaadin:clean-frontend vaadin:dance # options - "-Dmaven.test.skip=true" -DskipTests -DskipITs -Dmaven.surefire.debug -DenableCiProfile "-Dpmd.skip=true" "-Dcheckstyle.skip=true" "-Dtycho.mode=maven" "-Dmaven.test.failure.ignore=true" "-DgroupId=" "-DartifactId=" "-Dversion=" "-Dpackaging=jar" "-Dfile=" + "-Dmaven.test.skip=true" -DskipTests -DskipITs -Dmaven.surefire.debug -DenableCiProfile "-Dpmd.skip=true" "-Dcheckstyle.skip=true" "-Dtycho.mode=maven" "-Dmaven.test.failure.ignore=true" "-DgroupId=" "-DartifactId=" "-Dversion=" "-Dpackaging=jar" "-Dfile=" "-Dextensions=" # arguments -am --also-make From 55e4e6c73b2bb067974c6d49ba9da2ba1ee3295c Mon Sep 17 00:00:00 2001 From: "the.brain.w" Date: Fri, 30 Dec 2022 11:52:18 +0100 Subject: [PATCH 118/672] feat(systemd): add support for user units in prompt (#11417) --- plugins/systemd/systemd.plugin.zsh | 2 ++ 1 file changed, 2 insertions(+) diff --git a/plugins/systemd/systemd.plugin.zsh b/plugins/systemd/systemd.plugin.zsh index 7afd2be58..1270bea0e 100644 --- a/plugins/systemd/systemd.plugin.zsh +++ b/plugins/systemd/systemd.plugin.zsh @@ -107,6 +107,8 @@ function systemd_prompt_info { if systemctl is-active "$unit" &>/dev/null; then echo -n "$ZSH_THEME_SYSTEMD_PROMPT_ACTIVE" + elif systemctl --user is-active "$unit" &>/dev/null; then + echo -n "$ZSH_THEME_SYSTEMD_PROMPT_ACTIVE" else echo -n "$ZSH_THEME_SYSTEMD_PROMPT_NOTACTIVE" fi From 6710fd588aec2c0cb90e70c02db0837c3646af99 Mon Sep 17 00:00:00 2001 From: Ennio Mara Date: Mon, 2 Jan 2023 21:32:45 +0100 Subject: [PATCH 119/672] fix(autojump): fix autojump sourcing in nix (-darwin) (#11422) * fix(autojump): fix autojump sourcing in nix (-darwin) This plugin expects to source an sh/zsh file which sets up autojump, but that is not done when running Nix on macos using nix-darwin. Looking at the old value (/etc/profiles/per-user/$USER/bin/autojump), it points to a binary file instead of the setup script. * Use zsh file instead of sh --- plugins/autojump/autojump.plugin.zsh | 26 +++++++++++++------------- 1 file changed, 13 insertions(+), 13 deletions(-) diff --git a/plugins/autojump/autojump.plugin.zsh b/plugins/autojump/autojump.plugin.zsh index e11f231b6..9bc190bdc 100644 --- a/plugins/autojump/autojump.plugin.zsh +++ b/plugins/autojump/autojump.plugin.zsh @@ -1,18 +1,18 @@ declare -a autojump_paths autojump_paths=( - $HOME/.autojump/etc/profile.d/autojump.zsh # manual installation - $HOME/.autojump/share/autojump/autojump.zsh # manual installation - $HOME/.nix-profile/etc/profile.d/autojump.sh # NixOS installation - /run/current-system/sw/share/autojump/autojump.zsh # NixOS installation - /usr/share/autojump/autojump.zsh # Debian and Ubuntu package - /etc/profile.d/autojump.zsh # manual installation - /etc/profile.d/autojump.sh # Gentoo installation - /usr/local/share/autojump/autojump.zsh # FreeBSD installation - /usr/pkg/share/autojump/autojump.zsh # NetBSD installation - /opt/local/etc/profile.d/autojump.sh # macOS with MacPorts - /usr/local/etc/profile.d/autojump.sh # macOS with Homebrew (default) - /opt/homebrew/etc/profile.d/autojump.sh # macOS with Homebrew (default on M1 macs) - /etc/profiles/per-user/$USER/bin/autojump # macOS Nix, Home Manager and flakes + $HOME/.autojump/etc/profile.d/autojump.zsh # manual installation + $HOME/.autojump/share/autojump/autojump.zsh # manual installation + $HOME/.nix-profile/etc/profile.d/autojump.sh # NixOS installation + /run/current-system/sw/share/autojump/autojump.zsh # NixOS installation + /usr/share/autojump/autojump.zsh # Debian and Ubuntu package + /etc/profile.d/autojump.zsh # manual installation + /etc/profile.d/autojump.sh # Gentoo installation + /usr/local/share/autojump/autojump.zsh # FreeBSD installation + /usr/pkg/share/autojump/autojump.zsh # NetBSD installation + /opt/local/etc/profile.d/autojump.sh # macOS with MacPorts + /usr/local/etc/profile.d/autojump.sh # macOS with Homebrew (default) + /opt/homebrew/etc/profile.d/autojump.sh # macOS with Homebrew (default on M1 macs) + /etc/profiles/per-user/$USER/etc/profile.d/autojump.zsh # macOS Nix, Home Manager and flakes ) for file in $autojump_paths; do From 36f1055eeea0f455676381539fcb3e6e0a4da731 Mon Sep 17 00:00:00 2001 From: Ennio Mara Date: Mon, 2 Jan 2023 21:55:47 +0100 Subject: [PATCH 120/672] fix(autojump): use sh file instead of zsh in NixOS (#11425) --- plugins/autojump/autojump.plugin.zsh | 26 +++++++++++++------------- 1 file changed, 13 insertions(+), 13 deletions(-) diff --git a/plugins/autojump/autojump.plugin.zsh b/plugins/autojump/autojump.plugin.zsh index 9bc190bdc..1b868ee8d 100644 --- a/plugins/autojump/autojump.plugin.zsh +++ b/plugins/autojump/autojump.plugin.zsh @@ -1,18 +1,18 @@ declare -a autojump_paths autojump_paths=( - $HOME/.autojump/etc/profile.d/autojump.zsh # manual installation - $HOME/.autojump/share/autojump/autojump.zsh # manual installation - $HOME/.nix-profile/etc/profile.d/autojump.sh # NixOS installation - /run/current-system/sw/share/autojump/autojump.zsh # NixOS installation - /usr/share/autojump/autojump.zsh # Debian and Ubuntu package - /etc/profile.d/autojump.zsh # manual installation - /etc/profile.d/autojump.sh # Gentoo installation - /usr/local/share/autojump/autojump.zsh # FreeBSD installation - /usr/pkg/share/autojump/autojump.zsh # NetBSD installation - /opt/local/etc/profile.d/autojump.sh # macOS with MacPorts - /usr/local/etc/profile.d/autojump.sh # macOS with Homebrew (default) - /opt/homebrew/etc/profile.d/autojump.sh # macOS with Homebrew (default on M1 macs) - /etc/profiles/per-user/$USER/etc/profile.d/autojump.zsh # macOS Nix, Home Manager and flakes + $HOME/.autojump/etc/profile.d/autojump.zsh # manual installation + $HOME/.autojump/share/autojump/autojump.zsh # manual installation + $HOME/.nix-profile/etc/profile.d/autojump.sh # NixOS installation + /run/current-system/sw/share/autojump/autojump.zsh # NixOS installation + /usr/share/autojump/autojump.zsh # Debian and Ubuntu package + /etc/profile.d/autojump.zsh # manual installation + /etc/profile.d/autojump.sh # Gentoo installation + /usr/local/share/autojump/autojump.zsh # FreeBSD installation + /usr/pkg/share/autojump/autojump.zsh # NetBSD installation + /opt/local/etc/profile.d/autojump.sh # macOS with MacPorts + /usr/local/etc/profile.d/autojump.sh # macOS with Homebrew (default) + /opt/homebrew/etc/profile.d/autojump.sh # macOS with Homebrew (default on M1 macs) + /etc/profiles/per-user/$USER/etc/profile.d/autojump.sh # macOS Nix, Home Manager and flakes ) for file in $autojump_paths; do From 00c37b6991895aac0398a24d7d8b78cda63dec05 Mon Sep 17 00:00:00 2001 From: Alastair Rankine Date: Tue, 3 Jan 2023 03:44:53 -0500 Subject: [PATCH 121/672] feat(pipenv): standarize completion generation (#11424) Co-authored-by: Carlo Sala Closes #11423 --- plugins/pipenv/pipenv.plugin.zsh | 18 +++++++++++++----- 1 file changed, 13 insertions(+), 5 deletions(-) diff --git a/plugins/pipenv/pipenv.plugin.zsh b/plugins/pipenv/pipenv.plugin.zsh index 4be61a920..244bd6b7c 100644 --- a/plugins/pipenv/pipenv.plugin.zsh +++ b/plugins/pipenv/pipenv.plugin.zsh @@ -1,8 +1,16 @@ -# Pipenv completion -_pipenv() { - eval $(env COMMANDLINE="${words[1,$CURRENT]}" _PIPENV_COMPLETE=complete-zsh pipenv) -} -compdef _pipenv pipenv +if (( ! $+commands[pipenv] )); then + return +fi + +# If the completion file doesn't exist yet, we need to autoload it and +# bind it to `pipenv`. Otherwise, compinit will have already done that. +if [[ ! -f "$ZSH_CACHE_DIR/completions/_pipenv" ]]; then + typeset -g -A _comps + autoload -Uz _pipenv + _comps[pipenv]=_pipenv +fi + +_PIPENV_COMPLETE=zsh_source pipenv >| "$ZSH_CACHE_DIR/completions/_pipenv" &| # Automatic pipenv shell activation/deactivation _togglePipenvShell() { From 3fca9c8933afc5c118a73cedb171a3c7b8e92730 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Tue, 3 Jan 2023 10:02:03 +0100 Subject: [PATCH 122/672] fix(upgrade): check if git is available and working macOS seems to break dev tools when updating the system. This should prevent the previous issues. See #11309 Closes #11420 --- tools/check_for_upgrade.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tools/check_for_upgrade.sh b/tools/check_for_upgrade.sh index cc527e72d..3a6bb6555 100644 --- a/tools/check_for_upgrade.sh +++ b/tools/check_for_upgrade.sh @@ -24,7 +24,7 @@ zstyle -s ':omz:update' mode update_mode || { # - git is unavailable on the system. if [[ "$update_mode" = disabled ]] \ || [[ ! -w "$ZSH" || ! -O "$ZSH" ]] \ - || ! command -v git &>/dev/null; then + || ! command git --version 2>&1 >/dev/null; then unset update_mode return fi From 280c99dae691e468d12c94f64c97964b88cdad4e Mon Sep 17 00:00:00 2001 From: ZigZagT Date: Thu, 5 Jan 2023 15:03:12 -0800 Subject: [PATCH 123/672] feat(git): accept `default` and `mainline` as main branches (#11431) --- plugins/git/git.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/git/git.plugin.zsh b/plugins/git/git.plugin.zsh index 69745730c..76e58a121 100644 --- a/plugins/git/git.plugin.zsh +++ b/plugins/git/git.plugin.zsh @@ -31,7 +31,7 @@ function work_in_progress() { function git_main_branch() { command git rev-parse --git-dir &>/dev/null || return local ref - for ref in refs/{heads,remotes/{origin,upstream}}/{main,trunk}; do + for ref in refs/{heads,remotes/{origin,upstream}}/{main,trunk,mainline,default}; do if command git show-ref -q --verify $ref; then echo ${ref:t} return From 71ca38652b039c41ef9b415d0fc05926c37a0bfb Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Fri, 6 Jan 2023 00:14:33 +0100 Subject: [PATCH 124/672] fix(git-extras): type properly `__gitex_command_successful` calls Closes #11430 --- plugins/git-extras/git-extras.plugin.zsh | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/plugins/git-extras/git-extras.plugin.zsh b/plugins/git-extras/git-extras.plugin.zsh index b86d7c5b6..6b96e12af 100644 --- a/plugins/git-extras/git-extras.plugin.zsh +++ b/plugins/git-extras/git-extras.plugin.zsh @@ -51,7 +51,7 @@ __gitex_remote_names() { local expl declare -a remote_names remote_names=(${(f)"$(_call_program remotes git remote 2>/dev/null)"}) - __git_command_successful || return + __gitex_command_successful || return _wanted remote-names expl remote-name compadd $* - $remote_names } @@ -59,7 +59,7 @@ __gitex_tag_names() { local expl declare -a tag_names tag_names=(${${(f)"$(_call_program tags git for-each-ref --format='"%(refname)"' refs/tags 2>/dev/null)"}#refs/tags/}) - __git_command_successful || return + __gitex_command_successful || return _wanted tag-names expl tag-name compadd $* - $tag_names } @@ -68,7 +68,7 @@ __gitex_branch_names() { local expl declare -a branch_names branch_names=(${${(f)"$(_call_program branchrefs git for-each-ref --format='"%(refname)"' refs/heads 2>/dev/null)"}#refs/heads/}) - __git_command_successful || return + __gitex_command_successful || return _wanted branch-names expl branch-name compadd $* - $branch_names } @@ -76,7 +76,7 @@ __gitex_specific_branch_names() { local expl declare -a branch_names branch_names=(${${(f)"$(_call_program branchrefs git for-each-ref --format='"%(refname)"' refs/heads/"$1" 2>/dev/null)"}#refs/heads/$1/}) - __git_command_successful || return + __gitex_command_successful || return _wanted branch-names expl branch-name compadd - $branch_names } @@ -100,7 +100,7 @@ __gitex_submodule_names() { local expl declare -a submodule_names submodule_names=(${(f)"$(_call_program branchrefs git submodule status | awk '{print $2}')"}) # ' - __git_command_successful || return + __gitex_command_successful || return _wanted submodule-names expl submodule-name compadd $* - $submodule_names } @@ -109,7 +109,7 @@ __gitex_author_names() { local expl declare -a author_names author_names=(${(f)"$(_call_program branchrefs git log --format='%aN' | sort -u)"}) - __git_command_successful || return + __gitex_command_successful || return _wanted author-names expl author-name compadd $* - $author_names } From 69dfd7758033b3e771dcd184c1b143d166a85481 Mon Sep 17 00:00:00 2001 From: Maksym Date: Fri, 6 Jan 2023 14:39:45 +0000 Subject: [PATCH 125/672] chore: remove maksyms as maintainer of aws plugin (#11432) I'm afraid I no longer use `ohmyzsh` or even `zsh` in favour of `fish`. Hence, it doesn't make sense for me to continue being the code owner for the plugin. Good luck with an amazing tool! --- .github/CODEOWNERS | 1 - 1 file changed, 1 deletion(-) diff --git a/.github/CODEOWNERS b/.github/CODEOWNERS index c6b3e8ce9..6668cd7ce 100644 --- a/.github/CODEOWNERS +++ b/.github/CODEOWNERS @@ -1,6 +1,5 @@ # Plugin owners plugins/archlinux/ @ratijas -plugins/aws/ @maksyms plugins/genpass/ @atoponce plugins/git-lfs/ @hellovietduc plugins/gitfast/ @felipec From 08c3ce8882ea0bbbfb0a734f1f8870a72ba21f8a Mon Sep 17 00:00:00 2001 From: Lee Stetson Date: Mon, 9 Jan 2023 13:59:02 -0500 Subject: [PATCH 126/672] feat(bridgetown): Add plugin for Ruby bridgetown site generator (#10496) --- plugins/bridgetown/README.md | 26 ++++++++++++++++++++++++ plugins/bridgetown/bridgetown.plugin.zsh | 12 +++++++++++ 2 files changed, 38 insertions(+) create mode 100644 plugins/bridgetown/README.md create mode 100644 plugins/bridgetown/bridgetown.plugin.zsh diff --git a/plugins/bridgetown/README.md b/plugins/bridgetown/README.md new file mode 100644 index 000000000..0a41814ee --- /dev/null +++ b/plugins/bridgetown/README.md @@ -0,0 +1,26 @@ +# Bridgetown plugin + +This plugin adds some aliases and autocompletion for common [Bridgetown](https://bridgetownrb.com/) commands. + +To use it, add `bridgetown` to the plugins array in your zshrc file: + +```zsh +plugins=(... bridgetown) +``` + +## Aliases + +| Alias | Command | +|-------|----------------------------| +| br | `bridgetown` | +| bra | `bin/bridgetown apply` | +| brb | `bin/bridgetown build` | +| brc | `bin/bridgetown console` | +| brclean | `bin/bridgetown clean` | +| brd | `bin/bridgetown deploy` | +| brdoc | `bin/bridgetown doctor` | +| brh | `bin/bridgetown help` | +| brn | `bridgetown new` | +| brp | `bridgetown plugins` | +| brpl | `bridgetown plugins list` | +| brs | `bin/bridgetown start` | diff --git a/plugins/bridgetown/bridgetown.plugin.zsh b/plugins/bridgetown/bridgetown.plugin.zsh new file mode 100644 index 000000000..502e9dfe0 --- /dev/null +++ b/plugins/bridgetown/bridgetown.plugin.zsh @@ -0,0 +1,12 @@ +alias br='bridgetown' +alias bra='bin/bridgetown apply' +alias brb='bin/bridgetown build' +alias brc='bin/bridgetown console' +alias brclean='bin/bridgetown clean' +alias brd='bin/bridgetown deploy' +alias brdoc='bin/bridgetown doctor' +alias brh='bin/bridgetown help' +alias brn='bridgetown new' +alias brp='bridgetown plugins' +alias brpl='bridgetown plugins list' +alias brs='bin/bridgetown start' From 746424f1614a70a8c318979f5cf348babe603d54 Mon Sep 17 00:00:00 2001 From: Sung kyung Park <44727001+sungkpark@users.noreply.github.com> Date: Mon, 9 Jan 2023 20:02:44 +0100 Subject: [PATCH 127/672] feat(homebrew): Adding new alias for brew uninstall --zap as buz closes #10329 (#10331) * Adding new alias for brew uninstall --zap as buz * Closes #10329 * add buz * closes #10329 * Fix typo * Closes ohmyzsh#10329 * Closes ohmyzsh#10329 Co-authored-by: Sung Co-authored-by: Robby Russell --- plugins/brew/README.md | 3 +++ plugins/brew/brew.plugin.zsh | 2 ++ 2 files changed, 5 insertions(+) diff --git a/plugins/brew/README.md b/plugins/brew/README.md index 9ce2c5bb0..cfaedccd8 100644 --- a/plugins/brew/README.md +++ b/plugins/brew/README.md @@ -21,6 +21,7 @@ defined for convenience. | -------- | ------------------------------------- | ------------------------------------------------------------------- | | `bcubc` | `brew upgrade --cask && brew cleanup` | Update outdated casks, then run cleanup. | | `bcubo` | `brew update && brew outdated --cask` | Update Homebrew data, then list outdated casks. | +| `bcubc` | `brew upgrade --cask && brew cleanup` | Update outdated casks, then run cleanup. | | `brewp` | `brew pin` | Pin a specified formula so that it's not upgraded. | | `brews` | `brew list -1` | List installed formulae or the installed files for a given formula. | | `brewsp` | `brew list --pinned` | List pinned formulae, or show the version of a given formula. | @@ -28,6 +29,8 @@ defined for convenience. | `bubo` | `brew update && brew outdated` | Update Homebrew data, then list outdated formulae and casks. | | `bubu` | `bubo && bubc` | Do the last two operations above. | | `buf` | `brew upgrade --formula` | Upgrade only formulas (not casks). | +| `buz` | `brew uninstall --zap` | Remove all files associated with a cask. | + ## Completion diff --git a/plugins/brew/brew.plugin.zsh b/plugins/brew/brew.plugin.zsh index ea8900823..808c50907 100644 --- a/plugins/brew/brew.plugin.zsh +++ b/plugins/brew/brew.plugin.zsh @@ -27,12 +27,14 @@ fi alias bcubc='brew upgrade --cask && brew cleanup' alias bcubo='brew update && brew outdated --cask' +alias bcubc='brew upgrade --cask && brew cleanup' alias brewp='brew pin' alias brewsp='brew list --pinned' alias bubc='brew upgrade && brew cleanup' alias bubo='brew update && brew outdated' alias bubu='bubo && bubc' alias buf='brew upgrade --formula' +alias buz='brew uninstall --zap' function brews() { local formulae="$(brew leaves | xargs brew deps --installed --for-each)" From fc86a16255a92fad36882666e093750c1aba4b21 Mon Sep 17 00:00:00 2001 From: "F. Javier Campa L" Date: Mon, 9 Jan 2023 20:07:41 +0100 Subject: [PATCH 128/672] feat(homebrew): Brew greedy upgrade aliases (#9623) * Added 'greedy' brew upgrade aliases' * Added a description of the new 'greedy' upgrade aliases Co-authored-by: Robby Russell --- plugins/brew/README.md | 2 +- plugins/brew/brew.plugin.zsh | 2 ++ 2 files changed, 3 insertions(+), 1 deletion(-) diff --git a/plugins/brew/README.md b/plugins/brew/README.md index cfaedccd8..4a42b3d74 100644 --- a/plugins/brew/README.md +++ b/plugins/brew/README.md @@ -26,12 +26,12 @@ defined for convenience. | `brews` | `brew list -1` | List installed formulae or the installed files for a given formula. | | `brewsp` | `brew list --pinned` | List pinned formulae, or show the version of a given formula. | | `bubc` | `brew upgrade && brew cleanup` | Upgrade outdated formulae and casks, then run cleanup. | +| `bugbc` | `brew upgrade --greedy && brew cleanup` | Upgrade outdated formulae and casks (greedy), then run cleanup. | | `bubo` | `brew update && brew outdated` | Update Homebrew data, then list outdated formulae and casks. | | `bubu` | `bubo && bubc` | Do the last two operations above. | | `buf` | `brew upgrade --formula` | Upgrade only formulas (not casks). | | `buz` | `brew uninstall --zap` | Remove all files associated with a cask. | - ## Completion With the release of Homebrew 1.0, they decided to bundle the zsh completion as part of the diff --git a/plugins/brew/brew.plugin.zsh b/plugins/brew/brew.plugin.zsh index 808c50907..8275454a4 100644 --- a/plugins/brew/brew.plugin.zsh +++ b/plugins/brew/brew.plugin.zsh @@ -31,8 +31,10 @@ alias bcubc='brew upgrade --cask && brew cleanup' alias brewp='brew pin' alias brewsp='brew list --pinned' alias bubc='brew upgrade && brew cleanup' +alias bugbc='brew upgrade --greedy && brew cleanup' alias bubo='brew update && brew outdated' alias bubu='bubo && bubc' +alias bubug='bubo && bugbc' alias buf='brew upgrade --formula' alias buz='brew uninstall --zap' From 6eefaf56afae27739c31e21be477688634a6b5fa Mon Sep 17 00:00:00 2001 From: Kenneth Tan Date: Tue, 10 Jan 2023 03:14:35 +0800 Subject: [PATCH 129/672] fix(brew): renamed buf alias to bfu (#11195) * chore(plugins/brew): rename buf alias to bfu The alias `buf` collides with the protobuf tooling (buf)[https://buf.build/]. This commit renames the `buf` alias to `bfu` (`brew upgrade --formula`) so its semantically more aligned with `bcu` (`brew upgrade --cask`) as well as to avoid command collision especially with existing scripts that refers to `buf` as the tool and not the alias. * chore(brew): updated README.md Updated README to reflect renamed alias (`buf` -> `bfu`) Co-authored-by: Robby Russell From bc36043e8f004e130df7dc2f4708e2313e400bff Mon Sep 17 00:00:00 2001 From: A2n Date: Mon, 9 Jan 2023 20:23:31 +0100 Subject: [PATCH 130/672] feature(heroku-cli): Add heroku cli alias (#9073) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * ✨ feat(alias): import alias from local repo * 📝 feat(alias): import doc form local repo --- plugins/heroku-alias/README.md | 127 +++++++++++++++++++++++++++ plugins/heroku-alias/heroku.alias.sh | 92 +++++++++++++++++++ 2 files changed, 219 insertions(+) create mode 100644 plugins/heroku-alias/README.md create mode 100644 plugins/heroku-alias/heroku.alias.sh diff --git a/plugins/heroku-alias/README.md b/plugins/heroku-alias/README.md new file mode 100644 index 000000000..4b7b953fd --- /dev/null +++ b/plugins/heroku-alias/README.md @@ -0,0 +1,127 @@ +# heroku-alias +🧬 Full alias for heroku cli + +|🚀 last maj|📡 source| +|---|---| +|02/06/2020|[heroku cli doc](https://devcenter.heroku.com/articles/heroku-cli-commands)| + +# Alias list + +## general +| Alias | Command | +| ------------- | ------------- | +| h | heroku | +| hauto | heroku autocomplete $(echo $SHELL) | +| hl | heroku local | + +## config +| Alias | Command | +| ------------- | ------------- | +| hc | heroku config | +| hca | heroku config -a | +| hcr | heroku config -r | +| hcs | heroku config:set | +| hcu | heroku config:unset | +| hcfile | function hcfile bellow | + +```sh +hcfile() { + echo " Which platform [-r/a name] ? " + read platform + echo " Which file ? " + read file + while read line; + do heroku config:set "$platform" "$line"; + done < "$file" +} +``` + +## apps and favorites +| Alias | Command | +| ------------- | ------------- | +| ha | heroku apps | +| hpop | heroku create | +| hkill | heroku apps:destroy | +| hlog | heroku apps:errors | +| hfav | heroku apps:favorites | +| hfava | heroku apps:favorites:add | +| hfavr | heroku apps:favorites:remove | +| hai | heroku apps:info | +| hair | heroku apps:info -r | +| haia | heroku apps:info -a | + +# auth +| Alias | Command | +| ------------- | ------------- | +| h2fa | heroku auth:2fa | +| h2far | heroku auth:2fa:disable | + +# access +| Alias | Command | +| ------------- | ------------- | +| hac | heroku access | +| hacr | heroku access -r | +| haca | heroku access -a | +| hadd | heroku access:add | +| hdel | heroku access:remove | +| hup | heroku access:update | + +## addons +| Alias | Command | +| ------------- | ------------- | +| hads | heroku addons -A | +| hada | heroku addons -a | +| hadr | heroku addons -r | +| hadat | heroku addons:attach | +| hadc | heroku addons:create | +| hadel | heroku addons:destroy | +| hadde | heroku addons:detach | +| hadoc | heroku addons:docs | + +## login +| Alias | Command | +| ------------- | ------------- | +| hin | heroku login | +| hout | heroku logout | +| hi | heroku login -i | +| hwho | heroku auth:whoami | + +## authorizations +| Alias | Command | +| ------------- | ------------- | +| hth | heroku authorizations | +| hthadd | heroku authorizations:create | +| hthif | heroku authorizations:info | +| hthdel | heroku authorizations:revoke | +| hthrot | heroku authorizations:rotate | +| hthup | heroku authorizations:update | + +## plugins +| Alias | Command | +| ------------- | ------------- | +| hp | heroku plugins | + +# log +| Alias | Command | +| ------------- | ------------- | +|hg | heroku logs| +| hgt | heroku log tail | + +# database +| Alias | Command | +| ------------- | ------------- | +| hpg | heroku pg | +| hpsql | heroku pg:psql | +| hpb | heroku pg:backups | +| hpbc | heroku pg:backups:capture | +| hpbd | heroku pg:backups:download | +| hpbr | heroku pg:backups:restore | + +# certs +| Alias | Command | +| ------------- | ------------- | +| hssl | heroku certs | +| hssli | heroku certs:info | +| hssla | heroku certs:add | +| hsslu | heroku certs:update | +| hsslr | heroku certs:remove | diff --git a/plugins/heroku-alias/heroku.alias.sh b/plugins/heroku-alias/heroku.alias.sh new file mode 100644 index 000000000..7daf715b5 --- /dev/null +++ b/plugins/heroku-alias/heroku.alias.sh @@ -0,0 +1,92 @@ +# general +alias h='heroku' +alias hauto='heroku autocomplete $(echo $SHELL)' +alias hl='heroku local' + +# log +alias hg='heroku logs' +alias hgt='heroku log tail' + +# database +alias hpg='heroku pg' +alias hpsql='heroku pg:psql' +alias hpb='heroku pg:backups' +alias hpbc='heroku pg:backups:capture' +alias hpbd='heroku pg:backups:download' +alias hpbr='heroku pg:backups:restore' + +# config +alias hc='heroku config' +alias hca='heroku config -a' +alias hcr='heroku config -r' +alias hcs='heroku config:set' +alias hcu='heroku config:unset' + +# this function allow to load multi env set in a file +hcfile() { + echo 'Which platform [-r/a name] ?' + read platform + echo 'Which file ?' + read file + while read line; + do heroku config:set "$platform" "$line"; + done < "$file" +} + +# apps and favorites +alias ha='heroku apps' +alias hpop='heroku create' +alias hkill='heroku apps:destroy' +alias hlog='heroku apps:errors' +alias hfav='heroku apps:favorites' +alias hfava='heroku apps:favorites:add' +alias hfavr='heroku apps:favorites:remove' +alias hai='heroku apps:info' +alias hair='heroku apps:info -r' +alias haia='heroku apps:info -a' + +# auth +alias h2fa='heroku auth:2fa' +alias h2far='heroku auth:2fa:disable' + +# access +alias hac='heroku access' +alias hacr='heroku access -r' +alias haca='heroku access -a' +alias hadd='heroku access:add' +alias hdel='heroku access:remove' +alias hup='heroku access:update' + +# addons +alias hads='heroku addons -A' +alias hada='heroku addons -a' +alias hadr='heroku addons -r' +alias hadat='heroku addons:attach' +alias hadc='heroku addons:create' +alias hadel='heroku addons:destroy' +alias hadde='heroku addons:detach' +alias hadoc='heroku addons:docs' + +# login +alias hin='heroku login' +alias hout='heroku logout' +alias hi='heroku login -i' +alias hwho='heroku auth:whoami' + +# authorizations +alias hth='heroku authorizations' +alias hthadd='heroku authorizations:create' +alias hthif='heroku authorizations:info' +alias hthdel='heroku authorizations:revoke' +alias hthrot='heroku authorizations:rotate' +alias hthup='heroku authorizations:update' + +# plugins +alias hp='heroku plugins' + +# cert +alias hssl='heroku certs' +alias hssli='heroku certs:info' +alias hssla='heroku certs:add' +alias hsslu='heroku certs:update' +alias hsslr='heroku certs:remove' From 9f31951019401449e057a236886d133f58c5cc64 Mon Sep 17 00:00:00 2001 From: Alex Date: Mon, 9 Jan 2023 13:30:08 -0600 Subject: [PATCH 131/672] fix(jira): Make prefix check on "jira branch" command case-insensitive (#8799) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * Make prefix check on "jira branch" command case-insensitive * Update plugins/jira/jira.plugin.zsh Co-authored-by: Marc Cornellà * Fixing tabs to spaces Co-authored-by: Robby Russell Co-authored-by: Marc Cornellà --- plugins/jira/README.md | 5 +++++ plugins/jira/jira.plugin.zsh | 2 +- 2 files changed, 6 insertions(+), 1 deletion(-) diff --git a/plugins/jira/README.md b/plugins/jira/README.md index a5633af77..f8751aaa2 100644 --- a/plugins/jira/README.md +++ b/plugins/jira/README.md @@ -27,6 +27,11 @@ jira branch # opens an existing issue matching the current branch name # The branch name may have prefixes ending in "/": "feature/MP-1234", # and also suffixes starting with "_": "MP-1234_fix_dashboard" # In both these cases, the issue opened will be "MP-1234" + # This is also checks if the prefix is in the name, and adds it if not, so: + # "MP-1234" opens the issue "MP-1234", + # "mp-1234" opens the issue "mp-1234", + # and "1234" opens the issue "MP-1234". +# NOTE: since jira is case insensitive, the first two examples open the same issue jira ABC-123 # opens an existing issue jira ABC-123 m # opens an existing issue for adding a comment ``` diff --git a/plugins/jira/jira.plugin.zsh b/plugins/jira/jira.plugin.zsh index 22807e0ae..37d7b6a27 100644 --- a/plugins/jira/jira.plugin.zsh +++ b/plugins/jira/jira.plugin.zsh @@ -75,7 +75,7 @@ function jira() { # Strip suffixes starting with _ issue_arg=(${(s:_:)issue_arg}) issue_arg=${issue_arg[1]} - if [[ "$issue_arg" = ${jira_prefix}* ]]; then + if [[ "${issue_arg:l}" = ${jira_prefix:l}* ]]; then issue="${issue_arg}" else issue="${jira_prefix}${issue_arg}" From fc722807f815bd170849f92d215ce2afa62e55b6 Mon Sep 17 00:00:00 2001 From: August Feng <46177585+augustfengd@users.noreply.github.com> Date: Mon, 9 Jan 2023 14:43:42 -0500 Subject: [PATCH 132/672] refactor(jira)!: rename myissues to mine and add completion (#10931) --- plugins/jira/README.md | 2 +- plugins/jira/_jira | 1 + plugins/jira/jira.plugin.zsh | 2 +- 3 files changed, 3 insertions(+), 2 deletions(-) diff --git a/plugins/jira/README.md b/plugins/jira/README.md index f8751aaa2..a7cfe6d9e 100644 --- a/plugins/jira/README.md +++ b/plugins/jira/README.md @@ -18,11 +18,11 @@ This plugin supplies one command, `jira`, through which all its features are exp jira # performs the default action jira new # opens a new issue +jira mine # queries for your own issues jira dashboard # opens your JIRA dashboard jira tempo # opens your JIRA Tempo jira reported [username] # queries for issues reported by a user jira assigned [username] # queries for issues assigned to a user -jira myissues # queries for you own issues jira branch # opens an existing issue matching the current branch name # The branch name may have prefixes ending in "/": "feature/MP-1234", # and also suffixes starting with "_": "MP-1234_fix_dashboard" diff --git a/plugins/jira/_jira b/plugins/jira/_jira index 1ac3eeda3..0e37b7e9d 100644 --- a/plugins/jira/_jira +++ b/plugins/jira/_jira @@ -4,6 +4,7 @@ local -a _1st_arguments _1st_arguments=( 'new:create a new issue' + 'mine:open my issues' 'dashboard:open the dashboard' 'tempo:open the tempo' 'reported:search for issues reported by a user' diff --git a/plugins/jira/jira.plugin.zsh b/plugins/jira/jira.plugin.zsh index 37d7b6a27..0add040d1 100644 --- a/plugins/jira/jira.plugin.zsh +++ b/plugins/jira/jira.plugin.zsh @@ -44,7 +44,7 @@ function jira() { open_command "${jira_url}/secure/CreateIssue!default.jspa" elif [[ "$action" == "assigned" || "$action" == "reported" ]]; then _jira_query ${@:-$action} - elif [[ "$action" == "myissues" ]]; then + elif [[ "$action" == "mine" ]]; then echo "Opening my issues" open_command "${jira_url}/issues/?filter=-1" elif [[ "$action" == "dashboard" ]]; then From 585084354e7ecf3b93c6eedb2ece70e914ee28b9 Mon Sep 17 00:00:00 2001 From: Vladimir Date: Mon, 9 Jan 2023 21:45:20 +0200 Subject: [PATCH 133/672] feat(jira): add optional plugin "tempo" path (#11121) CHANGE: added new environment variable JIRA_TEMPO_PATH to allow set an optional path Co-authored-by: Vladimir Antoscenco --- plugins/jira/README.md | 1 + plugins/jira/jira.plugin.zsh | 7 ++++++- 2 files changed, 7 insertions(+), 1 deletion(-) diff --git a/plugins/jira/README.md b/plugins/jira/README.md index a7cfe6d9e..3d6d323a4 100644 --- a/plugins/jira/README.md +++ b/plugins/jira/README.md @@ -68,6 +68,7 @@ echo "https://jira.atlassian.com" >> .jira-url * `$JIRA_PREFIX` - Prefix added to issue ID arguments * `$JIRA_RAPID_BOARD` - Set to `true` if you use Rapid Board * `$JIRA_DEFAULT_ACTION` - Action to do when `jira` is called with no arguments; defaults to "new" +* `$JIRA_TEMPO_PATH` - Your JIRA tempo url path; defaults to "/secure/Tempo.jspa" ### Browser ### diff --git a/plugins/jira/jira.plugin.zsh b/plugins/jira/jira.plugin.zsh index 0add040d1..71224bdfb 100644 --- a/plugins/jira/jira.plugin.zsh +++ b/plugins/jira/jira.plugin.zsh @@ -56,13 +56,18 @@ function jira() { fi elif [[ "$action" == "tempo" ]]; then echo "Opening tempo" - open_command "${jira_url}/secure/Tempo.jspa" + if [[ -n "$JIRA_TEMPO_PATH" ]]; then + open_command "${jira_url}${JIRA_TEMPO_PATH}" + else + open_command "${jira_url}/secure/Tempo.jspa" + fi elif [[ "$action" == "dumpconfig" ]]; then echo "JIRA_URL=$jira_url" echo "JIRA_PREFIX=$jira_prefix" echo "JIRA_NAME=$JIRA_NAME" echo "JIRA_RAPID_BOARD=$JIRA_RAPID_BOARD" echo "JIRA_DEFAULT_ACTION=$JIRA_DEFAULT_ACTION" + echo "JIRA_TEMPO_PATH=$JIRA_TEMPO_PATH" else # Anything that doesn't match a special action is considered an issue name # but `branch` is a special case that will parse the current git branch From e0d0dfb845a8f1eb35bce8ca5afcd76cb2ffbb35 Mon Sep 17 00:00:00 2001 From: Arnaud Zheng Date: Mon, 9 Jan 2023 20:53:32 +0100 Subject: [PATCH 134/672] feat(jira): support rapid view on rapid board mode (#9459) * feat(jira): support rapid view on rapid board mode * Update README to clarify how the rapid board/view works Co-authored-by: Robby Russell --- plugins/jira/README.md | 3 ++- plugins/jira/jira.plugin.zsh | 13 ++++++++++++- 2 files changed, 14 insertions(+), 2 deletions(-) diff --git a/plugins/jira/README.md b/plugins/jira/README.md index 3d6d323a4..5dc5bfc96 100644 --- a/plugins/jira/README.md +++ b/plugins/jira/README.md @@ -18,8 +18,8 @@ This plugin supplies one command, `jira`, through which all its features are exp jira # performs the default action jira new # opens a new issue +jira dashboard [rapid_view] # opens your JIRA dashboard jira mine # queries for your own issues -jira dashboard # opens your JIRA dashboard jira tempo # opens your JIRA Tempo jira reported [username] # queries for issues reported by a user jira assigned [username] # queries for issues assigned to a user @@ -67,6 +67,7 @@ echo "https://jira.atlassian.com" >> .jira-url * `$JIRA_NAME` - Your JIRA username; used as the default user for `assigned`/`reported` searches * `$JIRA_PREFIX` - Prefix added to issue ID arguments * `$JIRA_RAPID_BOARD` - Set to `true` if you use Rapid Board +* `$JIRA_RAPID_VIEW` - Set the default rapid view; it doesn't work if `$JIRA_RAPID_BOARD` is set to false * `$JIRA_DEFAULT_ACTION` - Action to do when `jira` is called with no arguments; defaults to "new" * `$JIRA_TEMPO_PATH` - Your JIRA tempo url path; defaults to "/secure/Tempo.jspa" diff --git a/plugins/jira/jira.plugin.zsh b/plugins/jira/jira.plugin.zsh index 71224bdfb..e789fce92 100644 --- a/plugins/jira/jira.plugin.zsh +++ b/plugins/jira/jira.plugin.zsh @@ -50,7 +50,7 @@ function jira() { elif [[ "$action" == "dashboard" ]]; then echo "Opening dashboard" if [[ "$JIRA_RAPID_BOARD" == "true" ]]; then - open_command "${jira_url}/secure/RapidBoard.jspa" + _jira_rapid_board ${@} else open_command "${jira_url}/secure/Dashboard.jspa" fi @@ -65,6 +65,7 @@ function jira() { echo "JIRA_URL=$jira_url" echo "JIRA_PREFIX=$jira_prefix" echo "JIRA_NAME=$JIRA_NAME" + echo "JIRA_RAPID_VIEW=$JIRA_RAPID_VIEW" echo "JIRA_RAPID_BOARD=$JIRA_RAPID_BOARD" echo "JIRA_DEFAULT_ACTION=$JIRA_DEFAULT_ACTION" echo "JIRA_TEMPO_PATH=$JIRA_TEMPO_PATH" @@ -112,6 +113,16 @@ Valid options, in order of precedence: EOF } +function _jira_rapid_board() { + rapid_view=${2:=$JIRA_RAPID_VIEW} + + if [[ -z $rapid_view ]]; then + open_command "${jira_url}/secure/RapidBoard.jspa" + else + open_command "${jira_url}/secure/RapidBoard.jspa?rapidView=$rapid_view" + fi +} + function _jira_query() { emulate -L zsh local verb="$1" From 2c2187b09d6dc488bb67968748ec07f7235a0238 Mon Sep 17 00:00:00 2001 From: cxy004 Date: Tue, 10 Jan 2023 04:02:51 +0800 Subject: [PATCH 135/672] fix(macos): fix `man-preview` for macOS Ventura (#11324) --- plugins/macos/macos.plugin.zsh | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/plugins/macos/macos.plugin.zsh b/plugins/macos/macos.plugin.zsh index b540eecb5..e4d759dcf 100644 --- a/plugins/macos/macos.plugin.zsh +++ b/plugins/macos/macos.plugin.zsh @@ -224,8 +224,9 @@ function quick-look() { } function man-preview() { + local location # Don't let Preview.app steal focus if the man page doesn't exist - man -w "$@" &>/dev/null && man -t "$@" | open -f -a Preview || man "$@" + location=$(man -w "$@") && mandoc -Tpdf $location | open -f -a Preview } compdef _man man-preview From 046f0ca5571e28aa328566d5f81a338e074cf174 Mon Sep 17 00:00:00 2001 From: Robby Russell Date: Mon, 9 Jan 2023 20:25:08 +0000 Subject: [PATCH 136/672] fix(jira): Update README examples to a table format --- plugins/jira/README.md | 44 +++++++++++++++++++++++------------------- 1 file changed, 24 insertions(+), 20 deletions(-) diff --git a/plugins/jira/README.md b/plugins/jira/README.md index 5dc5bfc96..d78ea15a4 100644 --- a/plugins/jira/README.md +++ b/plugins/jira/README.md @@ -14,27 +14,31 @@ In this document, "JIRA" refers to the JIRA issue tracking server, and `jira` re This plugin supplies one command, `jira`, through which all its features are exposed. Most forms of this command open a JIRA page in your web browser. -``` -jira # performs the default action +## Commands + +| Command | Description | +| :------------ | :-------------------------------------------------------- | +| `jira` | Performs the default action | +| `jira new` | Opens a new Jira issue dialogue | +| `jira ABC-123` | Opens an existing issue | +| `jira ABC-123 m` | Opens an existing issue for adding a comment | +| `jira dashboard [rapid_view]` | # opens your JIRA dashboard | +| `jira mine` | Queries for your own issues | +| `jira tempo` | Opens your JIRA Tempo | +| `jira reported [username]` | Queries for issues reported by a user | +| `jira assigned [username]` | Queries for issues assigned to a user | +| `jira branch` | Opens an existing issue matching the current branch name | + + +### Jira Branch usage notes + +The branch name may have prefixes ending in "/": "feature/MP-1234", and also suffixes +starting with "_": "MP-1234_fix_dashboard". In both these cases, the issue opened will be "MP-1234" + +This is also checks if the prefix is in the name, and adds it if not, so: "MP-1234" opens the issue "MP-1234", +"mp-1234" opens the issue "mp-1234", and "1234" opens the issue "MP-1234". + -jira new # opens a new issue -jira dashboard [rapid_view] # opens your JIRA dashboard -jira mine # queries for your own issues -jira tempo # opens your JIRA Tempo -jira reported [username] # queries for issues reported by a user -jira assigned [username] # queries for issues assigned to a user -jira branch # opens an existing issue matching the current branch name - # The branch name may have prefixes ending in "/": "feature/MP-1234", - # and also suffixes starting with "_": "MP-1234_fix_dashboard" - # In both these cases, the issue opened will be "MP-1234" - # This is also checks if the prefix is in the name, and adds it if not, so: - # "MP-1234" opens the issue "MP-1234", - # "mp-1234" opens the issue "mp-1234", - # and "1234" opens the issue "MP-1234". -# NOTE: since jira is case insensitive, the first two examples open the same issue -jira ABC-123 # opens an existing issue -jira ABC-123 m # opens an existing issue for adding a comment -``` #### Debugging usage #### From e583648195a33afb6ec4ebddb1926570a9a5e475 Mon Sep 17 00:00:00 2001 From: Celestino Gomes Date: Mon, 9 Jan 2023 17:46:54 -0300 Subject: [PATCH 137/672] feat(qrcode): new plugin to generate qrcode via https://qrcode.show (#10247) * feat(qrcode): new plugin to generate qrcode via https://qrcode.show * code fix suggested by @JuniorJPDJ * Update docs to clarify how to interact with it Co-authored-by: Robby Russell --- plugins/qrcode/README.md | 8 ++++++++ plugins/qrcode/qrcode.plugin.zsh | 17 +++++++++++++++++ 2 files changed, 25 insertions(+) create mode 100644 plugins/qrcode/README.md create mode 100644 plugins/qrcode/qrcode.plugin.zsh diff --git a/plugins/qrcode/README.md b/plugins/qrcode/README.md new file mode 100644 index 000000000..bcc870541 --- /dev/null +++ b/plugins/qrcode/README.md @@ -0,0 +1,8 @@ +# QRCode plugin + +Generate a QR Code from the command line. Uses [QRcode.show](https://qrcode.show) via curl. + +alias | command +--------------- | -------- +`qrcode [text]` | `curl -d "text" qrcode.show` +`qrsvg [text]` | `curl -d "text" qrcode.show -H "Accepct: image.svg"` diff --git a/plugins/qrcode/qrcode.plugin.zsh b/plugins/qrcode/qrcode.plugin.zsh new file mode 100644 index 000000000..d757e135e --- /dev/null +++ b/plugins/qrcode/qrcode.plugin.zsh @@ -0,0 +1,17 @@ +# Imported and improved from https://qrcode.show/, section SHELL FUNCTIONS + +_qrcode_show_message() { + echo "Type or paste your text, add a new blank line, and press ^d" +} + +qrcode () { + local input="$*" + [ -z "$input" ] && _qrcode_show_message && local input="@/dev/stdin" + curl -d "$input" https://qrcode.show +} + +qrsvg () { + local input="$*" + [ -z "$input" ] && _qrcode_show_message && local input="@/dev/stdin" + curl -d "$input" https://qrcode.show -H "Accept: image/svg+xml" +} From 4181e8a2cc936bc7b7a89d674bf261023159ed35 Mon Sep 17 00:00:00 2001 From: Dmndz <46868530+d14mndz@users.noreply.github.com> Date: Mon, 9 Jan 2023 21:51:50 +0100 Subject: [PATCH 138/672] feat(yarn): add alias for `yarn why` (#10773) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * feat(yarn): add `yarn why` * docs(yarn): update readme Co-authored-by: Basia Józefowska Co-authored-by: Robby Russell --- plugins/yarn/README.md | 1 + plugins/yarn/yarn.plugin.zsh | 1 + 2 files changed, 2 insertions(+) diff --git a/plugins/yarn/README.md b/plugins/yarn/README.md index 270bf6b7f..5c7c7f323 100644 --- a/plugins/yarn/README.md +++ b/plugins/yarn/README.md @@ -55,3 +55,4 @@ zstyle ':omz:plugins:yarn' global-path no | yv | `yarn version` | Update the version of your package | | yw | `yarn workspace` | Run a command within a single workspace. | | yws | `yarn workspaces` | Run a command within all defined workspaces. | +| yy | `yarn why` | Show why a package has been installed, detailing which other packages depend on it | diff --git a/plugins/yarn/yarn.plugin.zsh b/plugins/yarn/yarn.plugin.zsh index 7ba710df7..157044d71 100644 --- a/plugins/yarn/yarn.plugin.zsh +++ b/plugins/yarn/yarn.plugin.zsh @@ -43,3 +43,4 @@ alias yup="yarn upgrade" alias yv="yarn version" alias yw="yarn workspace" alias yws="yarn workspaces" +alias yy="yarn why" From 3dd83a22a160249a71631a51490fd3b89d1b3975 Mon Sep 17 00:00:00 2001 From: Lawton Nichols Date: Wed, 11 Jan 2023 10:44:29 -0800 Subject: [PATCH 139/672] fix(lib): send carriage return after `title` to fix #11314 (#11315) Window and tab titles are changed by emitting an unprintable escape sequence to the terminal. These escape sequences do not play nicely with the TAB character on multiple terminal emulators--they create un-deletable characters on the first line after command execution. Sending "\r" after changing the window and tab titles allows all characters on the first line to be deleted. Fixes #11314 --- lib/termsupport.zsh | 2 ++ 1 file changed, 2 insertions(+) diff --git a/lib/termsupport.zsh b/lib/termsupport.zsh index 80ca7ef78..fc1cde55e 100644 --- a/lib/termsupport.zsh +++ b/lib/termsupport.zsh @@ -36,6 +36,8 @@ function title { fi ;; esac + + print -Pn "\r" # move the cursor to the beginning of the line } ZSH_THEME_TERM_TAB_TITLE_IDLE="%15<..<%~%<<" #15 char left truncated PWD From 0f71cfd3c1b82cbc6b2ddd8782e193f38cf343f9 Mon Sep 17 00:00:00 2001 From: Rafael Laurindo Date: Wed, 11 Jan 2023 15:54:53 -0300 Subject: [PATCH 140/672] docs(qrsvg): fix command example (#11436) --- plugins/qrcode/README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/qrcode/README.md b/plugins/qrcode/README.md index bcc870541..442838947 100644 --- a/plugins/qrcode/README.md +++ b/plugins/qrcode/README.md @@ -5,4 +5,4 @@ Generate a QR Code from the command line. Uses [QRcode.show](https://qrcode.show alias | command --------------- | -------- `qrcode [text]` | `curl -d "text" qrcode.show` -`qrsvg [text]` | `curl -d "text" qrcode.show -H "Accepct: image.svg"` +`qrsvg [text]` | `curl -d "text" qrcode.show -H "Accept: image/svg+xml"` From 17ea97332b2f2285e3c2e1a00f6745fb1fe1cec5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Thu, 12 Jan 2023 08:29:00 +0100 Subject: [PATCH 141/672] Revert "fix(lib): send carriage return after `title` to fix #11314 (#11315)" This reverts commit 3dd83a22a160249a71631a51490fd3b89d1b3975. See https://github.com/ohmyzsh/ohmyzsh/issues/11314#issuecomment-1379492472 --- lib/termsupport.zsh | 2 -- 1 file changed, 2 deletions(-) diff --git a/lib/termsupport.zsh b/lib/termsupport.zsh index fc1cde55e..80ca7ef78 100644 --- a/lib/termsupport.zsh +++ b/lib/termsupport.zsh @@ -36,8 +36,6 @@ function title { fi ;; esac - - print -Pn "\r" # move the cursor to the beginning of the line } ZSH_THEME_TERM_TAB_TITLE_IDLE="%15<..<%~%<<" #15 char left truncated PWD From 35454190f6aeae9b9f16acdbdd0cf72c32610ee8 Mon Sep 17 00:00:00 2001 From: Jack DeVries Date: Thu, 12 Jan 2023 13:41:47 +0100 Subject: [PATCH 142/672] feat(git): use verbose flags in aliases Closes #11244 Closes #11246 Closes #10101 Closes #11380 --- plugins/git/README.md | 366 ++++++++++++++++++------------------- plugins/git/git.plugin.zsh | 75 ++++---- 2 files changed, 219 insertions(+), 222 deletions(-) diff --git a/plugins/git/README.md b/plugins/git/README.md index 3beb0890a..8cb4215a9 100644 --- a/plugins/git/README.md +++ b/plugins/git/README.md @@ -10,191 +10,189 @@ plugins=(... git) ## Aliases -| Alias | Command | -|:---------------------|:---------------------------------------------------------------------------------------------------------------------------------| -| g | git | -| ga | git add | -| gaa | git add --all | -| gapa | git add --patch | -| gau | git add --update | -| gav | git add --verbose | -| gap | git apply | -| gapt | git apply --3way | -| gb | git branch | -| gba | git branch -a | -| gbd | git branch -d | -| gbda | git branch --no-color --merged \| grep -vE "^([+*]\|\s*($(git_main_branch)\|$(git_develop_branch))\s*$)" \| xargs git branch -d 2>/dev/null | -| gbD | git branch -D | -| gbl | git blame -b -w | -| gbnm | git branch --no-merged | -| gbr | git branch --remote | -| gbs | git bisect | -| gbsb | git bisect bad | -| gbsg | git bisect good | -| gbsr | git bisect reset | -| gbss | git bisect start | -| gc | git commit -v | -| gc! | git commit -v --amend | -| gcn | git commit -v --no-edit | -| gcn! | git commit -v --no-edit --amend | -| gca | git commit -v -a | -| gca! | git commit -v -a --amend | -| gcan! | git commit -v -a --no-edit --amend | -| gcans! | git commit -v -a -s --no-edit --amend | -| gcam | git commit -a -m | -| gcas | git commit -a -s | -| gcasm | git commit -a -s -m | -| gcsm | git commit -s -m | -| gcb | git checkout -b | -| gcf | git config --list | -| gcl | git clone --recurse-submodules | -| gccd | git clone --recurse-submodules "$@" && cd "$(basename $_ .git)" | -| gclean | git clean -id | -| gpristine | git reset --hard && git clean -dffx | -| gcm | git checkout $(git_main_branch) | -| gcd | git checkout $(git_develop_branch) | -| gcmsg | git commit -m | -| gco | git checkout | -| gcor | git checkout --recurse-submodules | -| gcount | git shortlog -sn | -| gcp | git cherry-pick | -| gcpa | git cherry-pick --abort | -| gcpc | git cherry-pick --continue | -| gcs | git commit -S | -| gd | git diff | -| gdca | git diff --cached | -| gdcw | git diff --cached --word-diff | -| gdct | git describe --tags $(git rev-list --tags --max-count=1) | -| gds | git diff --staged | -| gdt | git diff-tree --no-commit-id --name-only -r | -| gdnolock | git diff $@ ":(exclude)package-lock.json" ":(exclude)*.lock" | -| gdup | git diff @{upstream} | -| gdv | git diff -w $@ \| view - | -| gdw | git diff --word-diff | -| gf | git fetch | -| gfa | git fetch --all --prune | -| gfg | git ls-files \| grep | -| gfo | git fetch origin | -| gg | git gui citool | -| gga | git gui citool --amend | -| ggf | git push --force origin $(current_branch) | -| ggfl | git push --force-with-lease origin $(current_branch) | -| ggl | git pull origin $(current_branch) | -| ggp | git push origin $(current_branch) | -| ggpnp | ggl && ggp | -| ggpull | git pull origin "$(git_current_branch)" | -| ggpur | ggu | -| ggpush | git push origin "$(git_current_branch)" | -| ggsup | git branch --set-upstream-to=origin/$(git_current_branch) | -| ggu | git pull --rebase origin $(current_branch) | -| gpsup | git push --set-upstream origin $(git_current_branch) | -| ghh | git help | -| gignore | git update-index --assume-unchanged | -| gignored | git ls-files -v \| grep "^[[:lower:]]" | -| git-svn-dcommit-push | git svn dcommit && git push github $(git_main_branch):svntrunk | -| gk | gitk --all --branches &! | -| gke | gitk --all $(git log -g --pretty=%h) &! | -| gl | git pull | -| glg | git log --stat | -| glgp | git log --stat -p | -| glgg | git log --graph | -| glgga | git log --graph --decorate --all | -| glgm | git log --graph --max-count=10 | -| glo | git log --oneline --decorate | -| glol | git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ar) %C(bold blue)<%an>%Creset' | -| glols | git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ar) %C(bold blue)<%an>%Creset' --stat | -| glod | git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ad) %C(bold blue)<%an>%Creset' | -| glods | git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ad) %C(bold blue)<%an>%Creset' --date=short | -| glola | git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ar) %C(bold blue)<%an>%Creset' --all | -| glog | git log --oneline --decorate --graph | -| gloga | git log --oneline --decorate --graph --all | -| glp | git log --pretty=\ | -| gm | git merge | -| gmom | git merge origin/$(git_main_branch) | -| gmtl | git mergetool --no-prompt | -| gmtlvim | git mergetool --no-prompt --tool=vimdiff | -| gmum | git merge upstream/$(git_main_branch) | -| gma | git merge --abort | -| gp | git push | -| gpd | git push --dry-run | -| gpf | git push --force-with-lease | -| gpf! | git push --force | -| gpoat | git push origin --all && git push origin --tags | -| gpr | git pull --rebase | -| gpu | git push upstream | -| gpv | git push -v | -| gr | git remote | -| gra | git remote add | -| grb | git rebase | -| grba | git rebase --abort | -| grbc | git rebase --continue | -| grbd | git rebase $(git_develop_branch) | -| grbi | git rebase -i | -| grbm | git rebase $(git_main_branch) | -| grbom | git rebase origin/$(git_main_branch) | -| grbo | git rebase --onto | -| grbs | git rebase --skip | -| grev | git revert | -| grh | git reset | -| grhh | git reset --hard | -| groh | git reset origin/$(git_current_branch) --hard | -| grm | git rm | -| grmc | git rm --cached | -| grmv | git remote rename | -| grrm | git remote remove | -| grs | git restore | -| grset | git remote set-url | -| grss | git restore --source | -| grst | git restore --staged | -| grt | cd "$(git rev-parse --show-toplevel \|\| echo .)" | -| gru | git reset -- | -| grup | git remote update | -| grv | git remote -v | -| gsb | git status -sb | -| gsd | git svn dcommit | -| gsh | git show | -| gsi | git submodule init | -| gsps | git show --pretty=short --show-signature | -| gsr | git svn rebase | -| gss | git status -s | -| gst | git status | -| gsta | git stash push | -| gsta | git stash save | -| gstaa | git stash apply | -| gstc | git stash clear | -| gstd | git stash drop | -| gstl | git stash list | -| gstp | git stash pop | -| gsts | git stash show --text | -| gstu | git stash --include-untracked | -| gstall | git stash --all | -| gsu | git submodule update | -| gsw | git switch | -| gswc | git switch -c | -| gswm | git switch $(git_main_branch) | -| gswd | git switch $(git_develop_branch) | -| gts | git tag -s | -| gtv | git tag \| sort -V | -| gtl | gtl(){ git tag --sort=-v:refname -n -l ${1}* }; noglob gtl | -| gunignore | git update-index --no-assume-unchanged | -| gunwip | git log -n 1 \| grep -q -c "\-\-wip\-\-" && git reset HEAD~1 | -| gup | git pull --rebase | -| gupv | git pull --rebase -v | -| gupa | git pull --rebase --autostash | -| gupav | git pull --rebase --autostash -v | -| gupom | git pull --rebase origin $(git_main_branch) | -| gupomi | git pull --rebase=interactive origin $(git_main_branch) | -| glum | git pull upstream $(git_main_branch) | -| gluc | git pull upstream $(git_current_branch) | -| gwch | git whatchanged -p --abbrev-commit --pretty=medium | -| gwip | git add -A; git rm $(git ls-files --deleted) 2> /dev/null; git commit --no-verify --no-gpg-sign -m "--wip-- [skip ci]" | -| gam | git am | -| gamc | git am --continue | -| gams | git am --skip | -| gama | git am --abort | -| gamscp | git am --show-current-patch | +| Alias | Command | +| :------------------- | :--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| g | git | +| ga | git add | +| gaa | git add --all | +| gapa | git add --patch | +| gau | git add --update | +| gav | git add --verbose | +| gap | git apply | +| gapt | git apply --3way | +| gb | git branch | +| gba | git branch --all | +| gbd | git branch --delete | +| gbda | git branch --no-color --merged \| grep -vE "^([+*]\|\s*($(git_main_branch)\|$(git_develop_branch))\s*$)" \| xargs git branch --delete 2>/dev/null | +| gbD | git branch --delete --force | +| gbl | git blame -b -w | +| gbnm | git branch --no-merged | +| gbr | git branch --remote | +| gbs | git bisect | +| gbsb | git bisect bad | +| gbsg | git bisect good | +| gbsr | git bisect reset | +| gbss | git bisect start | +| gc | git commit --verbose | +| gc! | git commit --verbose --amend | +| gcn! | git commit --verbose --no-edit --amend | +| gca | git commit --verbose --all | +| gca! | git commit --verbose --all --amend | +| gcan! | git commit --verbose --all --no-edit --amend | +| gcans! | git commit --verbose --all --signoff --no-edit --amend | +| gcam | git commit --all --message | +| gcas | git commit --all --signoff | +| gcasm | git commit --all --signoff --message | +| gcsm | git commit --signoff --message | +| gcb | git checkout -b | +| gcf | git config --list | +| gcl | git clone --recurse-submodules | +| gccd | git clone --recurse-submodules "$@" && cd "$(basename $\_ .git)" | +| gclean | git clean --interactive -d | +| gpristine | git reset --hard && git clean -dffx | +| gcm | git checkout $(git_main_branch) | +| gcd | git checkout $(git_develop_branch) | +| gcmsg | git commit --message | +| gco | git checkout | +| gcor | git checkout --recurse-submodules | +| gcount | git shortlog --summary -n | +| gcp | git cherry-pick | +| gcpa | git cherry-pick --abort | +| gcpc | git cherry-pick --continue | +| gcs | git commit -S | +| gd | git diff | +| gdca | git diff --cached | +| gdcw | git diff --cached --word-diff | +| gdct | git describe --tags $(git rev-list --tags --max-count=1) | +| gds | git diff --staged | +| gdt | git diff-tree --no-commit-id --name-only -r | +| gdnolock | git diff $@ ":(exclude)package-lock.json" ":(exclude)\*.lock" | +| gdup | git diff @{upstream} | +| gdv | git diff -w $@ \| view - | +| gdw | git diff --word-diff | +| gf | git fetch | +| gfa | git fetch --all --prune | +| gfg | git ls-files \| grep | +| gfo | git fetch origin | +| gg | git gui citool | +| gga | git gui citool --amend | +| ggf | git push --force origin $(current_branch) | +| ggfl | git push --force-with-lease origin $(current_branch) | +| ggl | git pull origin $(current_branch) | +| ggp | git push origin $(current_branch) | +| ggpnp | ggl && ggp | +| ggpull | git pull origin "$(git_current_branch)" | +| ggpur | ggu | +| ggpush | git push origin "$(git_current_branch)" | +| ggsup | git branch --set-upstream-to=origin/$(git_current_branch) | +| ggu | git pull --rebase origin $(current_branch) | +| gpsup | git push --set-upstream origin $(git_current_branch) | +| ghh | git help | +| gignore | git update-index --assume-unchanged | +| gignored | git ls-files -v \| grep "^[[:lower:]]" | +| git-svn-dcommit-push | git svn dcommit && git push github $(git_main_branch):svntrunk | +| gk | gitk --all --branches &! | +| gke | gitk --all $(git log --walk-reflogs --pretty=%h) &! | +| gl | git pull | +| glg | git log --stat | +| glgp | git log --stat --patch | +| glgg | git log --graph | +| glgga | git log --graph --decorate --all | +| glgm | git log --graph --max-count=10 | +| glo | git log --oneline --decorate | +| glol | git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ar) %C(bold blue)<%an>%Creset' | +| glols | git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ar) %C(bold blue)<%an>%Creset' --stat | +| glod | git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ad) %C(bold blue)<%an>%Creset' | +| glods | git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ad) %C(bold blue)<%an>%Creset' --date=short | +| glola | git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ar) %C(bold blue)<%an>%Creset' --all | +| glog | git log --oneline --decorate --graph | +| gloga | git log --oneline --decorate --graph --all | +| glp | git log --pretty=\ | +| gm | git merge | +| gmom | git merge origin/$(git_main_branch) | +| gmtl | git mergetool --no-prompt | +| gmtlvim | git mergetool --no-prompt --tool=vimdiff | +| gmum | git merge upstream/$(git_main_branch) | +| gma | git merge --abort | +| gp | git push | +| gpd | git push --dry-run | +| gpf | git push --force-with-lease | +| gpf! | git push --force | +| gpoat | git push origin --all && git push origin --tags | +| gpr | git pull --rebase | +| gpu | git push upstream | +| gpv | git push --verbose | +| gr | git remote | +| gra | git remote add | +| grb | git rebase | +| grba | git rebase --abort | +| grbc | git rebase --continue | +| grbd | git rebase $(git_develop_branch) | +| grbi | git rebase --interactive | +| grbm | git rebase $(git_main_branch) | +| grbom | git rebase origin/$(git_main_branch) | +| grbo | git rebase --onto | +| grbs | git rebase --skip | +| grev | git revert | +| grh | git reset | +| grhh | git reset --hard | +| groh | git reset origin/$(git_current_branch) --hard | +| grm | git rm | +| grmc | git rm --cached | +| grmv | git remote rename | +| grrm | git remote remove | +| grs | git restore | +| grset | git remote set-url | +| grss | git restore --source | +| grst | git restore --staged | +| grt | cd "$(git rev-parse --show-toplevel \|\| echo .)" | +| gru | git reset -- | +| grup | git remote update | +| grv | git remote --verbose | +| gsb | git status --short -b | +| gsd | git svn dcommit | +| gsh | git show | +| gsi | git submodule init | +| gsps | git show --pretty=short --show-signature | +| gsr | git svn rebase | +| gss | git status --short | +| gst | git status | +| gsta | git stash push | +| gsta | git stash save | +| gstaa | git stash apply | +| gstc | git stash clear | +| gstd | git stash drop | +| gstl | git stash list | +| gstp | git stash pop | +| gsts | git stash show --text | +| gstu | git stash --include-untracked | +| gstall | git stash --all | +| gsu | git submodule update | +| gsw | git switch | +| gswc | git switch -c | +| gswm | git switch $(git_main_branch) | +| gswd | git switch $(git_develop_branch) | +| gts | git tag -s | +| gtv | git tag \| sort -V | +| gtl | gtl(){ git tag --sort=-v:refname -n --list ${1}\* }; noglob gtl | +| gunignore | git update-index --no-assume-unchanged | +| gunwip | git log --max-count=1 \| grep -q -c "\-\-wip\-\-" && git reset HEAD~1 | +| gup | git pull --rebase | +| gupv | git pull --rebase --verbose | +| gupa | git pull --rebase --autostash | +| gupav | git pull --rebase --autostash --verbose | +| gupom | git pull --rebase origin $(git_main_branch) | +| gupomi | git pull --rebase=interactive origin $(git_main_branch) | +| glum | git pull upstream $(git_main_branch) | +| gluc | git pull upstream $(git_current_branch) | +| gwch | git whatchanged -p --abbrev-commit --pretty=medium | +| gwip | git add -A; git rm $(git ls-files --deleted) 2> /dev/null; git commit --no-verify --no-gpg-sign --message "--wip-- [skip ci]" | +| gam | git am | +| gamc | git am --continue | +| gams | git am --skip | +| gama | git am --abort | +| gamscp | git am --show-current-patch | | gwt | git worktree | -| gwta | git worktree add | | gwtls | git worktree list | | gwtmv | git worktree move | | gwtrm | git worktree remove | diff --git a/plugins/git/git.plugin.zsh b/plugins/git/git.plugin.zsh index 76e58a121..7544ca440 100644 --- a/plugins/git/git.plugin.zsh +++ b/plugins/git/git.plugin.zsh @@ -69,10 +69,10 @@ alias gap='git apply' alias gapt='git apply --3way' alias gb='git branch' -alias gba='git branch -a' -alias gbd='git branch -d' -alias gbda='git branch --no-color --merged | command grep -vE "^([+*]|\s*($(git_main_branch)|$(git_develop_branch))\s*$)" | command xargs git branch -d 2>/dev/null' -alias gbD='git branch -D' +alias gba='git branch --all' +alias gbd='git branch --delete' +alias gbda='git branch --no-color --merged | command grep -vE "^([+*]|\s*($(git_main_branch)|$(git_develop_branch))\s*$)" | command xargs git branch --delete 2>/dev/null' +alias gbD='git branch --delete --force' alias gbl='git blame -b -w' alias gbnm='git branch --no-merged' alias gbr='git branch --remote' @@ -82,18 +82,17 @@ alias gbsg='git bisect good' alias gbsr='git bisect reset' alias gbss='git bisect start' -alias gc='git commit -v' -alias gc!='git commit -v --amend' -alias gcn='git commit -v --no-edit' -alias gcn!='git commit -v --no-edit --amend' -alias gca='git commit -v -a' -alias gca!='git commit -v -a --amend' -alias gcan!='git commit -v -a --no-edit --amend' -alias gcans!='git commit -v -a -s --no-edit --amend' -alias gcam='git commit -a -m' -alias gcsm='git commit -s -m' -alias gcas='git commit -a -s' -alias gcasm='git commit -a -s -m' +alias gc='git commit --verbose' +alias gc!='git commit --verbose --amend' +alias gcn!='git commit --verbose --no-edit --amend' +alias gca='git commit --verbose --all' +alias gca!='git commit --verbose --all --amend' +alias gcan!='git commit --verbose --all --no-edit --amend' +alias gcans!='git commit --verbose --all --signoff --no-edit --amend' +alias gcam='git commit --all --message' +alias gcsm='git commit --signoff --message' +alias gcas='git commit --all --signoff' +alias gcasm='git commit --all --signoff --message' alias gcb='git checkout -b' alias gcf='git config --list' @@ -104,20 +103,20 @@ function gccd() { compdef _git gccd=git-clone alias gcl='git clone --recurse-submodules' -alias gclean='git clean -id' -alias gpristine='git reset --hard && git clean -dffx' +alias gclean='git clean --interactive -d' +alias gpristine='git reset --hard && git clean --force -dx' alias gcm='git checkout $(git_main_branch)' alias gcd='git checkout $(git_develop_branch)' -alias gcmsg='git commit -m' +alias gcmsg='git commit --message' alias gco='git checkout' alias gcor='git checkout --recurse-submodules' -alias gcount='git shortlog -sn' +alias gcount='git shortlog --summary --numbered' alias gcp='git cherry-pick' alias gcpa='git cherry-pick --abort' alias gcpc='git cherry-pick --continue' -alias gcs='git commit -S' -alias gcss='git commit -S -s' -alias gcssm='git commit -S -s -m' +alias gcs='git commit --gpg-sign' +alias gcss='git commit --gpg-sign --signoff' +alias gcssm='git commit --gpg-sign --signoff --message' alias gd='git diff' alias gdca='git diff --cached' @@ -208,11 +207,11 @@ alias gignored='git ls-files -v | grep "^[[:lower:]]"' alias git-svn-dcommit-push='git svn dcommit && git push github $(git_main_branch):svntrunk' alias gk='\gitk --all --branches &!' -alias gke='\gitk --all $(git log -g --pretty=%h) &!' +alias gke='\gitk --all $(git log --walk-reflogs --pretty=%h) &!' alias gl='git pull' alias glg='git log --stat' -alias glgp='git log --stat -p' +alias glgp='git log --stat --patch' alias glgg='git log --graph' alias glgga='git log --graph --decorate --all' alias glgm='git log --graph --max-count=10' @@ -240,7 +239,7 @@ alias gpf!='git push --force' alias gpoat='git push origin --all && git push origin --tags' alias gpr='git pull --rebase' alias gpu='git push upstream' -alias gpv='git push -v' +alias gpv='git push --verbose' alias gr='git remote' alias gra='git remote add' @@ -248,7 +247,7 @@ alias grb='git rebase' alias grba='git rebase --abort' alias grbc='git rebase --continue' alias grbd='git rebase $(git_develop_branch)' -alias grbi='git rebase -i' +alias grbi='git rebase --interactive' alias grbm='git rebase $(git_main_branch)' alias grbom='git rebase origin/$(git_main_branch)' alias grbo='git rebase --onto' @@ -268,15 +267,15 @@ alias grst='git restore --staged' alias grt='cd "$(git rev-parse --show-toplevel || echo .)"' alias gru='git reset --' alias grup='git remote update' -alias grv='git remote -v' +alias grv='git remote --verbose' -alias gsb='git status -sb' +alias gsb='git status --short --branch' alias gsd='git svn dcommit' alias gsh='git show' alias gsi='git submodule init' alias gsps='git show --pretty=short --show-signature' alias gsr='git svn rebase' -alias gss='git status -s' +alias gss='git status --short' alias gst='git status' # use the default stash push on git 2.13 and newer @@ -294,27 +293,27 @@ alias gstu='gsta --include-untracked' alias gstall='git stash --all' alias gsu='git submodule update' alias gsw='git switch' -alias gswc='git switch -c' +alias gswc='git switch --create' alias gswm='git switch $(git_main_branch)' alias gswd='git switch $(git_develop_branch)' -alias gts='git tag -s' +alias gts='git tag --sign' alias gtv='git tag | sort -V' -alias gtl='gtl(){ git tag --sort=-v:refname -n -l "${1}*" }; noglob gtl' +alias gtl='gtl(){ git tag --sort=-v:refname -n --list "${1}*" }; noglob gtl' alias gunignore='git update-index --no-assume-unchanged' -alias gunwip='git log -n 1 | grep -q -c "\--wip--" && git reset HEAD~1' +alias gunwip='git log --max-count=1 | grep -q -c "\--wip--" && git reset HEAD~1' alias gup='git pull --rebase' -alias gupv='git pull --rebase -v' +alias gupv='git pull --rebase --verbose' alias gupa='git pull --rebase --autostash' -alias gupav='git pull --rebase --autostash -v' +alias gupav='git pull --rebase --autostash --verbose' alias gupom='git pull --rebase origin $(git_main_branch)' alias gupomi='git pull --rebase=interactive origin $(git_main_branch)' alias glum='git pull upstream $(git_main_branch)' alias gluc='git pull upstream $(git_current_branch)' alias gwch='git whatchanged -p --abbrev-commit --pretty=medium' -alias gwip='git add -A; git rm $(git ls-files --deleted) 2> /dev/null; git commit --no-verify --no-gpg-sign -m "--wip-- [skip ci]"' +alias gwip='git add -A; git rm $(git ls-files --deleted) 2> /dev/null; git commit --no-verify --no-gpg-sign --message "--wip-- [skip ci]"' alias gwt='git worktree' alias gwta='git worktree add' @@ -342,4 +341,4 @@ function grename() { fi } -unset git_version +unset git_version \ No newline at end of file From 6dc6646d529a7dc6a1d8e1a2c1507dff7e528c8d Mon Sep 17 00:00:00 2001 From: Romain Janvier Date: Thu, 12 Jan 2023 13:56:26 +0100 Subject: [PATCH 143/672] docs(git): add missing entries and run formatter --- plugins/git/README.md | 26 ++++++++++++++------------ 1 file changed, 14 insertions(+), 12 deletions(-) diff --git a/plugins/git/README.md b/plugins/git/README.md index 8cb4215a9..d455e0eff 100644 --- a/plugins/git/README.md +++ b/plugins/git/README.md @@ -60,6 +60,8 @@ plugins=(... git) | gcpa | git cherry-pick --abort | | gcpc | git cherry-pick --continue | | gcs | git commit -S | +| gcss | git commit -S -s | +| gcssm | git commit -S -s -m | | gd | git diff | | gdca | git diff --cached | | gdcw | git diff --cached --word-diff | @@ -157,8 +159,8 @@ plugins=(... git) | gsr | git svn rebase | | gss | git status --short | | gst | git status | -| gsta | git stash push | -| gsta | git stash save | +| gsta | git stash push (git version >= 2.13) | +| gsta | git stash save (git version < 2.13) | | gstaa | git stash apply | | gstc | git stash clear | | gstd | git stash drop | @@ -176,7 +178,7 @@ plugins=(... git) | gtv | git tag \| sort -V | | gtl | gtl(){ git tag --sort=-v:refname -n --list ${1}\* }; noglob gtl | | gunignore | git update-index --no-assume-unchanged | -| gunwip | git log --max-count=1 \| grep -q -c "\-\-wip\-\-" && git reset HEAD~1 | +| gunwip | git log --max-count=1 \| grep -q -c "\-\-wip\-\-" && git reset HEAD~1 | | gup | git pull --rebase | | gupv | git pull --rebase --verbose | | gupa | git pull --rebase --autostash | @@ -192,10 +194,10 @@ plugins=(... git) | gams | git am --skip | | gama | git am --abort | | gamscp | git am --show-current-patch | -| gwt | git worktree | -| gwtls | git worktree list | -| gwtmv | git worktree move | -| gwtrm | git worktree remove | +| gwt | git worktree | +| gwtls | git worktree list | +| gwtmv | git worktree move | +| gwtrm | git worktree remove | ### Main branch preference @@ -227,7 +229,7 @@ These are aliases that have been removed, renamed, or otherwise modified in a wa ### Current | Command | Description | -|:-----------------------|:---------------------------------------------------------------------------------------------------------| +| :--------------------- | :------------------------------------------------------------------------------------------------------- | | `grename ` | Rename `old` branch to `new`, including in origin remote | | current_branch | Return the name of the current branch | | git_current_user_name | Returns the `user.name` config value | @@ -240,13 +242,13 @@ These are aliases that have been removed, renamed, or otherwise modified in a wa These features allow to pause a branch development and switch to another one (_"Work in Progress"_, or wip). When you want to go back to work, just unwip it. | Command | Description | -|:-----------------|:------------------------------------------------| +| :--------------- | :---------------------------------------------- | | work_in_progress | Echoes a warning if the current branch is a wip | | gwip | Commit wip branch | | gunwip | Uncommit wip branch | ### Deprecated functions -| Command | Description | Reason | -|:-----------------------|:----------------------------------------|:----------------------------------------------------------------| -| current_repository | Return the names of the current remotes | Didn't work properly. Use `git remote -v` instead (`grv` alias) | +| Command | Description | Reason | +| :----------------- | :-------------------------------------- | :-------------------------------------------------------------- | +| current_repository | Return the names of the current remotes | Didn't work properly. Use `git remote -v` instead (`grv` alias) | From ec0003f2faaf45e8e11660c5b66e98d10d462ee5 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Fri, 13 Jan 2023 12:40:47 +0100 Subject: [PATCH 144/672] ci: update to `checkout@v3` to avoid warnings --- .github/workflows/main.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/main.yml b/.github/workflows/main.yml index 57a1e3833..8ee2df3d8 100644 --- a/.github/workflows/main.yml +++ b/.github/workflows/main.yml @@ -7,7 +7,7 @@ on: branches: - master push: - branches: + branches: - master concurrency: @@ -27,7 +27,7 @@ jobs: os: [ubuntu-latest, macos-latest] steps: - name: Set up git repository - uses: actions/checkout@v2 + uses: actions/checkout@v3 - name: Install zsh if: runner.os == 'Linux' run: sudo apt-get update; sudo apt-get install zsh From eb2147c7159cf1ed14b1e5b6784d7d07c3662b52 Mon Sep 17 00:00:00 2001 From: Noam Cohen Date: Fri, 13 Jan 2023 15:35:30 +0200 Subject: [PATCH 145/672] feat(aws): load profiles from credentials file (#11196) Fixes #8472 --- plugins/aws/aws.plugin.zsh | 1 + 1 file changed, 1 insertion(+) diff --git a/plugins/aws/aws.plugin.zsh b/plugins/aws/aws.plugin.zsh index 2167f552c..865e82f19 100644 --- a/plugins/aws/aws.plugin.zsh +++ b/plugins/aws/aws.plugin.zsh @@ -146,6 +146,7 @@ function aws_change_access_key() { } function aws_profiles() { + aws --no-cli-pager configure list-profiles 2> /dev/null && return [[ -r "${AWS_CONFIG_FILE:-$HOME/.aws/config}" ]] || return 1 grep --color=never -Eo '\[.*\]' "${AWS_CONFIG_FILE:-$HOME/.aws/config}" | sed -E 's/^[[:space:]]*\[(profile)?[[:space:]]*([^[:space:]]+)\][[:space:]]*$/\2/g' } From ca0acf31ef163fd2a6bf562c9b9d6077975b41f8 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Fri, 13 Jan 2023 14:42:11 +0100 Subject: [PATCH 146/672] fix(emacs): make `alternate-editor` work for emacs >28 Closes #11441 --- plugins/emacs/README.md | 2 +- plugins/emacs/emacs.plugin.zsh | 2 +- plugins/emacs/emacsclient.sh | 4 ++-- 3 files changed, 4 insertions(+), 4 deletions(-) diff --git a/plugins/emacs/README.md b/plugins/emacs/README.md index c8e33b5ab..8ed4a1473 100644 --- a/plugins/emacs/README.md +++ b/plugins/emacs/README.md @@ -25,6 +25,6 @@ The plugin uses a custom launcher (which we'll call here `$EMACS_LAUNCHER`) that | e | `emacs` | Same as emacs alias | | te | `$EMACS_LAUNCHER -nw` | Open terminal emacsclient | | eeval | `$EMACS_LAUNCHER --eval` | Same as `M-x eval` but from outside Emacs | -| eframe | `emacsclient --alternate-editor "" --create-frame` | Create new X frame | +| eframe | `emacsclient --alternate-editor="" --create-frame` | Create new X frame | | efile | - | Print the path to the file open in the current buffer | | ecd | - | Print the directory of the file open in the the current buffer | diff --git a/plugins/emacs/emacs.plugin.zsh b/plugins/emacs/emacs.plugin.zsh index fede5b0c4..4747f035b 100644 --- a/plugins/emacs/emacs.plugin.zsh +++ b/plugins/emacs/emacs.plugin.zsh @@ -32,7 +32,7 @@ alias te="$EMACS_PLUGIN_LAUNCHER -nw" # same than M-x eval but from outside Emacs. alias eeval="$EMACS_PLUGIN_LAUNCHER --eval" # create a new X frame -alias eframe='emacsclient --alternate-editor "" --create-frame' +alias eframe='emacsclient --alternate-editor="" --create-frame' # Emacs ANSI Term tracking if [[ -n "$INSIDE_EMACS" ]]; then diff --git a/plugins/emacs/emacsclient.sh b/plugins/emacs/emacsclient.sh index 96893c932..172c0ae96 100755 --- a/plugins/emacs/emacsclient.sh +++ b/plugins/emacs/emacsclient.sh @@ -15,11 +15,11 @@ emacsfun() { # Only create another X frame if there isn't one present if [ -z "$frames" -o "$frames" = nil ]; then - emacsclient --alternate-editor "" --create-frame "$@" + emacsclient --alternate-editor="" --create-frame "$@" return $? fi - emacsclient --alternate-editor "" "$@" + emacsclient --alternate-editor="" "$@" } # Adapted from https://github.com/davidshepherd7/emacs-read-stdin/blob/master/emacs-read-stdin.sh From df658350a38aa73920fdefa5b255f8d7a58d31dc Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Sun, 15 Jan 2023 17:11:29 +0100 Subject: [PATCH 147/672] fix(clipboard): move wsl detection to higher priority (#11440) Closes #8827 --- lib/clipboard.zsh | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/lib/clipboard.zsh b/lib/clipboard.zsh index ad83fc4b2..2f3b6bcad 100644 --- a/lib/clipboard.zsh +++ b/lib/clipboard.zsh @@ -57,6 +57,9 @@ function detect-clipboard() { elif [[ "${OSTYPE}" == (cygwin|msys)* ]]; then function clipcopy() { cat "${1:-/dev/stdin}" > /dev/clipboard; } function clippaste() { cat /dev/clipboard; } + elif (( $+commands[clip.exe] )) && (( $+commands[powershell.exe] )); then + function clipcopy() { cat "${1:-/dev/stdin}" | clip.exe; } + function clippaste() { powershell.exe -noprofile -command Get-Clipboard; } elif [ -n "${WAYLAND_DISPLAY:-}" ] && (( ${+commands[wl-copy]} )) && (( ${+commands[wl-paste]} )); then function clipcopy() { cat "${1:-/dev/stdin}" | wl-copy &>/dev/null &|; } function clippaste() { wl-paste; } @@ -81,9 +84,6 @@ function detect-clipboard() { elif [ -n "${TMUX:-}" ] && (( ${+commands[tmux]} )); then function clipcopy() { tmux load-buffer "${1:--}"; } function clippaste() { tmux save-buffer -; } - elif [[ $(uname -r) = *icrosoft* ]]; then - function clipcopy() { cat "${1:-/dev/stdin}" | clip.exe; } - function clippaste() { powershell.exe -noprofile -command Get-Clipboard; } else function _retry_clipboard_detection_or_fail() { local clipcmd="${1}"; shift From 4b5076b5ec450d30270f31a68d0299392ada042d Mon Sep 17 00:00:00 2001 From: xiagw Date: Mon, 16 Jan 2023 20:19:01 +0800 Subject: [PATCH 148/672] feat(extract): add `pbzip2` and `pixz` (#11435) --- plugins/extract/extract.plugin.zsh | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/plugins/extract/extract.plugin.zsh b/plugins/extract/extract.plugin.zsh index 1112dd52f..563d88c72 100644 --- a/plugins/extract/extract.plugin.zsh +++ b/plugins/extract/extract.plugin.zsh @@ -30,12 +30,15 @@ EOF local extract_dir="${1:t:r}" local file="$1" full_path="${1:A}" case "${file:l}" in - (*.tar.gz|*.tgz) (( $+commands[pigz] )) && { pigz -dc "$file" | tar xv } || tar zxvf "$file" ;; - (*.tar.bz2|*.tbz|*.tbz2) tar xvjf "$file" ;; + (*.tar.gz|*.tgz) + (( $+commands[pigz] )) && { tar -I pigz -xvf "$file" } || tar zxvf "$file" ;; + (*.tar.bz2|*.tbz|*.tbz2) + (( $+commands[pbzip2] )) && { tar -I pbzip2 -xvf "$file" } || tar xvjf "$file" ;; (*.tar.xz|*.txz) + (( $+commands[pixz] )) && { tar -I pixz -xvf "$file" } || { tar --xz --help &> /dev/null \ && tar --xz -xvf "$file" \ - || xzcat "$file" | tar xvf - ;; + || xzcat "$file" | tar xvf - } ;; (*.tar.zma|*.tlz) tar --lzma --help &> /dev/null \ && tar --lzma -xvf "$file" \ From 8f0e296dbf27026ea0515ebae0d3cc41f236ecdc Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Mon, 16 Jan 2023 20:16:00 +0100 Subject: [PATCH 149/672] feat(nsc): add completion plugin --- plugins/nsc/README.md | 11 +++++++++++ plugins/nsc/nsc.plugin.zsh | 13 +++++++++++++ 2 files changed, 24 insertions(+) create mode 100644 plugins/nsc/README.md create mode 100644 plugins/nsc/nsc.plugin.zsh diff --git a/plugins/nsc/README.md b/plugins/nsc/README.md new file mode 100644 index 000000000..ce0d2c15c --- /dev/null +++ b/plugins/nsc/README.md @@ -0,0 +1,11 @@ +# NSC plugin + +This plugin adds completion for the [NSC](https://github.com/nats-io/nsc). + +To use it, add `nsc` to the plugins array in your zshrc file: + +```zsh +plugins=(... nsc) +``` + +This plugin does not add any aliases. diff --git a/plugins/nsc/nsc.plugin.zsh b/plugins/nsc/nsc.plugin.zsh new file mode 100644 index 000000000..daa599e8f --- /dev/null +++ b/plugins/nsc/nsc.plugin.zsh @@ -0,0 +1,13 @@ +if (( ! $+commands[nsc] )); then + return +fi + +# If the completion file doesn't exist yet, we need to autoload it and +# bind it to `nsc`. Otherwise, compinit will have already done that. +if [[ ! -f "$ZSH_CACHE_DIR/completions/_nsc" ]]; then + typeset -g -A _comps + autoload -Uz _nsc + _comps[nsc]=_nsc +fi + +nsc completion zsh >| "$ZSH_CACHE_DIR/completions/_nsc" &| From 5b9de6a5304ad5f74ccb5862122a23b9ba06f6e3 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Mon, 19 Dec 2022 23:32:24 +0100 Subject: [PATCH 150/672] fix(init): remove duplicated check It was added due to #9039. See https://github.com/ohmyzsh/ohmyzsh/pull/11400#pullrequestreview-1223587420 --- oh-my-zsh.sh | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/oh-my-zsh.sh b/oh-my-zsh.sh index e94c2f417..98bda8c8b 100644 --- a/oh-my-zsh.sh +++ b/oh-my-zsh.sh @@ -57,9 +57,7 @@ mkdir -p "$ZSH_CACHE_DIR/completions" (( ${fpath[(Ie)"$ZSH_CACHE_DIR/completions"]} )) || fpath=("$ZSH_CACHE_DIR/completions" $fpath) # Check for updates on initial load... -if [[ "$DISABLE_AUTO_UPDATE" != true ]]; then - source "$ZSH/tools/check_for_upgrade.sh" -fi +source "$ZSH/tools/check_for_upgrade.sh" # Initializes Oh My Zsh From fe0dd8226d6f58ea98f9f84b279e6c3859993fb9 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Mon, 19 Dec 2022 23:33:55 +0100 Subject: [PATCH 151/672] fix(upgrade): do not upgrade if not called from tty Fixes #11390 --- .prettierrc | 4 ++++ tools/check_for_upgrade.sh | 2 ++ 2 files changed, 6 insertions(+) create mode 100644 .prettierrc diff --git a/.prettierrc b/.prettierrc new file mode 100644 index 000000000..a8f5a14b0 --- /dev/null +++ b/.prettierrc @@ -0,0 +1,4 @@ +{ + "printWidth": 110, + "proseWrap": "always" +} diff --git a/tools/check_for_upgrade.sh b/tools/check_for_upgrade.sh index 3a6bb6555..734714c94 100644 --- a/tools/check_for_upgrade.sh +++ b/tools/check_for_upgrade.sh @@ -21,9 +21,11 @@ zstyle -s ':omz:update' mode update_mode || { # Cancel update if: # - the automatic update is disabled. # - the current user doesn't have write permissions nor owns the $ZSH directory. +# - is not run from a tty # - git is unavailable on the system. if [[ "$update_mode" = disabled ]] \ || [[ ! -w "$ZSH" || ! -O "$ZSH" ]] \ + || [[ ! -t 1 ]] \ || ! command git --version 2>&1 >/dev/null; then unset update_mode return From 61dd3682e69aa990a8a3589c5c61ea2e1edf8312 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Tue, 17 Jan 2023 13:18:43 +0100 Subject: [PATCH 152/672] feat(nats)!: rename `nsc` plugin to `nats` --- plugins/nats/README.md | 14 ++++++++++++++ plugins/nats/nats.plugin.zsh | 23 +++++++++++++++++++++++ plugins/nsc/README.md | 11 ----------- plugins/nsc/nsc.plugin.zsh | 13 ------------- 4 files changed, 37 insertions(+), 24 deletions(-) create mode 100644 plugins/nats/README.md create mode 100644 plugins/nats/nats.plugin.zsh delete mode 100644 plugins/nsc/README.md delete mode 100644 plugins/nsc/nsc.plugin.zsh diff --git a/plugins/nats/README.md b/plugins/nats/README.md new file mode 100644 index 000000000..0ea26fca1 --- /dev/null +++ b/plugins/nats/README.md @@ -0,0 +1,14 @@ +# NATS plugin + +This plugin adds completion for several tools from [NATS](https://nats.io/). + +- [`nsc`](https://github.com/nats-io/nsc) +- [`natscli`](https://github.com/nats-io/natscli) + +To use it, add `nats` to the plugins array in your zshrc file: + +```zsh +plugins=(... nats) +``` + +This plugin does not add any aliases. diff --git a/plugins/nats/nats.plugin.zsh b/plugins/nats/nats.plugin.zsh new file mode 100644 index 000000000..8b95b07c6 --- /dev/null +++ b/plugins/nats/nats.plugin.zsh @@ -0,0 +1,23 @@ +if (( $+commands[nsc] )); then + # If the completion file doesn't exist yet, we need to autoload it and + # bind it to `nsc`. Otherwise, compinit will have already done that. + if [[ ! -f "$ZSH_CACHE_DIR/completions/_nsc" ]]; then + typeset -g -A _comps + autoload -Uz _nsc + _comps[nsc]=_nsc + fi + + nsc completion zsh >| "$ZSH_CACHE_DIR/completions/_nsc" &| +fi + +if (( $+commands[nats] )); then + # If the completion file doesn't exist yet, we need to autoload it and + # bind it to `nats`. Otherwise, compinit will have already done that. + if [[ ! -f "$ZSH_CACHE_DIR/completions/_nats" ]]; then + typeset -g -A _comps + autoload -Uz _nats + _comps[nats]=_nats + fi + + nats --completion-script-zsh >| "$ZSH_CACHE_DIR/completions/_nats" &| +fi diff --git a/plugins/nsc/README.md b/plugins/nsc/README.md deleted file mode 100644 index ce0d2c15c..000000000 --- a/plugins/nsc/README.md +++ /dev/null @@ -1,11 +0,0 @@ -# NSC plugin - -This plugin adds completion for the [NSC](https://github.com/nats-io/nsc). - -To use it, add `nsc` to the plugins array in your zshrc file: - -```zsh -plugins=(... nsc) -``` - -This plugin does not add any aliases. diff --git a/plugins/nsc/nsc.plugin.zsh b/plugins/nsc/nsc.plugin.zsh deleted file mode 100644 index daa599e8f..000000000 --- a/plugins/nsc/nsc.plugin.zsh +++ /dev/null @@ -1,13 +0,0 @@ -if (( ! $+commands[nsc] )); then - return -fi - -# If the completion file doesn't exist yet, we need to autoload it and -# bind it to `nsc`. Otherwise, compinit will have already done that. -if [[ ! -f "$ZSH_CACHE_DIR/completions/_nsc" ]]; then - typeset -g -A _comps - autoload -Uz _nsc - _comps[nsc]=_nsc -fi - -nsc completion zsh >| "$ZSH_CACHE_DIR/completions/_nsc" &| From f1a800067f46fa990a11ea0055459560ce63a7ae Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Thu, 19 Jan 2023 12:20:44 +0100 Subject: [PATCH 153/672] fix(brew)!: rename `buf` alias to `bfu` BREAKING CHANGE: rename `buf` alias to `bfu` to avoid conflicts with protobuf tool --- plugins/brew/README.md | 28 ++++++++++++++-------------- plugins/brew/brew.plugin.zsh | 2 +- 2 files changed, 15 insertions(+), 15 deletions(-) diff --git a/plugins/brew/README.md b/plugins/brew/README.md index 4a42b3d74..d0c150237 100644 --- a/plugins/brew/README.md +++ b/plugins/brew/README.md @@ -17,20 +17,20 @@ defined for convenience. ## Aliases -| Alias | Command | Description | -| -------- | ------------------------------------- | ------------------------------------------------------------------- | -| `bcubc` | `brew upgrade --cask && brew cleanup` | Update outdated casks, then run cleanup. | -| `bcubo` | `brew update && brew outdated --cask` | Update Homebrew data, then list outdated casks. | -| `bcubc` | `brew upgrade --cask && brew cleanup` | Update outdated casks, then run cleanup. | -| `brewp` | `brew pin` | Pin a specified formula so that it's not upgraded. | -| `brews` | `brew list -1` | List installed formulae or the installed files for a given formula. | -| `brewsp` | `brew list --pinned` | List pinned formulae, or show the version of a given formula. | -| `bubc` | `brew upgrade && brew cleanup` | Upgrade outdated formulae and casks, then run cleanup. | -| `bugbc` | `brew upgrade --greedy && brew cleanup` | Upgrade outdated formulae and casks (greedy), then run cleanup. | -| `bubo` | `brew update && brew outdated` | Update Homebrew data, then list outdated formulae and casks. | -| `bubu` | `bubo && bubc` | Do the last two operations above. | -| `buf` | `brew upgrade --formula` | Upgrade only formulas (not casks). | -| `buz` | `brew uninstall --zap` | Remove all files associated with a cask. | +| Alias | Command | Description | +| -------- | --------------------------------------- | ------------------------------------------------------------------- | +| `bcubc` | `brew upgrade --cask && brew cleanup` | Update outdated casks, then run cleanup. | +| `bcubo` | `brew update && brew outdated --cask` | Update Homebrew data, then list outdated casks. | +| `bcubc` | `brew upgrade --cask && brew cleanup` | Update outdated casks, then run cleanup. | +| `brewp` | `brew pin` | Pin a specified formula so that it's not upgraded. | +| `brews` | `brew list -1` | List installed formulae or the installed files for a given formula. | +| `brewsp` | `brew list --pinned` | List pinned formulae, or show the version of a given formula. | +| `bubc` | `brew upgrade && brew cleanup` | Upgrade outdated formulae and casks, then run cleanup. | +| `bugbc` | `brew upgrade --greedy && brew cleanup` | Upgrade outdated formulae and casks (greedy), then run cleanup. | +| `bubo` | `brew update && brew outdated` | Update Homebrew data, then list outdated formulae and casks. | +| `bubu` | `bubo && bubc` | Do the last two operations above. | +| `bfu` | `brew upgrade --formula` | Upgrade only formulas (not casks). | +| `buz` | `brew uninstall --zap` | Remove all files associated with a cask. | ## Completion diff --git a/plugins/brew/brew.plugin.zsh b/plugins/brew/brew.plugin.zsh index 8275454a4..f6abe0875 100644 --- a/plugins/brew/brew.plugin.zsh +++ b/plugins/brew/brew.plugin.zsh @@ -35,7 +35,7 @@ alias bugbc='brew upgrade --greedy && brew cleanup' alias bubo='brew update && brew outdated' alias bubu='bubo && bubc' alias bubug='bubo && bugbc' -alias buf='brew upgrade --formula' +alias bfu='brew upgrade --formula' alias buz='brew uninstall --zap' function brews() { From bf57b4ff3d53726a1317459b0f48853e90d7a6e4 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Joan=20Marc=C3=A8=20i=20Igual?= Date: Fri, 20 Jan 2023 19:45:14 +0100 Subject: [PATCH 154/672] feat(functions/take): make `.tgz` behave as `.tar.gz` (#11446) --- lib/functions.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/functions.zsh b/lib/functions.zsh index dfcc4d961..6e1faa6aa 100644 --- a/lib/functions.zsh +++ b/lib/functions.zsh @@ -56,7 +56,7 @@ function takegit() { } function take() { - if [[ $1 =~ ^(https?|ftp).*\.tar\.(gz|bz2|xz)$ ]]; then + if [[ $1 =~ ^(https?|ftp).*\.(tar\.(gz|bz2|xz)|tgz)$ ]]; then takeurl "$1" elif [[ $1 =~ ^([A-Za-z0-9]\+@|https?|git|ssh|ftps?|rsync).*\.git/?$ ]]; then takegit "$1" From ba8777fc3013a3c682d8144586e16457cbe12586 Mon Sep 17 00:00:00 2001 From: Yuxin Wu Date: Sat, 21 Jan 2023 02:36:07 -0800 Subject: [PATCH 155/672] perf(fzf): speed up startup on debian (#11122) --- plugins/fzf/fzf.plugin.zsh | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) diff --git a/plugins/fzf/fzf.plugin.zsh b/plugins/fzf/fzf.plugin.zsh index 9c8dd8648..85a0bf270 100644 --- a/plugins/fzf/fzf.plugin.zsh +++ b/plugins/fzf/fzf.plugin.zsh @@ -60,8 +60,8 @@ function fzf_setup_using_base_dir() { function fzf_setup_using_debian() { - if (( ! $+commands[dpkg] )) || ! dpkg -s fzf &>/dev/null; then - # Either not a debian based distro, or no fzf installed + if (( ! $+commands[dpkg] )); then + # Not a debian based distro return 1 fi @@ -72,11 +72,19 @@ function fzf_setup_using_debian() { case $PREFIX in *com.termux*) + if [[ ! -f "${PREFIX}/bin/fzf" ]]; then + # fzf not installed + return 1 + fi # Support Termux package completions="${PREFIX}/share/fzf/completion.zsh" key_bindings="${PREFIX}/share/fzf/key-bindings.zsh" ;; *) + if [[ ! -f /usr/bin/fzf ]]; then + # fzf not installed + return 1 + fi # Determine completion file path: first bullseye/sid, then buster/stretch completions="/usr/share/doc/fzf/examples/completion.zsh" [[ -f "$completions" ]] || completions="/usr/share/zsh/vendor-completions/_fzf" From a1c54e03f98b594a6fcc368c2c113d469ffaa368 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Sun, 22 Jan 2023 23:36:57 +0100 Subject: [PATCH 156/672] feat(fzf): add `skip-dpkg` flag to avoid some regressions See https://github.com/ohmyzsh/ohmyzsh/pull/11122#issuecomment-1399607430 --- plugins/fzf/README.md | 9 +++++++++ plugins/fzf/fzf.plugin.zsh | 4 ++-- 2 files changed, 11 insertions(+), 2 deletions(-) diff --git a/plugins/fzf/README.md b/plugins/fzf/README.md index beedf4690..7e3e3e5b0 100644 --- a/plugins/fzf/README.md +++ b/plugins/fzf/README.md @@ -50,3 +50,12 @@ Set whether to disable key bindings (CTRL-T, CTRL-R, ALT-C): ```zsh DISABLE_FZF_KEY_BINDINGS="true" ``` + +### Skip `dpkg` loading + +If you have `dpkg` available in your `$PATH` but you don't want to load `fzf` from there, and facing some +issues, you can define this option before loading `oh-my-zsh` in order to skip that loading: + +```zsh +zstyle ':omz:plugins:fzf' skip-dpkg yes +``` diff --git a/plugins/fzf/fzf.plugin.zsh b/plugins/fzf/fzf.plugin.zsh index 85a0bf270..c07d38493 100644 --- a/plugins/fzf/fzf.plugin.zsh +++ b/plugins/fzf/fzf.plugin.zsh @@ -60,8 +60,8 @@ function fzf_setup_using_base_dir() { function fzf_setup_using_debian() { - if (( ! $+commands[dpkg] )); then - # Not a debian based distro + if (( ! $+commands[dpkg] )) || zstyle -t ':omz:plugins:fzf' skip-dpkg; then + # Not a debian based distro return 1 fi From 7de55844b26394688221b1cd12ef4053b3c7f6c7 Mon Sep 17 00:00:00 2001 From: Bartek Pacia Date: Mon, 23 Jan 2023 19:40:42 +0100 Subject: [PATCH 157/672] feat(mlh): add separate prompt symbol for root user (#11451) --- themes/mlh.zsh-theme | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/themes/mlh.zsh-theme b/themes/mlh.zsh-theme index baff3fb63..c059bf850 100644 --- a/themes/mlh.zsh-theme +++ b/themes/mlh.zsh-theme @@ -47,6 +47,10 @@ if [ -z "$MLH_SHELL_SYMBOL" ]; then MLH_SHELL_SYMBOL="$ " fi +if [ -z "$MLH_SHELL_SYMBOL_ROOT" ]; then + MLH_SHELL_SYMBOL_ROOT="# " +fi + # colors USER_COLOR="%F{001}" DEVICE_COLOR="%F{033}" @@ -83,7 +87,11 @@ exit_code() { } prompt_end() { - printf "\n$MLH_SHELL_SYMBOL" + if [ "$UID" -eq 0 ]; then + printf "\n$MLH_SHELL_SYMBOL_ROOT" + else + printf "\n$MLH_SHELL_SYMBOL" + fi } # Set git_prompt_info text From 657ad0523d5a29e0bdc8af0cd63c23ac597406e8 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Wed, 25 Jan 2023 08:50:06 +0100 Subject: [PATCH 158/672] fix(theme-and-appearance): fix `diff` completion in macOS Closes #11416 Closes #11454 --- lib/theme-and-appearance.zsh | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/lib/theme-and-appearance.zsh b/lib/theme-and-appearance.zsh index 00947f72d..9b908bef0 100644 --- a/lib/theme-and-appearance.zsh +++ b/lib/theme-and-appearance.zsh @@ -41,7 +41,11 @@ fi # enable diff color if possible. if command diff --color /dev/null /dev/null &>/dev/null; then - alias diff='diff --color' + function color-diff { + diff --color $@ + } + alias diff="color-diff" + compdef _diff color-diff # compdef is already loaded by this point fi setopt auto_cd From e55e3f0f56ab4df21eb33e19569c295e7e5e71a4 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Thu, 26 Jan 2023 20:45:48 +0100 Subject: [PATCH 159/672] fix(systemadmin): handle error for no IPv6 route in `geteip` (#11458) --- plugins/systemadmin/systemadmin.plugin.zsh | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/plugins/systemadmin/systemadmin.plugin.zsh b/plugins/systemadmin/systemadmin.plugin.zsh index 9b5159ff1..7ce62bac1 100644 --- a/plugins/systemadmin/systemadmin.plugin.zsh +++ b/plugins/systemadmin/systemadmin.plugin.zsh @@ -140,7 +140,13 @@ function d0() { # gather external ip address function geteip() { curl -s -S -4 https://icanhazip.com - curl -s -S -6 https://icanhazip.com + + # handle case when there is no IPv6 external IP, which shows error + # curl: (7) Couldn't connect to server + curl -s -S -6 https://icanhazip.com 2>/dev/null + local ret=$? + (( ret == 7 )) && print -P -u2 "%F{red}error: no IPv6 route to host%f" + return $ret } # determine local IP address(es) From b0bffcaf865434711d98b63eddd0aa52be0fbeb1 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Fri, 27 Jan 2023 16:22:27 +0100 Subject: [PATCH 160/672] fix(fzf): fix check for true Debian-like in debian setup function (#11460) Check for `apt` and `apt-get` in debian setup function. Look for exact directory in debian-like setup function. Fixes #11459 --- plugins/fzf/README.md | 9 --------- plugins/fzf/fzf.plugin.zsh | 4 ++-- 2 files changed, 2 insertions(+), 11 deletions(-) diff --git a/plugins/fzf/README.md b/plugins/fzf/README.md index 7e3e3e5b0..beedf4690 100644 --- a/plugins/fzf/README.md +++ b/plugins/fzf/README.md @@ -50,12 +50,3 @@ Set whether to disable key bindings (CTRL-T, CTRL-R, ALT-C): ```zsh DISABLE_FZF_KEY_BINDINGS="true" ``` - -### Skip `dpkg` loading - -If you have `dpkg` available in your `$PATH` but you don't want to load `fzf` from there, and facing some -issues, you can define this option before loading `oh-my-zsh` in order to skip that loading: - -```zsh -zstyle ':omz:plugins:fzf' skip-dpkg yes -``` diff --git a/plugins/fzf/fzf.plugin.zsh b/plugins/fzf/fzf.plugin.zsh index c07d38493..7bb6667d0 100644 --- a/plugins/fzf/fzf.plugin.zsh +++ b/plugins/fzf/fzf.plugin.zsh @@ -60,7 +60,7 @@ function fzf_setup_using_base_dir() { function fzf_setup_using_debian() { - if (( ! $+commands[dpkg] )) || zstyle -t ':omz:plugins:fzf' skip-dpkg; then + if (( ! $+commands[apt] && ! $+commands[apt-get] )); then # Not a debian based distro return 1 fi @@ -81,7 +81,7 @@ function fzf_setup_using_debian() { key_bindings="${PREFIX}/share/fzf/key-bindings.zsh" ;; *) - if [[ ! -f /usr/bin/fzf ]]; then + if [[ ! -d /usr/share/doc/fzf/examples ]]; then # fzf not installed return 1 fi From 39525e5ec36052a83fadd47f377a26d33df851bd Mon Sep 17 00:00:00 2001 From: Taehyun Hwang Date: Sun, 29 Jan 2023 02:45:23 +0900 Subject: [PATCH 161/672] feat(git): add `gpsupf` alias (#11268) --- plugins/git/README.md | 1 + plugins/git/git.plugin.zsh | 3 ++- 2 files changed, 3 insertions(+), 1 deletion(-) diff --git a/plugins/git/README.md b/plugins/git/README.md index d455e0eff..d5eaaa53f 100644 --- a/plugins/git/README.md +++ b/plugins/git/README.md @@ -89,6 +89,7 @@ plugins=(... git) | ggsup | git branch --set-upstream-to=origin/$(git_current_branch) | | ggu | git pull --rebase origin $(current_branch) | | gpsup | git push --set-upstream origin $(git_current_branch) | +| gpsupf | git push --set-upstream origin $(git_current_branch) --force-with-lease | | ghh | git help | | gignore | git update-index --assume-unchanged | | gignored | git ls-files -v \| grep "^[[:lower:]]" | diff --git a/plugins/git/git.plugin.zsh b/plugins/git/git.plugin.zsh index 7544ca440..fc2c08ccd 100644 --- a/plugins/git/git.plugin.zsh +++ b/plugins/git/git.plugin.zsh @@ -199,6 +199,7 @@ alias ggpush='git push origin "$(git_current_branch)"' alias ggsup='git branch --set-upstream-to=origin/$(git_current_branch)' alias gpsup='git push --set-upstream origin $(git_current_branch)' +alias gpsupf='git push --set-upstream origin $(git_current_branch) --force-with-lease' alias ghh='git help' @@ -341,4 +342,4 @@ function grename() { fi } -unset git_version \ No newline at end of file +unset git_version From b2313ec7493dc127c9712f20654579221d0bcce6 Mon Sep 17 00:00:00 2001 From: Alex Date: Thu, 22 Oct 2020 21:57:23 -0400 Subject: [PATCH 162/672] feat(installer): respect and install in `$ZDOTDIR` if set (#9376) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Fixes #9001 Fixes #10479 Closes #9376 Co-authored-by: Marc Cornellà --- tools/install.sh | 45 ++++++++++++++++++++++++++++++--------------- 1 file changed, 30 insertions(+), 15 deletions(-) diff --git a/tools/install.sh b/tools/install.sh index a6538f9d7..4582ed03e 100755 --- a/tools/install.sh +++ b/tools/install.sh @@ -16,6 +16,9 @@ # ZSH=~/.zsh sh install.sh # # Respects the following environment variables: +# ZDOTDIR - path to Zsh dotfiles directory (default: unset). See [1][2] +# [1] https://zsh.sourceforge.io/Doc/Release/Parameters.html#index-ZDOTDIR +# [2] https://zsh.sourceforge.io/Doc/Release/Files.html#index-ZDOTDIR_002c-use-of # ZSH - path to the Oh My Zsh repository folder (default: $HOME/.oh-my-zsh) # REPO - name of the GitHub repo to install from (default: ohmyzsh/ohmyzsh) # REMOTE - full remote URL of the git repo to install (default: GitHub via HTTPS) @@ -53,8 +56,17 @@ HOME="${HOME:-$(eval echo ~$USER)}" # Track if $ZSH was provided custom_zsh=${ZSH:+yes} -# Default settings +# Use $zdot to keep track of where the directory is for zsh dotfiles +# To check if $ZDOTDIR was provided, explicitly check for $ZDOTDIR +zdot="${ZDOTDIR:-$HOME}" + +# Default value for $ZSH +# a) if $ZDOTDIR is supplied: $ZDOTDIR/ohmyzsh +# b) otherwise, $HOME/.oh-my-zsh +ZSH="${ZSH:-${ZDOTDIR:+$ZDOTDIR/ohmyzsh}}" ZSH="${ZSH:-$HOME/.oh-my-zsh}" + +# Default settings REPO=${REPO:-ohmyzsh/ohmyzsh} REMOTE=${REMOTE:-https://github.com/${REPO}.git} BRANCH=${BRANCH:-master} @@ -311,11 +323,11 @@ setup_zshrc() { echo "${FMT_BLUE}Looking for an existing zsh config...${FMT_RESET}" # Must use this exact name so uninstall.sh can find it - OLD_ZSHRC=~/.zshrc.pre-oh-my-zsh - if [ -f ~/.zshrc ] || [ -h ~/.zshrc ]; then + OLD_ZSHRC="$zdot/.zshrc.pre-oh-my-zsh" + if [ -f "$zdot/.zshrc" ] || [ -h "$zdot/.zshrc" ]; then # Skip this if the user doesn't want to replace an existing .zshrc if [ "$KEEP_ZSHRC" = yes ]; then - echo "${FMT_YELLOW}Found ~/.zshrc.${FMT_RESET} ${FMT_GREEN}Keeping...${FMT_RESET}" + echo "${FMT_YELLOW}Found ${zdot}/.zshrc.${FMT_RESET} ${FMT_GREEN}Keeping...${FMT_RESET}" return fi if [ -e "$OLD_ZSHRC" ]; then @@ -327,19 +339,22 @@ setup_zshrc() { fi mv "$OLD_ZSHRC" "${OLD_OLD_ZSHRC}" - echo "${FMT_YELLOW}Found old ~/.zshrc.pre-oh-my-zsh." \ + echo "${FMT_YELLOW}Found old .zshrc.pre-oh-my-zsh." \ "${FMT_GREEN}Backing up to ${OLD_OLD_ZSHRC}${FMT_RESET}" fi - echo "${FMT_YELLOW}Found ~/.zshrc.${FMT_RESET} ${FMT_GREEN}Backing up to ${OLD_ZSHRC}${FMT_RESET}" - mv ~/.zshrc "$OLD_ZSHRC" + echo "${FMT_YELLOW}Found ${zdot}/.zshrc.${FMT_RESET} ${FMT_GREEN}Backing up to ${OLD_ZSHRC}${FMT_RESET}" + mv "$zdot/.zshrc" "$OLD_ZSHRC" fi - echo "${FMT_GREEN}Using the Oh My Zsh template file and adding it to ~/.zshrc.${FMT_RESET}" + echo "${FMT_GREEN}Using the Oh My Zsh template file and adding it to $zdot/.zshrc.${FMT_RESET}" - # Replace $HOME path with '$HOME' in $ZSH variable in .zshrc file - omz=$(echo "$ZSH" | sed "s|^$HOME/|\$HOME/|") - sed "s|^export ZSH=.*$|export ZSH=\"${omz}\"|" "$ZSH/templates/zshrc.zsh-template" > ~/.zshrc-omztemp - mv -f ~/.zshrc-omztemp ~/.zshrc + # Modify $ZSH variable in .zshrc directory to use the literal $ZDOTDIR or $HOME + omz="$ZSH" + [ -z "$ZDOTDIR" ] || omz=$(echo "$omz" | sed "s|^$ZDOTDIR/|\$ZDOTDIR/|") + omz=$(echo "$omz" | sed "s|^$HOME/|\$HOME/|") + + sed "s|^export ZSH=.*$|export ZSH=\"${omz}\"|" "$ZSH/templates/zshrc.zsh-template" > "$zdot/.zshrc-omztemp" + mv -f "$zdot/.zshrc-omztemp" "$zdot/.zshrc" echo } @@ -407,9 +422,9 @@ EOF # We're going to change the default shell, so back up the current one if [ -n "$SHELL" ]; then - echo "$SHELL" > ~/.shell.pre-oh-my-zsh + echo "$SHELL" > "$zdot/.shell.pre-oh-my-zsh" else - grep "^$USER:" /etc/passwd | awk -F: '{print $7}' > ~/.shell.pre-oh-my-zsh + grep "^$USER:" /etc/passwd | awk -F: '{print $7}' > "$zdot/.shell.pre-oh-my-zsh" fi echo "Changing your shell to $zsh..." @@ -451,7 +466,7 @@ print_success() { printf '\n' printf '\n' printf "%s %s %s\n" "Before you scream ${FMT_BOLD}${FMT_YELLOW}Oh My Zsh!${FMT_RESET} look over the" \ - "$(fmt_code "$(fmt_link ".zshrc" "file://$HOME/.zshrc" --text)")" \ + "$(fmt_code "$(fmt_link ".zshrc" "file://$zdot/.zshrc" --text)")" \ "file to select plugins, themes, and options." printf '\n' printf '%s\n' "• Follow us on Twitter: $(fmt_link @ohmyzsh https://twitter.com/ohmyzsh)" From 27f31799df369ffdd825014bbbb853ad6a1ee520 Mon Sep 17 00:00:00 2001 From: Stoyan Dimov Date: Wed, 1 Feb 2023 10:51:31 +0100 Subject: [PATCH 163/672] feat(dotnet): add `dwt` alias (#11470) --- plugins/dotnet/README.md | 1 + plugins/dotnet/dotnet.plugin.zsh | 1 + 2 files changed, 2 insertions(+) diff --git a/plugins/dotnet/README.md b/plugins/dotnet/README.md index 87dfd8f8d..a15e80577 100644 --- a/plugins/dotnet/README.md +++ b/plugins/dotnet/README.md @@ -17,6 +17,7 @@ plugins=(... dotnet) | dt | dotnet test | Run unit tests using the test runner specified in a .NET project. | | dw | dotnet watch | Watch for source file changes and restart the dotnet command. | | dwr | dotnet watch run | Watch for source file changes and restart the `run` command. | +| dwt | dotnet watch test| Watch for source file changes and restart the `test` command. | | ds | dotnet sln | Modify Visual Studio solution files. | | da | dotnet add | Add a package or reference to a .NET project. | | dp | dotnet pack | Create a NuGet package. | diff --git a/plugins/dotnet/dotnet.plugin.zsh b/plugins/dotnet/dotnet.plugin.zsh index 8ea31cdbd..89d464670 100644 --- a/plugins/dotnet/dotnet.plugin.zsh +++ b/plugins/dotnet/dotnet.plugin.zsh @@ -26,6 +26,7 @@ alias dr='dotnet run' alias dt='dotnet test' alias dw='dotnet watch' alias dwr='dotnet watch run' +alias dwt='dotnet watch test' alias ds='dotnet sln' alias da='dotnet add' alias dp='dotnet pack' From 5c9a3d2f4f5cecc019b49d8fa3c151e547f8b139 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Wed, 1 Feb 2023 21:19:55 +0100 Subject: [PATCH 164/672] fix(installer): don't use `$ZDOTDIR` in zshrc file if same as `$HOME` Fixes #11471 --- tools/install.sh | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/tools/install.sh b/tools/install.sh index 4582ed03e..3ea12f8d4 100755 --- a/tools/install.sh +++ b/tools/install.sh @@ -61,9 +61,9 @@ custom_zsh=${ZSH:+yes} zdot="${ZDOTDIR:-$HOME}" # Default value for $ZSH -# a) if $ZDOTDIR is supplied: $ZDOTDIR/ohmyzsh +# a) if $ZDOTDIR is supplied and not $HOME: $ZDOTDIR/ohmyzsh # b) otherwise, $HOME/.oh-my-zsh -ZSH="${ZSH:-${ZDOTDIR:+$ZDOTDIR/ohmyzsh}}" +[ "$ZDOTDIR" = "$HOME" ] || ZSH="${ZSH:-${ZDOTDIR:+$ZDOTDIR/ohmyzsh}}" ZSH="${ZSH:-$HOME/.oh-my-zsh}" # Default settings @@ -350,7 +350,9 @@ setup_zshrc() { # Modify $ZSH variable in .zshrc directory to use the literal $ZDOTDIR or $HOME omz="$ZSH" - [ -z "$ZDOTDIR" ] || omz=$(echo "$omz" | sed "s|^$ZDOTDIR/|\$ZDOTDIR/|") + if [ -n "$ZDOTDIR" ] && [ "$ZDOTDIR" != "$HOME" ]; then + omz=$(echo "$omz" | sed "s|^$ZDOTDIR/|\$ZDOTDIR/|") + fi omz=$(echo "$omz" | sed "s|^$HOME/|\$HOME/|") sed "s|^export ZSH=.*$|export ZSH=\"${omz}\"|" "$ZSH/templates/zshrc.zsh-template" > "$zdot/.zshrc-omztemp" From 6c3cf658f6f341f7c716d6ff16714465cb651725 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Thu, 2 Feb 2023 08:49:08 +0100 Subject: [PATCH 165/672] fix(installer): automatically create ZDOTDIR path if it doesn't exist --- tools/install.sh | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/tools/install.sh b/tools/install.sh index 3ea12f8d4..f4ef16a0c 100755 --- a/tools/install.sh +++ b/tools/install.sh @@ -523,6 +523,11 @@ EOF exit 1 fi + # Create ZDOTDIR folder structure if it doesn't exist + if [ -n "$ZDOTDIR" ]; then + mkdir -p "$ZDOTDIR" + fi + setup_ohmyzsh setup_zshrc setup_shell From b256c12d2e96d0fbe63910df82b9709cca4b38df Mon Sep 17 00:00:00 2001 From: David Yang Date: Thu, 2 Feb 2023 16:03:41 +0800 Subject: [PATCH 166/672] docs(fasd): recommend fork over original fasd (#11474) --- plugins/fasd/README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/fasd/README.md b/plugins/fasd/README.md index a5c74e5b8..7c44ac84d 100644 --- a/plugins/fasd/README.md +++ b/plugins/fasd/README.md @@ -10,7 +10,7 @@ plugins=(... fasd) ## Installation -Please find detailed installation guide [`here`](https://github.com/clvv/fasd#install) +Please find detailed installation guide [`here`](https://github.com/whjvenyl/fasd#install) ## Aliases From ea4854dba3ef72e18df2c7cc79db2806d92322eb Mon Sep 17 00:00:00 2001 From: Hazael Sanchez Date: Thu, 2 Feb 2023 02:30:34 -0800 Subject: [PATCH 167/672] feat(directories): add config to skip aliases (#11469) Co-authored-by: Carlo Sala --- README.md | 10 ++++++++++ lib/directories.zsh | 2 ++ 2 files changed, 12 insertions(+) diff --git a/README.md b/README.md index 1e4b7ff70..7f4a26cab 100644 --- a/README.md +++ b/README.md @@ -276,6 +276,16 @@ If you have many functions that go well together, you can put them as a `XYZ.plu If you would like to override the functionality of a plugin distributed with Oh My Zsh, create a plugin of the same name in the `custom/plugins/` directory and it will be loaded instead of the one in `plugins/`. +### Remove directories aliases + +If you want to skip ohmyzsh default +[directories aliases](https://github.com/ohmyzsh/ohmyzsh/blob/master/lib/directories.zsh) you can add the +following snippet to your `zshrc`, before loading `oh-my-zsh.sh` script: + +```zsh +zstyle ':omz:directories' aliases no +``` + ## Getting Updates By default, you will be prompted to check for updates every 2 weeks. You can choose other update modes by adding a line to your `~/.zshrc` file, **before Oh My Zsh is loaded**: diff --git a/lib/directories.zsh b/lib/directories.zsh index c62f56468..5aa1b3d5b 100644 --- a/lib/directories.zsh +++ b/lib/directories.zsh @@ -3,6 +3,8 @@ setopt auto_pushd setopt pushd_ignore_dups setopt pushdminus +zstyle -T ':omz:directories' aliases || return + alias -g ...='../..' alias -g ....='../../..' alias -g .....='../../../..' From f8bf8f0029a475831ebfba0799975ede20e08742 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Thu, 15 Dec 2022 23:06:06 +0100 Subject: [PATCH 168/672] fix(sudo): only call redisplay if zle is enabled Fixes #11322 --- plugins/sudo/sudo.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/sudo/sudo.plugin.zsh b/plugins/sudo/sudo.plugin.zsh index 2a0b3bfc4..66b253fe7 100644 --- a/plugins/sudo/sudo.plugin.zsh +++ b/plugins/sudo/sudo.plugin.zsh @@ -96,7 +96,7 @@ sudo-command-line() { LBUFFER="${WHITESPACE}${LBUFFER}" # Redisplay edit buffer (compatibility with zsh-syntax-highlighting) - zle redisplay + zle && zle redisplay # only run redisplay if zle is enabled } } From 9b91e8256011240cbf65ba65fbe55c5fd9dbae07 Mon Sep 17 00:00:00 2001 From: david Date: Sun, 5 Feb 2023 11:32:49 +0400 Subject: [PATCH 169/672] feat(extract): add `zpaq` support (#11478) --- plugins/extract/README.md | 1 + plugins/extract/_extract | 2 +- plugins/extract/extract.plugin.zsh | 1 + 3 files changed, 3 insertions(+), 1 deletion(-) diff --git a/plugins/extract/README.md b/plugins/extract/README.md index 44f0b05a1..f67b53618 100644 --- a/plugins/extract/README.md +++ b/plugins/extract/README.md @@ -55,6 +55,7 @@ plugins=(... extract) | `xz` | LZMA2 archive | | `zip` | Zip archive | | `zst` | Zstandard file (zstd) | +| `zpaq` | Zpaq file | See [list of archive formats](https://en.wikipedia.org/wiki/List_of_archive_formats) for more information regarding archive formats. diff --git a/plugins/extract/_extract b/plugins/extract/_extract index 27b099c9e..64678fede 100644 --- a/plugins/extract/_extract +++ b/plugins/extract/_extract @@ -3,5 +3,5 @@ _arguments \ '(-r --remove)'{-r,--remove}'[Remove archive.]' \ - "*::archive file:_files -g '(#i)*.(7z|Z|apk|aar|bz2|cab|cpio|deb|ear|gz|ipa|ipsw|jar|lrz|lz4|lzma|rar|rpm|sublime-package|tar|tar.bz2|tar.gz|tar.lrz|tar.lz|tar.lz4|tar.xz|tar.zma|tar.zst|tbz|tbz2|tgz|tlz|txz|tzst|war|whl|xpi|xz|zip|zst)(-.)'" \ + "*::archive file:_files -g '(#i)*.(7z|Z|apk|aar|bz2|cab|cpio|deb|ear|gz|ipa|ipsw|jar|lrz|lz4|lzma|rar|rpm|sublime-package|tar|tar.bz2|tar.gz|tar.lrz|tar.lz|tar.lz4|tar.xz|tar.zma|tar.zst|tbz|tbz2|tgz|tlz|txz|tzst|war|whl|xpi|xz|zip|zst|zpaq)(-.)'" \ && return 0 diff --git a/plugins/extract/extract.plugin.zsh b/plugins/extract/extract.plugin.zsh index 563d88c72..4c84ef883 100644 --- a/plugins/extract/extract.plugin.zsh +++ b/plugins/extract/extract.plugin.zsh @@ -73,6 +73,7 @@ EOF (*.zst) unzstd "$file" ;; (*.cab) cabextract -d "$extract_dir" "$file" ;; (*.cpio) cpio -idmvF "$file" ;; + (*.zpaq) zpaq x "$file" ;; (*) echo "extract: '$file' cannot be extracted" >&2 success=1 ;; From d48cbb82b1a44d646c6b12b6bfb13c5fd366e1ae Mon Sep 17 00:00:00 2001 From: Unnit Metaliya Date: Mon, 6 Feb 2023 06:07:40 -0500 Subject: [PATCH 170/672] feat(git)!: add `force-if-includes` flag (#11481) Co-authored-by: Carlo Sala Closes #11388 BREAKING CHANGE: `gpf` and `gpsupf` now have the `--force-if-includes` flag if git version is greater than 2.30. It will make force pushes more safer. See https://stackoverflow.com/questions/65837109/when-should-i-use-git-push-force-if-includes --- plugins/git/README.md | 5 ++++- plugins/git/git.plugin.zsh | 8 ++++++-- 2 files changed, 10 insertions(+), 3 deletions(-) diff --git a/plugins/git/README.md b/plugins/git/README.md index d5eaaa53f..cd018d435 100644 --- a/plugins/git/README.md +++ b/plugins/git/README.md @@ -89,7 +89,8 @@ plugins=(... git) | ggsup | git branch --set-upstream-to=origin/$(git_current_branch) | | ggu | git pull --rebase origin $(current_branch) | | gpsup | git push --set-upstream origin $(git_current_branch) | -| gpsupf | git push --set-upstream origin $(git_current_branch) --force-with-lease | +| gpsupf | git push --set-upstream origin $(git_current_branch) --force-with-lease --force-if-includes (git version >= 2.30) | +| gpsupf | git push --set-upstream origin $(git_current_branch) --force-with-lease (git version < 2.30) | | ghh | git help | | gignore | git update-index --assume-unchanged | | gignored | git ls-files -v \| grep "^[[:lower:]]" | @@ -120,6 +121,8 @@ plugins=(... git) | gp | git push | | gpd | git push --dry-run | | gpf | git push --force-with-lease | +| gpf | git push --force-with-lease --force-if-includes (git version >= 2.30) | +| gpf | git push --force-with-lease (git version < 2.30) | | gpf! | git push --force | | gpoat | git push origin --all && git push origin --tags | | gpr | git pull --rebase | diff --git a/plugins/git/git.plugin.zsh b/plugins/git/git.plugin.zsh index fc2c08ccd..7541ccff2 100644 --- a/plugins/git/git.plugin.zsh +++ b/plugins/git/git.plugin.zsh @@ -199,7 +199,9 @@ alias ggpush='git push origin "$(git_current_branch)"' alias ggsup='git branch --set-upstream-to=origin/$(git_current_branch)' alias gpsup='git push --set-upstream origin $(git_current_branch)' -alias gpsupf='git push --set-upstream origin $(git_current_branch) --force-with-lease' +is-at-least 2.30 "$git_version" \ + && alias gpsupf='git push --set-upstream origin $(git_current_branch) --force-with-lease --force-if-includes' \ + || alias gpsupf='git push --set-upstream origin $(git_current_branch) --force-with-lease' alias ghh='git help' @@ -235,7 +237,9 @@ alias gma='git merge --abort' alias gp='git push' alias gpd='git push --dry-run' -alias gpf='git push --force-with-lease' +is-at-least 2.30 "$git_version" \ + && alias gpf='git push --force-with-lease --force-if-includes' \ + || alias gpf='git push --force-with-lease' alias gpf!='git push --force' alias gpoat='git push origin --all && git push origin --tags' alias gpr='git pull --rebase' From 3fd63fdf01344bb5f5f13a9c33eb0b7a72fe4771 Mon Sep 17 00:00:00 2001 From: Andrew Stone <61954919+adrwstone@users.noreply.github.com> Date: Mon, 6 Feb 2023 07:39:37 -0330 Subject: [PATCH 171/672] feat(zsh-interactive-cd): sync version with upstream (#11024) --- plugins/zsh-interactive-cd/LICENSE | 375 ++++++++++++++++++ plugins/zsh-interactive-cd/README.md | 22 +- plugins/zsh-interactive-cd/demo.gif | Bin 0 -> 1497944 bytes .../zsh-interactive-cd.plugin.zsh | 54 ++- 4 files changed, 425 insertions(+), 26 deletions(-) create mode 100644 plugins/zsh-interactive-cd/LICENSE create mode 100644 plugins/zsh-interactive-cd/demo.gif diff --git a/plugins/zsh-interactive-cd/LICENSE b/plugins/zsh-interactive-cd/LICENSE new file mode 100644 index 000000000..40b3f8d7a --- /dev/null +++ b/plugins/zsh-interactive-cd/LICENSE @@ -0,0 +1,375 @@ +Copyright 2017-2018 Henry Chang + +Mozilla Public License Version 2.0 +================================== + +1. Definitions +-------------- + +1.1. "Contributor" + means each individual or legal entity that creates, contributes to + the creation of, or owns Covered Software. + +1.2. "Contributor Version" + means the combination of the Contributions of others (if any) used + by a Contributor and that particular Contributor's Contribution. + +1.3. "Contribution" + means Covered Software of a particular Contributor. + +1.4. "Covered Software" + means Source Code Form to which the initial Contributor has attached + the notice in Exhibit A, the Executable Form of such Source Code + Form, and Modifications of such Source Code Form, in each case + including portions thereof. + +1.5. "Incompatible With Secondary Licenses" + means + + (a) that the initial Contributor has attached the notice described + in Exhibit B to the Covered Software; or + + (b) that the Covered Software was made available under the terms of + version 1.1 or earlier of the License, but not also under the + terms of a Secondary License. + +1.6. "Executable Form" + means any form of the work other than Source Code Form. + +1.7. "Larger Work" + means a work that combines Covered Software with other material, in + a separate file or files, that is not Covered Software. + +1.8. "License" + means this document. + +1.9. "Licensable" + means having the right to grant, to the maximum extent possible, + whether at the time of the initial grant or subsequently, any and + all of the rights conveyed by this License. + +1.10. "Modifications" + means any of the following: + + (a) any file in Source Code Form that results from an addition to, + deletion from, or modification of the contents of Covered + Software; or + + (b) any new file in Source Code Form that contains any Covered + Software. + +1.11. "Patent Claims" of a Contributor + means any patent claim(s), including without limitation, method, + process, and apparatus claims, in any patent Licensable by such + Contributor that would be infringed, but for the grant of the + License, by the making, using, selling, offering for sale, having + made, import, or transfer of either its Contributions or its + Contributor Version. + +1.12. "Secondary License" + means either the GNU General Public License, Version 2.0, the GNU + Lesser General Public License, Version 2.1, the GNU Affero General + Public License, Version 3.0, or any later versions of those + licenses. + +1.13. "Source Code Form" + means the form of the work preferred for making modifications. + +1.14. "You" (or "Your") + means an individual or a legal entity exercising rights under this + License. For legal entities, "You" includes any entity that + controls, is controlled by, or is under common control with You. For + purposes of this definition, "control" means (a) the power, direct + or indirect, to cause the direction or management of such entity, + whether by contract or otherwise, or (b) ownership of more than + fifty percent (50%) of the outstanding shares or beneficial + ownership of such entity. + +2. License Grants and Conditions +-------------------------------- + +2.1. Grants + +Each Contributor hereby grants You a world-wide, royalty-free, +non-exclusive license: + +(a) under intellectual property rights (other than patent or trademark) + Licensable by such Contributor to use, reproduce, make available, + modify, display, perform, distribute, and otherwise exploit its + Contributions, either on an unmodified basis, with Modifications, or + as part of a Larger Work; and + +(b) under Patent Claims of such Contributor to make, use, sell, offer + for sale, have made, import, and otherwise transfer either its + Contributions or its Contributor Version. + +2.2. Effective Date + +The licenses granted in Section 2.1 with respect to any Contribution +become effective for each Contribution on the date the Contributor first +distributes such Contribution. + +2.3. Limitations on Grant Scope + +The licenses granted in this Section 2 are the only rights granted under +this License. No additional rights or licenses will be implied from the +distribution or licensing of Covered Software under this License. +Notwithstanding Section 2.1(b) above, no patent license is granted by a +Contributor: + +(a) for any code that a Contributor has removed from Covered Software; + or + +(b) for infringements caused by: (i) Your and any other third party's + modifications of Covered Software, or (ii) the combination of its + Contributions with other software (except as part of its Contributor + Version); or + +(c) under Patent Claims infringed by Covered Software in the absence of + its Contributions. + +This License does not grant any rights in the trademarks, service marks, +or logos of any Contributor (except as may be necessary to comply with +the notice requirements in Section 3.4). + +2.4. Subsequent Licenses + +No Contributor makes additional grants as a result of Your choice to +distribute the Covered Software under a subsequent version of this +License (see Section 10.2) or under the terms of a Secondary License (if +permitted under the terms of Section 3.3). + +2.5. Representation + +Each Contributor represents that the Contributor believes its +Contributions are its original creation(s) or it has sufficient rights +to grant the rights to its Contributions conveyed by this License. + +2.6. Fair Use + +This License is not intended to limit any rights You have under +applicable copyright doctrines of fair use, fair dealing, or other +equivalents. + +2.7. Conditions + +Sections 3.1, 3.2, 3.3, and 3.4 are conditions of the licenses granted +in Section 2.1. + +3. Responsibilities +------------------- + +3.1. Distribution of Source Form + +All distribution of Covered Software in Source Code Form, including any +Modifications that You create or to which You contribute, must be under +the terms of this License. You must inform recipients that the Source +Code Form of the Covered Software is governed by the terms of this +License, and how they can obtain a copy of this License. You may not +attempt to alter or restrict the recipients' rights in the Source Code +Form. + +3.2. Distribution of Executable Form + +If You distribute Covered Software in Executable Form then: + +(a) such Covered Software must also be made available in Source Code + Form, as described in Section 3.1, and You must inform recipients of + the Executable Form how they can obtain a copy of such Source Code + Form by reasonable means in a timely manner, at a charge no more + than the cost of distribution to the recipient; and + +(b) You may distribute such Executable Form under the terms of this + License, or sublicense it under different terms, provided that the + license for the Executable Form does not attempt to limit or alter + the recipients' rights in the Source Code Form under this License. + +3.3. Distribution of a Larger Work + +You may create and distribute a Larger Work under terms of Your choice, +provided that You also comply with the requirements of this License for +the Covered Software. If the Larger Work is a combination of Covered +Software with a work governed by one or more Secondary Licenses, and the +Covered Software is not Incompatible With Secondary Licenses, this +License permits You to additionally distribute such Covered Software +under the terms of such Secondary License(s), so that the recipient of +the Larger Work may, at their option, further distribute the Covered +Software under the terms of either this License or such Secondary +License(s). + +3.4. Notices + +You may not remove or alter the substance of any license notices +(including copyright notices, patent notices, disclaimers of warranty, +or limitations of liability) contained within the Source Code Form of +the Covered Software, except that You may alter any license notices to +the extent required to remedy known factual inaccuracies. + +3.5. Application of Additional Terms + +You may choose to offer, and to charge a fee for, warranty, support, +indemnity or liability obligations to one or more recipients of Covered +Software. However, You may do so only on Your own behalf, and not on +behalf of any Contributor. You must make it absolutely clear that any +such warranty, support, indemnity, or liability obligation is offered by +You alone, and You hereby agree to indemnify every Contributor for any +liability incurred by such Contributor as a result of warranty, support, +indemnity or liability terms You offer. You may include additional +disclaimers of warranty and limitations of liability specific to any +jurisdiction. + +4. Inability to Comply Due to Statute or Regulation +--------------------------------------------------- + +If it is impossible for You to comply with any of the terms of this +License with respect to some or all of the Covered Software due to +statute, judicial order, or regulation then You must: (a) comply with +the terms of this License to the maximum extent possible; and (b) +describe the limitations and the code they affect. Such description must +be placed in a text file included with all distributions of the Covered +Software under this License. Except to the extent prohibited by statute +or regulation, such description must be sufficiently detailed for a +recipient of ordinary skill to be able to understand it. + +5. Termination +-------------- + +5.1. The rights granted under this License will terminate automatically +if You fail to comply with any of its terms. However, if You become +compliant, then the rights granted under this License from a particular +Contributor are reinstated (a) provisionally, unless and until such +Contributor explicitly and finally terminates Your grants, and (b) on an +ongoing basis, if such Contributor fails to notify You of the +non-compliance by some reasonable means prior to 60 days after You have +come back into compliance. Moreover, Your grants from a particular +Contributor are reinstated on an ongoing basis if such Contributor +notifies You of the non-compliance by some reasonable means, this is the +first time You have received notice of non-compliance with this License +from such Contributor, and You become compliant prior to 30 days after +Your receipt of the notice. + +5.2. If You initiate litigation against any entity by asserting a patent +infringement claim (excluding declaratory judgment actions, +counter-claims, and cross-claims) alleging that a Contributor Version +directly or indirectly infringes any patent, then the rights granted to +You by any and all Contributors for the Covered Software under Section +2.1 of this License shall terminate. + +5.3. In the event of termination under Sections 5.1 or 5.2 above, all +end user license agreements (excluding distributors and resellers) which +have been validly granted by You or Your distributors under this License +prior to termination shall survive termination. + +************************************************************************ +* * +* 6. Disclaimer of Warranty * +* ------------------------- * +* * +* Covered Software is provided under this License on an "as is" * +* basis, without warranty of any kind, either expressed, implied, or * +* statutory, including, without limitation, warranties that the * +* Covered Software is free of defects, merchantable, fit for a * +* particular purpose or non-infringing. The entire risk as to the * +* quality and performance of the Covered Software is with You. * +* Should any Covered Software prove defective in any respect, You * +* (not any Contributor) assume the cost of any necessary servicing, * +* repair, or correction. This disclaimer of warranty constitutes an * +* essential part of this License. No use of any Covered Software is * +* authorized under this License except under this disclaimer. * +* * +************************************************************************ + +************************************************************************ +* * +* 7. Limitation of Liability * +* -------------------------- * +* * +* Under no circumstances and under no legal theory, whether tort * +* (including negligence), contract, or otherwise, shall any * +* Contributor, or anyone who distributes Covered Software as * +* permitted above, be liable to You for any direct, indirect, * +* special, incidental, or consequential damages of any character * +* including, without limitation, damages for lost profits, loss of * +* goodwill, work stoppage, computer failure or malfunction, or any * +* and all other commercial damages or losses, even if such party * +* shall have been informed of the possibility of such damages. This * +* limitation of liability shall not apply to liability for death or * +* personal injury resulting from such party's negligence to the * +* extent applicable law prohibits such limitation. Some * +* jurisdictions do not allow the exclusion or limitation of * +* incidental or consequential damages, so this exclusion and * +* limitation may not apply to You. * +* * +************************************************************************ + +8. Litigation +------------- + +Any litigation relating to this License may be brought only in the +courts of a jurisdiction where the defendant maintains its principal +place of business and such litigation shall be governed by laws of that +jurisdiction, without reference to its conflict-of-law provisions. +Nothing in this Section shall prevent a party's ability to bring +cross-claims or counter-claims. + +9. Miscellaneous +---------------- + +This License represents the complete agreement concerning the subject +matter hereof. If any provision of this License is held to be +unenforceable, such provision shall be reformed only to the extent +necessary to make it enforceable. Any law or regulation which provides +that the language of a contract shall be construed against the drafter +shall not be used to construe this License against a Contributor. + +10. Versions of the License +--------------------------- + +10.1. New Versions + +Mozilla Foundation is the license steward. Except as provided in Section +10.3, no one other than the license steward has the right to modify or +publish new versions of this License. Each version will be given a +distinguishing version number. + +10.2. Effect of New Versions + +You may distribute the Covered Software under the terms of the version +of the License under which You originally received the Covered Software, +or under the terms of any subsequent version published by the license +steward. + +10.3. Modified Versions + +If you create software not governed by this License, and you want to +create a new license for such software, you may create and use a +modified version of this License if you rename the license and remove +any references to the name of the license steward (except to note that +such modified license differs from this License). + +10.4. Distributing Source Code Form that is Incompatible With Secondary +Licenses + +If You choose to distribute Source Code Form that is Incompatible With +Secondary Licenses under the terms of this version of the License, the +notice described in Exhibit B of this License must be attached. + +Exhibit A - Source Code Form License Notice +------------------------------------------- + + This Source Code Form is subject to the terms of the Mozilla Public + License, v. 2.0. If a copy of the MPL was not distributed with this + file, You can obtain one at http://mozilla.org/MPL/2.0/. + +If it is not possible or desirable to put the notice in a particular +file, then You may include the notice in a location (such as a LICENSE +file in a relevant directory) where a recipient would be likely to look +for such a notice. + +You may add additional accurate notices of copyright ownership. + +Exhibit B - "Incompatible With Secondary Licenses" Notice +--------------------------------------------------------- + + This Source Code Form is "Incompatible With Secondary Licenses", as + defined by the Mozilla Public License, v. 2.0. diff --git a/plugins/zsh-interactive-cd/README.md b/plugins/zsh-interactive-cd/README.md index c8337fbc8..4bffbf04a 100644 --- a/plugins/zsh-interactive-cd/README.md +++ b/plugins/zsh-interactive-cd/README.md @@ -1,23 +1,15 @@ # zsh-interactive-cd -This plugin adds a fish-like interactive tab completion for the `cd` command. +## Demo -To use it, add `zsh-interactive-cd` to the plugins array of your zshrc file: -```zsh -plugins=(... zsh-interactive-cd) -``` +![demo](demo.gif) -![demo](https://user-images.githubusercontent.com/1441704/74360670-cb202900-4dc5-11ea-9734-f60caf726e85.gif) +## Installation + +1. Install [fzf](https://github.com/junegunn/fzf) by following its [installation instruction](https://github.com/junegunn/fzf#installation). + +2. Source `zsh-interactive-cd.plugin.zsh` in `.zshrc`. ## Usage Press tab for completion as usual, it'll launch fzf automatically. Check fzf’s [readme](https://github.com/junegunn/fzf#search-syntax) for more search syntax usage. - -## Requirements - -This plugin requires [fzf](https://github.com/junegunn/fzf). Install it by following -its [installation instructions](https://github.com/junegunn/fzf#installation). - -## Author - -[Henry Chang](https://github.com/changyuheng) diff --git a/plugins/zsh-interactive-cd/demo.gif b/plugins/zsh-interactive-cd/demo.gif new file mode 100644 index 0000000000000000000000000000000000000000..3568ecf954a3c2049908e97d355f6f187236be2e GIT binary patch literal 1497944 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 X;3jbPW_>hb&1gGZ#0+KDXh|$) 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

bogU9f46#s7|g*9DnHc#ZX1%PZw8X9rcNx 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

c0G|jOehxcrJE#~+^<4CICh<+|*h~U(_|?L& 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 z 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 z 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

vjvr*3acwQ*9%t#^SG7aLPlLPpi(q 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%0DF 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

3S3oM_iLYf& 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 cgAjFS{v{$R|C|/dev/null \ - | cut -b $(( ${length} + 2 ))- | sed '/^$/d' | while read -r line; do + | cut -b $(( ${length} + 2 ))- | command sed '/^$/d' | while read -r line; do if [[ "${line[1]}" == "." ]]; then continue fi @@ -32,13 +38,19 @@ __zic_matched_subdir_list() { seg=$(basename -- "$1") starts_with_dir=$( \ find -L "$dir" -mindepth 1 -maxdepth 1 -type d \ - 2>/dev/null | cut -b $(( ${length} + 2 ))- | sed '/^$/d' \ + 2>/dev/null | cut -b $(( ${length} + 2 ))- | command sed '/^$/d' \ | while read -r line; do if [[ "${seg[1]}" != "." && "${line[1]}" == "." ]]; then continue fi - if [[ "$line" == "$seg"* ]]; then - echo "$line" + if [ "$zic_case_insensitive" = "true" ]; then + if [[ "$line:u" == "$seg:u"* ]]; then + echo "$line" + fi + else + if [[ "$line" == "$seg"* ]]; then + echo "$line" + fi fi done ) @@ -46,19 +58,36 @@ __zic_matched_subdir_list() { echo "$starts_with_dir" else find -L "$dir" -mindepth 1 -maxdepth 1 -type d \ - 2>/dev/null | cut -b $(( ${length} + 2 ))- | sed '/^$/d' \ + 2>/dev/null | cut -b $(( ${length} + 2 ))- | command sed '/^$/d' \ | while read -r line; do if [[ "${seg[1]}" != "." && "${line[1]}" == "." ]]; then continue fi - if [[ "$line" == *"$seg"* ]]; then - echo "$line" + if [ "$zic_case_insensitive" = "true" ]; then + if [[ "$line:u" == *"$seg:u"* ]]; then + echo "$line" + fi + else + if [[ "$line" == *"$seg"* ]]; then + echo "$line" + fi fi done fi fi } +__zic_fzf_bindings() { + autoload is-at-least + fzf=$(__zic_fzf_prog) + + if $(is-at-least '0.21.0' $(${=fzf} --version)); then + echo 'shift-tab:up,tab:down,bspace:backward-delete-char/eof' + else + echo 'shift-tab:up,tab:down' + fi +} + _zic_list_generator() { __zic_matched_subdir_list "${(Q)@[-1]}" | sort } @@ -75,6 +104,7 @@ _zic_complete() { fi fzf=$(__zic_fzf_prog) + fzf_bindings=$(__zic_fzf_bindings) if [ $(echo $l | wc -l) -eq 1 ]; then matches=${(q)l} @@ -82,7 +112,7 @@ _zic_complete() { matches=$(echo $l \ | FZF_DEFAULT_OPTS="--height ${FZF_TMUX_HEIGHT:-40%} \ --reverse $FZF_DEFAULT_OPTS $FZF_COMPLETION_OPTS \ - --bind 'shift-tab:up,tab:down'" ${=fzf} \ + --bind '${fzf_bindings}'" ${=fzf} \ | while read -r item; do echo -n "${(q)item} " done) @@ -144,5 +174,7 @@ zic-completion() { } zle -N zic-completion -bindkey -M emacs '^I' zic-completion -bindkey -M viins '^I' zic-completion +if [ -z $zic_custom_binding ]; then + zic_custom_binding='^I' +fi +bindkey "${zic_custom_binding}" zic-completion From 379fe0fe131cff7a480f7975b32b0ea6fc7c2370 Mon Sep 17 00:00:00 2001 From: Julien Rottenberg Date: Tue, 7 Feb 2023 03:33:59 -0800 Subject: [PATCH 172/672] feat(azure): add `azure` plugin (#8848) Co-authored-by: hagridaaron Co-authored-by: Terry Closes #8847 --- lib/prompt_info_functions.zsh | 1 + plugins/azure/README.md | 49 +++++++++++++++++++++++++++ plugins/azure/azure.plugin.zsh | 60 ++++++++++++++++++++++++++++++++++ 3 files changed, 110 insertions(+) create mode 100644 plugins/azure/README.md create mode 100644 plugins/azure/azure.plugin.zsh diff --git a/lib/prompt_info_functions.zsh b/lib/prompt_info_functions.zsh index e5535848b..3dc9b6d10 100644 --- a/lib/prompt_info_functions.zsh +++ b/lib/prompt_info_functions.zsh @@ -18,6 +18,7 @@ function chruby_prompt_info \ vi_mode_prompt_info \ virtualenv_prompt_info \ jenv_prompt_info \ + azure_prompt_info \ tf_prompt_info \ { return 1 diff --git a/plugins/azure/README.md b/plugins/azure/README.md new file mode 100644 index 000000000..f39930851 --- /dev/null +++ b/plugins/azure/README.md @@ -0,0 +1,49 @@ +# azure + +This plugin provides completion support for [azure cli](https://docs.microsoft.com/en-us/cli/azure/) +and a few utilities to manage azure subscriptions and display them in the prompt. + +To use it, add `azure` to the plugins array in your zshrc file. + +```zsh +plugins=(... azure) +``` + +## Plugin commands + + +* `az_subscriptions`: lists the available subscriptions in the `AZURE_CONFIG_DIR` (default: `~/.azure/`). + Used to provide completion for the `azss` function. + +* `azgs`: gets the current value of `$azure_subscription`. + +* `azss []`: sets the `$azure_subscription`. + + +NOTE : because azure keeps the state of active subscription in ${AZURE_CONFIG_DIR:-$HOME/.azure/azureProfile.json}, the prompt command requires `jq` to be enabled to parse the file. If jq is not in the path the prompt will show nothing + +## Theme + +The plugin creates an `azure_prompt_info` function that you can use in your theme, which displays +the current `$azure_subscription`. It uses two variables to control how that is shown: + +- ZSH_THEME_AZURE_PREFIX: sets the prefix of the azure_subscription. Defaults to ``. + + +``` +RPROMPT='$(azure_prompt_info)' +``` + +## Develop + +On ubuntu get a working environment with : + +` docker run -it -v $(pwd):/mnt -w /mnt ubuntu bash` + +``` +apt install -y curl jq zsh git vim +sh -c "$(curl -fsSL https://raw.github.com/ohmyzsh/ohmyzsh/master/tools/install.sh)" +curl -sL https://aka.ms/InstallAzureCLIDeb | bash +``` \ No newline at end of file diff --git a/plugins/azure/azure.plugin.zsh b/plugins/azure/azure.plugin.zsh new file mode 100644 index 000000000..7bb173a5c --- /dev/null +++ b/plugins/azure/azure.plugin.zsh @@ -0,0 +1,60 @@ +# AZ Get Subscritions +function azgs() { + az account show --output tsv --query 'name' 2>/dev/null +} + +# AZ Subscription Selection +alias azss="az account set --subscription" + + +function az_subscriptions() { + az account list --all --output tsv --query '[*].name' 2> /dev/null +} + +function _az_subscriptions() { + reply=($(az_subscriptions)) +} +compctl -K _az_subscriptions azss + +# Azure prompt +function azure_prompt_info() { + [[ ! -f "${AZURE_CONFIG_DIR:-$HOME/.azure/azureProfile.json}" ]] && return + # azgs is too expensive, if we have jq, we enable the prompt + (( $+commands[jq] )) || return 1 + azgs=$(jq -r '.subscriptions[] | select(.isDefault==true) .name' ${AZURE_CONFIG_DIR:-$HOME/.azure/azureProfile.json}) + echo "${ZSH_THEME_AZURE_PREFIX:=}" +} + + +# Load az completions +function _az-homebrew-installed() { + # check if Homebrew is installed + (( $+commands[brew] )) || return 1 + + # speculatively check default brew prefix + if [ -h /usr/local/opt/az ]; then + _brew_prefix=/usr/local/opt/az + else + # ok, it is not in the default prefix + # this call to brew is expensive (about 400 ms), so at least let's make it only once + _brew_prefix=$(brew --prefix azure-cli) + fi +} + + +# get az.completion.sh location from $PATH +_az_zsh_completer_path="$commands[az_zsh_completer.sh]" + +# otherwise check common locations +if [[ -z $_az_zsh_completer_path ]]; then + # Homebrew + if _az-homebrew-installed; then + _az_zsh_completer_path=$_brew_prefix/libexec/bin/az.completion.sh + # Linux + else + _az_zsh_completer_path=/etc/bash_completion.d/azure-cli + fi +fi + +[[ -r $_az_zsh_completer_path ]] && source $_az_zsh_completer_path +unset _az_zsh_completer_path _brew_prefix From 87f1941d27df2e9a3390e5d1cddf6c264ba7311d Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Tue, 7 Feb 2023 16:17:07 +0100 Subject: [PATCH 173/672] docs(git): remove duplicated line --- plugins/git/README.md | 1 - 1 file changed, 1 deletion(-) diff --git a/plugins/git/README.md b/plugins/git/README.md index cd018d435..1c3f8acf0 100644 --- a/plugins/git/README.md +++ b/plugins/git/README.md @@ -120,7 +120,6 @@ plugins=(... git) | gma | git merge --abort | | gp | git push | | gpd | git push --dry-run | -| gpf | git push --force-with-lease | | gpf | git push --force-with-lease --force-if-includes (git version >= 2.30) | | gpf | git push --force-with-lease (git version < 2.30) | | gpf! | git push --force | From 45571bfa03934359a49f7043cbcf50abccdf448c Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Wed, 8 Feb 2023 11:35:48 +0100 Subject: [PATCH 174/672] fix(git): `gpristine` requires two `--force` flags Fixes #11483 --- plugins/git/git.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/git/git.plugin.zsh b/plugins/git/git.plugin.zsh index 7541ccff2..70e6b4439 100644 --- a/plugins/git/git.plugin.zsh +++ b/plugins/git/git.plugin.zsh @@ -104,7 +104,7 @@ compdef _git gccd=git-clone alias gcl='git clone --recurse-submodules' alias gclean='git clean --interactive -d' -alias gpristine='git reset --hard && git clean --force -dx' +alias gpristine='git reset --hard && git clean --force -dfx' alias gcm='git checkout $(git_main_branch)' alias gcd='git checkout $(git_develop_branch)' alias gcmsg='git commit --message' From 0e9e5360c400cda5a80c9394583b9acbf7cfe711 Mon Sep 17 00:00:00 2001 From: Bartek Pacia Date: Thu, 9 Feb 2023 12:24:39 +0100 Subject: [PATCH 175/672] feat(gradle): update completion from upstream (#11485) --- plugins/gradle/_gradle | 23 +++++++++++++++++------ 1 file changed, 17 insertions(+), 6 deletions(-) diff --git a/plugins/gradle/_gradle b/plugins/gradle/_gradle index 770723d85..1da5aebee 100644 --- a/plugins/gradle/_gradle +++ b/plugins/gradle/_gradle @@ -1,4 +1,3 @@ -#compdef gradle gradlew gw # # Taken from https://github.com/gradle/gradle-completion # Copyright (c) 2017 Eric Wendelin @@ -22,6 +21,8 @@ # SOFTWARE. # Terms +#compdef gradle gradlew gw + __gradle-set-project-root-dir() { local dir=`pwd` project_root_dir=`pwd` @@ -96,7 +97,7 @@ __gradle-generate-script-cache() { zle -R "Generating Gradle build script cache" # Cache all Gradle scripts local -a gradle_build_scripts - gradle_build_scripts=( $(find $project_root_dir -type f -name "*.gradle" -o -name "*.gradle.kts" 2>/dev/null | grep -E -v "$script_exclude_pattern") ) + gradle_build_scripts=( $(find $project_root_dir -type f -name "*.gradle" -o -name "*.gradle.kts" 2>/dev/null | egrep -v "$script_exclude_pattern") ) printf "%s\n" "${gradle_build_scripts[@]}" >| $cache_dir/$cache_name fi } @@ -116,9 +117,9 @@ __gradle-generate-tasks-cache() { # Reuse Gradle Daemon if IDLE but don't start a new one. local gradle_tasks_output if [[ ! -z "$($gradle_cmd --status 2>/dev/null | grep IDLE)" ]]; then - gradle_tasks_output="$($gradle_cmd --daemon --build-file $gradle_build_file --console plain -q tasks --all 2>/dev/null)" + gradle_tasks_output="$($gradle_cmd --daemon --no-scan --build-file $gradle_build_file --console=plain -q tasks --all 2>/dev/null)" else - gradle_tasks_output="$($gradle_cmd --no-daemon --build-file $gradle_build_file --console plain -q tasks --all 2>/dev/null)" + gradle_tasks_output="$($gradle_cmd --no-daemon --no-scan --build-file $gradle_build_file --console=plain -q tasks --all 2>/dev/null)" fi local gradle_all_tasks="" root_tasks="" subproject_tasks="" output_line local -a match @@ -180,7 +181,7 @@ __gradle_tasks() { local cached_checksum="$(cat $cache_dir/$cache_name.md5)" local -a cached_tasks if [[ -z $cur ]]; then - cached_tasks=(${(f)"$(cat $cache_dir/$cached_checksum)"}) + cached_tasks=(${(f)"$(grep -v "^\\\:" $cache_dir/$cached_checksum)"}) else cached_tasks=(${(f)"$(grep "^${cur//:/\\\\:}" $cache_dir/$cached_checksum)"}) fi @@ -191,7 +192,7 @@ __gradle_tasks() { # Regenerate tasks cache in the background if [[ $gradle_files_checksum != "$(cat $cache_dir/$cache_name.md5)" || ! -f $cache_dir/$gradle_files_checksum || $(wc -c < $cache_dir/$gradle_files_checksum) -le 1 ]]; then - $(__gradle-generate-tasks-cache 1>&2 2>/dev/null &) + $(__gradle-generate-tasks-cache &> /dev/null &) fi else _describe 'built-in tasks' '( @@ -262,7 +263,10 @@ __gradle_subcommand() { {-b,--build-file}'[Specifies the build file.]:build script:_files -g \*.gradle' \ {-C,--cache}'[Specifies how compiled build scripts should be cached.]:cache policy:(on rebuild)' \ {-c,--settings-file}'[Specifies the settings file.]:settings file:_files -g \*.gradle' \ + '(--configuration-cache)--no-configuration-cache[Disables the configuration cache. Gradle will not reuse the build configuration from previous builds.]' \ + '--configuration-cache-problems=[Configures how the configuration cache handles problems]:problem handling:(fail warn)' \ '(--no-configure-on-demand)--configure-on-demand[Only relevant projects are configured in this build run.]' \ + '(--no-configuration-cache)--configuration-cache[Enables the configuration cache. Gradle will try to reuse the build configuration from previous builds.]' \ '--console=[Specifies which type of console output to generate.]:console output type:(plain auto rich verbose)' \ '--continue[Continues task execution after a task failure.]' \ '-Dorg.gradle.cache.reserved.mb=[Reserve Gradle Daemon memory for operations.]' \ @@ -276,6 +280,7 @@ __gradle_subcommand() { '-Dorg.gradle.logging.level=[Set default Gradle log level.]:log level:(quiet warn lifecycle info debug)' \ '-Dorg.gradle.parallel=[Set true to enable parallel project builds.]:enable parallel build:(true false)' \ '-Dorg.gradle.priority=[Set priority for Gradle worker processes.]:priority:(low normal)' \ + '-Dorg.gradle.unsafe.watch-fs=[Set true to enable Gradle file watcher.]:enable watcher:(true false)' \ '-Dorg.gradle.warning.mode=[Set types of warnings to log.]:warning level:(all summary none)' \ '-Dorg.gradle.workers.max=[Set the number of workers Gradle is allowed to use.]' \ '(-i --info -w --warn -q --quiet)'{-d,--debug}'[Log in debug mode (includes normal stacktrace).]' \ @@ -314,6 +319,7 @@ __gradle_subcommand() { '(--write-locks)--update-locks[Perform a partial update of the dependency lock.]' \ '(-d --debug -q --quiet -i --info)'{-w,--warn}'[Log warnings and errors only.]' \ '--warning-mode=[Set types of warnings to log.]:warning mode:(all summary none)' \ + '(--no-watch-fs)--watch-fs[Gradle watches filesystem for incremental builds.]' \ '(--update-locks)--write-locks[Persists dependency resolution for locked configurations.]' \ {-x,--exclude-task}'[Specify a task to be excluded from execution.]' && ret=0 ;; @@ -347,6 +353,9 @@ _gradle() { {-b,--build-file}'[Specifies the build file.]:build script:_files -g \*.gradle' \ {-C,--cache}'[Specifies how compiled build scripts should be cached.]:cache policy:(on rebuild)' \ {-c,--settings-file}'[Specifies the settings file.]:settings file:_files -g \*.gradle:->argument-expected' \ + '(--no-configuration-cache)--configuration-cache[Enables the configuration cache. Gradle will try to reuse the build configuration from previous builds.]' \ + '(--configuration-cache)--no-configuration-cache[Disables the configuration cache. Gradle will not reuse the build configuration from previous builds.]' \ + '--configuration-cache-problems=[Configures how the configuration cache handles problems]:problem handling:(fail warn)' \ '(--no-configure-on-demand)--configure-on-demand[Only relevant projects are configured in this build run.]' \ '--console=[Specifies which type of console output to generate.]:console output type:(plain auto rich verbose)' \ '--continue[Continues task execution after a task failure.]' \ @@ -361,6 +370,7 @@ _gradle() { '-Dorg.gradle.logging.level=[Set default Gradle log level.]:log level:(quiet warn lifecycle info debug)' \ '-Dorg.gradle.parallel=[Set true to enable parallel project builds.]:(true false)' \ '-Dorg.gradle.priority=[Set priority for Gradle worker processes.]:priority:(low normal)' \ + '-Dorg.gradle.unsafe.watch-fs=[Set true to enable Gradle file watcher.]:enable watcher:(true false)' \ '-Dorg.gradle.warning.mode=[Set types of warnings to log.]:warning level:(all summary none)' \ '-Dorg.gradle.workers.max=[Set the number of workers Gradle is allowed to use.]' \ '(-i --info -w --warn -q --quiet)'{-d,--debug}'[Log in debug mode (includes normal stacktrace).]' \ @@ -404,6 +414,7 @@ _gradle() { '(-d --debug -q --quiet -i --info)'{-w,--warn}'[Log warnings and errors only.]' \ '--warning-mode=[Set types of warnings to log.]:warning mode:(all summary none)' \ '(--update-locks)--write-locks[Persists dependency resolution for locked configurations.]' \ + '(--no-watch-fs)--watch-fs[Gradle watches filesystem for incremental builds.]' \ {-x,--exclude-task}'[Specify a task to be excluded from execution.]' \ '(-)*:: :->task-or-option' && ret=0 From 041c35ffc8cd97dd6327f44e35fa777af6f8e845 Mon Sep 17 00:00:00 2001 From: Samyak Sarnayak Date: Thu, 9 Feb 2023 16:57:41 +0530 Subject: [PATCH 176/672] feat(amuse): add virtualenv support (#8987) Fixes #7766 Closes #8814 --- themes/amuse.zsh-theme | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/themes/amuse.zsh-theme b/themes/amuse.zsh-theme index 3f7ec0bc5..d787fdaa4 100644 --- a/themes/amuse.zsh-theme +++ b/themes/amuse.zsh-theme @@ -11,8 +11,14 @@ ZSH_THEME_RUBY_PROMPT_PREFIX="%{$fg_bold[red]%}‹" ZSH_THEME_RUBY_PROMPT_SUFFIX="›%{$reset_color%}" PROMPT=' -%{$fg_bold[green]%}%~%{$reset_color%}$(git_prompt_info) ⌚ %{$fg_bold[red]%}%*%{$reset_color%} +%{$fg_bold[green]%}%~%{$reset_color%}$(git_prompt_info)$(virtualenv_prompt_info) ⌚ %{$fg_bold[red]%}%*%{$reset_color%} $ ' RPROMPT='$(ruby_prompt_info)' +VIRTUAL_ENV_DISABLE_PROMPT=0 +ZSH_THEME_VIRTUAL_ENV_PROMPT_PREFIX=" %{$fg[green]%}🐍" +ZSH_THEME_VIRTUAL_ENV_PROMPT_SUFFIX="%{$reset_color%}" +ZSH_THEME_VIRTUALENV_PREFIX=$ZSH_THEME_VIRTUAL_ENV_PROMPT_PREFIX +ZSH_THEME_VIRTUALENV_SUFFIX=$ZSH_THEME_VIRTUAL_ENV_PROMPT_SUFFIX + From f9104d155f618f2d6f5e13af648c81a5d036a592 Mon Sep 17 00:00:00 2001 From: Bartek Pacia Date: Sat, 11 Feb 2023 20:54:20 +0100 Subject: [PATCH 177/672] fix(gradle): move compdef line (#11488) --- plugins/gradle/_gradle | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/plugins/gradle/_gradle b/plugins/gradle/_gradle index 1da5aebee..f8df928b4 100644 --- a/plugins/gradle/_gradle +++ b/plugins/gradle/_gradle @@ -1,3 +1,6 @@ +#compdef gradle gradlew gw +# THE LINE ABOVE MUST BE THE FIRST LINE OF THIS FILE IN ORDER FOR COMPLETION TO WORK + # # Taken from https://github.com/gradle/gradle-completion # Copyright (c) 2017 Eric Wendelin @@ -21,8 +24,6 @@ # SOFTWARE. # Terms -#compdef gradle gradlew gw - __gradle-set-project-root-dir() { local dir=`pwd` project_root_dir=`pwd` From 3e1c0d51cb66cf02357b25f514d55a3de8197647 Mon Sep 17 00:00:00 2001 From: GrandZhuo Date: Sun, 12 Feb 2023 16:53:04 +0800 Subject: [PATCH 178/672] fix(fzf): installation dir for brew M1 (#11490) --- plugins/fzf/fzf.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/fzf/fzf.plugin.zsh b/plugins/fzf/fzf.plugin.zsh index 7bb6667d0..b253a23d2 100644 --- a/plugins/fzf/fzf.plugin.zsh +++ b/plugins/fzf/fzf.plugin.zsh @@ -9,7 +9,7 @@ function fzf_setup_using_base_dir() { "${HOME}/.nix-profile/share/fzf" "${XDG_DATA_HOME:-$HOME/.local/share}/fzf" "/usr/local/opt/fzf" - "/opt/homebrew/bin/fzf" + "/opt/homebrew/opt/fzf" "/usr/share/fzf" "/usr/local/share/examples/fzf" ) From ed407466b8ae3c12c2f03da004d721618e64fd49 Mon Sep 17 00:00:00 2001 From: Ruben van Erk Date: Sun, 12 Feb 2023 16:05:06 +0100 Subject: [PATCH 179/672] docs(lando): php support (#11491) --- plugins/lando/README.md | 1 + 1 file changed, 1 insertion(+) diff --git a/plugins/lando/README.md b/plugins/lando/README.md index 928a42bca..6daeae4e4 100644 --- a/plugins/lando/README.md +++ b/plugins/lando/README.md @@ -17,6 +17,7 @@ plugins=(... lando) | `drush` | `lando drush` | | `gulp` | `lando gulp` | | `npm` | `lando npm` | +| `php` | `lando php` | | `wp` | `lando wp` | | `yarn` | `lando yarn` | From 416560c9bf0c03afe6f576ab9e420256843bfb8b Mon Sep 17 00:00:00 2001 From: Richard Mitchell Date: Sun, 12 Feb 2023 11:46:25 -0500 Subject: [PATCH 180/672] docs(lib/directories): comment how to disable alias (#11489) --- lib/directories.zsh | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/lib/directories.zsh b/lib/directories.zsh index 5aa1b3d5b..091140626 100644 --- a/lib/directories.zsh +++ b/lib/directories.zsh @@ -3,6 +3,11 @@ setopt auto_pushd setopt pushd_ignore_dups setopt pushdminus +# add (uncommented): +# zstyle ':omz:directories' aliases no +# to your `zshrc` before loading `oh-my-zsh.sh` +# to disable the following aliases and functions + zstyle -T ':omz:directories' aliases || return alias -g ...='../..' From 69b5737daf0448ad7e6686174638be74f86afdec Mon Sep 17 00:00:00 2001 From: shelfofclub Date: Tue, 14 Feb 2023 20:44:23 +0800 Subject: [PATCH 181/672] fix(af-magic): fix python venv checking logic (#11495) --- themes/af-magic.zsh-theme | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/themes/af-magic.zsh-theme b/themes/af-magic.zsh-theme index 2ef9b02d7..1b629e43a 100644 --- a/themes/af-magic.zsh-theme +++ b/themes/af-magic.zsh-theme @@ -10,7 +10,7 @@ function afmagic_dashes { # if there is a python virtual environment and it is displayed in # the prompt, account for it when returning the number of dashes - if [[ -n "$python_env" && "$PS1" = \(* ]]; then + if [[ -n "$python_env" && "$PS1" = *\(${python_env}\)* ]]; then echo $(( COLUMNS - ${#python_env} - 3 )) else echo $COLUMNS From 574669da6b71462c1f92c75ad75f66476b92974c Mon Sep 17 00:00:00 2001 From: Richard Mitchell Date: Sat, 11 Feb 2023 10:46:31 -0500 Subject: [PATCH 182/672] fix(correction)!: remove aliases for non standard commands BREAKING CHANGE: This commit removes aliases for some commands that previously were not being autocorrected. If you are using autocorrection, please check it. --- lib/correction.zsh | 5 ----- 1 file changed, 5 deletions(-) diff --git a/lib/correction.zsh b/lib/correction.zsh index 4259d3418..ba9664fcb 100644 --- a/lib/correction.zsh +++ b/lib/correction.zsh @@ -1,13 +1,8 @@ if [[ "$ENABLE_CORRECTION" == "true" ]]; then alias cp='nocorrect cp' - alias ebuild='nocorrect ebuild' - alias gist='nocorrect gist' - alias heroku='nocorrect heroku' - alias hpodder='nocorrect hpodder' alias man='nocorrect man' alias mkdir='nocorrect mkdir' alias mv='nocorrect mv' - alias mysql='nocorrect mysql' alias sudo='nocorrect sudo' alias su='nocorrect su' From 8a68bf67720a6a5442ae947d10d74b1dd3558d91 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Thu, 16 Feb 2023 12:54:23 +0100 Subject: [PATCH 183/672] fix(theme-and-appearance): test color ls with $ZSH directory Fixes #11500 --- lib/theme-and-appearance.zsh | 17 +++++++++++------ 1 file changed, 11 insertions(+), 6 deletions(-) diff --git a/lib/theme-and-appearance.zsh b/lib/theme-and-appearance.zsh index 9b908bef0..c83f58c7b 100644 --- a/lib/theme-and-appearance.zsh +++ b/lib/theme-and-appearance.zsh @@ -7,32 +7,37 @@ export LSCOLORS="Gxfxcxdxbxegedabagacad" # TODO organise this chaotic logic if [[ "$DISABLE_LS_COLORS" != "true" ]]; then + if [[ -d "$ZSH" ]]; then + _test_dir="$ZSH" + else + _test_dir="." + fi # Find the option for using colors in ls, depending on the version if [[ "$OSTYPE" == netbsd* ]]; then # On NetBSD, test if "gls" (GNU ls) is installed (this one supports colors); # otherwise, leave ls as is, because NetBSD's ls doesn't support -G - gls --color -d . &>/dev/null && alias ls='gls --color=tty' + gls --color -d "$_test_dir" &>/dev/null && alias ls='gls --color=tty' elif [[ "$OSTYPE" == openbsd* ]]; then # On OpenBSD, "gls" (ls from GNU coreutils) and "colorls" (ls from base, # with color and multibyte support) are available from ports. "colorls" # will be installed on purpose and can't be pulled in by installing # coreutils, so prefer it to "gls". - gls --color -d . &>/dev/null && alias ls='gls --color=tty' - colorls -G -d . &>/dev/null && alias ls='colorls -G' + gls --color -d "$_test_dir" &>/dev/null && alias ls='gls --color=tty' + colorls -G -d "$_test_dir" &>/dev/null && alias ls='colorls -G' elif [[ "$OSTYPE" == (darwin|freebsd)* ]]; then # this is a good alias, it works by default just using $LSCOLORS - ls -G . &>/dev/null && alias ls='ls -G' + ls -G "$_test_dir" &>/dev/null && alias ls='ls -G' # only use coreutils ls if there is a dircolors customization present ($LS_COLORS or .dircolors file) # otherwise, gls will use the default color scheme which is ugly af - [[ -n "$LS_COLORS" || -f "$HOME/.dircolors" ]] && gls --color -d . &>/dev/null && alias ls='gls --color=tty' + [[ -n "$LS_COLORS" || -f "$HOME/.dircolors" ]] && gls --color -d "$_test_dir" &>/dev/null && alias ls='gls --color=tty' else # For GNU ls, we use the default ls color theme. They can later be overwritten by themes. if [[ -z "$LS_COLORS" ]]; then (( $+commands[dircolors] )) && eval "$(dircolors -b)" fi - ls --color -d . &>/dev/null && alias ls='ls --color=tty' || { ls -G . &>/dev/null && alias ls='ls -G' } + ls --color -d "$_test_dir" &>/dev/null && alias ls='ls --color=tty' || { ls -G "$_test_dir" &>/dev/null && alias ls='ls -G' } # Take advantage of $LS_COLORS for completion as well. zstyle ':completion:*' list-colors "${(s.:.)LS_COLORS}" From 25368f9a65e805a961884ce70206c907218fc741 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Juan=20Antonio=20Ram=C3=ADrez?= Date: Fri, 17 Feb 2023 03:09:00 -0400 Subject: [PATCH 184/672] fix(gcloud): add location of latest snap install (#11502) Latest snap installs gcloud at /snap/google-cloud-cli, so add that to the list of possible locations. --- plugins/gcloud/gcloud.plugin.zsh | 1 + 1 file changed, 1 insertion(+) diff --git a/plugins/gcloud/gcloud.plugin.zsh b/plugins/gcloud/gcloud.plugin.zsh index 9be9d68aa..30f1dba8f 100644 --- a/plugins/gcloud/gcloud.plugin.zsh +++ b/plugins/gcloud/gcloud.plugin.zsh @@ -10,6 +10,7 @@ if [[ -z "${CLOUDSDK_HOME}" ]]; then "/opt/homebrew/Caskroom/google-cloud-sdk/latest/google-cloud-sdk" "/usr/share/google-cloud-sdk" "/snap/google-cloud-sdk/current" + "/snap/google-cloud-cli/current" "/usr/lib/google-cloud-sdk" "/usr/lib64/google-cloud-sdk" "/opt/google-cloud-sdk" From aace3a6144a859d877927746a865de820e5af838 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Fri, 17 Feb 2023 16:42:59 +0100 Subject: [PATCH 185/672] chore: add `.idea` directory to `.gitignore` --- .gitignore | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/.gitignore b/.gitignore index 71ae444e5..10bd4bebc 100644 --- a/.gitignore +++ b/.gitignore @@ -8,4 +8,5 @@ log/ .DS_Store # editor configs -.vscode \ No newline at end of file +.vscode +.idea From cc73a929f637899407d7a17648f89c63b71cc1ff Mon Sep 17 00:00:00 2001 From: guenthgr Date: Fri, 17 Feb 2023 17:29:10 +0100 Subject: [PATCH 186/672] feat(git): add `gpod` alias Closes #11501 --- plugins/git/README.md | 1 + plugins/git/git.plugin.zsh | 1 + 2 files changed, 2 insertions(+) diff --git a/plugins/git/README.md b/plugins/git/README.md index 1c3f8acf0..9972a6d8d 100644 --- a/plugins/git/README.md +++ b/plugins/git/README.md @@ -124,6 +124,7 @@ plugins=(... git) | gpf | git push --force-with-lease (git version < 2.30) | | gpf! | git push --force | | gpoat | git push origin --all && git push origin --tags | +| gpod | git push origin --delete | | gpr | git pull --rebase | | gpu | git push upstream | | gpv | git push --verbose | diff --git a/plugins/git/git.plugin.zsh b/plugins/git/git.plugin.zsh index 70e6b4439..b016d80db 100644 --- a/plugins/git/git.plugin.zsh +++ b/plugins/git/git.plugin.zsh @@ -242,6 +242,7 @@ is-at-least 2.30 "$git_version" \ || alias gpf='git push --force-with-lease' alias gpf!='git push --force' alias gpoat='git push origin --all && git push origin --tags' +alias gpod='git push origin --delete' alias gpr='git pull --rebase' alias gpu='git push upstream' alias gpv='git push --verbose' From 8c808da23c9bafdc9d4b7b73934d6621d3a1f83e Mon Sep 17 00:00:00 2001 From: Francesco Ilario Date: Mon, 20 Feb 2023 15:35:58 +0100 Subject: [PATCH 187/672] feat(git): add aliases for gone branches (#9250) Closes #8457 Closes #9973 --- plugins/git/README.md | 3 +++ plugins/git/git.plugin.zsh | 3 +++ 2 files changed, 6 insertions(+) diff --git a/plugins/git/README.md b/plugins/git/README.md index 9972a6d8d..0895ce39c 100644 --- a/plugins/git/README.md +++ b/plugins/git/README.md @@ -25,6 +25,9 @@ plugins=(... git) | gbd | git branch --delete | | gbda | git branch --no-color --merged \| grep -vE "^([+*]\|\s*($(git_main_branch)\|$(git_develop_branch))\s*$)" \| xargs git branch --delete 2>/dev/null | | gbD | git branch --delete --force | +| gbg | git branch -vv | grep ": gone\]" | +| gbgd | local res=$(git branch -vv | grep ": gone\]" | awk '{print $1}') && [[ $res ]] && echo $res | xargs git branch -d | +| gbgD | local res=$(git branch -vv | grep ": gone\]" | awk '{print $1}') && [[ $res ]] && echo $res | xargs git branch -D | | gbl | git blame -b -w | | gbnm | git branch --no-merged | | gbr | git branch --remote | diff --git a/plugins/git/git.plugin.zsh b/plugins/git/git.plugin.zsh index b016d80db..ed17436e8 100644 --- a/plugins/git/git.plugin.zsh +++ b/plugins/git/git.plugin.zsh @@ -73,6 +73,9 @@ alias gba='git branch --all' alias gbd='git branch --delete' alias gbda='git branch --no-color --merged | command grep -vE "^([+*]|\s*($(git_main_branch)|$(git_develop_branch))\s*$)" | command xargs git branch --delete 2>/dev/null' alias gbD='git branch --delete --force' +alias gbg='git branch -vv | grep ": gone\]"' +alias gbgd='local res=$(gbg | awk '"'"'{print $1}'"'"') && [[ $res ]] && echo $res | xargs git branch -d' +alias gbgD='local res=$(gbg | awk '"'"'{print $1}'"'"') && [[ $res ]] && echo $res | xargs git branch -D' alias gbl='git blame -b -w' alias gbnm='git branch --no-merged' alias gbr='git branch --remote' From c50bac7b42e7d24dd9ef314fa9bf17859e4218ed Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Tue, 21 Feb 2023 11:19:56 +0100 Subject: [PATCH 188/672] fix(terraform): go back to zsh custom completion Revert fcbfdf42de702d55174fe2b19142ba232289671e --- plugins/terraform/_terraform | 411 +++++++++++++++++++++++++ plugins/terraform/terraform.plugin.zsh | 5 - 2 files changed, 411 insertions(+), 5 deletions(-) create mode 100644 plugins/terraform/_terraform diff --git a/plugins/terraform/_terraform b/plugins/terraform/_terraform new file mode 100644 index 000000000..625834563 --- /dev/null +++ b/plugins/terraform/_terraform @@ -0,0 +1,411 @@ +#compdef terraform + +local -a _terraform_cmds opt_args +_terraform_cmds=( + 'apply:Builds or changes infrastructure' + 'console:Interactive console for Terraform interpolations' + 'destroy:Destroy Terraform-managed infrastructure' + 'fmt:Rewrites config files to canonical format' + 'force-unlock:Manually unlock the terraform state' + 'get:Download and install modules for the configuration' + 'graph:Create a visual graph of Terraform resources' + 'import:Import existing infrastructure into Terraform' + 'init:Initialize a Terraform working directory' + 'login:Obtain and save credentials for a remote host' + 'logout:Remove locally-stored credentials for a remote host' + 'output:Read an output from a state file' + 'plan:Generate and show an execution plan' + 'providers:Prints a tree of the providers used in the configuration' + 'refresh:Update local state file against real resources' + 'show:Inspect Terraform state or plan' + 'state:Advanced state management' + 'taint:Manually mark a resource for recreation' + 'untaint:Manually unmark a resource as tainted' + 'validate:Validates the Terraform files' + 'version:Prints the Terraform version' + 'workspace:Workspace management' + '0.12upgrade:Rewrites pre-0.12 module source code for v0.12' + '0.13upgrade:Rewrites pre-0.13 module source code for v0.13' +) + +__012upgrade() { + _arguments \ + '-yes[Skip the initial introduction messages and interactive confirmation. This can be used to run this command in batch from a script.]' \ + '-force[ Override the heuristic that attempts to detect if a configuration is already written for v0.12 or later. Some of the transformations made by this command are not idempotent, so re-running against the same module may change the meanings expressions in the module.]' +} + +__013upgrade() { + _arguments \ + '-yes[Skip the initial introduction messages and interactive confirmation. This can be used to run this command in batch from a script.]' +} + +__apply() { + _arguments \ + '-auto-approve[Skip interactive approval of plan before applying.]' \ + '-backup=[(path) Path to backup the existing state file before modifying. Defaults to the "-state-out" path with ".backup" extension. Set to "-" to disable backup.]:backupfile:_files -g "*.backup"' \ + '-compact-warnings[If Terraform produces any warnings that are not accompanied by errors, show them in a more compact form that includes only the summary messages.]' \ + '-lock=[(true) Lock the state file when locking is supported.]:lock:(true false)' \ + '-lock-timeout=[(0s) Duration to retry a state lock.]' \ + '-input=[(true) Ask for input for variables if not directly set.]' \ + '-no-color[If specified, output will be colorless.]' \ + '-parallelism=[(10) Limit the number of parallel resource operations.]' \ + '-refresh=[(true) Update state prior to checking for differences. This has no effect if a plan file is given to apply.]' \ + '-state=[(terraform.tfstate) Path to read and save state (unless state-out is specified).]:statefile:_files -g "*.tfstate"' \ + '-state-out=[(path) Path to write state to that is different than "-state". This can be used to preserve the old state.]:statefile:_files -g "*.tfstate"' \ + '*-target=[(resource) Resource to target. Operation will be limited to this resource and its dependencies. This flag can be used multiple times.]:target:__statelist' \ + '*-var[("foo=bar") Set a variable in the Terraform configuration. This flag can be set multiple times.]' \ + '*-var-file=[(foo) Set variables in the Terraform configuration from a file. If "terraform.tfvars" or any ".auto.tfvars" files are present, they will be automatically loaded.]:file:_files -g "*.tfvars{,.json}"' +} + +__console() { + _arguments \ + '-state=[(terraform.tfstate) Path to read state.]' \ + '*-var[("foo=bar") Set a variable in the Terraform configuration. This flag can be set multiple times.]' \ + '*-var-file=[(foo) Set variables in the Terraform configuration from a file. If "terraform.tfvars" or any ".auto.tfvars" files are present, they will be automatically loaded.]:file:_files -g "*.tfvars{,.json}"' +} + +__destroy() { + _arguments \ + '-backup=[(path) Path to backup the existing state file before modifying. Defaults to the "-state-out" path with ".backup" extension. Set to "-" to disable backup.]:backupfile:_files -g "*.backup"' \ + '-auto-approve[Skip interactive approval before destroying.]' \ + '-force[Deprecated: same as auto-approve.]' \ + '-lock=[(true) Lock the state file when locking is supported.]:lock:(true false)' \ + '-lock-timeout=[(0s) Duration to retry a state lock.]' \ + '-no-color[If specified, output will contain no color.]' \ + '-parallelism=[(10) Limit the number of concurrent operations.]' \ + '-refresh=[(true) Update state prior to checking for differences. This has no effect if a plan file is given to apply.]' \ + '-state=[(terraform.tfstate) Path to read and save state (unless state-out is specified).]:statefile:_files -g "*.tfstate"' \ + '-state-out=[(path) Path to write state to that is different than "-state". This can be used to preserve the old state.]:statefile:_files -g "*.tfstate"' \ + '*-target=[(resource) Resource to target. Operation will be limited to this resource and its dependencies. This flag can be used multiple times.]:target:__statelist' \ + '*-var[("foo=bar") Set a variable in the Terraform configuration. This flag can be set multiple times.]' \ + '*-var-file=[(foo) Set variables in the Terraform configuration from a file. If "terraform.tfvars" or any ".auto.tfvars" files are present, they will be automatically loaded.]:file:_files -g "*.tfvars{,.json}"' +} + +__fmt() { + _arguments \ + '-list=[(true) List files whose formatting differs (always false if using STDIN)]' \ + '-write=[(true) Write result to source file instead of STDOUT (always false if using STDIN or -check)]' \ + '-diff=[(false) Display diffs of formatting changes]' \ + '-check=[(false) Check if the input is formatted. Exit status will be 0 if all input is properly formatted and non-zero otherwise.]' \ + '-recursive=[(false) Also process files in subdirectories. By default, only the given directory (or current directory) is processed.]' +} + +__force_unlock() { + _arguments \ + "-force[Don't ask for input for unlock confirmation.]" +} + +__get() { + _arguments \ + '-update=[(false) If true, modules already downloaded will be checked for updates and updated if necessary.]' \ + '-no-color[Disable text coloring in the output.]' +} + +__graph() { + _arguments \ + '-draw-cycles[Highlight any cycles in the graph with colored edges. This helps when diagnosing cycle errors.]' \ + '-type=[(plan) Type of graph to output. Can be: plan, plan-destroy, apply, validate, input, refresh.]' +} + +__import() { + _arguments \ + '-backup=[(path) Path to backup the existing state file before modifying. Defaults to the "-state-out" path with ".backup" extension. Set to "-" to disable backup.]:backupfile:_files -g "*.backup"' \ + '-config=[(path) Path to a directory of Terraform configuration files to use to configure the provider. Defaults to pwd. If no config files are present, they must be provided via the input prompts or env vars.]' \ + '-allow-missing-config[Allow import when no resource configuration block exists.]' \ + '-input=[(true) Ask for input for variables if not directly set.]' \ + '-lock=[(true) Lock the state file when locking is supported.]:lock:(true false)' \ + '-lock-timeout=[(0s) Duration to retry a state lock.]' \ + '-no-color[If specified, output will contain no color.]' \ + '-state=[(PATH) Path to the source state file. Defaults to the configured backend, or "terraform.tfstate"]:statefile:_files -g "*.tfstate"' \ + '-state-out=[(PATH) Path to the destination state file to write to. If this is not specified, the source state file will be used. This can be a new or existing path.]:statefile:_files -g "*.tfstate"' \ + '*-var[("foo=bar") Set a variable in the Terraform configuration. This flag can be set multiple times. This is only useful with the "-config" flag.]' \ + '*-var-file=[(foo) Set variables in the Terraform configuration from a file. If "terraform.tfvars" or any ".auto.tfvars" files are present, they will be automatically loaded.]:file:_files -g "*.tfvars{,.json}"' +} + +__init() { + _arguments \ + '-backend=[(true) Configure the backend for this configuration.]' \ + '-backend-config=[This can be either a path to an HCL file with key/value assignments (same format as terraform.tfvars) or a 'key=value' format. This is merged with what is in the configuration file. This can be specified multiple times. The backend type must be in the configuration itself.]' \ + '-force-copy[Suppress prompts about copying state data. This is equivalent to providing a "yes" to all confirmation prompts.]' \ + '-from-module=[(SOURCE) Copy the contents of the given module into the target directory before initialization.]' \ + '-get=[(true) Download any modules for this configuration.]' \ + '-get-plugins=[(true) Download any missing plugins for this configuration.]' \ + '-input=[(true) Ask for input if necessary. If false, will error if input was required.]' \ + '-lock=[(true) Lock the state file when locking is supported.]:lock:(true false)' \ + '-lock-timeout=[(0s) Duration to retry a state lock.]' \ + '-no-color[If specified, output will contain no color.]' \ + '-plugin-dir[Directory containing plugin binaries. This overrides all default search paths for plugins, and prevents the automatic installation of plugins. This flag can be used multiple times.]:plugin_dir:_files -/' \ + '-reconfigure[Reconfigure the backend, ignoring any saved configuration.]' \ + '-upgrade=[(false) If installing modules (-get) or plugins (-get-plugins), ignore previously-downloaded objects and install the latest version allowed within configured constraints.]' \ + '-verify-plugins=[(true) Verify the authenticity and integrity of automatically downloaded plugins.]' +} + +__login() { + _arguments \ + +} + +__logout() { + _arguments \ + +} + +__output() { + _arguments \ + '-state=[(path) Path to the state file to read. Defaults to "terraform.tfstate".]:statefile:_files -g "*.tfstate"' \ + '-no-color[If specified, output will contain no color.]' \ + '-json[If specified, machine readable output will be printed in JSON format]' +} + +__plan() { + _arguments \ + '-compact-warnings[If Terraform produces any warnings that are not accompanied by errors, show them in a more compact form that includes only the summary messages.]' \ + '-destroy[If set, a plan will be generated to destroy all resources managed by the given configuration and state.]' \ + '-detailed-exitcode[() Return detailed exit codes when the command exits. This will change the meaning of exit codes to: 0 - Succeeded, diff is empty (no changes); 1 - Errored, 2 - Succeeded; there is a diff]' \ + '-input=[(true) Ask for input for variables if not directly set.]' \ + '-lock=[(true) Lock the state file when locking is supported.]:lock:(true false)' \ + '-lock-timeout=[(0s) Duration to retry a state lock.]' \ + '-no-color[() If specified, output will contain no color.]' \ + '-out=[(path) Write a plan file to the given path. This can be used as input to the "apply" command.]' \ + '-parallelism=[(10) Limit the number of concurrent operations.]' \ + '-refresh=[(true) Update state prior to checking for differences.]' \ + '-state=[(statefile) Path to a Terraform state file to use to look up Terraform-managed resources. By default it will use the state "terraform.tfstate" if it exists.]:statefile:_files -g "*.tfstate"' \ + '*-target=[(resource) Resource to target. Operation will be limited to this resource and its dependencies. This flag can be used multiple times.]:target:__statelist' \ + '*-var[("foo=bar") Set a variable in the Terraform configuration. This flag can be set multiple times.]' \ + '*-var-file=[(foo) Set variables in the Terraform configuration from a file. If "terraform.tfvars" or any ".auto.tfvars" files are present, they will be automatically loaded.]:file:_files -g "*.tfvars{,.json}"' +} + +__providers() { + local -a __providers_cmds + __providers_cmds=( + 'mirror:Mirrors the provider plugins needed for the current configuration' + 'schema:Prints the schemas of the providers used in the configuration' + ) + _describe -t providers "providers commands" __providers_cmds + +} + +__providers_mirror() { + _arguments \ + '-platform=[(os_arch) Choose which target platform to build a mirror for.]' \ + "*:target_dir:_files -/" +} + +__providers_schema() { + _arguments \ + '-json[]' \ + '::' +} + +__refresh() { + _arguments \ + '-backup=[(path) Path to backup the existing state file before modifying. Defaults to the "-state-out" path with ".backup" extension. Set to "-" to disable backup.]::backupfile:_files -g "*.backup"' \ + '-compact-warnings[If Terraform produces any warnings that are not accompanied by errors, show them in a more compact form that includes only the summary messages.]' \ + '-input=[(true) Ask for input for variables if not directly set.]' \ + '-lock=[(true) Lock the state file when locking is supported.]:lock:(true false)' \ + '-lock-timeout=[(0s) Duration to retry a state lock.]' \ + '-no-color[If specified, output will not contain any color.]' \ + '-state=[(path) Path to read and save state (unless state-out is specified). Defaults to "terraform.tfstate".]:statefile:_files -g "*.tfstate"' \ + '-state-out=[(path) Path to write state to that is different than "-state". This can be used to preserve the old state.]:statefile:_files -g "*.tfstate"' \ + '*-target=[(resource) A Resource Address to target. Operation will be limited to this resource and its dependencies. This flag can be used multiple times.]:target:__statelist' \ + '*-var[("foo=bar") Set a variable in the Terraform configuration. This flag can be set multiple times.]' \ + '*-var-file=[(foo) Set variables in the Terraform configuration from a file. If "terraform.tfvars" or any ".auto.tfvars" files are present, they will be automatically loaded.]:file:_files -g "*.tfvars{,.json}"' +} + +__show() { + _arguments \ + '-json[If specified, output the Terraform plan or state in a machine-readable form.]' \ + '-no-color[If specified, output will not contain any color.]' +} + +__state() { + local -a __state_cmds + __state_cmds=( + 'list:List resources in the state' + 'mv:Move an item in the state' + 'pull:Pull current state and output to stdout' + 'push:Update remote state from a local state file' + 'replace-provider:Replace provider for resources in the Terraform state' + 'rm:Remove instances from the state' + 'show:Show a resource in the state' + ) + _describe -t state "state commands" __state_cmds +} + +__state_list() { + _arguments \ + '-state=[(statefile) Path to a Terraform state file to use to look up Terraform-managed resources. By default, Terraform will consult the state of the currently-selected workspace.]' \ + '-id=[(id) Filters the results to include only instances whose resource types have an attribute named id whose value equals the given id string.]' \ + "*:address:__statelist" +} + +__state_mv() { + _arguments \ + "-dry-run[If set, prints out what would've been moved but doesn't actually move anything.]" \ + '-backup=[(PATH) Path where Terraform should write the backup for the original state. This can"t be disabled. If not set, Terraform will write it to the same path as the statefile with a ".backup" extension.]:backupfile:_files -g "*.backup"' \ + '-backup-out=[(PATH) Path where Terraform should write the backup for the destination state. This can"t be disabled. If not set, Terraform will write it to the same path as the destination state file with a backup extension. This only needs to be specified if -state-out is set to a different path than -state.]:backupfile:_files -g "*.backup"' \ + "-lock=[(true) Lock the state files when locking is supported.]:lock:(true false)" \ + "-lock-timeout=[(0s) Duration to retry a state lock.]" \ + '-state=[(path) Path to the source state file. Defaults to the configured backend, or "terraform.tfstate"]:statefile:_files -g "*.tfstate"' \ + '-state-out=[(path) Path to the destination state file to write to. If this isn"t specified, the source state file will be used. This can be a new or existing path.]:statefile:_files -g "*.tfstate"' \ + "::" \ + ":source:__statelist" \ + ":destination: " +} + +__state_push() { + _arguments \ + "-force[Write the state even if lineages don't match or the remote serial is higher.]" \ + '-lock=[(true) Lock the state file when locking is supported.]:lock:(true false)' \ + "-lock-timeout=[(0s) Duration to retry a state lock.]" \ + "::" \ + ":destination:_files" +} + +__state_replace_provider() { + _arguments \ + '-auto-approve[Skip interactive approval.]' \ + '-backup=[(PATH) Path where Terraform should write the backup for the state file. This can"t be disabled. If not set, Terraform will write it to the same path as the state file with a ".backup" extension.]:backupfile:_files -g "*.backup"' \ + "-lock=[(true) Lock the state files when locking is supported.]:lock:(true false)" \ + "-lock-timeout=[(0s) Duration to retry a state lock.]" \ + '-state=[(PATH) Path to the source state file. Defaults to the configured backend, or "terraform.tfstate"]:statefile:_files -g "*.tfstate"' \ + ":from_provider_fqn:" \ + ":to_provider_fqn:" +} + +__state_rm() { + _arguments \ + "-dry-run[If set, prints out what would've been removed but doesn't actually remove anything.]" \ + '-backup=[(PATH) Path where Terraform should write the backup for the original state.]::backupfile:_files -g "*.backup"' \ + "-lock=[(true) Lock the state file when locking is supported.]:lock:(true false)" \ + "-lock-timeout=[(0s) Duration to retry a state lock.]" \ + '-state=[(PATH) Path to the state file to update. Defaults to the current workspace state.]:statefile:_files -g "*.tfstate"' \ + "*:address:__statelist" +} + + +__state_show() { + _arguments \ + '-state=[(statefile) Path to a Terraform state file to use to look up Terraform-managed resources. By default it will use the state "terraform.tfstate" if it exists.]:statefile:_files -g "*.tfstate"' \ + "*:address:__statelist" +} + +__statelist() { + compadd $(terraform state list $opt_args[-state]) +} + +__taint() { + _arguments \ + '-allow-missing[If specified, the command will succeed (exit code 0) even if the resource is missing.]' \ + '-backup=[(path) Path to backup the existing state file before modifying. Defaults to the "-state-out" path with ".backup" extension. Set to "-" to disable backup.]:backupfile:_files -g "*.backup"' \ + '-lock=[(true) Lock the state file when locking is supported.]:lock:(true false)' \ + '-lock-timeout=[(0s) Duration to retry a state lock.]' \ + '-module=[(path) The module path where the resource lives. By default this will be root. Child modules can be specified by names. Ex. "consul" or "consul.vpc" (nested modules).]' \ + '-state=[(path) Path to read and save state (unless state-out is specified). Defaults to "terraform.tfstate".]:statefile:_files -g "*.tfstate"' \ + '-state-out=[(path) Path to write updated state file. By default, the "-state" path will be used.]:statefile:_files -g "*.tfstate"' \ + "*:address:__statelist" +} + +__untaint() { + _arguments \ + '-allow-missing[If specified, the command will succeed (exit code 0) even if the resource is missing.]' \ + '-backup=[(path) Path to backup the existing state file before modifying. Defaults to the "-state-out" path with ".backup" extension. Set to "-" to disable backup.]:backupfile:_files -g "*.backup"' \ + '-lock=[(true) Lock the state file when locking is supported.]:lock:(true false)' \ + '-lock-timeout=[(0s) Duration to retry a state lock.]' \ + '-module=[(path) The module path where the resource lives. By default this will be root. Child modules can be specified by names. Ex. "consul" or "consul.vpc" (nested modules).]' \ + '-state=[(path) Path to read and save state (unless state-out is specified). Defaults to "terraform.tfstate".]:statefile:_files -g "*.tfstate"' \ + '-state-out=[(path) Path to write updated state file. By default, the "-state" path will be used.]:statefile:_files -g "*.tfstate"' +} + +__validate() { + _arguments \ + '-no-color[If specified, output will not contain any color.]' \ + '-json[Produce output in a machine-readable JSON format, suitable for use in text editor integrations and other automated systems.]' \ + ':dir:_files -/' +} + +__version() { + _arguments \ + '-json[Output the version information as a JSON object.]' +} + +__workspace() { + local -a __workspace_cmds + __workspace_cmds=( + 'delete:Delete a workspace' + 'list:List Workspaces' + 'new:Create a new workspace' + 'select:Select a workspace' + 'show:Show the name of the current workspace' + ) + _describe -t workspace "workspace commands" __workspace_cmds +} + +_arguments '*:: :->command' + +if (( CURRENT == 1 )); then + _describe -t commands "terraform command" _terraform_cmds + return +fi + +local -a _command_args +case "$words[1]" in + 0.12upgrade) + __012upgrade ;; + 0.13upgrade) + __013upgrade ;; + apply) + __apply ;; + console) + __console;; + destroy) + __destroy ;; + fmt) + __fmt;; + force-unlock) + __force_unlock;; + get) + __get ;; + graph) + __graph ;; + import) + __import;; + init) + __init ;; + login) + __login ;; + logout) + __logout ;; + output) + __output ;; + plan) + __plan ;; + providers) + test $CURRENT -lt 3 && __providers + [[ $words[2] = "mirror" ]] && __providers_mirror + [[ $words[2] = "schema" ]] && __providers_schema + ;; + refresh) + __refresh ;; + show) + __show ;; + state) + test $CURRENT -lt 3 && __state + [[ $words[2] = "list" ]] && __state_list + [[ $words[2] = "mv" ]] && __state_mv + [[ $words[2] = "push" ]] && __state_push + [[ $words[2] = "replace-provider" ]] && __state_replace_provider + [[ $words[2] = "rm" ]] && __state_rm + [[ $words[2] = "show" ]] && __state_show + ;; + taint) + __taint ;; + untaint) + __untaint ;; + validate) + __validate ;; + version) + __version ;; + workspace) + test $CURRENT -lt 3 && __workspace ;; +esac diff --git a/plugins/terraform/terraform.plugin.zsh b/plugins/terraform/terraform.plugin.zsh index eaa1e2e81..d9e39e6ac 100644 --- a/plugins/terraform/terraform.plugin.zsh +++ b/plugins/terraform/terraform.plugin.zsh @@ -16,8 +16,3 @@ alias tfi='terraform init' alias tfo='terraform output' alias tfp='terraform plan' alias tfv='terraform validate' - -if (( $+commands[terraform] )); then - autoload -U +X bashcompinit && bashcompinit - complete -o nospace -C terraform terraform -fi From 9f9d3b7d247b3c3e21542abaaf107e3d15aac1a5 Mon Sep 17 00:00:00 2001 From: rohitbahekar <57762527+rohitbahekar@users.noreply.github.com> Date: Tue, 21 Feb 2023 15:53:04 +0530 Subject: [PATCH 189/672] feat(terraform): add `tfc` alias (#10815) --- plugins/terraform/README.md | 1 + plugins/terraform/terraform.plugin.zsh | 1 + 2 files changed, 2 insertions(+) diff --git a/plugins/terraform/README.md b/plugins/terraform/README.md index 59c6e7f2a..c19f2ad1c 100644 --- a/plugins/terraform/README.md +++ b/plugins/terraform/README.md @@ -19,6 +19,7 @@ plugins=(... terraform) | ----- | -------------------- | | `tf` | `terraform` | | `tfa` | `terraform apply` | +| `tfc` | `terraform console` | | `tfd` | `terraform destroy` | | `tff` | `terraform fmt` | | `tfi` | `terraform init` | diff --git a/plugins/terraform/terraform.plugin.zsh b/plugins/terraform/terraform.plugin.zsh index d9e39e6ac..7006f204b 100644 --- a/plugins/terraform/terraform.plugin.zsh +++ b/plugins/terraform/terraform.plugin.zsh @@ -10,6 +10,7 @@ function tf_prompt_info() { alias tf='terraform' alias tfa='terraform apply' +alias tfc='terraform console' alias tfd='terraform destroy' alias tff='terraform fmt' alias tfi='terraform init' From a4f08ad238dba23a68df2a89b8fd47b8a9d26b0e Mon Sep 17 00:00:00 2001 From: Filippo Bonazzi Date: Wed, 22 Feb 2023 10:16:28 +0100 Subject: [PATCH 190/672] feat(extract): support `obscpio` format (#11511) Co-authored-by: Carlo Sala --- plugins/extract/README.md | 15 ++++++++------- plugins/extract/_extract | 2 +- plugins/extract/extract.plugin.zsh | 2 +- 3 files changed, 10 insertions(+), 9 deletions(-) diff --git a/plugins/extract/README.md b/plugins/extract/README.md index f67b53618..ac4a8e197 100644 --- a/plugins/extract/README.md +++ b/plugins/extract/README.md @@ -1,10 +1,10 @@ # extract plugin -This plugin defines a function called `extract` that extracts the archive file -you pass it, and it supports a wide variety of archive filetypes. +This plugin defines a function called `extract` that extracts the archive file you pass it, and it supports a +wide variety of archive filetypes. -This way you don't have to know what specific command extracts a file, you just -do `extract ` and the function takes care of the rest. +This way you don't have to know what specific command extracts a file, you just do `extract ` and +the function takes care of the rest. To use it, add `extract` to the plugins array in your zshrc file: @@ -15,7 +15,7 @@ plugins=(... extract) ## Supported file extensions | Extension | Description | -|:------------------|:-------------------------------------| +| :---------------- | :----------------------------------- | | `7z` | 7zip file | | `Z` | Z archive (LZW) | | `apk` | Android app file | @@ -32,6 +32,7 @@ plugins=(... extract) | `lrz` | LRZ archive | | `lz4` | LZ4 archive | | `lzma` | LZMA archive | +| `obscpio` | cpio archive used on OBS | | `rar` | WinRAR archive | | `rpm` | RPM package | | `sublime-package` | Sublime Text package | @@ -57,5 +58,5 @@ plugins=(... extract) | `zst` | Zstandard file (zstd) | | `zpaq` | Zpaq file | -See [list of archive formats](https://en.wikipedia.org/wiki/List_of_archive_formats) for -more information regarding archive formats. +See [list of archive formats](https://en.wikipedia.org/wiki/List_of_archive_formats) for more information +regarding archive formats. diff --git a/plugins/extract/_extract b/plugins/extract/_extract index 64678fede..56b17058f 100644 --- a/plugins/extract/_extract +++ b/plugins/extract/_extract @@ -3,5 +3,5 @@ _arguments \ '(-r --remove)'{-r,--remove}'[Remove archive.]' \ - "*::archive file:_files -g '(#i)*.(7z|Z|apk|aar|bz2|cab|cpio|deb|ear|gz|ipa|ipsw|jar|lrz|lz4|lzma|rar|rpm|sublime-package|tar|tar.bz2|tar.gz|tar.lrz|tar.lz|tar.lz4|tar.xz|tar.zma|tar.zst|tbz|tbz2|tgz|tlz|txz|tzst|war|whl|xpi|xz|zip|zst|zpaq)(-.)'" \ + "*::archive file:_files -g '(#i)*.(7z|Z|apk|aar|bz2|cab|cpio|deb|ear|gz|ipa|ipsw|jar|lrz|lz4|lzma|obscpio|rar|rpm|sublime-package|tar|tar.bz2|tar.gz|tar.lrz|tar.lz|tar.lz4|tar.xz|tar.zma|tar.zst|tbz|tbz2|tgz|tlz|txz|tzst|war|whl|xpi|xz|zip|zst|zpaq)(-.)'" \ && return 0 diff --git a/plugins/extract/extract.plugin.zsh b/plugins/extract/extract.plugin.zsh index 4c84ef883..7b7a2fa4f 100644 --- a/plugins/extract/extract.plugin.zsh +++ b/plugins/extract/extract.plugin.zsh @@ -72,7 +72,7 @@ EOF builtin cd -q ..; command rm *.tar.* debian-binary ;; (*.zst) unzstd "$file" ;; (*.cab) cabextract -d "$extract_dir" "$file" ;; - (*.cpio) cpio -idmvF "$file" ;; + (*.cpio|*.obscpio) cpio -idmvF "$file" ;; (*.zpaq) zpaq x "$file" ;; (*) echo "extract: '$file' cannot be extracted" >&2 From 221eb9b90ab4d03b6f00e62f31e979459e08e7ca Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E5=86=AF=E4=B8=8D=E6=B8=B8?= <71683364+mefengl@users.noreply.github.com> Date: Tue, 21 Feb 2023 03:07:45 +0800 Subject: [PATCH 191/672] feat(marktext): add plugin Closes #11507 --- plugins/marktext/README.md | 17 +++++++++++++++++ plugins/marktext/marktext.plugin.zsh | 7 +++++++ 2 files changed, 24 insertions(+) create mode 100644 plugins/marktext/README.md create mode 100644 plugins/marktext/marktext.plugin.zsh diff --git a/plugins/marktext/README.md b/plugins/marktext/README.md new file mode 100644 index 000000000..71d287451 --- /dev/null +++ b/plugins/marktext/README.md @@ -0,0 +1,17 @@ +## marktext + +Plugin for MarkText, a previewer for Markdown files on Mac OS X + +### Requirements + + * [MarkText](https://github.com/marktext/marktext) + +### Usage + + * If `marktext` is called without an argument, open MarkText + + * If `marktext` is passed a file, open it in MarkText + +### Credits + + * just copied from plugins/marked2, all credits to marked2 plugin author diff --git a/plugins/marktext/marktext.plugin.zsh b/plugins/marktext/marktext.plugin.zsh new file mode 100644 index 000000000..1da85bcca --- /dev/null +++ b/plugins/marktext/marktext.plugin.zsh @@ -0,0 +1,7 @@ +# +# If marktext is called without an argument, open MarkText +# If marktext is passed a file, open it in MarkText +# +function marktext() { + open -a "MarkText.app" "$1" +} From a24e91908adb25dfc222e6a6f6431e2fbc890545 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E5=86=AF=E4=B8=8D=E6=B8=B8?= <71683364+mefengl@users.noreply.github.com> Date: Wed, 22 Feb 2023 18:26:30 +0800 Subject: [PATCH 192/672] feat(marked): remove unnecessary code --- plugins/marked2/marked2.plugin.zsh | 7 +------ 1 file changed, 1 insertion(+), 6 deletions(-) diff --git a/plugins/marked2/marked2.plugin.zsh b/plugins/marked2/marked2.plugin.zsh index 56863ade5..45f4b65c1 100644 --- a/plugins/marked2/marked2.plugin.zsh +++ b/plugins/marked2/marked2.plugin.zsh @@ -3,10 +3,5 @@ # If marked is passed a file, open it in Marked # function marked() { - if [ "$1" ] - then - open -a "marked 2.app" "$1" - else - open -a "marked 2.app" - fi + open -a "marked 2.app" "$1" } From aca048814b2462501ab82938ff2473661182fffb Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Wed, 22 Feb 2023 15:35:12 +0100 Subject: [PATCH 193/672] fix(theme-and-appearance): avoid infinite recursion --- lib/theme-and-appearance.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/theme-and-appearance.zsh b/lib/theme-and-appearance.zsh index c83f58c7b..1b64b51d4 100644 --- a/lib/theme-and-appearance.zsh +++ b/lib/theme-and-appearance.zsh @@ -47,7 +47,7 @@ fi # enable diff color if possible. if command diff --color /dev/null /dev/null &>/dev/null; then function color-diff { - diff --color $@ + command diff --color $@ } alias diff="color-diff" compdef _diff color-diff # compdef is already loaded by this point From b54ef89fab89eaa62ece588f96d8cbd7c222d854 Mon Sep 17 00:00:00 2001 From: WaferJay <17383312+WaferJay@users.noreply.github.com> Date: Fri, 24 Feb 2023 05:32:40 +0800 Subject: [PATCH 194/672] fix(af-magic): fix logic for separator with virtualenv (#11518) --- themes/af-magic.zsh-theme | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/themes/af-magic.zsh-theme b/themes/af-magic.zsh-theme index 1b629e43a..70549d01f 100644 --- a/themes/af-magic.zsh-theme +++ b/themes/af-magic.zsh-theme @@ -6,7 +6,8 @@ # dashed separator size function afmagic_dashes { # check either virtualenv or condaenv variables - local python_env="${VIRTUAL_ENV:-$CONDA_DEFAULT_ENV}" + local python_env_dir="${VIRTUAL_ENV:-$CONDA_DEFAULT_ENV}" + local python_env="${python_env_dir##*/}" # if there is a python virtual environment and it is displayed in # the prompt, account for it when returning the number of dashes From 8a008e1f51d451db21232edd6f1709e6c5ea334e Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Thu, 23 Feb 2023 23:00:31 +0100 Subject: [PATCH 195/672] fix(azure): load completion properly for brew (#11499) Closes #11497 --- plugins/azure/azure.plugin.zsh | 12 +++++++----- 1 file changed, 7 insertions(+), 5 deletions(-) diff --git a/plugins/azure/azure.plugin.zsh b/plugins/azure/azure.plugin.zsh index 7bb173a5c..51b54dbc1 100644 --- a/plugins/azure/azure.plugin.zsh +++ b/plugins/azure/azure.plugin.zsh @@ -32,12 +32,14 @@ function _az-homebrew-installed() { (( $+commands[brew] )) || return 1 # speculatively check default brew prefix - if [ -h /usr/local/opt/az ]; then - _brew_prefix=/usr/local/opt/az + if [[ -d /usr/local ]]; then + _brew_prefix=/usr/local + elif [[ -d /opt/homebrew ]]; then + _brew_prefix=/opt/homebrew else # ok, it is not in the default prefix # this call to brew is expensive (about 400 ms), so at least let's make it only once - _brew_prefix=$(brew --prefix azure-cli) + _brew_prefix=$(brew --prefix) fi } @@ -49,12 +51,12 @@ _az_zsh_completer_path="$commands[az_zsh_completer.sh]" if [[ -z $_az_zsh_completer_path ]]; then # Homebrew if _az-homebrew-installed; then - _az_zsh_completer_path=$_brew_prefix/libexec/bin/az.completion.sh + _az_zsh_completer_path=$_brew_prefix/etc/bash_completion.d/az # Linux else _az_zsh_completer_path=/etc/bash_completion.d/azure-cli fi fi -[[ -r $_az_zsh_completer_path ]] && source $_az_zsh_completer_path +[[ -r $_az_zsh_completer_path ]] && autoload -U +X bashcompinit && bashcompinit && source $_az_zsh_completer_path unset _az_zsh_completer_path _brew_prefix From bd9c216fe04a1542913f524cad1719797ce39ba2 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Zolt=C3=A1n=20Reegn?= Date: Fri, 24 Feb 2023 17:27:15 +0100 Subject: [PATCH 196/672] feat(iterm2): add shell integration script (#11509) --- plugins/iterm2/README.md | 12 ++ plugins/iterm2/iterm2.plugin.zsh | 11 ++ plugins/iterm2/iterm2_shell_integration.zsh | 178 ++++++++++++++++++++ plugins/iterm2/update | 4 + 4 files changed, 205 insertions(+) create mode 100644 plugins/iterm2/iterm2_shell_integration.zsh create mode 100755 plugins/iterm2/update diff --git a/plugins/iterm2/README.md b/plugins/iterm2/README.md index 50cdebf5e..3d11622df 100644 --- a/plugins/iterm2/README.md +++ b/plugins/iterm2/README.md @@ -2,11 +2,20 @@ This plugin adds a few functions that are useful when using [iTerm2](https://www.iterm2.com/). + To use it, add _iterm2_ to the plugins array of your zshrc file: ``` plugins=(... iterm2) ``` +Optionally, the plugin also applies the [Shell Integration Script for iTerm2](https://iterm2.com/documentation-shell-integration.html). +You can enable the integration with zstyle. It's important to add this line +before the line sourcing oh-my-zsh: + +``` +zstyle :omz:plugins:iterm2 shell-integration yes +``` + ## Plugin commands * `_iterm2_command ` @@ -24,6 +33,9 @@ plugins=(... iterm2) * `iterm2_tab_color_reset` resets the color of iTerm2's current tab back to default. + +For shell integration features see the [official documentation](https://iterm2.com/documentation-shell-integration.html). + ## Contributors - [Aviv Rosenberg](https://github.com/avivrosenberg) diff --git a/plugins/iterm2/iterm2.plugin.zsh b/plugins/iterm2/iterm2.plugin.zsh index 9d8e40bf6..d00232a30 100644 --- a/plugins/iterm2/iterm2.plugin.zsh +++ b/plugins/iterm2/iterm2.plugin.zsh @@ -7,6 +7,17 @@ # This plugin is only relevant if the terminal is iTerm2 on OSX. if [[ "$OSTYPE" == darwin* ]] && [[ -n "$ITERM_SESSION_ID" ]] ; then + # maybe make it the default in the future and allow opting out? + if zstyle -t ':omz:plugins:iterm2' shell-integration; then + # Handle $0 according to the standard: + # https://zdharma-continuum.github.io/Zsh-100-Commits-Club/Zsh-Plugin-Standard.html + 0="${${ZERO:-${0:#$ZSH_ARGZERO}}:-${(%):-%N}}" + 0="${${(M)0:#/*}:-$PWD/$0}" + + # See official docs: https://iterm2.com/documentation-shell-integration.html + source "${0:A:h}/iterm2_shell_integration.zsh" + fi + ### # Executes an arbitrary iTerm2 command via an escape code sequence. # See https://iterm2.com/documentation-escape-codes.html for all supported commands. diff --git a/plugins/iterm2/iterm2_shell_integration.zsh b/plugins/iterm2/iterm2_shell_integration.zsh new file mode 100644 index 000000000..7871ddded --- /dev/null +++ b/plugins/iterm2/iterm2_shell_integration.zsh @@ -0,0 +1,178 @@ +# This program is free software; you can redistribute it and/or +# modify it under the terms of the GNU General Public License +# as published by the Free Software Foundation; either version 2 +# of the License, or (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program; if not, write to the Free Software +# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. + +if [[ -o interactive ]]; then + if [ "${ITERM_ENABLE_SHELL_INTEGRATION_WITH_TMUX-}""$TERM" != "tmux-256color" -a "${ITERM_ENABLE_SHELL_INTEGRATION_WITH_TMUX-}""$TERM" != "screen" -a "${ITERM_SHELL_INTEGRATION_INSTALLED-}" = "" -a "$TERM" != linux -a "$TERM" != dumb ]; then + ITERM_SHELL_INTEGRATION_INSTALLED=Yes + ITERM2_SHOULD_DECORATE_PROMPT="1" + # Indicates start of command output. Runs just before command executes. + iterm2_before_cmd_executes() { + if [ "$TERM_PROGRAM" = "iTerm.app" ]; then + printf "\033]133;C;\r\007" + else + printf "\033]133;C;\007" + fi + } + + iterm2_set_user_var() { + printf "\033]1337;SetUserVar=%s=%s\007" "$1" $(printf "%s" "$2" | base64 | tr -d '\n') + } + + # Users can write their own version of this method. It should call + # iterm2_set_user_var but not produce any other output. + # e.g., iterm2_set_user_var currentDirectory $PWD + # Accessible in iTerm2 (in a badge now, elsewhere in the future) as + # \(user.currentDirectory). + whence -v iterm2_print_user_vars > /dev/null 2>&1 + if [ $? -ne 0 ]; then + iterm2_print_user_vars() { + true + } + fi + + iterm2_print_state_data() { + local _iterm2_hostname="${iterm2_hostname-}" + if [ -z "${iterm2_hostname:-}" ]; then + _iterm2_hostname=$(hostname -f 2>/dev/null) + fi + printf "\033]1337;RemoteHost=%s@%s\007" "$USER" "${_iterm2_hostname-}" + printf "\033]1337;CurrentDir=%s\007" "$PWD" + iterm2_print_user_vars + } + + # Report return code of command; runs after command finishes but before prompt + iterm2_after_cmd_executes() { + printf "\033]133;D;%s\007" "$STATUS" + iterm2_print_state_data + } + + # Mark start of prompt + iterm2_prompt_mark() { + printf "\033]133;A\007" + } + + # Mark end of prompt + iterm2_prompt_end() { + printf "\033]133;B\007" + } + + # There are three possible paths in life. + # + # 1) A command is entered at the prompt and you press return. + # The following steps happen: + # * iterm2_preexec is invoked + # * PS1 is set to ITERM2_PRECMD_PS1 + # * ITERM2_SHOULD_DECORATE_PROMPT is set to 1 + # * The command executes (possibly reading or modifying PS1) + # * iterm2_precmd is invoked + # * ITERM2_PRECMD_PS1 is set to PS1 (as modified by command execution) + # * PS1 gets our escape sequences added to it + # * zsh displays your prompt + # * You start entering a command + # + # 2) You press ^C while entering a command at the prompt. + # The following steps happen: + # * (iterm2_preexec is NOT invoked) + # * iterm2_precmd is invoked + # * iterm2_before_cmd_executes is called since we detected that iterm2_preexec was not run + # * (ITERM2_PRECMD_PS1 and PS1 are not messed with, since PS1 already has our escape + # sequences and ITERM2_PRECMD_PS1 already has PS1's original value) + # * zsh displays your prompt + # * You start entering a command + # + # 3) A new shell is born. + # * PS1 has some initial value, either zsh's default or a value set before this script is sourced. + # * iterm2_precmd is invoked + # * ITERM2_SHOULD_DECORATE_PROMPT is initialized to 1 + # * ITERM2_PRECMD_PS1 is set to the initial value of PS1 + # * PS1 gets our escape sequences added to it + # * Your prompt is shown and you may begin entering a command. + # + # Invariants: + # * ITERM2_SHOULD_DECORATE_PROMPT is 1 during and just after command execution, and "" while the prompt is + # shown and until you enter a command and press return. + # * PS1 does not have our escape sequences during command execution + # * After the command executes but before a new one begins, PS1 has escape sequences and + # ITERM2_PRECMD_PS1 has PS1's original value. + iterm2_decorate_prompt() { + # This should be a raw PS1 without iTerm2's stuff. It could be changed during command + # execution. + ITERM2_PRECMD_PS1="$PS1" + ITERM2_SHOULD_DECORATE_PROMPT="" + + # Add our escape sequences just before the prompt is shown. + # Use ITERM2_SQUELCH_MARK for people who can't mdoify PS1 directly, like powerlevel9k users. + # This is gross but I had a heck of a time writing a correct if statetment for zsh 5.0.2. + local PREFIX="" + if [[ $PS1 == *"$(iterm2_prompt_mark)"* ]]; then + PREFIX="" + elif [[ "${ITERM2_SQUELCH_MARK-}" != "" ]]; then + PREFIX="" + else + PREFIX="%{$(iterm2_prompt_mark)%}" + fi + PS1="$PREFIX$PS1%{$(iterm2_prompt_end)%}" + ITERM2_DECORATED_PS1="$PS1" + } + + iterm2_precmd() { + local STATUS="$?" + if [ -z "${ITERM2_SHOULD_DECORATE_PROMPT-}" ]; then + # You pressed ^C while entering a command (iterm2_preexec did not run) + iterm2_before_cmd_executes + if [ "$PS1" != "${ITERM2_DECORATED_PS1-}" ]; then + # PS1 changed, perhaps in another precmd. See issue 9938. + ITERM2_SHOULD_DECORATE_PROMPT="1" + fi + fi + + iterm2_after_cmd_executes "$STATUS" + + if [ -n "$ITERM2_SHOULD_DECORATE_PROMPT" ]; then + iterm2_decorate_prompt + fi + } + + # This is not run if you press ^C while entering a command. + iterm2_preexec() { + # Set PS1 back to its raw value prior to executing the command. + PS1="$ITERM2_PRECMD_PS1" + ITERM2_SHOULD_DECORATE_PROMPT="1" + iterm2_before_cmd_executes + } + + # If hostname -f is slow on your system set iterm2_hostname prior to + # sourcing this script. We know it is fast on macOS so we don't cache + # it. That lets us handle the hostname changing like when you attach + # to a VPN. + if [ -z "${iterm2_hostname-}" ]; then + if [ "$(uname)" != "Darwin" ]; then + iterm2_hostname=`hostname -f 2>/dev/null` + # Some flavors of BSD (i.e. NetBSD and OpenBSD) don't have the -f option. + if [ $? -ne 0 ]; then + iterm2_hostname=`hostname` + fi + fi + fi + + [[ -z ${precmd_functions-} ]] && precmd_functions=() + precmd_functions=($precmd_functions iterm2_precmd) + + [[ -z ${preexec_functions-} ]] && preexec_functions=() + preexec_functions=($preexec_functions iterm2_preexec) + + iterm2_print_state_data + printf "\033]1337;ShellIntegrationVersion=14;shell=zsh\007" + fi +fi diff --git a/plugins/iterm2/update b/plugins/iterm2/update new file mode 100755 index 000000000..da8dae690 --- /dev/null +++ b/plugins/iterm2/update @@ -0,0 +1,4 @@ +#!/bin/sh + +curl -s -L https://iterm2.com/shell_integration/zsh \ + -o iterm2_shell_integration.zsh From 5cb943eea46d322542c5c2a9f54b201eddc2aa67 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Fri, 24 Feb 2023 17:27:23 +0100 Subject: [PATCH 197/672] fix(lib): fix return code after expected non-zero exit code (#11524) Fixes #11524 --- lib/directories.zsh | 2 +- lib/vcs_info.zsh | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/lib/directories.zsh b/lib/directories.zsh index 091140626..9274b5f5f 100644 --- a/lib/directories.zsh +++ b/lib/directories.zsh @@ -8,7 +8,7 @@ setopt pushdminus # to your `zshrc` before loading `oh-my-zsh.sh` # to disable the following aliases and functions -zstyle -T ':omz:directories' aliases || return +zstyle -T ':omz:directories' aliases || return 0 alias -g ...='../..' alias -g ....='../../..' diff --git a/lib/vcs_info.zsh b/lib/vcs_info.zsh index e60938c14..be6d32ee9 100644 --- a/lib/vcs_info.zsh +++ b/lib/vcs_info.zsh @@ -38,7 +38,7 @@ # due to malicious input as a consequence of CVE-2021-45444, which affects # zsh versions from 5.0.3 to 5.8. # -autoload -Uz +X regexp-replace VCS_INFO_formats 2>/dev/null || return +autoload -Uz +X regexp-replace VCS_INFO_formats 2>/dev/null || return 0 # We use $tmp here because it's already a local variable in VCS_INFO_formats typeset PATCH='for tmp (base base-name branch misc revision subdir) hook_com[$tmp]="${hook_com[$tmp]//\%/%%}"' From 277f38212aef31a6baba2cf1a0a355af611be5e0 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Fri, 24 Feb 2023 20:55:31 +0100 Subject: [PATCH 198/672] refactor: reorganize setopts in lib folder --- lib/directories.zsh | 1 + lib/misc.zsh | 8 +++----- lib/theme-and-appearance.zsh | 2 -- 3 files changed, 4 insertions(+), 7 deletions(-) diff --git a/lib/directories.zsh b/lib/directories.zsh index 9274b5f5f..13b680c19 100644 --- a/lib/directories.zsh +++ b/lib/directories.zsh @@ -1,4 +1,5 @@ # Changing/making/removing directory +setopt auto_cd setopt auto_pushd setopt pushd_ignore_dups setopt pushdminus diff --git a/lib/misc.zsh b/lib/misc.zsh index 1f637083a..132f33551 100644 --- a/lib/misc.zsh +++ b/lib/misc.zsh @@ -15,8 +15,9 @@ if [[ $DISABLE_MAGIC_FUNCTIONS != true ]]; then done fi -## jobs -setopt long_list_jobs +setopt multios # enable redirect to multiple streams: echo >file1 >file2 +setopt long_list_jobs # show long list format job notifications +setopt interactivecomments # recognize comments env_default 'PAGER' 'less' env_default 'LESS' '-R' @@ -30,6 +31,3 @@ if (( $+commands[ack-grep] )); then elif (( $+commands[ack] )); then alias afind='ack -il' fi - -# recognize comments -setopt interactivecomments diff --git a/lib/theme-and-appearance.zsh b/lib/theme-and-appearance.zsh index 1b64b51d4..208ab9ce5 100644 --- a/lib/theme-and-appearance.zsh +++ b/lib/theme-and-appearance.zsh @@ -53,8 +53,6 @@ if command diff --color /dev/null /dev/null &>/dev/null; then compdef _diff color-diff # compdef is already loaded by this point fi -setopt auto_cd -setopt multios setopt prompt_subst [[ -n "$WINDOW" ]] && SCREEN_NO="%B$WINDOW%b " || SCREEN_NO="" From cd647b6dc6779a1aafa2bcc3a81ec10b65c783ac Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Sun, 26 Feb 2023 15:44:18 +0100 Subject: [PATCH 199/672] fix(gnu-utils): reset ls alias to use GNU-based --color argument (#11527) Fixes #11503 --- plugins/gnu-utils/gnu-utils.plugin.zsh | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/plugins/gnu-utils/gnu-utils.plugin.zsh b/plugins/gnu-utils/gnu-utils.plugin.zsh index 9419127d8..6bd3e8463 100644 --- a/plugins/gnu-utils/gnu-utils.plugin.zsh +++ b/plugins/gnu-utils/gnu-utils.plugin.zsh @@ -61,3 +61,14 @@ __gnu_utils_preexec() { autoload -Uz add-zsh-hook add-zsh-hook preexec __gnu_utils_preexec + +# lib/theme-and-appearance.zsh sets the alias for ls not knowing that +# we'll be using GNU ls. We'll reset this to use GNU ls --color. +# See https://github.com/ohmyzsh/ohmyzsh/issues/11503 +# +# The ls alias might look like: +# - ls='ls -G' +# - ls='gls --color=tty' +if [[ -x "${commands[gls]}" && "${aliases[ls]}" = (*-G*|gls*) ]]; then + alias ls='ls --color=tty' +fi From 0ca8907f0e6185545c5e38f77ae2f09ca2a44e77 Mon Sep 17 00:00:00 2001 From: Jannik Date: Sun, 26 Feb 2023 20:37:03 +0100 Subject: [PATCH 200/672] fix(lib): fix case-insensitive completion for zsh 5.9 (#11526) --- lib/completion.zsh | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/lib/completion.zsh b/lib/completion.zsh index 2c5695487..63379b53f 100644 --- a/lib/completion.zsh +++ b/lib/completion.zsh @@ -18,9 +18,9 @@ if [[ "$CASE_SENSITIVE" = true ]]; then zstyle ':completion:*' matcher-list 'r:|=*' 'l:|=* r:|=*' else if [[ "$HYPHEN_INSENSITIVE" = true ]]; then - zstyle ':completion:*' matcher-list 'm:{a-zA-Z-_}={A-Za-z_-}' 'r:|=*' 'l:|=* r:|=*' + zstyle ':completion:*' matcher-list 'm:{[:lower:][:upper:]-_}={[:upper:][:lower:]_-}' 'r:|=*' 'l:|=* r:|=*' else - zstyle ':completion:*' matcher-list 'm:{a-zA-Z}={A-Za-z}' 'r:|=*' 'l:|=* r:|=*' + zstyle ':completion:*' matcher-list 'm:{[:lower:][:upper:]}={[:upper:][:lower:]}' 'r:|=*' 'l:|=* r:|=*' fi fi unset CASE_SENSITIVE HYPHEN_INSENSITIVE From 16050ab80e63f8e53c07777b4c2ae16ad085e5ad Mon Sep 17 00:00:00 2001 From: Richard Mitchell Date: Sun, 26 Feb 2023 16:40:44 -0500 Subject: [PATCH 201/672] feat(macos): allow multiple man pages in `man-preview` (#11365) --- plugins/macos/README.md | 2 +- plugins/macos/macos.plugin.zsh | 7 ++++--- 2 files changed, 5 insertions(+), 4 deletions(-) diff --git a/plugins/macos/README.md b/plugins/macos/README.md index 1bc4244a4..1cb9b395d 100644 --- a/plugins/macos/README.md +++ b/plugins/macos/README.md @@ -25,7 +25,7 @@ Original author: [Sorin Ionescu](https://github.com/sorin-ionescu) | `pxd` | Return the current Xcode project directory | | `cdx` | `cd` to the current Xcode project directory | | `quick-look` | Quick-Look a specified file | -| `man-preview` | Open a specified man page in Preview app | +| `man-preview` | Open man pages in Preview app | | `showfiles` | Show hidden files in Finder | | `hidefiles` | Hide the hidden files in Finder | | `itunes` | _DEPRECATED_. Use `music` from macOS Catalina on | diff --git a/plugins/macos/macos.plugin.zsh b/plugins/macos/macos.plugin.zsh index e4d759dcf..e27d412c8 100644 --- a/plugins/macos/macos.plugin.zsh +++ b/plugins/macos/macos.plugin.zsh @@ -224,9 +224,10 @@ function quick-look() { } function man-preview() { - local location - # Don't let Preview.app steal focus if the man page doesn't exist - location=$(man -w "$@") && mandoc -Tpdf $location | open -f -a Preview + local page + for page in "${(@f)"$(man -w $@)"}"; do + command mandoc -Tpdf $page | open -f -a Preview + done } compdef _man man-preview From 21bdb18b2d1fe8b547a42da7ac7b58fb28563a2c Mon Sep 17 00:00:00 2001 From: Carlos Eduardo Monti Date: Mon, 27 Feb 2023 20:22:39 +0100 Subject: [PATCH 202/672] feat(nodenv): add plugin for `nodenv` (#9880) Co-authored-by: Matthew Boston --- plugins/nodenv/README.md | 20 +++++++++++++++ plugins/nodenv/nodenv.plugin.zsh | 43 ++++++++++++++++++++++++++++++++ 2 files changed, 63 insertions(+) create mode 100644 plugins/nodenv/README.md create mode 100644 plugins/nodenv/nodenv.plugin.zsh diff --git a/plugins/nodenv/README.md b/plugins/nodenv/README.md new file mode 100644 index 000000000..550597025 --- /dev/null +++ b/plugins/nodenv/README.md @@ -0,0 +1,20 @@ +# nodenv plugin + +The primary job of this plugin is to provide `nodenv_prompt_info` which can be added to your theme to include Node +version information into your prompt. + +To use it, add `nodenv` to the plugins array in your zshrc file: + +```zsh +plugins=(... nodenv) +``` + +## Functions + +* `nodenv_prompt_info`: displays the Node version in use by nodenv; or the global Node + version, if nodenv wasn't found. You can use this function in your prompt by adding + `$(nodenv_prompt_info)` to PROMPT or RPROMPT: + + ```zsh + RPROMPT='$(nodenv_prompt_info)' + ``` diff --git a/plugins/nodenv/nodenv.plugin.zsh b/plugins/nodenv/nodenv.plugin.zsh new file mode 100644 index 000000000..79a4ffbb5 --- /dev/null +++ b/plugins/nodenv/nodenv.plugin.zsh @@ -0,0 +1,43 @@ +# This plugin loads nodenv into the current shell and provides prompt info via +# the 'nodenv_prompt_info' function. + +FOUND_NODENV=${+commands[nodenv]} + +if [[ $FOUND_NODENV -ne 1 ]]; then + nodenvdirs=( + "$HOME/.nodenv" + "/usr/local/nodenv" + "/opt/nodenv" + "/usr/local/opt/nodenv" + ) + for dir in $nodenvdirs; do + if [[ -d "${dir}/bin" ]]; then + export PATH="$PATH:${dir}/bin" + FOUND_NODENV=1 + break + fi + done + + if [[ $FOUND_NODENV -ne 1 ]]; then + if (( $+commands[brew] )) && dir=$(brew --prefix nodenv 2>/dev/null); then + if [[ -d "${dir}/bin" ]]; then + export PATH="$PATH:${dir}/bin" + FOUND_NODENV=1 + fi + fi + fi +fi + +if [[ $FOUND_NODENV -eq 1 ]]; then + eval "$(nodenv init --no-rehash - zsh)" + function nodenv_prompt_info() { + nodenv version-name 2>/dev/null + } +else + # fallback to system node + function nodenv_prompt_info() { + echo "system: $(node -v 2>&1 | cut -c 2-)" + } +fi + +unset FOUND_NODENV nodenvdirs dir From f42c965da44be6940134b805edb54c5eca37d9ae Mon Sep 17 00:00:00 2001 From: ZYX Date: Mon, 27 Feb 2023 14:39:38 -0500 Subject: [PATCH 203/672] fix(aliases): clarify how to pass in keywords to `acs` (#11521) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Co-authored-by: Marc Cornellà --- plugins/aliases/README.md | 2 +- plugins/aliases/cheatsheet.py | 10 +++++----- 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/plugins/aliases/README.md b/plugins/aliases/README.md index 4e77f67b3..6a2da3d74 100644 --- a/plugins/aliases/README.md +++ b/plugins/aliases/README.md @@ -19,7 +19,7 @@ Requirements: Python needs to be installed. - `acs -h/--help`: print help mesage -- `acs `: filter aliases by `` and highlight +- `acs `: filter and highlight aliases by `` - `acs -g /--group `: show only aliases for group ``. Multiple uses of the flag show all groups diff --git a/plugins/aliases/cheatsheet.py b/plugins/aliases/cheatsheet.py index 3362a6ab6..fb8c74aa4 100644 --- a/plugins/aliases/cheatsheet.py +++ b/plugins/aliases/cheatsheet.py @@ -51,18 +51,18 @@ def pretty_print(cheatsheet, wfilter, group_list=None, groups_only=False): continue aliases = cheatsheet.get(key) if not wfilter: - pretty_print_group(key, aliases, wfilter, groups_only) + pretty_print_group(key, aliases, only_groupname=groups_only) else: - pretty_print_group(key, [ alias for alias in aliases if alias[0].find(wfilter)>-1 or alias[1].find(wfilter)>-1], wfilter) + pretty_print_group(key, [ alias for alias in aliases if wfilter in alias[0] or wfilter in alias[1] ], wfilter) if __name__ == '__main__': - parser = argparse.ArgumentParser(description="Pretty print aliases.") - parser.add_argument('filter', nargs="*", help="search aliases matching string") + parser = argparse.ArgumentParser(description="Pretty print aliases.", prog="acs") + parser.add_argument('filter', nargs="*", metavar="", help="search aliases matching keywords") parser.add_argument('-g', '--group', dest="group_list", action='append', help="only print aliases in given groups") parser.add_argument('--groups', dest='groups_only', action='store_true', help="only print alias groups") args = parser.parse_args() lines = sys.stdin.readlines() group_list = args.group_list or None - wfilter = " ".join(args.filter) or None + wfilter = " ".join(args.filter[1:]) if args.filter else None pretty_print(cheatsheet(lines), wfilter, group_list, args.groups_only) From b602e0a066d8c98e8c02201ad16c764447fd8531 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Mon, 27 Feb 2023 20:46:42 +0100 Subject: [PATCH 204/672] fix(aliases): fix regression in filter argument --- plugins/aliases/cheatsheet.py | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/plugins/aliases/cheatsheet.py b/plugins/aliases/cheatsheet.py index fb8c74aa4..7505d304b 100644 --- a/plugins/aliases/cheatsheet.py +++ b/plugins/aliases/cheatsheet.py @@ -51,9 +51,9 @@ def pretty_print(cheatsheet, wfilter, group_list=None, groups_only=False): continue aliases = cheatsheet.get(key) if not wfilter: - pretty_print_group(key, aliases, only_groupname=groups_only) + pretty_print_group(key, aliases, wfilter, groups_only) else: - pretty_print_group(key, [ alias for alias in aliases if wfilter in alias[0] or wfilter in alias[1] ], wfilter) + pretty_print_group(key, [ alias for alias in aliases if alias[0].find(wfilter)>-1 or alias[1].find(wfilter)>-1], wfilter) if __name__ == '__main__': parser = argparse.ArgumentParser(description="Pretty print aliases.", prog="acs") @@ -64,5 +64,5 @@ if __name__ == '__main__': lines = sys.stdin.readlines() group_list = args.group_list or None - wfilter = " ".join(args.filter[1:]) if args.filter else None + wfilter = " ".join(args.filter) or None pretty_print(cheatsheet(lines), wfilter, group_list, args.groups_only) From a4a9a8cd8ccb4240a7c5df5f6766bd5340646e63 Mon Sep 17 00:00:00 2001 From: Julian Suarez <49501306+jsred@users.noreply.github.com> Date: Wed, 1 Mar 2023 07:23:32 -0300 Subject: [PATCH 205/672] feat(rvm): add `rb32` alias (#11533) --- plugins/rvm/README.md | 1 + plugins/rvm/rvm.plugin.zsh | 1 + 2 files changed, 2 insertions(+) diff --git a/plugins/rvm/README.md b/plugins/rvm/README.md index 576b037b0..410bd60c0 100644 --- a/plugins/rvm/README.md +++ b/plugins/rvm/README.md @@ -24,6 +24,7 @@ plugins=(... rvm) | `rb27` | `rvm use ruby-2.7` | | `rb30` | `rvm use ruby-3.0` | | `rb31` | `rvm use ruby-3.1` | +| `rb32` | `rvm use ruby-3.2` | | `rvm-update` | `rvm get head` | | `gems` | `gem list` | | `rvms` | `rvm gemset` | diff --git a/plugins/rvm/rvm.plugin.zsh b/plugins/rvm/rvm.plugin.zsh index 2a091d019..3ddf04176 100644 --- a/plugins/rvm/rvm.plugin.zsh +++ b/plugins/rvm/rvm.plugin.zsh @@ -27,6 +27,7 @@ rubies=( 27 'ruby-2.7' 30 'ruby-3.0' 31 'ruby-3.1' + 32 'ruby-3.2' ) for v in ${(k)rubies}; do From 14978859c5b8d9385c9b836cd09c97cc08b6035b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Batuhan=20=C5=9Eanl=C4=B1?= <32306925+batuhan0sanli@users.noreply.github.com> Date: Thu, 2 Mar 2023 12:03:50 +0300 Subject: [PATCH 206/672] docs(brew): remove duplication (#11535) --- plugins/brew/README.md | 1 - 1 file changed, 1 deletion(-) diff --git a/plugins/brew/README.md b/plugins/brew/README.md index d0c150237..412daae63 100644 --- a/plugins/brew/README.md +++ b/plugins/brew/README.md @@ -21,7 +21,6 @@ defined for convenience. | -------- | --------------------------------------- | ------------------------------------------------------------------- | | `bcubc` | `brew upgrade --cask && brew cleanup` | Update outdated casks, then run cleanup. | | `bcubo` | `brew update && brew outdated --cask` | Update Homebrew data, then list outdated casks. | -| `bcubc` | `brew upgrade --cask && brew cleanup` | Update outdated casks, then run cleanup. | | `brewp` | `brew pin` | Pin a specified formula so that it's not upgraded. | | `brews` | `brew list -1` | List installed formulae or the installed files for a given formula. | | `brewsp` | `brew list --pinned` | List pinned formulae, or show the version of a given formula. | From 5bf7f9c83325a6cb2752e14ca01a574dbeef206e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Fri, 3 Mar 2023 12:34:31 +0100 Subject: [PATCH 207/672] fix(lib): use `$BROWSER` in `open_command` if set (#11532) Fixes #11098 --- lib/functions.zsh | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/lib/functions.zsh b/lib/functions.zsh index 6e1faa6aa..1d85ea38a 100644 --- a/lib/functions.zsh +++ b/lib/functions.zsh @@ -30,6 +30,13 @@ function open_command() { ;; esac + # If a URL is passed, $BROWSER might be set to a local browser within SSH. + # See https://github.com/ohmyzsh/ohmyzsh/issues/11098 + if [[ -n "$BROWSER" && "$1" = (http|https)://* ]]; then + "$BROWSER" "$@" + return + fi + ${=open_cmd} "$@" &>/dev/null } From 95d0c4b603e0c880bcf20bc9211b2162e94ed925 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Fri, 3 Mar 2023 14:38:50 +0100 Subject: [PATCH 208/672] refactor(theme-and-appearance): reorganize and clean up logic (#11529) Co-authored-by: Andrew Janke Co-authored-by: Marcelo Parada Co-authored-by: Uy Ha Co-authored-by: Valentin Uveges --- lib/theme-and-appearance.zsh | 147 +++++++++++++++++++++-------------- 1 file changed, 87 insertions(+), 60 deletions(-) diff --git a/lib/theme-and-appearance.zsh b/lib/theme-and-appearance.zsh index 208ab9ce5..985d3bc11 100644 --- a/lib/theme-and-appearance.zsh +++ b/lib/theme-and-appearance.zsh @@ -1,66 +1,93 @@ -# ls colors +# Sets color variable such as $fg, $bg, $color and $reset_color autoload -U colors && colors -# Enable ls colors -export LSCOLORS="Gxfxcxdxbxegedabagacad" - -# TODO organise this chaotic logic - -if [[ "$DISABLE_LS_COLORS" != "true" ]]; then - if [[ -d "$ZSH" ]]; then - _test_dir="$ZSH" - else - _test_dir="." - fi - # Find the option for using colors in ls, depending on the version - if [[ "$OSTYPE" == netbsd* ]]; then - # On NetBSD, test if "gls" (GNU ls) is installed (this one supports colors); - # otherwise, leave ls as is, because NetBSD's ls doesn't support -G - gls --color -d "$_test_dir" &>/dev/null && alias ls='gls --color=tty' - elif [[ "$OSTYPE" == openbsd* ]]; then - # On OpenBSD, "gls" (ls from GNU coreutils) and "colorls" (ls from base, - # with color and multibyte support) are available from ports. "colorls" - # will be installed on purpose and can't be pulled in by installing - # coreutils, so prefer it to "gls". - gls --color -d "$_test_dir" &>/dev/null && alias ls='gls --color=tty' - colorls -G -d "$_test_dir" &>/dev/null && alias ls='colorls -G' - elif [[ "$OSTYPE" == (darwin|freebsd)* ]]; then - # this is a good alias, it works by default just using $LSCOLORS - ls -G "$_test_dir" &>/dev/null && alias ls='ls -G' - - # only use coreutils ls if there is a dircolors customization present ($LS_COLORS or .dircolors file) - # otherwise, gls will use the default color scheme which is ugly af - [[ -n "$LS_COLORS" || -f "$HOME/.dircolors" ]] && gls --color -d "$_test_dir" &>/dev/null && alias ls='gls --color=tty' - else - # For GNU ls, we use the default ls color theme. They can later be overwritten by themes. - if [[ -z "$LS_COLORS" ]]; then - (( $+commands[dircolors] )) && eval "$(dircolors -b)" - fi - - ls --color -d "$_test_dir" &>/dev/null && alias ls='ls --color=tty' || { ls -G "$_test_dir" &>/dev/null && alias ls='ls -G' } - - # Take advantage of $LS_COLORS for completion as well. - zstyle ':completion:*' list-colors "${(s.:.)LS_COLORS}" - fi -fi - -# enable diff color if possible. -if command diff --color /dev/null /dev/null &>/dev/null; then - function color-diff { - command diff --color $@ - } - alias diff="color-diff" - compdef _diff color-diff # compdef is already loaded by this point -fi - +# Expand variables and commands in PROMPT variables setopt prompt_subst -[[ -n "$WINDOW" ]] && SCREEN_NO="%B$WINDOW%b " || SCREEN_NO="" - -# git theming default: Variables for theming the git info prompt -ZSH_THEME_GIT_PROMPT_PREFIX="git:(" # Prefix at the very beginning of the prompt, before the branch name -ZSH_THEME_GIT_PROMPT_SUFFIX=")" # At the very end of the prompt -ZSH_THEME_GIT_PROMPT_DIRTY="*" # Text to display if the branch is dirty -ZSH_THEME_GIT_PROMPT_CLEAN="" # Text to display if the branch is clean +# Prompt function theming defaults +ZSH_THEME_GIT_PROMPT_PREFIX="git:(" # Beginning of the git prompt, before the branch name +ZSH_THEME_GIT_PROMPT_SUFFIX=")" # End of the git prompt +ZSH_THEME_GIT_PROMPT_DIRTY="*" # Text to display if the branch is dirty +ZSH_THEME_GIT_PROMPT_CLEAN="" # Text to display if the branch is clean ZSH_THEME_RUBY_PROMPT_PREFIX="(" ZSH_THEME_RUBY_PROMPT_SUFFIX=")" + + +# Use diff --color if available +if command diff --color /dev/null{,} &>/dev/null; then + function diff { + command diff --color "$@" + } +fi + + +# Don't set ls coloring if disabled +[[ "$DISABLE_LS_COLORS" != true ]] || return 0 + +function test-ls-args { + local cmd="$1" # ls, gls, colorls, ... + local args="${@[2,-1]}" # arguments except the first one + command "$cmd" "$args" /dev/null &>/dev/null +} + +# Find the option for using colors in ls, depending on the version +case "$OSTYPE" in + netbsd*) + # On NetBSD, test if `gls` (GNU ls) is installed (this one supports colors); + # otherwise, leave ls as is, because NetBSD's ls doesn't support -G + test-ls-args gls --color && alias ls='gls --color=tty' + ;; + openbsd*) + # On OpenBSD, `gls` (ls from GNU coreutils) and `colorls` (ls from base, + # with color and multibyte support) are available from ports. + # `colorls` will be installed on purpose and can't be pulled in by installing + # coreutils (which might be installed for ), so prefer it to `gls`. + test-ls-args gls --color && alias ls='gls --color=tty' + test-ls-args colorls -G && alias ls='colorls -G' + ;; + (darwin|freebsd)*) + # This alias works by default just using $LSCOLORS + test-ls-args ls -G && alias ls='ls -G' + # Only use GNU ls if installed and there are user defaults for $LS_COLORS, + # as the default coloring scheme is not very pretty + [[ -n "$LS_COLORS" || -f "$HOME/.dircolors" ]] \ + && test-ls-args gls --color \ + && alias ls='gls --color=tty' + ;; + *) + if test-ls-args ls --color; then + alias ls='ls --color=tty' + elif test-ls-args ls -G; then + alias ls='ls -G' + fi + ;; +esac + +unfunction test-ls-args + + +# Default coloring for BSD-based ls +export LSCOLORS="Gxfxcxdxbxegedabagacad" + +# Default coloring for GNU-based ls +if [[ -z "$LS_COLORS" ]]; then + # Define LS_COLORS via dircolors if available. Otherwise, set a default + # equivalent to LSCOLORS (generated via https://geoff.greer.fm/lscolors) + if (( $+commands[dircolors] )); then + [[ -f "$HOME/.dircolors" ]] \ + && source <(dircolors -b "$HOME/.dircolors") \ + || source <(dircolors -b) + else + export LS_COLORS="di=34:ln=35:so=32:pi=33:ex=31:bd=34;46:cd=34;43:su=37;41:sg=30;43:tw=30;42:ow=34;42:" + fi +fi + +# Take advantage of $LS_COLORS for completion as well. +function omz_set_completion_colors { + zstyle ':completion:*' list-colors "${(s.:.)LS_COLORS}" + add-zsh-hook -d precmd omz_set_completion_colors + unfunction omz_set_completion_colors +} + +autoload -Uz add-zsh-hook +add-zsh-hook precmd omz_set_completion_colors From 6f3304f442afde6e1cf3e7e8641a405d29d2e73d Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Sat, 4 Mar 2023 09:25:01 +0100 Subject: [PATCH 209/672] feat(argocd): add completion plugin Co-authored-by: Sumudu Lansakara Closes #9900 --- plugins/argocd/README.md | 20 ++++++++++++++++++++ plugins/argocd/gh.plugin.zsh | 14 ++++++++++++++ 2 files changed, 34 insertions(+) create mode 100644 plugins/argocd/README.md create mode 100644 plugins/argocd/gh.plugin.zsh diff --git a/plugins/argocd/README.md b/plugins/argocd/README.md new file mode 100644 index 000000000..0f900ff22 --- /dev/null +++ b/plugins/argocd/README.md @@ -0,0 +1,20 @@ +# Argo CD plugin + +This plugin adds completion for the [Argo CD](https://argoproj.github.io/cd/) CLI. + +To use it, add `argocd` to the plugins array in your zshrc file: + +```zsh +plugins=(... argocd) +``` + +This plugin does not add any aliases. + +## Cache + +This plugin caches the completion script and is automatically updated asynchronously when the plugin is +loaded, which is usually when you start up a new terminal emulator. + +The cache is stored at: + +- `$ZSH_CACHE/completions/_argocd` completions script diff --git a/plugins/argocd/gh.plugin.zsh b/plugins/argocd/gh.plugin.zsh new file mode 100644 index 000000000..8de7b0238 --- /dev/null +++ b/plugins/argocd/gh.plugin.zsh @@ -0,0 +1,14 @@ +# Autocompletion for argocd. +if (( ! $+commands[argocd] )); then + return +fi + +# If the completion file doesn't exist yet, we need to autoload it and +# bind it to `argocd`. Otherwise, compinit will have already done that. +if [[ ! -f "$ZSH_CACHE_DIR/completions/_argocd" ]]; then + typeset -g -A _comps + autoload -Uz _argocd + _comps[argocd]=_argocd +fi + +argocd completion zsh >| "$ZSH_CACHE_DIR/completions/_argocd" &| From 3b759c5dc926d0973d82fa1b8ffed45d770d20e8 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Mon, 6 Mar 2023 11:25:47 +0100 Subject: [PATCH 210/672] fix(argocd): typo in filename --- plugins/argocd/{gh.plugin.zsh => argocd.plugin.zsh} | 0 1 file changed, 0 insertions(+), 0 deletions(-) rename plugins/argocd/{gh.plugin.zsh => argocd.plugin.zsh} (100%) diff --git a/plugins/argocd/gh.plugin.zsh b/plugins/argocd/argocd.plugin.zsh similarity index 100% rename from plugins/argocd/gh.plugin.zsh rename to plugins/argocd/argocd.plugin.zsh From 06c16175ea4aa81d4b64c0772f44c11e505a0eb7 Mon Sep 17 00:00:00 2001 From: Karim Benbourenane Date: Tue, 7 Mar 2023 03:25:34 -0500 Subject: [PATCH 211/672] fix(aliases): group properly aliases (#11546) --- plugins/aliases/cheatsheet.py | 1 + 1 file changed, 1 insertion(+) diff --git a/plugins/aliases/cheatsheet.py b/plugins/aliases/cheatsheet.py index 7505d304b..f742fba9e 100644 --- a/plugins/aliases/cheatsheet.py +++ b/plugins/aliases/cheatsheet.py @@ -15,6 +15,7 @@ def parse(line): def cheatsheet(lines): exps = [ parse(line) for line in lines ] + exps.sort(key=lambda exp:exp[2]) cheatsheet = {'_default': []} for key, group in itertools.groupby(exps, lambda exp:exp[2]): group_list = [ item for item in group ] From 46fd7972a2170388c9b8e9f6e58d6c8408ad4904 Mon Sep 17 00:00:00 2001 From: potato <851951875@qq.com> Date: Tue, 7 Mar 2023 20:33:16 +0800 Subject: [PATCH 212/672] feat(aws): add AWS_REGION to aws_prompt_info (#10062) --- plugins/aws/README.md | 22 +++++++++++++++----- plugins/aws/aws.plugin.zsh | 41 ++++++++++++++++++++++++++++++++++++-- 2 files changed, 56 insertions(+), 7 deletions(-) diff --git a/plugins/aws/README.md b/plugins/aws/README.md index d6f4f4600..e1e355741 100644 --- a/plugins/aws/README.md +++ b/plugins/aws/README.md @@ -1,7 +1,7 @@ # aws This plugin provides completion support for [awscli](https://docs.aws.amazon.com/cli/latest/reference/index.html) -and a few utilities to manage AWS profiles and display them in the prompt. +and a few utilities to manage AWS profiles/regions and display them in the prompt. To use it, add `aws` to the plugins array in your zshrc file. @@ -16,6 +16,9 @@ plugins=(... aws) Run `asp` without arguments to clear the profile. * `asp [] login`: If AWS SSO has been configured in your aws profile, it will run the `aws sso login` command following profile selection. +* `asr []`: sets `$AWS_REGION` and `$AWS_DEFAULT_REGION` (legacy) to ``. + Run `asr` without arguments to clear the profile. + * `acp [] []`: in addition to `asp` functionality, it actually changes the profile by assuming the role specified in the `` configuration. It supports MFA and sets `$AWS_ACCESS_KEY_ID`, `$AWS_SECRET_ACCESS_KEY` and `$AWS_SESSION_TOKEN`, if @@ -25,25 +28,34 @@ plugins=(... aws) * `agp`: gets the current value of `$AWS_PROFILE`. +* `agr`: gets the current value of `$AWS_REGION`. + * `aws_change_access_key`: changes the AWS access key of a profile. * `aws_profiles`: lists the available profiles in the `$AWS_CONFIG_FILE` (default: `~/.aws/config`). Used to provide completion for the `asp` function. +* `aws_regions`: lists the available regions. + Used to provide completion for the `asr` function. + ## Plugin options * Set `SHOW_AWS_PROMPT=false` in your zshrc file if you want to prevent the plugin from modifying your RPROMPT. Some themes might overwrite the value of RPROMPT instead of appending to it, so they'll need to be fixed to - see the AWS profile prompt. + see the AWS profile/region prompt. ## Theme The plugin creates an `aws_prompt_info` function that you can use in your theme, which displays -the current `$AWS_PROFILE`. It uses two variables to control how that is shown: +the current `$AWS_PROFILE` and `$AWS_REGION`. It uses four variables to control how that is shown: -* ZSH_THEME_AWS_PREFIX: sets the prefix of the AWS_PROFILE. Defaults to ``. +* ZSH_THEME_AWS_PROFILE_SUFFIX: sets the suffix of the AWS_PROFILE. Defaults to `>`. + +* ZSH_THEME_AWS_REGION_PREFIX: sets the prefix of the AWS_REGION. Defaults to ``. ## Configuration diff --git a/plugins/aws/aws.plugin.zsh b/plugins/aws/aws.plugin.zsh index 865e82f19..1c386a3e1 100644 --- a/plugins/aws/aws.plugin.zsh +++ b/plugins/aws/aws.plugin.zsh @@ -2,6 +2,10 @@ function agp() { echo $AWS_PROFILE } +function agr() { + echo $AWS_REGION +} + # AWS profile selection function asp() { if [[ -z "$1" ]]; then @@ -27,6 +31,25 @@ function asp() { fi } +# AWS region selection +function asr() { + if [[ -z "$1" ]]; then + unset AWS_DEFAULT_REGION AWS_REGION + echo AWS region cleared. + return + fi + + local -a available_regions + available_regions=($(aws_regions)) + if [[ -z "${available_regions[(r)$1]}" ]]; then + echo "${fg[red]}Available regions: \n$(aws_regions)" + return 1 + fi + + export AWS_REGION=$1 + export AWS_DEFAULT_REGION=$1 +} + # AWS profile switch function acp() { if [[ -z "$1" ]]; then @@ -145,12 +168,25 @@ function aws_change_access_key() { AWS_PAGER="" aws iam list-access-keys } +function aws_regions() { + if [[ $AWS_DEFAULT_PROFILE || $AWS_PROFILE ]];then + aws ec2 describe-regions |grep RegionName | awk -F ':' '{gsub(/"/, "", $2);gsub(/,/, "", $2);gsub(/ /, "", $2); print $2}' + else + echo "You must specify a AWS profile." + fi +} + function aws_profiles() { aws --no-cli-pager configure list-profiles 2> /dev/null && return [[ -r "${AWS_CONFIG_FILE:-$HOME/.aws/config}" ]] || return 1 grep --color=never -Eo '\[.*\]' "${AWS_CONFIG_FILE:-$HOME/.aws/config}" | sed -E 's/^[[:space:]]*\[(profile)?[[:space:]]*([^[:space:]]+)\][[:space:]]*$/\2/g' } +function _aws_regions() { + reply=($(aws_regions)) +} +compctl -K _aws_regions asr + function _aws_profiles() { reply=($(aws_profiles)) } @@ -158,8 +194,8 @@ compctl -K _aws_profiles asp acp aws_change_access_key # AWS prompt function aws_prompt_info() { - [[ -n "$AWS_PROFILE" ]] || return - echo "${ZSH_THEME_AWS_PREFIX=}" + if [[ -z $AWS_REGION && -z $AWS_PROFILE ]];then return; fi + echo "${ZSH_THEME_AWS_PROFILE_PREFIX:=} ${ZSH_THEME_AWS_REGION_PREFIX:=}" } if [[ "$SHOW_AWS_PROMPT" != false && "$RPROMPT" != *'$(aws_prompt_info)'* ]]; then @@ -211,3 +247,4 @@ else [[ -r $_aws_zsh_completer_path ]] && source $_aws_zsh_completer_path unset _aws_zsh_completer_path _brew_prefix fi + From d342b353e32091ef7384b86fd86b1a88dbd44609 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Tue, 7 Mar 2023 18:49:17 +0100 Subject: [PATCH 213/672] fix(init): set completion colors on theme load, not with `precmd` This fixes an edge case where the user actually sets zstyle ':completion:*' list-colors in their zshrc, but the previous code used a precmd hook, which would override the user changes. With this change our modifications will be set in the init script, after the theme loads, so that later changes can affect our defaults. Note that this will not be run for users on plugin managers, as these don't generally run our init script. --- lib/theme-and-appearance.zsh | 10 ---------- oh-my-zsh.sh | 3 +++ 2 files changed, 3 insertions(+), 10 deletions(-) diff --git a/lib/theme-and-appearance.zsh b/lib/theme-and-appearance.zsh index 985d3bc11..e245570e3 100644 --- a/lib/theme-and-appearance.zsh +++ b/lib/theme-and-appearance.zsh @@ -81,13 +81,3 @@ if [[ -z "$LS_COLORS" ]]; then export LS_COLORS="di=34:ln=35:so=32:pi=33:ex=31:bd=34;46:cd=34;43:su=37;41:sg=30;43:tw=30;42:ow=34;42:" fi fi - -# Take advantage of $LS_COLORS for completion as well. -function omz_set_completion_colors { - zstyle ':completion:*' list-colors "${(s.:.)LS_COLORS}" - add-zsh-hook -d precmd omz_set_completion_colors - unfunction omz_set_completion_colors -} - -autoload -Uz add-zsh-hook -add-zsh-hook precmd omz_set_completion_colors diff --git a/oh-my-zsh.sh b/oh-my-zsh.sh index 98bda8c8b..363cfca8b 100644 --- a/oh-my-zsh.sh +++ b/oh-my-zsh.sh @@ -189,3 +189,6 @@ if [[ -n "$ZSH_THEME" ]]; then echo "[oh-my-zsh] theme '$ZSH_THEME' not found" fi fi + +# set completion colors to be the same as `ls`, after theme has been loaded +[[ -z "$LS_COLORS" ]] || zstyle ':completion:*' list-colors "${(s.:.)LS_COLORS}" From e0f92c8df52335c266f73e3cc3384b277f3e9a34 Mon Sep 17 00:00:00 2001 From: Julien Vincent Date: Tue, 7 Mar 2023 21:46:21 +0200 Subject: [PATCH 214/672] feat(vi-mode): add settings for vi-mode cursor styles (#10860) --- plugins/vi-mode/README.md | 21 +++++++++++++++++++++ plugins/vi-mode/vi-mode.plugin.zsh | 23 ++++++++++++++++------- 2 files changed, 37 insertions(+), 7 deletions(-) diff --git a/plugins/vi-mode/README.md b/plugins/vi-mode/README.md index 476666bf6..3b819c7cb 100644 --- a/plugins/vi-mode/README.md +++ b/plugins/vi-mode/README.md @@ -29,6 +29,8 @@ plugins=(... vi-mode) VI_MODE_SET_CURSOR=true ``` + See [Cursor Styles](#cursor-styles) for controlling how the cursor looks in different modes + - `MODE_INDICATOR`: controls the string displayed when the shell is in normal mode. See [Mode indicators](#mode-indicators) for details. @@ -52,6 +54,25 @@ INSERT_MODE_INDICATOR="%F{yellow}+%f" You can also use the `vi_mode_prompt_info` function in your prompt, which will display this mode indicator. +## Cursor Styles + +You can control the cursor style used in each active vim mode by changing the values of the following variables. + +```zsh +# defaults +VI_MODE_CURSOR_NORMAL=2 +VI_MODE_CURSOR_VISUAL=6 +VI_MODE_CURSOR_INSERT=6 +VI_MODE_CURSOR_OPPEND=0 +``` + +- 0, 1 - Blinking block +- 2 - Solid block +- 3 - Blinking underline +- 4 - Solid underline +- 5 - Blinking line +- 6 - Solid line + ## Key bindings Use `ESC` or `CTRL-[` to enter `Normal mode`. diff --git a/plugins/vi-mode/vi-mode.plugin.zsh b/plugins/vi-mode/vi-mode.plugin.zsh index 149d6bbd5..9a410c1fb 100644 --- a/plugins/vi-mode/vi-mode.plugin.zsh +++ b/plugins/vi-mode/vi-mode.plugin.zsh @@ -14,6 +14,15 @@ typeset -g VI_MODE_RESET_PROMPT_ON_MODE_CHANGE # Unset or set to any other value to do the opposite. typeset -g VI_MODE_SET_CURSOR +# Control how the cursor appears in the various vim modes. This only applies +# if $VI_MODE_SET_CURSOR=true. +# +# See https://vt100.net/docs/vt510-rm/DECSCUSR for cursor styles +typeset -g VI_MODE_CURSOR_NORMAL=2 +typeset -g VI_MODE_CURSOR_VISUAL=6 +typeset -g VI_MODE_CURSOR_INSERT=6 +typeset -g VI_MODE_CURSOR_OPPEND=0 + typeset -g VI_KEYMAP=main function _vi-mode-set-cursor-shape-for-keymap() { @@ -22,13 +31,13 @@ function _vi-mode-set-cursor-shape-for-keymap() { # https://vt100.net/docs/vt510-rm/DECSCUSR local _shape=0 case "${1:-${VI_KEYMAP:-main}}" in - main) _shape=6 ;; # vi insert: line - viins) _shape=6 ;; # vi insert: line - isearch) _shape=6 ;; # inc search: line - command) _shape=6 ;; # read a command name - vicmd) _shape=2 ;; # vi cmd: block - visual) _shape=2 ;; # vi visual mode: block - viopp) _shape=0 ;; # vi operation pending: blinking block + main) _shape=$VI_MODE_CURSOR_INSERT ;; # vi insert: line + viins) _shape=$VI_MODE_CURSOR_INSERT ;; # vi insert: line + isearch) _shape=$VI_MODE_CURSOR_INSERT ;; # inc search: line + command) _shape=$VI_MODE_CURSOR_INSERT ;; # read a command name + vicmd) _shape=$VI_MODE_CURSOR_NORMAL ;; # vi cmd: block + visual) _shape=$VI_MODE_CURSOR_VISUAL ;; # vi visual mode: block + viopp) _shape=$VI_MODE_CURSOR_OPPEND ;; # vi operation pending: blinking block *) _shape=0 ;; esac printf $'\e[%d q' "${_shape}" From 1c325de464117aa058d5f810b96ed54d65e5d0d5 Mon Sep 17 00:00:00 2001 From: Robby Russell Date: Tue, 7 Mar 2023 11:52:38 -0800 Subject: [PATCH 215/672] Fixing link to PA website in README Was linking to an old URL --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index 7f4a26cab..4042c8c26 100644 --- a/README.md +++ b/README.md @@ -374,4 +374,4 @@ Oh My Zsh is released under the [MIT license](LICENSE.txt). ![Planet Argon](https://pa-github-assets.s3.amazonaws.com/PARGON_logo_digital_COL-small.jpg) -Oh My Zsh was started by the team at [Planet Argon](https://www.planetargon.com/?utm_source=github), a [Ruby on Rails development agency](https://www.planetargon.com/skills/ruby-on-rails-development?utm_source=github). Check out our [other open source projects](https://www.planetargon.com/open-source?utm_source=github). +Oh My Zsh was started by the team at [Planet Argon](https://www.planetargon.com/?utm_source=github), a [Ruby on Rails development agency](http://www.planetargon.com/services/ruby-on-rails-development?utm_source=github). Check out our [other open source projects](https://www.planetargon.com/open-source?utm_source=github). From 3ea0e0d2343a2e79be0c2c6ace030a595d5cec2f Mon Sep 17 00:00:00 2001 From: Benjamin Lieb Date: Wed, 8 Mar 2023 03:29:21 -0500 Subject: [PATCH 216/672] docs(vi-mode): document how to add vi-mode info on the prompt (#11548) --- plugins/vi-mode/README.md | 19 +++++++++++++++++-- 1 file changed, 17 insertions(+), 2 deletions(-) diff --git a/plugins/vi-mode/README.md b/plugins/vi-mode/README.md index 3b819c7cb..0cb516751 100644 --- a/plugins/vi-mode/README.md +++ b/plugins/vi-mode/README.md @@ -51,8 +51,23 @@ MODE_INDICATOR="%F{white}+%f" INSERT_MODE_INDICATOR="%F{yellow}+%f" ``` -You can also use the `vi_mode_prompt_info` function in your prompt, which will display -this mode indicator. +### Adding mode indicators to your prompt + +`Vi-mode` by default will add mode indicators to `RPROMPT` **unless** that is defined by +a preceding plugin. + +If `PROMPT` or `RPROMPT` is not defined to your liking, you can add mode info manually. The `vi_mode_prompt_info` function is available to insert mode indicator information. + +Here are some examples: + +```bash +source $ZSH/oh-my-zsh.sh + +PROMPT="$PROMPT\$(vi_mode_prompt_info)" +RPROMPT="\$(vi_mode_prompt_info)$RPROMPT" +``` + +Note the `\$` here, which importantly prevents interpolation at the time of defining, but allows it to be executed for each prompt update event. ## Cursor Styles From 92387d9fff83934a8628697a4397a65030f0301e Mon Sep 17 00:00:00 2001 From: Zhong Zheng Date: Sat, 11 Mar 2023 01:52:44 +1100 Subject: [PATCH 217/672] feat(rails): add `rta` alias (#11553) --- plugins/rails/README.md | 1 + plugins/rails/rails.plugin.zsh | 1 + 2 files changed, 2 insertions(+) diff --git a/plugins/rails/README.md b/plugins/rails/README.md index fa66750f0..b2425aabc 100644 --- a/plugins/rails/README.md +++ b/plugins/rails/README.md @@ -47,6 +47,7 @@ plugins=(... rails) | `rsp` | `rails server --port` | Launch a web server and specify the listening port | | `rsts` | `rails stats` | Print code statistics | | `rt` | `rails test` | Run Rails tests | +| `rta` | `rails test:all` | Runs all Rails tests, including system tests | | `ru` | `rails runner` | Run Ruby code in the context of Rails | ### Foreman diff --git a/plugins/rails/rails.plugin.zsh b/plugins/rails/rails.plugin.zsh index b11cbb5c7..015dc9ecb 100644 --- a/plugins/rails/rails.plugin.zsh +++ b/plugins/rails/rails.plugin.zsh @@ -75,6 +75,7 @@ alias rsd='rails server --debugger' alias rsp='rails server --port' alias rsts='rails stats' alias rt='rails test' +alias rta='rails test:all' alias ru='rails runner' # Foreman aliases From 72732a224e886933df6b64a49ec6f5e94c884612 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Sun, 12 Mar 2023 15:47:58 +0100 Subject: [PATCH 218/672] fix(lib): set equivalent LS_COLORS and LSCOLORS variables As reported by https://geoff.greer.fm/lscolors Fixes #11554 --- lib/theme-and-appearance.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/theme-and-appearance.zsh b/lib/theme-and-appearance.zsh index e245570e3..d8859b04c 100644 --- a/lib/theme-and-appearance.zsh +++ b/lib/theme-and-appearance.zsh @@ -78,6 +78,6 @@ if [[ -z "$LS_COLORS" ]]; then && source <(dircolors -b "$HOME/.dircolors") \ || source <(dircolors -b) else - export LS_COLORS="di=34:ln=35:so=32:pi=33:ex=31:bd=34;46:cd=34;43:su=37;41:sg=30;43:tw=30;42:ow=34;42:" + export LS_COLORS="di=1;36:ln=35:so=32:pi=33:ex=31:bd=34;46:cd=34;43:su=30;41:sg=30;46:tw=30;42:ow=30;43" fi fi From 82d261603d968dfe5e86a44464c38fd88dda802c Mon Sep 17 00:00:00 2001 From: vladislav doster <10052309+vladdoster@users.noreply.github.com> Date: Mon, 20 Mar 2023 02:11:03 -0500 Subject: [PATCH 219/672] feat(gnu-utils): add `gindent` (#11569) --- plugins/gnu-utils/gnu-utils.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/gnu-utils/gnu-utils.plugin.zsh b/plugins/gnu-utils/gnu-utils.plugin.zsh index 6bd3e8463..6023bf2b4 100644 --- a/plugins/gnu-utils/gnu-utils.plugin.zsh +++ b/plugins/gnu-utils/gnu-utils.plugin.zsh @@ -19,7 +19,7 @@ __gnu_utils() { 'gchown' 'gchroot' 'gcksum' 'gcomm' 'gcp' 'gcsplit' 'gcut' 'gdate' 'gdd' 'gdf' 'gdir' 'gdircolors' 'gdirname' 'gdu' 'gecho' 'genv' 'gexpand' 'gexpr' 'gfactor' 'gfalse' 'gfmt' 'gfold' 'ggroups' 'ghead' 'ghostid' - 'gid' 'ginstall' 'gjoin' 'gkill' 'glink' 'gln' 'glogname' 'gls' 'gmd5sum' + 'gid' 'gindent' 'ginstall' 'gjoin' 'gkill' 'glink' 'gln' 'glogname' 'gls' 'gmd5sum' 'gmkdir' 'gmkfifo' 'gmknod' 'gmktemp' 'gmv' 'gnice' 'gnl' 'gnohup' 'gnproc' 'god' 'gpaste' 'gpathchk' 'gpinky' 'gpr' 'gprintenv' 'gprintf' 'gptx' 'gpwd' 'greadlink' 'grm' 'grmdir' 'gruncon' 'gseq' 'gsha1sum' 'gsha224sum' From 4a39779067eda369152bfd6b653f843286c930c0 Mon Sep 17 00:00:00 2001 From: Yu Xiang Zhang Date: Tue, 14 Mar 2023 19:02:54 +0000 Subject: [PATCH 220/672] feat(aws): set region when AWS_REGION is not set --- plugins/aws/README.md | 2 +- plugins/aws/aws.plugin.zsh | 7 +++++-- 2 files changed, 6 insertions(+), 3 deletions(-) diff --git a/plugins/aws/README.md b/plugins/aws/README.md index e1e355741..846bf1414 100644 --- a/plugins/aws/README.md +++ b/plugins/aws/README.md @@ -12,7 +12,7 @@ plugins=(... aws) ## Plugin commands * `asp []`: sets `$AWS_PROFILE` and `$AWS_DEFAULT_PROFILE` (legacy) to ``. - It also sets `$AWS_EB_PROFILE` to `` for the Elastic Beanstalk CLI. + It also sets `$AWS_EB_PROFILE` to `` for the Elastic Beanstalk CLI. It sets `$AWS_PROFILE_REGION` for display in `aws_prompt_info`. Run `asp` without arguments to clear the profile. * `asp [] login`: If AWS SSO has been configured in your aws profile, it will run the `aws sso login` command following profile selection. diff --git a/plugins/aws/aws.plugin.zsh b/plugins/aws/aws.plugin.zsh index 1c386a3e1..39c47d572 100644 --- a/plugins/aws/aws.plugin.zsh +++ b/plugins/aws/aws.plugin.zsh @@ -9,7 +9,7 @@ function agr() { # AWS profile selection function asp() { if [[ -z "$1" ]]; then - unset AWS_DEFAULT_PROFILE AWS_PROFILE AWS_EB_PROFILE + unset AWS_DEFAULT_PROFILE AWS_PROFILE AWS_EB_PROFILE AWS_PROFILE_REGION echo AWS profile cleared. return fi @@ -26,6 +26,8 @@ function asp() { export AWS_PROFILE=$1 export AWS_EB_PROFILE=$1 + export AWS_PROFILE_REGION=$(aws configure get region) + if [[ "$2" == "login" ]]; then aws sso login fi @@ -195,7 +197,8 @@ compctl -K _aws_profiles asp acp aws_change_access_key # AWS prompt function aws_prompt_info() { if [[ -z $AWS_REGION && -z $AWS_PROFILE ]];then return; fi - echo "${ZSH_THEME_AWS_PROFILE_PREFIX:=} ${ZSH_THEME_AWS_REGION_PREFIX:=}" + region=${AWS_REGION:-${AWS_DEFAULT_REGION:-$AWS_PROFILE_REGION}} + echo "${ZSH_THEME_AWS_PROFILE_PREFIX:=} ${ZSH_THEME_AWS_REGION_PREFIX:=}" } if [[ "$SHOW_AWS_PROMPT" != false && "$RPROMPT" != *'$(aws_prompt_info)'* ]]; then From f9f01e48a890ad4359a6973d1b8a7039f57b2d08 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Tue, 21 Mar 2023 15:29:48 +0100 Subject: [PATCH 221/672] fix(aws): do not print region if it's not defined Closes #11568 Closes #11570 --- plugins/aws/aws.plugin.zsh | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) diff --git a/plugins/aws/aws.plugin.zsh b/plugins/aws/aws.plugin.zsh index 39c47d572..0242be97e 100644 --- a/plugins/aws/aws.plugin.zsh +++ b/plugins/aws/aws.plugin.zsh @@ -196,9 +196,15 @@ compctl -K _aws_profiles asp acp aws_change_access_key # AWS prompt function aws_prompt_info() { - if [[ -z $AWS_REGION && -z $AWS_PROFILE ]];then return; fi - region=${AWS_REGION:-${AWS_DEFAULT_REGION:-$AWS_PROFILE_REGION}} - echo "${ZSH_THEME_AWS_PROFILE_PREFIX:=} ${ZSH_THEME_AWS_REGION_PREFIX:=}" + local _aws_to_show + if [[ -n $AWS_PROFILE ]];then + _aws_to_show+="${ZSH_THEME_AWS_PROFILE_PREFIX:=}" + fi + if [[ -n $AWS_REGION ]]; then + [[ -n $AWS_PROFILE ]] && _aws_to_show+=" " + _aws_to_show+="${ZSH_THEME_AWS_REGION_PREFIX:=}" + fi + echo "$_aws_to_show" } if [[ "$SHOW_AWS_PROMPT" != false && "$RPROMPT" != *'$(aws_prompt_info)'* ]]; then From 5efcfc39735c818a9778172356f82ec0eb3e5916 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jose=20C=2E=20Mass=C3=B3n?= <939888+Abuelodelanada@users.noreply.github.com> Date: Thu, 23 Mar 2023 05:42:20 -0300 Subject: [PATCH 222/672] feat(juju): add functions to get current controller and model (#11572) --- plugins/juju/README.md | 2 ++ plugins/juju/juju.plugin.zsh | 32 +++++++++++++++++++++++++++++++- 2 files changed, 33 insertions(+), 1 deletion(-) diff --git a/plugins/juju/README.md b/plugins/juju/README.md index f0c65309c..6ee333f50 100644 --- a/plugins/juju/README.md +++ b/plugins/juju/README.md @@ -126,5 +126,7 @@ Naming convention: - `jaddr [unit_num]`: display app or unit IP address. - `jreld `: display app and unit relation data. - `jclean`: destroy all controllers +- `jcontroller`: display the controller your are connected to. +- `jmodel`: display the model your are connected to. - `wjst [interval_secs] [args_for_watch]`: watch juju status, with optional interval (default: 5s); you may pass additional arguments to `watch`. diff --git a/plugins/juju/juju.plugin.zsh b/plugins/juju/juju.plugin.zsh index be8a2c7ae..0c60e35ce 100644 --- a/plugins/juju/juju.plugin.zsh +++ b/plugins/juju/juju.plugin.zsh @@ -163,10 +163,40 @@ jreld() { juju run "relation-get -r $relid - $2" --unit $2/$3 } +# Return Juju current controller +jcontroller() { + local controller="$(awk '/current-controller/ {print $2}' ~/.local/share/juju/controllers.yaml)" + if [[ -z "$controller" ]]; then + return 1 + fi + + echo $controller + return 0 +} + +# Return Juju current model +jmodel() { + local yqbin="$(whereis yq | awk '{print $2}')" + + if [[ -z "$yqbin" ]]; then + echo "--" + return 1 + fi + + local model="$(yq e ".controllers.$(jcontroller).current-model" < ~/.local/share/juju/models.yaml | cut -d/ -f2)" + + if [[ -z "$model" ]]; then + echo "--" + return 1 + fi + + echo $model + return 0 +} + # Watch juju status, with optional interval (default: 5 sec) wjst() { local interval="${1:-5}" shift $(( $# > 0 )) watch -n "$interval" --color juju status --relations --color "$@" } - From c08b925d282e35ea7bd9a8f4c29de2ece0debb49 Mon Sep 17 00:00:00 2001 From: Michele Bologna Date: Thu, 23 Mar 2023 14:34:43 +0100 Subject: [PATCH 223/672] fix(uninstall): abort uninstall if unable to change shell (#10357) --- tools/uninstall.sh | 23 ++++++++++++----------- 1 file changed, 12 insertions(+), 11 deletions(-) diff --git a/tools/uninstall.sh b/tools/uninstall.sh index 6a0e7b4c7..6e3df7aca 100644 --- a/tools/uninstall.sh +++ b/tools/uninstall.sh @@ -1,3 +1,15 @@ +if hash chsh >/dev/null 2>&1 && [ -f ~/.shell.pre-oh-my-zsh ]; then + old_shell=$(cat ~/.shell.pre-oh-my-zsh) + echo "Switching your shell back to '$old_shell':" + if chsh -s "$old_shell"; then + rm -f ~/.shell.pre-oh-my-zsh + else + echo "Could not change default shell. Change it manually by running chsh" + echo "or editing the /etc/passwd file." + exit + fi +fi + read -r -p "Are you sure you want to remove Oh My Zsh? [y/N] " confirmation if [ "$confirmation" != y ] && [ "$confirmation" != Y ]; then echo "Uninstall cancelled" @@ -25,16 +37,5 @@ else echo "No original zsh config found" fi -if hash chsh >/dev/null 2>&1 && [ -f ~/.shell.pre-oh-my-zsh ]; then - old_shell=$(cat ~/.shell.pre-oh-my-zsh) - echo "Switching your shell back to '$old_shell':" - if chsh -s "$old_shell"; then - rm -f ~/.shell.pre-oh-my-zsh - else - echo "Could not change default shell. Change it manually by running chsh" - echo "or editing the /etc/passwd file." - fi -fi - echo "Thanks for trying out Oh My Zsh. It's been uninstalled." echo "Don't forget to restart your terminal!" From 8f6fbe238969ecb22fbdae75450a9f8705c9f979 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?H=C3=A5vard=20Bartnes?= Date: Tue, 28 Mar 2023 12:50:05 +0200 Subject: [PATCH 224/672] feat(upgrade): add verbosity settings Co-authored-by: Carlo Sala Closes #11574 Closes #11579 --- README.md | 12 +++++++++ lib/cli.zsh | 5 ++-- tools/check_for_upgrade.sh | 3 ++- tools/upgrade.sh | 53 ++++++++++++++++++++++++++++---------- 4 files changed, 56 insertions(+), 17 deletions(-) diff --git a/README.md b/README.md index 4042c8c26..4f0aeb7b4 100644 --- a/README.md +++ b/README.md @@ -317,6 +317,18 @@ zstyle ':omz:update' frequency 7 zstyle ':omz:update' frequency 0 ``` +### Updates verbosity + +You can also limit the update verbosity with the following settings: + +```sh +zstyle ':omz:update' verbose default # default update prompt + +zstyle ':omz:update' verbose minimal # only few lines + +zstyle ':omz:update' verbose silent # only errors +``` + ### Manual Updates If you'd like to update at any point in time (maybe someone just released a new plugin and you don't want to wait a week?) you just need to run: diff --git a/lib/cli.zsh b/lib/cli.zsh index fed00d21d..ba3e39eb5 100644 --- a/lib/cli.zsh +++ b/lib/cli.zsh @@ -776,10 +776,11 @@ function _omz::update { local last_commit=$(builtin cd -q "$ZSH"; git rev-parse HEAD) # Run update script + zstyle -s ':omz:update' verbose verbose_mode || verbose_mode=default if [[ "$1" != --unattended ]]; then - ZSH="$ZSH" command zsh -f "$ZSH/tools/upgrade.sh" --interactive || return $? + ZSH="$ZSH" command zsh -f "$ZSH/tools/upgrade.sh" -i -v $verbose_mode || return $? else - ZSH="$ZSH" command zsh -f "$ZSH/tools/upgrade.sh" || return $? + ZSH="$ZSH" command zsh -f "$ZSH/tools/upgrade.sh" -v $verbose_mode || return $? fi # Update last updated file diff --git a/tools/check_for_upgrade.sh b/tools/check_for_upgrade.sh index 734714c94..81c371b3f 100644 --- a/tools/check_for_upgrade.sh +++ b/tools/check_for_upgrade.sh @@ -95,7 +95,8 @@ function update_last_updated_file() { } function update_ohmyzsh() { - if ZSH="$ZSH" zsh -f "$ZSH/tools/upgrade.sh" --interactive; then + zstyle -s ':omz:update' verbose verbose_mode || verbose_mode=default + if ZSH="$ZSH" zsh -f "$ZSH/tools/upgrade.sh" -i -v $verbose_mode; then update_last_updated_file fi } diff --git a/tools/upgrade.sh b/tools/upgrade.sh index 596a59302..684ad894a 100755 --- a/tools/upgrade.sh +++ b/tools/upgrade.sh @@ -12,6 +12,23 @@ esac cd "$ZSH" +verbose_mode="default" +interactive=false + +while getopts "v:i" opt; do + case $opt in + v) + if [[ $OPTARG == default || $OPTARG == minimal || $OPTARG == silent ]]; then + verbose_mode=$OPTARG + else + echo "[oh-my-zsh] update verbosity '$OPTARG' is not valid" + echo "[oh-my-zsh] valid options are 'default', 'minimal' and 'silent'" + fi + ;; + i) interactive=true ;; + esac +done + # Use colors, but only if connected to a terminal # and that terminal supports them. @@ -203,7 +220,9 @@ git checkout -q "$branch" -- || exit 1 last_commit=$(git rev-parse "$branch") # Update Oh My Zsh -printf "${BLUE}%s${RESET}\n" "Updating Oh My Zsh" +if [[ $verbose_mode != silent ]]; then + printf "${BLUE}%s${RESET}\n" "Updating Oh My Zsh" +fi if LANG= git pull --quiet --rebase $remote $branch; then # Check if it was really updated or not if [[ "$(git rev-parse HEAD)" = "$last_commit" ]]; then @@ -215,24 +234,30 @@ if LANG= git pull --quiet --rebase $remote $branch; then git config oh-my-zsh.lastVersion "$last_commit" # Print changelog to the terminal - if [[ "$1" = --interactive ]]; then + if [[ interactive == true && $verbose_mode == default ]] ; then "$ZSH/tools/changelog.sh" HEAD "$last_commit" fi - printf "${BLUE}%s \`${BOLD}%s${RESET}${BLUE}\`${RESET}\n" "You can see the changelog with" "omz changelog" + if [[ $verbose_mode != silent ]]; then + printf "${BLUE}%s \`${BOLD}%s${RESET}${BLUE}\`${RESET}\n" "You can see the changelog with" "omz changelog" + fi fi - printf '%s %s__ %s %s %s %s %s__ %s\n' $RAINBOW $RESET - printf '%s ____ %s/ /_ %s ____ ___ %s__ __ %s ____ %s_____%s/ /_ %s\n' $RAINBOW $RESET - printf '%s / __ \\%s/ __ \\ %s / __ `__ \\%s/ / / / %s /_ / %s/ ___/%s __ \\ %s\n' $RAINBOW $RESET - printf '%s/ /_/ /%s / / / %s / / / / / /%s /_/ / %s / /_%s(__ )%s / / / %s\n' $RAINBOW $RESET - printf '%s\\____/%s_/ /_/ %s /_/ /_/ /_/%s\\__, / %s /___/%s____/%s_/ /_/ %s\n' $RAINBOW $RESET - printf '%s %s %s %s /____/ %s %s %s %s\n' $RAINBOW $RESET - printf '\n' - printf "${BLUE}%s${RESET}\n\n" "$message" - printf "${BLUE}${BOLD}%s %s${RESET}\n" "To keep up with the latest news and updates, follow us on Twitter:" "$(fmt_link @ohmyzsh https://twitter.com/ohmyzsh)" - printf "${BLUE}${BOLD}%s %s${RESET}\n" "Want to get involved in the community? Join our Discord:" "$(fmt_link "Discord server" https://discord.gg/ohmyzsh)" - printf "${BLUE}${BOLD}%s %s${RESET}\n" "Get your Oh My Zsh swag at:" "$(fmt_link "Planet Argon Shop" https://shop.planetargon.com/collections/oh-my-zsh)" + if [[ $verbose_mode == default ]]; then + printf '%s %s__ %s %s %s %s %s__ %s\n' $RAINBOW $RESET + printf '%s ____ %s/ /_ %s ____ ___ %s__ __ %s ____ %s_____%s/ /_ %s\n' $RAINBOW $RESET + printf '%s / __ \\%s/ __ \\ %s / __ `__ \\%s/ / / / %s /_ / %s/ ___/%s __ \\ %s\n' $RAINBOW $RESET + printf '%s/ /_/ /%s / / / %s / / / / / /%s /_/ / %s / /_%s(__ )%s / / / %s\n' $RAINBOW $RESET + printf '%s\\____/%s_/ /_/ %s /_/ /_/ /_/%s\\__, / %s /___/%s____/%s_/ /_/ %s\n' $RAINBOW $RESET + printf '%s %s %s %s /____/ %s %s %s %s\n' $RAINBOW $RESET + printf '\n' + printf "${BLUE}%s${RESET}\n\n" "$message" + printf "${BLUE}${BOLD}%s %s${RESET}\n" "To keep up with the latest news and updates, follow us on Twitter:" "$(fmt_link @ohmyzsh https://twitter.com/ohmyzsh)" + printf "${BLUE}${BOLD}%s %s${RESET}\n" "Want to get involved in the community? Join our Discord:" "$(fmt_link "Discord server" https://discord.gg/ohmyzsh)" + printf "${BLUE}${BOLD}%s %s${RESET}\n" "Get your Oh My Zsh swag at:" "$(fmt_link "Planet Argon Shop" https://shop.planetargon.com/collections/oh-my-zsh)" + elif [[ $verbose_mode == minimal ]]; then + printf "${BLUE}%s${RESET}\n" "$message" + fi else ret=$? printf "${RED}%s${RESET}\n" 'There was an error updating. Try again later?' From fcbdc330ff50617c8b84d39ce069cc75df41108f Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Tue, 28 Mar 2023 16:55:53 +0200 Subject: [PATCH 225/672] fix(aws): restore accidentally deleted variable Closes #11589 --- plugins/aws/aws.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/aws/aws.plugin.zsh b/plugins/aws/aws.plugin.zsh index 0242be97e..a379eaa18 100644 --- a/plugins/aws/aws.plugin.zsh +++ b/plugins/aws/aws.plugin.zsh @@ -197,6 +197,7 @@ compctl -K _aws_profiles asp acp aws_change_access_key # AWS prompt function aws_prompt_info() { local _aws_to_show + local region="${AWS_REGION:-${AWS_DEFAULT_REGION:-$AWS_PROFILE_REGION}}" if [[ -n $AWS_PROFILE ]];then _aws_to_show+="${ZSH_THEME_AWS_PROFILE_PREFIX:=}" fi @@ -211,7 +212,6 @@ if [[ "$SHOW_AWS_PROMPT" != false && "$RPROMPT" != *'$(aws_prompt_info)'* ]]; th RPROMPT='$(aws_prompt_info)'"$RPROMPT" fi - # Load awscli completions # AWS CLI v2 comes with its own autocompletion. Check if that is there, otherwise fall back From 7837ba6a993fb2243b3e69fdbd63b437a8674b4c Mon Sep 17 00:00:00 2001 From: Webpage-gh <70434775+Webpage-gh@users.noreply.github.com> Date: Fri, 31 Mar 2023 13:37:01 +0800 Subject: [PATCH 226/672] fix(installer): don't use `sudo` when user is in Termux (#11591) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Co-authored-by: Marc Cornellà --- tools/install.sh | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/tools/install.sh b/tools/install.sh index f4ef16a0c..efdb7d482 100755 --- a/tools/install.sh +++ b/tools/install.sh @@ -84,6 +84,11 @@ command_exists() { user_can_sudo() { # Check if sudo is installed command_exists sudo || return 1 + # Termux can't run sudo unless the device is rooted. Either way, `chsh` works + # without sudo, so we can detect it and exit the function early. + case "$PREFIX" in + *com.termux*) return 1 ;; + esac # The following command has 3 parts: # # 1. Run `sudo` with `-v`. Does the following: From b9c4e2e82337594c2899db1f9ca005bb02fe20cd Mon Sep 17 00:00:00 2001 From: Guy Sartorelli <36352093+GuySartorelli@users.noreply.github.com> Date: Fri, 31 Mar 2023 18:49:59 +1300 Subject: [PATCH 227/672] feat(changelog): provide links in changelog (#11578) --- tools/changelog.sh | 98 +++++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 96 insertions(+), 2 deletions(-) diff --git a/tools/changelog.sh b/tools/changelog.sh index a5cc468f2..5f7a14d03 100755 --- a/tools/changelog.sh +++ b/tools/changelog.sh @@ -157,6 +157,89 @@ function parse-commit { fi } +################################ +# SUPPORTS HYPERLINKS FUNCTION # +################################ + +# The code for checking if a terminal supports hyperlinks is copied from install.sh + +# The [ -t 1 ] check only works when the function is not called from +# a subshell (like in `$(...)` or `(...)`, so this hack redefines the +# function at the top level to always return false when stdout is not +# a tty. +if [ -t 1 ]; then + is_tty() { + true + } +else + is_tty() { + false + } +fi + +# This function uses the logic from supports-hyperlinks[1][2], which is +# made by Kat Marchán (@zkat) and licensed under the Apache License 2.0. +# [1] https://github.com/zkat/supports-hyperlinks +# [2] https://crates.io/crates/supports-hyperlinks +# +# Copyright (c) 2021 Kat Marchán +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. +supports_hyperlinks() { + # $FORCE_HYPERLINK must be set and be non-zero (this acts as a logic bypass) + if [ -n "$FORCE_HYPERLINK" ]; then + [ "$FORCE_HYPERLINK" != 0 ] + return $? + fi + + # If stdout is not a tty, it doesn't support hyperlinks + is_tty || return 1 + + # DomTerm terminal emulator (domterm.org) + if [ -n "$DOMTERM" ]; then + return 0 + fi + + # VTE-based terminals above v0.50 (Gnome Terminal, Guake, ROXTerm, etc) + if [ -n "$VTE_VERSION" ]; then + [ $VTE_VERSION -ge 5000 ] + return $? + fi + + # If $TERM_PROGRAM is set, these terminals support hyperlinks + case "$TERM_PROGRAM" in + Hyper|iTerm.app|terminology|WezTerm) return 0 ;; + esac + + # kitty supports hyperlinks + if [ "$TERM" = xterm-kitty ]; then + return 0 + fi + + # Windows Terminal also supports hyperlinks + if [ -n "$WT_SESSION" ]; then + return 0 + fi + + # Konsole supports hyperlinks, but it's an opt-in setting that can't be detected + # https://github.com/ohmyzsh/ohmyzsh/issues/10964 + # if [ -n "$KONSOLE_VERSION" ]; then + # return 0 + # fi + + return 1 +} + ############################# # RELEASE CHANGELOG DISPLAY # ############################# @@ -208,7 +291,13 @@ function display-release { local hash="${1:-$hash}" case "$output" in raw) printf '%s' "$hash" ;; - text) printf '\e[33m%s\e[0m' "$hash" ;; # red + text) + local text="\e[33m$hash\e[0m"; # red + if supports_hyperlinks; then + printf "\e]8;;%s\a%s\e]8;;\a" "https://github.com/ohmyzsh/ohmyzsh/commit/$hash" $text; + else + echo $text; + fi ;; md) printf '[`%s`](https://github.com/ohmyzsh/ohmyzsh/commit/%s)' "$hash" "$hash" ;; esac } @@ -272,7 +361,12 @@ function display-release { case "$output" in raw) printf '%s' "$subject" ;; # In text mode, highlight (#) and dim text between `backticks` - text) sed -E $'s|#([0-9]+)|\e[32m#\\1\e[0m|g;s|`([^`]+)`|`\e[2m\\1\e[0m`|g' <<< "$subject" ;; + text) + if supports_hyperlinks; then + sed -E $'s|#([0-9]+)|\e]8;;https://github.com/ohmyzsh/ohmyzsh/issues/\\1\a\e[32m#\\1\e[0m\e]8;;\a|g' <<< "$subject" + else + sed -E $'s|#([0-9]+)|\e[32m#\\1\e[0m|g;s|`([^`]+)`|`\e[2m\\1\e[0m`|g' <<< "$subject" + fi ;; # In markdown mode, link to (#) issues md) sed -E 's|#([0-9]+)|[#\1](https://github.com/ohmyzsh/ohmyzsh/issues/\1)|g' <<< "$subject" ;; esac From cc9913210498e2d527486310f1e8a53b93f55ca8 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Fri, 31 Mar 2023 07:51:10 +0200 Subject: [PATCH 228/672] fix(vi-mode): fix check for prompt redisplay on mode change (#11547) --- plugins/vi-mode/vi-mode.plugin.zsh | 27 ++++++++++++++++----------- 1 file changed, 16 insertions(+), 11 deletions(-) diff --git a/plugins/vi-mode/vi-mode.plugin.zsh b/plugins/vi-mode/vi-mode.plugin.zsh index 9a410c1fb..d44be69d4 100644 --- a/plugins/vi-mode/vi-mode.plugin.zsh +++ b/plugins/vi-mode/vi-mode.plugin.zsh @@ -43,12 +43,25 @@ function _vi-mode-set-cursor-shape-for-keymap() { printf $'\e[%d q' "${_shape}" } +function _vi-mode-should-reset-prompt() { + # If $VI_MODE_RESET_PROMPT_ON_MODE_CHANGE is unset (default), dynamically + # check whether we're using the prompt to display vi-mode info + if [[ -z "${VI_MODE_RESET_PROMPT_ON_MODE_CHANGE:-}" ]]; then + [[ "${PS1} ${RPS1}" = *'$(vi_mode_prompt_info)'* ]] + return $? + fi + + # If $VI_MODE_RESET_PROMPT_ON_MODE_CHANGE was manually set, let's check + # if it was specifically set to true or it was disabled with any other value + [[ "${VI_MODE_RESET_PROMPT_ON_MODE_CHANGE}" = true ]] +} + # Updates editor information when the keymap changes. function zle-keymap-select() { # update keymap variable for the prompt typeset -g VI_KEYMAP=$KEYMAP - if [[ "${VI_MODE_RESET_PROMPT_ON_MODE_CHANGE:-}" = true ]]; then + if _vi-mode-should-reset-prompt; then zle reset-prompt zle -R fi @@ -59,10 +72,9 @@ zle -N zle-keymap-select # These "echoti" statements were originally set in lib/key-bindings.zsh # Not sure the best way to extend without overriding. function zle-line-init() { - local prev_vi_keymap - prev_vi_keymap="${VI_KEYMAP:-}" + local prev_vi_keymap="${VI_KEYMAP:-}" typeset -g VI_KEYMAP=main - [[ "$prev_vi_keymap" != 'main' ]] && [[ "${VI_MODE_RESET_PROMPT_ON_MODE_CHANGE:-}" = true ]] && zle reset-prompt + [[ "$prev_vi_keymap" != 'main' ]] && _vi-mode-should-reset-prompt && zle reset-prompt (( ! ${+terminfo[smkx]} )) || echoti smkx _vi-mode-set-cursor-shape-for-keymap "${VI_KEYMAP}" } @@ -138,13 +150,6 @@ if [[ -z "$MODE_INDICATOR" ]]; then fi function vi_mode_prompt_info() { - # If we're using the prompt to display mode info, and we haven't explicitly - # disabled "reset prompt on mode change", then set it here. - # - # We do that here instead of the `if` statement below because the user may - # set RPS1/RPROMPT to something else in their custom config. - : "${VI_MODE_RESET_PROMPT_ON_MODE_CHANGE:=true}" - echo "${${VI_KEYMAP/vicmd/$MODE_INDICATOR}/(main|viins)/$INSERT_MODE_INDICATOR}" } From 029a6d2de8681d52142129eb8b6ff0f20be9f0a6 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Fri, 31 Mar 2023 15:30:19 +0200 Subject: [PATCH 229/672] fix(upgrade): typo in variable check --- tools/upgrade.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tools/upgrade.sh b/tools/upgrade.sh index 684ad894a..d9a372d13 100755 --- a/tools/upgrade.sh +++ b/tools/upgrade.sh @@ -234,7 +234,7 @@ if LANG= git pull --quiet --rebase $remote $branch; then git config oh-my-zsh.lastVersion "$last_commit" # Print changelog to the terminal - if [[ interactive == true && $verbose_mode == default ]] ; then + if [[ $interactive == true && $verbose_mode == default ]]; then "$ZSH/tools/changelog.sh" HEAD "$last_commit" fi From 6ef236dd99f2090b54911f9135d00ac37d6757ff Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Sat, 1 Apr 2023 10:14:18 +0200 Subject: [PATCH 230/672] fix(updater): search for upstream remote if using non-conventional name (#11135) Fixes #11135 --- tools/upgrade.sh | 26 +++++++++++++++++--------- 1 file changed, 17 insertions(+), 9 deletions(-) diff --git a/tools/upgrade.sh b/tools/upgrade.sh index d9a372d13..34ff3f027 100755 --- a/tools/upgrade.sh +++ b/tools/upgrade.sh @@ -1,5 +1,7 @@ #!/usr/bin/env zsh +local ret=0 # exit code + # Protect against running with shells other than zsh if [ -z "$ZSH_VERSION" ]; then exec zsh "$0" "$@" @@ -181,17 +183,23 @@ fi # Update upstream remote to ohmyzsh org git remote -v | while read remote url extra; do case "$url" in - https://github.com/robbyrussell/oh-my-zsh(|.git)) - git remote set-url "$remote" "https://github.com/ohmyzsh/ohmyzsh.git" - break ;; - git@github.com:robbyrussell/oh-my-zsh(|.git)) - git remote set-url "$remote" "git@github.com:ohmyzsh/ohmyzsh.git" - break ;; - # Update out-of-date "unauthenticated git protocol on port 9418" to https git://github.com/robbyrussell/oh-my-zsh(|.git)) - git remote set-url "$remote" "https://github.com/ohmyzsh/ohmyzsh.git" - break ;; + # Update out-of-date "unauthenticated git protocol on port 9418" to https + git remote set-url "$remote" "https://github.com/ohmyzsh/ohmyzsh.git" ;; + https://github.com/robbyrussell/oh-my-zsh(|.git)) + git remote set-url "$remote" "https://github.com/ohmyzsh/ohmyzsh.git" ;; + git@github.com:robbyrussell/oh-my-zsh(|.git)) + git remote set-url "$remote" "git@github.com:ohmyzsh/ohmyzsh.git" ;; + https://github.com/ohmyzsh/ohmyzsh(|.git)) ;; + git@github.com:ohmyzsh/ohmyzsh(|.git)) ;; + *) continue ;; esac + + # If we reach this point we have found the proper ohmyzsh upstream remote. If we don't, + # we'll only update from the set remote if `oh-my-zsh.remote` has been set to a remote, + # as when installing from a fork. + git config --local oh-my-zsh.remote "$remote" + break done # Set git-config values known to fix git errors From 68005b887055ddd1c6d3fd1381b6eb7b786a0a38 Mon Sep 17 00:00:00 2001 From: Saverio Guzzo Date: Sun, 2 Apr 2023 12:54:55 +0200 Subject: [PATCH 231/672] docs(spotify): fix link (#11593) --- plugins/macos/spotify | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/macos/spotify b/plugins/macos/spotify index 491a60686..5fb40517c 100644 --- a/plugins/macos/spotify +++ b/plugins/macos/spotify @@ -43,7 +43,7 @@ showAPIHelp() { echo " find music by name. It is very likely you want this feature!"; echo; echo " To get this to work, you need to sign up (or in) and create an 'Application' at:"; - echo " https://developer.spotify.com/my-applications/#!/applications/create"; + echo " https://developer.spotify.com/dashboard/create"; echo; echo " Once you've created an application, find the 'Client ID' and 'Client Secret'"; echo " values, and enter them into your shpotify config file at '${USER_CONFIG_FILE}'"; From f7d903f3a31567f326d0f8ec2414722d0e3b992a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Sun, 2 Apr 2023 13:40:49 +0200 Subject: [PATCH 232/672] fix(vi-mode): fix cursor change on visual mode (#11586) Fixes #11586 --- plugins/vi-mode/vi-mode.plugin.zsh | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/plugins/vi-mode/vi-mode.plugin.zsh b/plugins/vi-mode/vi-mode.plugin.zsh index d44be69d4..cc9817a74 100644 --- a/plugins/vi-mode/vi-mode.plugin.zsh +++ b/plugins/vi-mode/vi-mode.plugin.zsh @@ -43,6 +43,13 @@ function _vi-mode-set-cursor-shape-for-keymap() { printf $'\e[%d q' "${_shape}" } +function _visual-mode { + typeset -g VI_KEYMAP=visual + _vi-mode-set-cursor-shape-for-keymap "$VI_KEYMAP" + zle .visual-mode +} +zle -N visual-mode _visual-mode + function _vi-mode-should-reset-prompt() { # If $VI_MODE_RESET_PROMPT_ON_MODE_CHANGE is unset (default), dynamically # check whether we're using the prompt to display vi-mode info From 75405b7b0ae03a1fdf2fdb172d2a50cd5f570162 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Sun, 2 Apr 2023 14:28:01 +0200 Subject: [PATCH 233/672] feat(extract): always extract files into its own folder (#11596) --- plugins/extract/extract.plugin.zsh | 84 ++++++++++++++++++------------ 1 file changed, 51 insertions(+), 33 deletions(-) diff --git a/plugins/extract/extract.plugin.zsh b/plugins/extract/extract.plugin.zsh index 7b7a2fa4f..c416f49ce 100644 --- a/plugins/extract/extract.plugin.zsh +++ b/plugins/extract/extract.plugin.zsh @@ -29,61 +29,79 @@ EOF local success=0 local extract_dir="${1:t:r}" local file="$1" full_path="${1:A}" + + # Create an extraction directory based on the file name + command mkdir -p "$extract_dir" + builtin cd -q "$extract_dir" + case "${file:l}" in (*.tar.gz|*.tgz) - (( $+commands[pigz] )) && { tar -I pigz -xvf "$file" } || tar zxvf "$file" ;; + (( $+commands[pigz] )) && { tar -I pigz -xvf "$full_path" } || tar zxvf "$full_path" ;; (*.tar.bz2|*.tbz|*.tbz2) - (( $+commands[pbzip2] )) && { tar -I pbzip2 -xvf "$file" } || tar xvjf "$file" ;; + (( $+commands[pbzip2] )) && { tar -I pbzip2 -xvf "$full_path" } || tar xvjf "$full_path" ;; (*.tar.xz|*.txz) - (( $+commands[pixz] )) && { tar -I pixz -xvf "$file" } || { + (( $+commands[pixz] )) && { tar -I pixz -xvf "$full_path" } || { tar --xz --help &> /dev/null \ - && tar --xz -xvf "$file" \ - || xzcat "$file" | tar xvf - } ;; + && tar --xz -xvf "$full_path" \ + || xzcat "$full_path" | tar xvf - } ;; (*.tar.zma|*.tlz) tar --lzma --help &> /dev/null \ - && tar --lzma -xvf "$file" \ - || lzcat "$file" | tar xvf - ;; + && tar --lzma -xvf "$full_path" \ + || lzcat "$full_path" | tar xvf - ;; (*.tar.zst|*.tzst) tar --zstd --help &> /dev/null \ - && tar --zstd -xvf "$file" \ - || zstdcat "$file" | tar xvf - ;; - (*.tar) tar xvf "$file" ;; - (*.tar.lz) (( $+commands[lzip] )) && tar xvf "$file" ;; - (*.tar.lz4) lz4 -c -d "$file" | tar xvf - ;; - (*.tar.lrz) (( $+commands[lrzuntar] )) && lrzuntar "$file" ;; - (*.gz) (( $+commands[pigz] )) && pigz -dk "$file" || gunzip -k "$file" ;; - (*.bz2) bunzip2 "$file" ;; - (*.xz) unxz "$file" ;; - (*.lrz) (( $+commands[lrunzip] )) && lrunzip "$file" ;; - (*.lz4) lz4 -d "$file" ;; - (*.lzma) unlzma "$file" ;; - (*.z) uncompress "$file" ;; - (*.zip|*.war|*.jar|*.ear|*.sublime-package|*.ipa|*.ipsw|*.xpi|*.apk|*.aar|*.whl) unzip "$file" -d "$extract_dir" ;; - (*.rar) unrar x -ad "$file" ;; + && tar --zstd -xvf "$full_path" \ + || zstdcat "$full_path" | tar xvf - ;; + (*.tar) tar xvf "$full_path" ;; + (*.tar.lz) (( $+commands[lzip] )) && tar xvf "$full_path" ;; + (*.tar.lz4) lz4 -c -d "$full_path" | tar xvf - ;; + (*.tar.lrz) (( $+commands[lrzuntar] )) && lrzuntar "$full_path" ;; + (*.gz) (( $+commands[pigz] )) && pigz -dk "$full_path" || gunzip -k "$full_path" ;; + (*.bz2) bunzip2 "$full_path" ;; + (*.xz) unxz "$full_path" ;; + (*.lrz) (( $+commands[lrunzip] )) && lrunzip "$full_path" ;; + (*.lz4) lz4 -d "$full_path" ;; + (*.lzma) unlzma "$full_path" ;; + (*.z) uncompress "$full_path" ;; + (*.zip|*.war|*.jar|*.ear|*.sublime-package|*.ipa|*.ipsw|*.xpi|*.apk|*.aar|*.whl) unzip "$full_path" ;; + (*.rar) unrar x -ad "$full_path" ;; (*.rpm) - command mkdir -p "$extract_dir" && builtin cd -q "$extract_dir" \ - && rpm2cpio "$full_path" | cpio --quiet -id ;; - (*.7z) 7za x "$file" ;; + rpm2cpio "$full_path" | cpio --quiet -id ;; + (*.7z) 7za x "$full_path" ;; (*.deb) - command mkdir -p "$extract_dir/control" "$extract_dir/data" - builtin cd -q "$extract_dir"; ar vx "$full_path" > /dev/null + command mkdir -p "control" "data" + ar vx "$full_path" > /dev/null builtin cd -q control; extract ../control.tar.* builtin cd -q ../data; extract ../data.tar.* builtin cd -q ..; command rm *.tar.* debian-binary ;; - (*.zst) unzstd "$file" ;; - (*.cab) cabextract -d "$extract_dir" "$file" ;; - (*.cpio|*.obscpio) cpio -idmvF "$file" ;; - (*.zpaq) zpaq x "$file" ;; + (*.zst) unzstd "$full_path" ;; + (*.cab) cabextract "$full_path" ;; + (*.cpio|*.obscpio) cpio -idmvF "$full_path" ;; + (*.zpaq) zpaq x "$full_path" ;; (*) echo "extract: '$file' cannot be extracted" >&2 success=1 ;; esac (( success = success > 0 ? success : $? )) - (( success == 0 && remove_archive == 0 )) && rm "$full_path" + (( success == 0 && remove_archive == 0 )) && command rm "$full_path" shift - # Go back to original working directory in case we ran cd previously + # Go back to original working directory + # and remove extraction directory if there was an error builtin cd -q "$pwd" + (( success > 0 )) && command rm -r "$extract_dir" + + # If content of extract dir is a single directory, move its contents up + # Glob flags: + # - D: include files starting with . + # - N: no error if directory is empty + # - Y2: at most give 2 files + local -a content + content=("${extract_dir}"/*(DNY2)) + if [[ ${#content} -eq 1 && -d "${content[1]}" ]]; then + command mv -f "${content[1]}" . + command rmdir "$extract_dir" + fi done } From d47e1d65f66f9bb2e7a96ba58797b33f0e91a623 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Sun, 2 Apr 2023 16:33:54 +0200 Subject: [PATCH 234/672] fix(extract): safely remove extract directory The previous code would remove the extract directory if the command failed. This could be bad because we're not checking if the extract directory already existed (since we're using `mkdir -p`), so it could be possible that the extract operation failed, and we'd be removing a directory that already existed and had files in it. This change only removes the directory if there are no files in it, regardless of whether the extract operation was successful or not. This is much safer. --- plugins/extract/extract.plugin.zsh | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/plugins/extract/extract.plugin.zsh b/plugins/extract/extract.plugin.zsh index c416f49ce..40e67575f 100644 --- a/plugins/extract/extract.plugin.zsh +++ b/plugins/extract/extract.plugin.zsh @@ -88,9 +88,7 @@ EOF shift # Go back to original working directory - # and remove extraction directory if there was an error builtin cd -q "$pwd" - (( success > 0 )) && command rm -r "$extract_dir" # If content of extract dir is a single directory, move its contents up # Glob flags: @@ -102,6 +100,8 @@ EOF if [[ ${#content} -eq 1 && -d "${content[1]}" ]]; then command mv -f "${content[1]}" . command rmdir "$extract_dir" + elif [[ ${#content} -eq 0 ]]; then + command rmdir "$extract_dir" fi done } From f8bf88edca7a3246e065f13cefac2c5f1ab396e0 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Mon, 3 Apr 2023 22:21:49 +0200 Subject: [PATCH 235/672] chore(installer): remove words triggering false positives in antiviruses --- tools/install.sh | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/tools/install.sh b/tools/install.sh index efdb7d482..fcfbcf778 100755 --- a/tools/install.sh +++ b/tools/install.sh @@ -84,8 +84,7 @@ command_exists() { user_can_sudo() { # Check if sudo is installed command_exists sudo || return 1 - # Termux can't run sudo unless the device is rooted. Either way, `chsh` works - # without sudo, so we can detect it and exit the function early. + # Termux can't run sudo, so we can detect it and exit the function early. case "$PREFIX" in *com.termux*) return 1 ;; esac From 1ad167dfac325a9f92e0693c70d0ab3f7c4c574b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Mon, 3 Apr 2023 23:14:36 +0200 Subject: [PATCH 236/672] feat(init)!: allow turning off aliases for libs and plugins (#11550) BREAKING CHANGE: the previous zstyle setting to disable `lib/directories.zsh` aliases has been changed to the new syntax: `zstyle ':omz:lib:directories' aliases no`. See https://github.com/ohmyzsh/ohmyzsh#skip-aliases to see other ways you can use this setting. Co-authored-by: Carlo Sala --- README.md | 54 ++++++++++++++++++++++++++++++++++++++++----- lib/directories.zsh | 6 ----- oh-my-zsh.sh | 45 ++++++++++++++++++++++++++++++------- 3 files changed, 86 insertions(+), 19 deletions(-) diff --git a/README.md b/README.md index 4f0aeb7b4..556d4c8c5 100644 --- a/README.md +++ b/README.md @@ -40,7 +40,9 @@ To learn more, visit [ohmyz.sh](https://ohmyz.sh), follow [@ohmyzsh](https://twi - [Manual Installation](#manual-installation) - [Installation Problems](#installation-problems) - [Custom Plugins and Themes](#custom-plugins-and-themes) + - [Skip aliases](#skip-aliases) - [Getting Updates](#getting-updates) + - [Updates verbosity](#updates-verbosity) - [Manual Updates](#manual-updates) - [Uninstalling Oh My Zsh](#uninstalling-oh-my-zsh) - [How do I contribute to Oh My Zsh?](#how-do-i-contribute-to-oh-my-zsh) @@ -276,16 +278,58 @@ If you have many functions that go well together, you can put them as a `XYZ.plu If you would like to override the functionality of a plugin distributed with Oh My Zsh, create a plugin of the same name in the `custom/plugins/` directory and it will be loaded instead of the one in `plugins/`. -### Remove directories aliases +### Skip aliases -If you want to skip ohmyzsh default -[directories aliases](https://github.com/ohmyzsh/ohmyzsh/blob/master/lib/directories.zsh) you can add the -following snippet to your `zshrc`, before loading `oh-my-zsh.sh` script: + -```zsh +If you want to skip default Oh My Zsh aliases (those defined in `lib/*` files) or plugin aliases, +you can use the settings below in your `~/.zshrc` file, **before Oh My Zsh is loaded**. Note that +there are many different ways to skip aliases, depending on your needs. + +```sh +# Skip all aliases, in lib files and enabled plugins +zstyle ':omz:*' aliases no + +# Skip all aliases in lib files +zstyle ':omz:lib:*' aliases no +# Skip only aliases defined in the directories.zsh lib file +zstyle ':omz:lib:directories' aliases no + +# Skip all plugin aliases +zstyle ':omz:plugins:*' aliases no +# Skip only the aliases from the git plugin +zstyle ':omz:plugins:git' aliases no +``` + +You can combine these in other ways taking into account that more specific scopes takes precedence: + +```sh +# Skip all plugin aliases, except for the git plugin +zstyle ':omz:plugins:*' aliases no +zstyle ':omz:plugins:git' aliases yes +``` + +A previous version of this feature was using the setting below, which has been removed: + +```sh zstyle ':omz:directories' aliases no ``` +Instead, you can now use the following: + +```sh +zstyle ':omz:lib:directories' aliases no +``` + +#### Notice + +> This feature is currently in a testing phase and it may be subject to change in the future. +> It is also not currently compatible with plugin managers such as zpm or zinit, which don't +> source the init script (`oh-my-zsh.sh`) where this feature is implemented in. + +> It is also not currently aware of "aliases" that are defined as functions. Example of such +> are `gccd`, `ggf`, or `ggl` functions from the git plugin. + ## Getting Updates By default, you will be prompted to check for updates every 2 weeks. You can choose other update modes by adding a line to your `~/.zshrc` file, **before Oh My Zsh is loaded**: diff --git a/lib/directories.zsh b/lib/directories.zsh index 13b680c19..8927a56ad 100644 --- a/lib/directories.zsh +++ b/lib/directories.zsh @@ -4,12 +4,6 @@ setopt auto_pushd setopt pushd_ignore_dups setopt pushdminus -# add (uncommented): -# zstyle ':omz:directories' aliases no -# to your `zshrc` before loading `oh-my-zsh.sh` -# to disable the following aliases and functions - -zstyle -T ':omz:directories' aliases || return 0 alias -g ...='../..' alias -g ....='../../..' diff --git a/oh-my-zsh.sh b/oh-my-zsh.sh index 363cfca8b..20d2e354c 100644 --- a/oh-my-zsh.sh +++ b/oh-my-zsh.sh @@ -146,22 +146,51 @@ if command mkdir "${ZSH_COMPDUMP}.lock" 2>/dev/null; then command rm -rf "$ZSH_COMPDUMP.zwc.old" "${ZSH_COMPDUMP}.lock" fi +_omz_source() { + local context filepath="$1" + + # Construct zstyle context based on path + case "$filepath" in + lib/*) context="lib:${filepath:t:r}" ;; # :t = lib_name.zsh, :r = lib_name + plugins/*) context="plugins:${filepath:h2:t}" ;; # :h2 = plugins/plugin_name, :t = plugin_name + esac + + local disable_aliases=0 + zstyle -T ":omz:${context}" aliases || disable_aliases=1 + + # Back up alias names prior to sourcing + local -a aliases_pre galiases_pre + if (( disable_aliases )); then + aliases_pre=("${(@k)aliases}") + galiases_pre=("${(@k)galiases}") + fi + + # Source file from $ZSH_CUSTOM if it exists, otherwise from $ZSH + if [[ -f "$ZSH_CUSTOM/$filepath" ]]; then + source "$ZSH_CUSTOM/$filepath" + elif [[ -f "$ZSH/$filepath" ]]; then + source "$ZSH/$filepath" + fi + + # Unset all aliases that don't appear in the backed up list of aliases + if (( disable_aliases )); then + local -a disabled + # ${var:|array} gets the list of items in var not in array + disabled=("${(@k)aliases:|aliases_pre}" "${(@k)galiases:|galiases_pre}") + (( $#disabled == 0 )) || unalias "${(@)disabled}" + fi +} + # Load all of the config files in ~/oh-my-zsh that end in .zsh # TIP: Add files you don't want in git to .gitignore for config_file ("$ZSH"/lib/*.zsh); do - custom_config_file="$ZSH_CUSTOM/lib/${config_file:t}" - [[ -f "$custom_config_file" ]] && config_file="$custom_config_file" - source "$config_file" + _omz_source "${config_file:t2}" done unset custom_config_file # Load all of the plugins that were defined in ~/.zshrc for plugin ($plugins); do - if [[ -f "$ZSH_CUSTOM/plugins/$plugin/$plugin.plugin.zsh" ]]; then - source "$ZSH_CUSTOM/plugins/$plugin/$plugin.plugin.zsh" - elif [[ -f "$ZSH/plugins/$plugin/$plugin.plugin.zsh" ]]; then - source "$ZSH/plugins/$plugin/$plugin.plugin.zsh" - fi + _omz_source "plugins/$plugin/$plugin.plugin.zsh" done unset plugin From c7bb88f9ad3eb742aecca2e36b615819cead10f4 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Mon, 3 Apr 2023 23:27:14 +0200 Subject: [PATCH 237/672] fix(changelog): ignore lines containing whitespace in breaking change commits --- tools/changelog.sh | 3 +++ 1 file changed, 3 insertions(+) diff --git a/tools/changelog.sh b/tools/changelog.sh index 5f7a14d03..1af74e42d 100755 --- a/tools/changelog.sh +++ b/tools/changelog.sh @@ -106,6 +106,9 @@ function parse-commit { message="${match[1]}" # remove CR characters (might be inserted in GitHub UI commit description form) message="${message//$'\r'/}" + # remove lines containing only whitespace + local nlnl=$'\n\n' + message="${message//$'\n'[[:space:]]##$'\n'/$nlnl}" # skip next paragraphs (separated by two newlines or more) message="${message%%$'\n\n'*}" # ... and replace newlines with spaces From 9233ef75f28423d147a2f9f64a45a77b1886ee5d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Mon, 3 Apr 2023 23:36:44 +0200 Subject: [PATCH 238/672] fix(init): don't use digits in parameter modifiers for compatibility (#11598) Digit modifiers were introduced in zsh 5.7.1 [1]. This commit uses readily available alternatives for backwards compatibility. [1] https://github.com/zsh-users/zsh/commit/b8dc5a7f6d Fixes #11598 --- oh-my-zsh.sh | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/oh-my-zsh.sh b/oh-my-zsh.sh index 20d2e354c..e047d4834 100644 --- a/oh-my-zsh.sh +++ b/oh-my-zsh.sh @@ -151,8 +151,8 @@ _omz_source() { # Construct zstyle context based on path case "$filepath" in - lib/*) context="lib:${filepath:t:r}" ;; # :t = lib_name.zsh, :r = lib_name - plugins/*) context="plugins:${filepath:h2:t}" ;; # :h2 = plugins/plugin_name, :t = plugin_name + lib/*) context="lib:${filepath:t:r}" ;; # :t = lib_name.zsh, :r = lib_name + plugins/*) context="plugins:${filepath:h:t}" ;; # :h = plugins/plugin_name, :t = plugin_name esac local disable_aliases=0 @@ -184,7 +184,7 @@ _omz_source() { # Load all of the config files in ~/oh-my-zsh that end in .zsh # TIP: Add files you don't want in git to .gitignore for config_file ("$ZSH"/lib/*.zsh); do - _omz_source "${config_file:t2}" + _omz_source "lib/${config_file:t}" done unset custom_config_file From 8d23fbd6964b8446bbc73ff04507362d1fd49eb5 Mon Sep 17 00:00:00 2001 From: Christian Parpart Date: Tue, 4 Apr 2023 16:47:13 +0200 Subject: [PATCH 239/672] feat(termsupport): add contour terminal (#11599) Signed-off-by: Christian Parpart --- lib/termsupport.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/termsupport.zsh b/lib/termsupport.zsh index 80ca7ef78..5bc418761 100644 --- a/lib/termsupport.zsh +++ b/lib/termsupport.zsh @@ -17,7 +17,7 @@ function title { : ${2=$1} case "$TERM" in - cygwin|xterm*|putty*|rxvt*|konsole*|ansi|mlterm*|alacritty|st*|foot) + cygwin|xterm*|putty*|rxvt*|konsole*|ansi|mlterm*|alacritty|st*|foot|contour*) print -Pn "\e]2;${2:q}\a" # set window name print -Pn "\e]1;${1:q}\a" # set tab name ;; From 33aadeced0bf17b8abc7d680b424de7c5e71dd45 Mon Sep 17 00:00:00 2001 From: Richard Mitchell Date: Tue, 4 Apr 2023 17:52:16 -0400 Subject: [PATCH 240/672] feat(term_tab): add support for macOS (#11391) --- plugins/term_tab/term_tab.plugin.zsh | 1 + 1 file changed, 1 insertion(+) diff --git a/plugins/term_tab/term_tab.plugin.zsh b/plugins/term_tab/term_tab.plugin.zsh index 1b612df68..89acd9103 100644 --- a/plugins/term_tab/term_tab.plugin.zsh +++ b/plugins/term_tab/term_tab.plugin.zsh @@ -28,6 +28,7 @@ function _term_list(){ case $OSTYPE in solaris*) dirs=( ${(M)${${(f)"$(pgrep -U $UID -x zsh|xargs pwdx)"}:#$$:*}%%/*} ) ;; linux*) dirs=( /proc/${^$(pidof zsh):#$$}/cwd(N:A) ) ;; + darwin*) dirs=( $( lsof -d cwd -c zsh -a -w -Fn | sed -n 's/^n//p' ) ) ;; esac dirs=( ${(D)dirs} ) From 25c2c3a4683be60c3526858be960ee6ce1249245 Mon Sep 17 00:00:00 2001 From: Alexander Schlarb Date: Sun, 16 May 2021 18:58:38 +0200 Subject: [PATCH 241/672] feat(lib): send OSC 7 on directory change for more supported terminals (#9914) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Previously this was only emitted on macOS with Apple's Terminal.app (and compatible clones like iTerm2), but it is used by other terminal emulators as well to obtain the actual current working directory wiht symlinks intact. All non-supporting terminal emulators tested gracefully ignored this value, so emit this on these as well in case they (or some other app masquarading as them) add future support for this value. Closes #9914 Co-authored-by: Marc Cornellà --- lib/termsupport.zsh | 70 ++++++++++++++++++++++++++++++--------------- 1 file changed, 47 insertions(+), 23 deletions(-) diff --git a/lib/termsupport.zsh b/lib/termsupport.zsh index 5bc418761..cf8f08741 100644 --- a/lib/termsupport.zsh +++ b/lib/termsupport.zsh @@ -109,28 +109,52 @@ if [[ -z "$INSIDE_EMACS" || "$INSIDE_EMACS" = vterm ]]; then add-zsh-hook preexec omz_termsupport_preexec fi -# Keep Apple Terminal.app's current working directory updated -# Based on this answer: https://superuser.com/a/315029 -# With extra fixes to handle multibyte chars and non-UTF-8 locales +# Keep terminal emulator's current working directory correct, +# even if the current working directory path contains symbolic links +# +# References: +# - Apple's Terminal.app: https://superuser.com/a/315029 +# - iTerm2: https://iterm2.com/documentation-escape-codes.html (iTerm2 Extension / CurrentDir+RemoteHost) +# - Konsole: https://bugs.kde.org/show_bug.cgi?id=327720#c1 +# - libvte (gnome-terminal, mate-terminal, …): https://bugzilla.gnome.org/show_bug.cgi?id=675987#c14 +# Apparently it had a bug before ~2012 were it would display the unknown OSC 7 code +# +# As of May 2021 mlterm, PuTTY, rxvt, screen, termux & xterm simply ignore the unknown OSC. -if [[ "$TERM_PROGRAM" == "Apple_Terminal" ]] && [[ -z "$INSIDE_EMACS" ]]; then - # Emits the control sequence to notify Terminal.app of the cwd - # Identifies the directory using a file: URI scheme, including - # the host name to disambiguate local vs. remote paths. - function update_terminalapp_cwd() { - emulate -L zsh - - # Percent-encode the host and path names. - local URL_HOST URL_PATH - URL_HOST="$(omz_urlencode -P $HOST)" || return 1 - URL_PATH="$(omz_urlencode -P $PWD)" || return 1 - - # Undocumented Terminal.app-specific control sequence - printf '\e]7;%s\a' "file://$URL_HOST$URL_PATH" - } - - # Use a precmd hook instead of a chpwd hook to avoid contaminating output - add-zsh-hook precmd update_terminalapp_cwd - # Run once to get initial cwd set - update_terminalapp_cwd +# Don't define the function if we're inside Emacs +if [[ -n "$INSIDE_EMACS" ]]; then + return fi + +# Don't define the function if we're in an unsupported terminal +case "$TERM" in + # all of these either process OSC 7 correctly or ignore entirely + xterm*|putty*|rxvt*|konsole*|mlterm*|alacritty|screen*|tmux*) ;; + contour*|foot*) ;; + *) + # Terminal.app and iTerm2 process OSC 7 correctly + case "$TERM_PROGRAM" in + Apple_Terminal|iTerm.app) ;; + *) return ;; + esac ;; +esac + +# Emits the control sequence to notify many terminal emulators +# of the cwd +# +# Identifies the directory using a file: URI scheme, including +# the host name to disambiguate local vs. remote paths. +function omz_termsupport_cwd { + # Percent-encode the host and path names. + local URL_HOST URL_PATH + URL_HOST="$(omz_urlencode -P $HOST)" || return 1 + URL_PATH="$(omz_urlencode -P $PWD)" || return 1 + + # common control sequence (OSC 7) to set current host and path + printf "\e]7;%s\a" "file://${URL_HOST}${URL_PATH}" +} + +# Use a precmd hook instead of a chpwd hook to avoid contaminating output +# i.e. when a script or function changes directory without `cd -q`, chpwd +# will be called the output may be swallowed by the script or function. +add-zsh-hook precmd omz_termsupport_cwd From cf0c80049288d1029aee824bf975016c4201a3ef Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Fran=C3=A7ois=20M?= Date: Thu, 6 Apr 2023 15:11:52 +0200 Subject: [PATCH 242/672] feat(toolbox)!: rename and add aliases (#11580) --- plugins/toolbox/README.md | 3 ++- plugins/toolbox/toolbox.plugin.zsh | 3 ++- 2 files changed, 4 insertions(+), 2 deletions(-) diff --git a/plugins/toolbox/README.md b/plugins/toolbox/README.md index abaca31f4..bc04a906b 100644 --- a/plugins/toolbox/README.md +++ b/plugins/toolbox/README.md @@ -22,4 +22,5 @@ RPROMPT='$(toolbox_prompt_info)' | Alias | Command | Description | |-------|----------------------|----------------------------------------| -| tb | `toolbox enter` | Enters the toolbox environment | +| tbe | `toolbox enter` | Enters the toolbox environment | +| tbr | `toolbox run` | Run a command in an existing toolbox | diff --git a/plugins/toolbox/toolbox.plugin.zsh b/plugins/toolbox/toolbox.plugin.zsh index d24d6d396..377e498cd 100644 --- a/plugins/toolbox/toolbox.plugin.zsh +++ b/plugins/toolbox/toolbox.plugin.zsh @@ -2,4 +2,5 @@ function toolbox_prompt_info() { [[ -f /run/.toolboxenv ]] && echo "⬢" } -alias tb="toolbox enter" +alias tbe="toolbox enter" +alias tbr="toolbox run" From 49d34d00cdaf132f318700398bf42120ff1af8e7 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Thu, 6 Apr 2023 21:06:16 +0200 Subject: [PATCH 243/672] fix(extract): fix conflict if compressed file has a folder of the same name This change fixes the case where the compressed file (e.g. tools.tgz) only contains a folder with the same name (e.g. tools) in its root folder. tools.tgz: |- tools |- fileA.txt |- fileB.txt \- fileC.txt In that case, the "smart" folder creation mechanism will extract the files in a folder "tools", and this extraction folder will contain a single folder with the same name. Before this fix, the tool would try to move out the inside folder to the parent one, but there would already be a folder named "tools", so it would generate a conflict. This change first renames the inside folder to a random string, and only then it is moved outside and the old extraction folder is deleted. --- plugins/extract/extract.plugin.zsh | 18 ++++++++++++++++-- 1 file changed, 16 insertions(+), 2 deletions(-) diff --git a/plugins/extract/extract.plugin.zsh b/plugins/extract/extract.plugin.zsh index 40e67575f..34c080653 100644 --- a/plugins/extract/extract.plugin.zsh +++ b/plugins/extract/extract.plugin.zsh @@ -98,8 +98,22 @@ EOF local -a content content=("${extract_dir}"/*(DNY2)) if [[ ${#content} -eq 1 && -d "${content[1]}" ]]; then - command mv -f "${content[1]}" . - command rmdir "$extract_dir" + # The extracted folder (${content[1]}) may have the same name as $extract_dir + # If so, we need to rename it to avoid conflicts in a 3-step process + # + # 1. Move and rename the extracted folder to a temporary random name + # 2. Delete the empty folder + # 3. Rename the extracted folder to the original name + if [[ "${content[1]:t}" == "$extract_dir" ]]; then + # =(:) gives /tmp/zsh, with :t it gives zsh + local tmp_dir==(:); tmp_dir="${tmp_dir:t}" + command mv -f "${content[1]}" "$tmp_dir" \ + && command rmdir "$extract_dir" \ + && command mv -f "$tmp_dir" "$extract_dir" + else + command mv -f "${content[1]}" . \ + && command rmdir "$extract_dir" + fi elif [[ ${#content} -eq 0 ]]; then command rmdir "$extract_dir" fi From 01c82c381d90f10239908ace41df9532c8c45495 Mon Sep 17 00:00:00 2001 From: Alexander Huynh Date: Fri, 7 Apr 2023 07:35:12 -0400 Subject: [PATCH 244/672] fix(jump): even spacing between marks (#11601) --- plugins/jump/jump.plugin.zsh | 7 +++---- 1 file changed, 3 insertions(+), 4 deletions(-) diff --git a/plugins/jump/jump.plugin.zsh b/plugins/jump/jump.plugin.zsh index c2da1144e..829c9d9cb 100644 --- a/plugins/jump/jump.plugin.zsh +++ b/plugins/jump/jump.plugin.zsh @@ -35,12 +35,11 @@ marks() { max=${#link:t} fi done - local printf_markname_template="$(printf -- "%%%us " "$max")" + local printf_markname_template="$(printf -- "%%%us" "$max")" for link in $MARKPATH/{,.}*(@N); do - local markname="$fg[cyan]${link:t}$reset_color" + local markname="$fg[cyan]$(printf -- "$printf_markname_template" "${link:t}")$reset_color" local markpath="$fg[blue]$(readlink $link)$reset_color" - printf -- "$printf_markname_template" "$markname" - printf -- "-> %s\n" "$markpath" + printf -- "%s -> %s\n" "$markname" "$markpath" done } From 9b1ef262bcc8d47a6d20b4efc673557560df6647 Mon Sep 17 00:00:00 2001 From: deimosian Date: Fri, 7 Apr 2023 11:43:45 +0000 Subject: [PATCH 245/672] feat(archlinux): unify `upgrade` function (#11597) Co-authored-by: Carlo Sala --- plugins/archlinux/archlinux.plugin.zsh | 31 +++++++++++++++++++++----- 1 file changed, 26 insertions(+), 5 deletions(-) diff --git a/plugins/archlinux/archlinux.plugin.zsh b/plugins/archlinux/archlinux.plugin.zsh index 4f1364779..e3b1b1261 100644 --- a/plugins/archlinux/archlinux.plugin.zsh +++ b/plugins/archlinux/archlinux.plugin.zsh @@ -23,7 +23,6 @@ alias pacfiles='pacman -F' alias pacls='pacman -Ql' alias pacown='pacman -Qo' alias pacupd="sudo pacman -Sy" -alias upgrade='sudo pacman -Syu' function paclist() { # Based on https://bbs.archlinux.org/viewtopic.php?id=93683 @@ -109,7 +108,6 @@ if (( $+commands[aura] )); then alias auupd="sudo aura -Sy" alias auupg='sudo sh -c "aura -Syu && aura -Au"' alias ausu='sudo sh -c "aura -Syu --no-confirm && aura -Au --no-confirm"' - alias upgrade='sudo aura -Syu' # extra bonus specially for aura alias auown="aura -Qqo" @@ -136,7 +134,6 @@ if (( $+commands[pacaur] )); then alias painsd='pacaur -S --asdeps' alias pamir='pacaur -Syy' alias paupd="pacaur -Sy" - alias upgrade='pacaur -Syu' fi if (( $+commands[trizen] )); then @@ -158,7 +155,6 @@ if (( $+commands[trizen] )); then alias trinsd='trizen -S --asdeps' alias trmir='trizen -Syy' alias trupd="trizen -Sy" - alias upgrade='trizen -Syu' fi if (( $+commands[yay] )); then @@ -180,5 +176,30 @@ if (( $+commands[yay] )); then alias yainsd='yay -S --asdeps' alias yamir='yay -Syy' alias yaupd="yay -Sy" - alias upgrade='yay -Syu' fi + +# Check Arch Linux PGP Keyring before System Upgrade to prevent failure. +function upgrade() { + echo "[oh-my-zsh] Checking Arch Linux PGP Keyring" + local installedver="$(sudo pacman -Qi archlinux-keyring | grep -Po '(?<=Version : ).*')" + local currentver="$(sudo pacman -Si archlinux-keyring | grep -Po '(?<=Version : ).*')" + if [ $installedver != $currentver ]; then + echo "[oh-my-zsh] Arch Linux PGP Keyring is out of date." + echo "[oh-my-zsh] Updating before full system upgrade." + sudo pacman -Syu --needed --noconfirm archlinux-keyring + else + echo "[oh-my-zsh] Arch Linux PGP Keyring is up to date." + fi + echo "[oh-mh-zsh] Proceeding with full system upgrade." + if (( $+commands[yay] )); then + yay -Syu + elif (( $+commands[trizen] )); then + trizen -Syu + elif (( $+commands[pacaur] )); then + pacaur -Syu + elif (( $+commands[aura] )); then + sudo aura -Syu + else + sudo pacman -Syu + fi +} From e906a3130eb5031a2c82d9187ea17387881631db Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Sat, 8 Apr 2023 11:13:30 +0200 Subject: [PATCH 246/672] fix(azure): look properly for azure config file Closes #11606 --- plugins/azure/azure.plugin.zsh | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/plugins/azure/azure.plugin.zsh b/plugins/azure/azure.plugin.zsh index 51b54dbc1..8fec3c1f7 100644 --- a/plugins/azure/azure.plugin.zsh +++ b/plugins/azure/azure.plugin.zsh @@ -18,10 +18,10 @@ compctl -K _az_subscriptions azss # Azure prompt function azure_prompt_info() { - [[ ! -f "${AZURE_CONFIG_DIR:-$HOME/.azure/azureProfile.json}" ]] && return + [[ ! -f "${AZURE_CONFIG_DIR:-$HOME/.azure}/azureProfile.json" ]] && return # azgs is too expensive, if we have jq, we enable the prompt (( $+commands[jq] )) || return 1 - azgs=$(jq -r '.subscriptions[] | select(.isDefault==true) .name' ${AZURE_CONFIG_DIR:-$HOME/.azure/azureProfile.json}) + azgs=$(jq -r '.subscriptions[] | select(.isDefault==true) .name' "${AZURE_CONFIG_DIR:-$HOME/.azure}/azureProfile.json") echo "${ZSH_THEME_AZURE_PREFIX:=}" } From ad99f0c164111fa3cfcbfc5b9cda321800541936 Mon Sep 17 00:00:00 2001 From: Aleks Date: Sat, 8 Apr 2023 13:36:54 +0200 Subject: [PATCH 247/672] feat(git): add merge squash alias (`gms`) (#10937) --- plugins/git/README.md | 1 + plugins/git/git.plugin.zsh | 1 + 2 files changed, 2 insertions(+) diff --git a/plugins/git/README.md b/plugins/git/README.md index 0895ce39c..f87d3fbca 100644 --- a/plugins/git/README.md +++ b/plugins/git/README.md @@ -116,6 +116,7 @@ plugins=(... git) | gloga | git log --oneline --decorate --graph --all | | glp | git log --pretty=\ | | gm | git merge | +| gms | git merge --squash | | gmom | git merge origin/$(git_main_branch) | | gmtl | git mergetool --no-prompt | | gmtlvim | git mergetool --no-prompt --tool=vimdiff | diff --git a/plugins/git/git.plugin.zsh b/plugins/git/git.plugin.zsh index ed17436e8..3c8d53c8c 100644 --- a/plugins/git/git.plugin.zsh +++ b/plugins/git/git.plugin.zsh @@ -237,6 +237,7 @@ alias gmtl='git mergetool --no-prompt' alias gmtlvim='git mergetool --no-prompt --tool=vimdiff' alias gmum='git merge upstream/$(git_main_branch)' alias gma='git merge --abort' +alias gms="git merge --squash" alias gp='git push' alias gpd='git push --dry-run' From 90ec2d1a68049d8b7e57b87c3661d8cacf54655c Mon Sep 17 00:00:00 2001 From: deimosian Date: Sun, 9 Apr 2023 04:24:55 -0400 Subject: [PATCH 248/672] fix(archlinux): keyring update function (#11607) --- plugins/archlinux/archlinux.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/archlinux/archlinux.plugin.zsh b/plugins/archlinux/archlinux.plugin.zsh index e3b1b1261..ce7bfdf23 100644 --- a/plugins/archlinux/archlinux.plugin.zsh +++ b/plugins/archlinux/archlinux.plugin.zsh @@ -186,7 +186,7 @@ function upgrade() { if [ $installedver != $currentver ]; then echo "[oh-my-zsh] Arch Linux PGP Keyring is out of date." echo "[oh-my-zsh] Updating before full system upgrade." - sudo pacman -Syu --needed --noconfirm archlinux-keyring + sudo pacman -Sy --needed --noconfirm archlinux-keyring else echo "[oh-my-zsh] Arch Linux PGP Keyring is up to date." fi From 4586808f86bf3bfdf97685380472b63597ce43c0 Mon Sep 17 00:00:00 2001 From: deimosian Date: Sun, 9 Apr 2023 06:58:38 -0400 Subject: [PATCH 249/672] feat(archlinux): improve update function messages (#11608) --- plugins/archlinux/archlinux.plugin.zsh | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/plugins/archlinux/archlinux.plugin.zsh b/plugins/archlinux/archlinux.plugin.zsh index ce7bfdf23..da170f488 100644 --- a/plugins/archlinux/archlinux.plugin.zsh +++ b/plugins/archlinux/archlinux.plugin.zsh @@ -180,17 +180,17 @@ fi # Check Arch Linux PGP Keyring before System Upgrade to prevent failure. function upgrade() { - echo "[oh-my-zsh] Checking Arch Linux PGP Keyring" + echo ":: Checking Arch Linux PGP Keyring..." local installedver="$(sudo pacman -Qi archlinux-keyring | grep -Po '(?<=Version : ).*')" local currentver="$(sudo pacman -Si archlinux-keyring | grep -Po '(?<=Version : ).*')" if [ $installedver != $currentver ]; then - echo "[oh-my-zsh] Arch Linux PGP Keyring is out of date." - echo "[oh-my-zsh] Updating before full system upgrade." + echo " Arch Linux PGP Keyring is out of date." + echo " Updating before full system upgrade." sudo pacman -Sy --needed --noconfirm archlinux-keyring else - echo "[oh-my-zsh] Arch Linux PGP Keyring is up to date." + echo " Arch Linux PGP Keyring is up to date." + echo " Proceeding with full system upgrade." fi - echo "[oh-mh-zsh] Proceeding with full system upgrade." if (( $+commands[yay] )); then yay -Syu elif (( $+commands[trizen] )); then From b4f9698733d7b29cc495e649e26fd6c3a5dcfcae Mon Sep 17 00:00:00 2001 From: Josh McKinney Date: Tue, 11 Apr 2023 01:41:00 -0700 Subject: [PATCH 250/672] docs(ssh-agent): macOS and p10k advices (#11612) --- plugins/ssh-agent/README.md | 27 +++++++++++++++++++++++++++ 1 file changed, 27 insertions(+) diff --git a/plugins/ssh-agent/README.md b/plugins/ssh-agent/README.md index fa6a996d4..8c118e65b 100644 --- a/plugins/ssh-agent/README.md +++ b/plugins/ssh-agent/README.md @@ -99,6 +99,33 @@ ssh-add -K -c -a /run/user/1000/ssh-auth For valid `ssh-add` arguments run `ssh-add --help` or `man ssh-add`. +### Powerline 10k specific settings + +Powerline10k has an instant prompt setting that doesn't like when this plugin +writes to the console. Consider using the following settings if you're using +p10k (documented above): + +``` +zstyle :omz:plugins:ssh-agent quiet yes +zstyle :omz:plugins:ssh-agent lazy yes +``` + +### macOS specific settings + +macOS supports using passphrases stored in the keychain when adding identities +to the ssh-agent. + +``` +ssh-add --apple-use-keychain ~/.ssh/id_rsa ... +``` + + +This plugin can be configured to use the keychain when loading using the following: + +``` +zstyle :omz:plugins:ssh-agent ssh-add-args --apple-load-keychain +``` + ## Credits Based on code from Joseph M. Reagle: https://www.cygwin.com/ml/cygwin/2001-06/msg00537.html From bd5ebba834c53e730671d9d24d93eb98b812a579 Mon Sep 17 00:00:00 2001 From: Eddie Romanov <81505200+SnoopDraugg@users.noreply.github.com> Date: Sun, 16 Apr 2023 03:49:04 -0400 Subject: [PATCH 251/672] feat(pipenv): add pupd alias (#11616) --- plugins/pipenv/README.md | 1 + plugins/pipenv/pipenv.plugin.zsh | 1 + 2 files changed, 2 insertions(+) diff --git a/plugins/pipenv/README.md b/plugins/pipenv/README.md index ab1c1e442..4329feb32 100644 --- a/plugins/pipenv/README.md +++ b/plugins/pipenv/README.md @@ -23,6 +23,7 @@ This plugin provides some features to simplify the use of Pipenv while working o - `psh` is aliased to `pipenv shell` - `psy` is aliased to `pipenv sync` - `pu` is aliased to `pipenv uninstall` + - `pupd` is aliased to `pipenv update` - `pwh` is aliased to `pipenv --where` - `pvenv` is aliased to `pipenv --venv` - `ppy` is aliased to `pipenv --py` diff --git a/plugins/pipenv/pipenv.plugin.zsh b/plugins/pipenv/pipenv.plugin.zsh index 244bd6b7c..22d1a3131 100644 --- a/plugins/pipenv/pipenv.plugin.zsh +++ b/plugins/pipenv/pipenv.plugin.zsh @@ -47,6 +47,7 @@ alias prun="pipenv run" alias psh="pipenv shell" alias psy="pipenv sync" alias pu="pipenv uninstall" +alias pupd="pipenv update" alias pwh="pipenv --where" alias pvenv="pipenv --venv" alias ppy="pipenv --py" From d889eca72633b7a66d6c832736a5460c5f1a1833 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Mon, 17 Apr 2023 20:09:30 +0200 Subject: [PATCH 252/672] fix(check_for_upgrade): update properly `LAST_EPOCH` Fixes #11617 --- tools/check_for_upgrade.sh | 1 + 1 file changed, 1 insertion(+) diff --git a/tools/check_for_upgrade.sh b/tools/check_for_upgrade.sh index 81c371b3f..3210e4375 100644 --- a/tools/check_for_upgrade.sh +++ b/tools/check_for_upgrade.sh @@ -180,6 +180,7 @@ function has_typed_input() { # Check if there are updates available before proceeding if ! is_update_available; then + update_last_updated_file return fi From 673b9fc3317d48a169fe612575186b3eb1a42a13 Mon Sep 17 00:00:00 2001 From: Mark Keisler Date: Tue, 18 Apr 2023 03:36:07 -0500 Subject: [PATCH 253/672] feat(aws)!: improve `aws_change_access_key` (#11378) BREAKING CHANGE: This commit removes compatibility for `aws` cli v1. Now only v2 is supported. --- plugins/aws/README.md | 11 ++++++----- plugins/aws/aws.plugin.zsh | 37 +++++++++++++++++++++++++++++++------ 2 files changed, 37 insertions(+), 11 deletions(-) diff --git a/plugins/aws/README.md b/plugins/aws/README.md index 846bf1414..54bc7a44d 100644 --- a/plugins/aws/README.md +++ b/plugins/aws/README.md @@ -1,7 +1,8 @@ # aws -This plugin provides completion support for [awscli](https://docs.aws.amazon.com/cli/latest/reference/index.html) +This plugin provides completion support for [awscli v2](https://awscli.amazonaws.com/v2/documentation/api/latest/reference/index.html) and a few utilities to manage AWS profiles/regions and display them in the prompt. +[awscli v1](https://docs.aws.amazon.com/cli/latest/userguide/cliv2-migration.html) is no longer supported. To use it, add `aws` to the plugins array in your zshrc file. @@ -12,9 +13,9 @@ plugins=(... aws) ## Plugin commands * `asp []`: sets `$AWS_PROFILE` and `$AWS_DEFAULT_PROFILE` (legacy) to ``. - It also sets `$AWS_EB_PROFILE` to `` for the Elastic Beanstalk CLI. It sets `$AWS_PROFILE_REGION` for display in `aws_prompt_info`. + It also sets `$AWS_EB_PROFILE` to `` for the Elastic Beanstalk CLI. It sets `$AWS_PROFILE_REGION` for display in `aws_prompt_info`. Run `asp` without arguments to clear the profile. -* `asp [] login`: If AWS SSO has been configured in your aws profile, it will run the `aws sso login` command following profile selection. +* `asp [] login`: If AWS SSO has been configured in your aws profile, it will run the `aws sso login` command following profile selection. * `asr []`: sets `$AWS_REGION` and `$AWS_DEFAULT_REGION` (legacy) to ``. Run `asr` without arguments to clear the profile. @@ -65,7 +66,7 @@ the current `$AWS_PROFILE` and `$AWS_REGION`. It uses four variables to control Source profile credentials in `~/.aws/credentials`: -``` +```ini [source-profile-name] aws_access_key_id = ... aws_secret_access_key = ... @@ -73,7 +74,7 @@ aws_secret_access_key = ... Role configuration in `~/.aws/config`: -``` +```ini [profile source-profile-name] mfa_serial = arn:aws:iam::111111111111:mfa/myuser region = us-east-1 diff --git a/plugins/aws/aws.plugin.zsh b/plugins/aws/aws.plugin.zsh index a379eaa18..d45abba57 100644 --- a/plugins/aws/aws.plugin.zsh +++ b/plugins/aws/aws.plugin.zsh @@ -160,14 +160,39 @@ function aws_change_access_key() { return 1 fi - echo "Insert the credentials when asked." - asp "$1" || return 1 - AWS_PAGER="" aws iam create-access-key - AWS_PAGER="" aws configure --profile "$1" + local profile="$1" + # Get current access key + local original_aws_access_key_id="$(aws configure get aws_access_key_id --profile $profile)" - echo "You can now safely delete the old access key running \`aws iam delete-access-key --access-key-id ID\`" + asp "$profile" || return 1 + echo "Generating a new access key pair for you now." + if aws --no-cli-pager iam create-access-key; then + echo "Insert the newly generated credentials when asked." + aws --no-cli-pager configure --profile $profile + else + echo "Current access keys:" + aws --no-cli-pager iam list-access-keys + echo "Profile \"${profile}\" is currently using the $original_aws_access_key_id key. You can delete an old access key by running \`aws --profile $profile iam delete-access-key --access-key-id AccessKeyId\`" + return 1 + fi + + read -q "yn?Would you like to disable your previous access key (${original_aws_access_key_id}) now? " + case $yn in + [Yy]*) + echo -n "\nDisabling access key ${original_aws_access_key_id}..." + if aws --no-cli-pager update-access-key --access-key-id ${original_aws_access_key_id} --status Inactive; then + echo "done." + else + echo "\nFailed to disable ${original_aws_access_key_id} key." + fi + ;; + *) + echo "" + ;; + esac + echo "You can now safely delete the old access key by running \`aws --profile $profile iam delete-access-key --access-key-id ${original_aws_access_key_id}\`" echo "Your current keys are:" - AWS_PAGER="" aws iam list-access-keys + aws --no-cli-pager iam list-access-keys } function aws_regions() { From 9139d30ca30f8f687cc21121ed9b4f5238bc5260 Mon Sep 17 00:00:00 2001 From: Roeniss Moon Date: Wed, 19 Apr 2023 22:46:10 +0900 Subject: [PATCH 254/672] feat(aws): allow more customisation in prompt function (#11619) --- plugins/aws/README.md | 2 ++ plugins/aws/aws.plugin.zsh | 9 ++++++--- 2 files changed, 8 insertions(+), 3 deletions(-) diff --git a/plugins/aws/README.md b/plugins/aws/README.md index 54bc7a44d..9e1e055b8 100644 --- a/plugins/aws/README.md +++ b/plugins/aws/README.md @@ -58,6 +58,8 @@ the current `$AWS_PROFILE` and `$AWS_REGION`. It uses four variables to control * ZSH_THEME_AWS_REGION_SUFFIX: sets the suffix of the AWS_REGION. Defaults to `>`. +* ZSH_THEME_AWS_DIVIDER: sets the divider between ZSH_THEME_AWS_PROFILE_SUFFIX and ZSH_THEME_AWS_REGION_PREFIX. Defaults to ` ` (single space). + ## Configuration [Configuration and credential file settings](https://docs.aws.amazon.com/cli/latest/userguide/cli-configure-files.html) by AWS diff --git a/plugins/aws/aws.plugin.zsh b/plugins/aws/aws.plugin.zsh index d45abba57..0da91bc22 100644 --- a/plugins/aws/aws.plugin.zsh +++ b/plugins/aws/aws.plugin.zsh @@ -223,13 +223,16 @@ compctl -K _aws_profiles asp acp aws_change_access_key function aws_prompt_info() { local _aws_to_show local region="${AWS_REGION:-${AWS_DEFAULT_REGION:-$AWS_PROFILE_REGION}}" + if [[ -n $AWS_PROFILE ]];then - _aws_to_show+="${ZSH_THEME_AWS_PROFILE_PREFIX:=}" + _aws_to_show+="${ZSH_THEME_AWS_PROFILE_PREFIX=""}" fi + if [[ -n $AWS_REGION ]]; then - [[ -n $AWS_PROFILE ]] && _aws_to_show+=" " - _aws_to_show+="${ZSH_THEME_AWS_REGION_PREFIX:=}" + [[ -n $AWS_PROFILE ]] && _aws_to_show+="${ZSH_THEME_AWS_DIVIDER=' '}" + _aws_to_show+="${ZSH_THEME_AWS_REGION_PREFIX=""}" fi + echo "$_aws_to_show" } From 18c837b136a9591117ef059eb8266c490d5eeee1 Mon Sep 17 00:00:00 2001 From: Erin Schlarb Date: Thu, 20 Apr 2023 13:30:49 +0200 Subject: [PATCH 255/672] fix(dirhistory): run properly if `ksh_arrays` is set (#11630) --- plugins/dirhistory/dirhistory.plugin.zsh | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/plugins/dirhistory/dirhistory.plugin.zsh b/plugins/dirhistory/dirhistory.plugin.zsh index 7021fc03a..8d67c6188 100644 --- a/plugins/dirhistory/dirhistory.plugin.zsh +++ b/plugins/dirhistory/dirhistory.plugin.zsh @@ -19,15 +19,17 @@ export DIRHISTORY_SIZE=30 # Returns the element if the array was not empty, # otherwise returns empty string. function pop_past() { - typeset -g $1="${dirhistory_past[$#dirhistory_past]}" + setopt localoptions no_ksh_arrays if [[ $#dirhistory_past -gt 0 ]]; then + typeset -g $1="${dirhistory_past[$#dirhistory_past]}" dirhistory_past[$#dirhistory_past]=() fi } function pop_future() { - typeset -g $1="${dirhistory_future[$#dirhistory_future]}" + setopt localoptions no_ksh_arrays if [[ $#dirhistory_future -gt 0 ]]; then + typeset -g $1="${dirhistory_future[$#dirhistory_future]}" dirhistory_future[$#dirhistory_future]=() fi } @@ -35,6 +37,7 @@ function pop_future() { # Push a new element onto the end of dirhistory_past. If the size of the array # is >= DIRHISTORY_SIZE, the array is shifted function push_past() { + setopt localoptions no_ksh_arrays if [[ $#dirhistory_past -ge $DIRHISTORY_SIZE ]]; then shift dirhistory_past fi @@ -44,6 +47,7 @@ function push_past() { } function push_future() { + setopt localoptions no_ksh_arrays if [[ $#dirhistory_future -ge $DIRHISTORY_SIZE ]]; then shift dirhistory_future fi From 5b11e70a9617c6e248fd6947e84016bd8c37028e Mon Sep 17 00:00:00 2001 From: Erin Schlarb Date: Thu, 20 Apr 2023 13:32:32 +0200 Subject: [PATCH 256/672] fix(cli): execute as expected if `ksh_arrays` is set (#11629) --- lib/cli.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/cli.zsh b/lib/cli.zsh index ba3e39eb5..561c1b98b 100644 --- a/lib/cli.zsh +++ b/lib/cli.zsh @@ -11,7 +11,7 @@ function omz { # Subcommand functions start with _ so that they don't # appear as completion entries when looking for `omz` - (( $+functions[_omz::$command] )) || { + (( ${+functions[_omz::$command]} )) || { _omz::help return 1 } From 91c7ed45a312a71b7d3b856228047ddcd51d4651 Mon Sep 17 00:00:00 2001 From: Nathanial Spearing Date: Thu, 20 Apr 2023 07:42:47 -0400 Subject: [PATCH 257/672] feat(npm): add `npmrd` alias (#11627) --- plugins/npm/README.md | 1 + plugins/npm/npm.plugin.zsh | 3 +++ 2 files changed, 4 insertions(+) diff --git a/plugins/npm/README.md b/plugins/npm/README.md index 8eafc6d61..420dd710a 100644 --- a/plugins/npm/README.md +++ b/plugins/npm/README.md @@ -29,6 +29,7 @@ plugins=(... npm) | `npmI` | `npm init` | Run npm init | | `npmi` | `npm info` | Run npm info | | `npmSe` | `npm search` | Run npm search | +| `npmrd` | `npm run dev` | Run npm run dev | ## `npm install` / `npm uninstall` toggle diff --git a/plugins/npm/npm.plugin.zsh b/plugins/npm/npm.plugin.zsh index e0dcbf142..3cba18f6c 100644 --- a/plugins/npm/npm.plugin.zsh +++ b/plugins/npm/npm.plugin.zsh @@ -70,6 +70,9 @@ alias npmi="npm info" # Run npm search alias npmSe="npm search" +# Run npm run dev +alias npmrd="npm run dev" + npm_toggle_install_uninstall() { # Look up to the previous 2 history commands local line From 07454029bd67239ce42aaa68b427fbbe8e428e7d Mon Sep 17 00:00:00 2001 From: Andrew Xie <62098008+axieax@users.noreply.github.com> Date: Fri, 21 Apr 2023 16:59:58 +1000 Subject: [PATCH 258/672] feat(starship): create plugin (#10947) Co-authored-by: Carlo Sala --- .github/CODEOWNERS | 1 + plugins/starship/README.md | 21 +++++++++++++++++++++ plugins/starship/starship.plugin.zsh | 8 ++++++++ 3 files changed, 30 insertions(+) create mode 100644 plugins/starship/README.md create mode 100644 plugins/starship/starship.plugin.zsh diff --git a/.github/CODEOWNERS b/.github/CODEOWNERS index 6668cd7ce..599b765ca 100644 --- a/.github/CODEOWNERS +++ b/.github/CODEOWNERS @@ -9,3 +9,4 @@ plugins/shell-proxy/ @septs plugins/universalarchive/ @Konfekt plugins/wp-cli/ @joshmedeski plugins/zoxide/ @ajeetdsouza +plugins/starship/ @axieax diff --git a/plugins/starship/README.md b/plugins/starship/README.md new file mode 100644 index 000000000..0e66c5294 --- /dev/null +++ b/plugins/starship/README.md @@ -0,0 +1,21 @@ +# starship plugin + +Initializes [starship prompt](https://starship.rs) - a minimal, blazing-fast and infinitely customizable cross-shell prompt. + +[Demo](https://user-images.githubusercontent.com/62098008/169764279-50b48262-9506-4651-ba89-f6611a88ebf0.mp4) + +[External repository](https://github.com/axieax/zsh-starship) for this zsh plugin. + +# Installation + +**Note:** you have to [install starship](https://starship.rs/guide/#%F0%9F%9A%80-installation) first. + +## [oh-my-zsh](https://github.com/ohmyzsh/ohmyzsh) + +Add `starship` to the plugins array in your `.zshrc` file: + +```zsh +plugins=(... starship) +``` + +## ⚠️ ENABLING THIS PLUGIN WILL UNSET YOUR ZSH_THEME VARIABLE diff --git a/plugins/starship/starship.plugin.zsh b/plugins/starship/starship.plugin.zsh new file mode 100644 index 000000000..8c5d9135e --- /dev/null +++ b/plugins/starship/starship.plugin.zsh @@ -0,0 +1,8 @@ +# ignore oh-my-zsh theme +unset ZSH_THEME + +if (( $+commands[starship] )); then + eval "$(starship init zsh)" +else + echo '[oh-my-zsh] starship not found, please install it from https://starship.rs' +fi From 5d3e86e2a48adf7a308773f8f1b725d187c7c5ef Mon Sep 17 00:00:00 2001 From: Miguel Sempere Date: Fri, 21 Apr 2023 08:15:31 +0100 Subject: [PATCH 259/672] feat(dbt): create plugin (#11635) Co-authored-by: Carlo Sala --- .github/CODEOWNERS | 1 + plugins/dbt/README.md | 29 +++++++++++++++++++++++++++++ plugins/dbt/dbt.plugin.zsh | 23 +++++++++++++++++++++++ 3 files changed, 53 insertions(+) create mode 100644 plugins/dbt/README.md create mode 100644 plugins/dbt/dbt.plugin.zsh diff --git a/.github/CODEOWNERS b/.github/CODEOWNERS index 599b765ca..0c5f3acee 100644 --- a/.github/CODEOWNERS +++ b/.github/CODEOWNERS @@ -10,3 +10,4 @@ plugins/universalarchive/ @Konfekt plugins/wp-cli/ @joshmedeski plugins/zoxide/ @ajeetdsouza plugins/starship/ @axieax +plugins/dbt/ @msempere diff --git a/plugins/dbt/README.md b/plugins/dbt/README.md new file mode 100644 index 000000000..e05d79cc3 --- /dev/null +++ b/plugins/dbt/README.md @@ -0,0 +1,29 @@ +# dbt plugin + +## Introduction + +The `dbt plugin` adds several aliases for useful [dbt](https://docs.getdbt.com/) commands and +[aliases](#aliases). + +To use it, add `dbt` to the plugins array of your zshrc file: + +``` +plugins=(... dbt) +``` + +## Aliases + +| Alias | Command | Description | +| ------ | ------------------------------------------------ | ---------------------------------------------------- | +| dbtlm | `dbt ls -s state:modified` | List modified models only | +| dbtrm | `dbt run -s state:modified` | Run modified models only | +| dbttm | `dbt test -m state:modified` | Test modified models only | +| dbtrtm | `dbtrm && dbttm` | Run and test modified models only | +| dbtrs | `dbt clean; dbt deps; dbt seed` | Re-seed data | +| dbtfrt | `dbtrs; dbt run --full-refresh; dbt test` | Perform a full fresh run with tests | +| dbtcds | `dbt docs generate; dbt docs serve` | Generate docs without compiling | +| dbtds | `dbt docs generate --no-compile; dbt docs serve` | Generate and serve docs skipping doc. re-compilation | + +## Maintainer + +### [msempere](https://github.com/msempere) diff --git a/plugins/dbt/dbt.plugin.zsh b/plugins/dbt/dbt.plugin.zsh new file mode 100644 index 000000000..6fcc2eecf --- /dev/null +++ b/plugins/dbt/dbt.plugin.zsh @@ -0,0 +1,23 @@ +# list modified models only +alias dbtlm="dbt ls -s state:modified" + +# run modified models only +alias dbtrm="dbt run -s state:modified" + +# test modified models only +alias dbttm="dbt test -m state:modified" + +# run and test modified models only +alias dbtrtm="dbtrm && dbttm" + +# re-seed data +alias dbtrs="dbt clean; dbt deps; dbt seed" + +# perform a full fresh run with tests +alias dbtfrt="dbtrs; dbt run --full-refresh; dbt test" + +# generate and serve docs +alias dbtcds="dbt docs generate; dbt docs serve" + +# generate and serve docs skipping doc. re-compilation +alias dbtds="dbt docs generate --no-compile; dbt docs serve" From 343c78ae91ff03ea66517b1d69b25fa262ce5408 Mon Sep 17 00:00:00 2001 From: Idan Fishman Date: Thu, 27 Apr 2023 11:49:26 +0200 Subject: [PATCH 260/672] fix(aws): set properly set divider to space Closes #11649 Co-authored-by: Carlo Sala --- plugins/aws/aws.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/aws/aws.plugin.zsh b/plugins/aws/aws.plugin.zsh index 0da91bc22..a437dc8e8 100644 --- a/plugins/aws/aws.plugin.zsh +++ b/plugins/aws/aws.plugin.zsh @@ -229,7 +229,7 @@ function aws_prompt_info() { fi if [[ -n $AWS_REGION ]]; then - [[ -n $AWS_PROFILE ]] && _aws_to_show+="${ZSH_THEME_AWS_DIVIDER=' '}" + [[ -n $AWS_PROFILE ]] && _aws_to_show+="${ZSH_THEME_AWS_DIVIDER=" "}" _aws_to_show+="${ZSH_THEME_AWS_REGION_PREFIX=""}" fi From 65699912be974d36b732b63e32c3b9428d23ace8 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Thu, 27 Apr 2023 09:57:44 +0200 Subject: [PATCH 261/672] fix(azure): recognize properly linuxbrew Closes #11644 --- plugins/azure/azure.plugin.zsh | 8 +++----- 1 file changed, 3 insertions(+), 5 deletions(-) diff --git a/plugins/azure/azure.plugin.zsh b/plugins/azure/azure.plugin.zsh index 8fec3c1f7..22fbea80f 100644 --- a/plugins/azure/azure.plugin.zsh +++ b/plugins/azure/azure.plugin.zsh @@ -31,11 +31,9 @@ function _az-homebrew-installed() { # check if Homebrew is installed (( $+commands[brew] )) || return 1 - # speculatively check default brew prefix - if [[ -d /usr/local ]]; then - _brew_prefix=/usr/local - elif [[ -d /opt/homebrew ]]; then - _brew_prefix=/opt/homebrew + # if so, we assume it's default way to install brew + if [[ ${commands[brew]:t2} == bin/brew ]]; then + _brew_prefix="${commands[brew]:h:h}" # remove trailing /bin/brew else # ok, it is not in the default prefix # this call to brew is expensive (about 400 ms), so at least let's make it only once From 5fc1118fd240a0d87ad022d36f48cb31d869ab2e Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Thu, 27 Apr 2023 19:42:55 +0200 Subject: [PATCH 262/672] chore(azure): fix typo --- plugins/azure/azure.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/azure/azure.plugin.zsh b/plugins/azure/azure.plugin.zsh index 22fbea80f..b33b0f805 100644 --- a/plugins/azure/azure.plugin.zsh +++ b/plugins/azure/azure.plugin.zsh @@ -1,4 +1,4 @@ -# AZ Get Subscritions +# AZ Get Subscriptions function azgs() { az account show --output tsv --query 'name' 2>/dev/null } From 2e7a247cab663fbc0aafdefa15bf10eb4dd64563 Mon Sep 17 00:00:00 2001 From: Bas Nijholt Date: Fri, 28 Apr 2023 09:05:36 +0200 Subject: [PATCH 263/672] feat(z): update to latest upstream version Mirror of https://github.com/agkozak/zsh-z/commit/6bfe418332866d15373392164df11b4fbec2083f Closes #11652 Co-authored-by: Carlo Sala --- plugins/z/LICENSE | 2 +- plugins/z/MANUAL.md | 21 ++++++++++-- plugins/z/_z | 2 +- plugins/z/img/mit_license.svg | 1 + plugins/z/img/zsh_4.3.11_plus.svg | 1 + plugins/z/z.plugin.zsh | 54 ++++++++++++++++++++++++------- 6 files changed, 65 insertions(+), 16 deletions(-) create mode 100644 plugins/z/img/mit_license.svg create mode 100644 plugins/z/img/zsh_4.3.11_plus.svg diff --git a/plugins/z/LICENSE b/plugins/z/LICENSE index d1cca7ae5..6af13b9e0 100644 --- a/plugins/z/LICENSE +++ b/plugins/z/LICENSE @@ -1,6 +1,6 @@ MIT License -Copyright (c) 2018-2022 Alexandros Kozak +Copyright (c) 2018-2023 Alexandros Kozak Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal diff --git a/plugins/z/MANUAL.md b/plugins/z/MANUAL.md index dcca3c452..d367c3026 100644 --- a/plugins/z/MANUAL.md +++ b/plugins/z/MANUAL.md @@ -1,5 +1,9 @@ # Zsh-z +[![MIT License](img/mit_license.svg)](https://opensource.org/licenses/MIT) +![Zsh version 4.3.11 and higher](img/zsh_4.3.11_plus.svg) +[![GitHub stars](https://img.shields.io/github/stars/agkozak/zsh-z.svg)](https://github.com/agkozak/zsh-z/stargazers) + Zsh-z is a command line tool that allows you to jump quickly to directories that you have visited frequently in the past, or recently -- but most often a combination of the two (a concept known as ["frecency"](https://en.wikipedia.org/wiki/Frecency)). It works by keeping track of when you go to directories and how much time you spend in them. It is then in the position to guess where you want to go when you type a partial string, e.g., `z src` might take you to `~/src/zsh`. `z zsh` might also get you there, and `z c/z` might prove to be even more specific -- it all depends on your habits and how much time you have been using Zsh-z to build up a database. After using Zsh-z for a little while, you will get to where you want to be by typing considerably less than you would need if you were using `cd`. Zsh-z is a native Zsh port of [rupa/z](https://github.com/rupa/z), a tool written for `bash` and Zsh that uses embedded `awk` scripts to do the heavy lifting. It was quite possibly my most used command line tool for a couple of years. I decided to translate it, `awk` parts and all, into pure Zsh script, to see if by eliminating calls to external tools (`awk`, `sort`, `date`, `sed`, `mv`, `rm`, and `chown`) and reducing forking through subshells I could make it faster. The performance increase is impressive, particularly on systems where forking is slow, such as Cygwin, MSYS2, and WSL. I have found that, in those environments, switching directories using Zsh-z can be over 100% faster than it is using `rupa/z`. @@ -28,6 +32,10 @@ Zsh-z is a drop-in replacement for `rupa/z` and will, by default, use the same d

Here are the latest features and updates. +- April 27, 2023 + + Zsh-z now allows the user to specify the directory-changing command using the `ZSHZ_CD` environment variable (default: `builtin cd`; props @basnijholt). +- January 27, 2023 + + If the datafile directory specified by `ZSHZ_DATA` or `_Z_DATA` does not already exist, create it (props @mattmc3). - June 29, 2022 + Zsh-z is less likely to leave temporary files sitting around (props @mafredri). - June 27, 2022 @@ -118,13 +126,19 @@ Add the line to your `.zshrc`, somewhere above the line that says `antigen apply`. -### For [oh-my-zsh](http://ohmyz.sh/) users +### For [Oh My Zsh](http://ohmyz.sh/) users -Execute the following command: +Zsh-z is now included as part of Oh My Zsh! As long as you are using an up-to-date installation of Oh My Zsh, you can activate Zsh-z simply by adding `z` to your `plugins` array in your `.zshrc`, e.g., + + plugins=( git z ) + +It is as simple as that. + +If, however, you prefer always to use the latest version of Zsh-z from the `agkozak/zsh-z` repo, you may install it thus: git clone https://github.com/agkozak/zsh-z ${ZSH_CUSTOM:-~/.oh-my-zsh/custom}/plugins/zsh-z -and add `zsh-z` to the line of your `.zshrc` that specifies `plugins=()`, e.g., `plugins=( git zsh-z )`. +and activate it by adding `zsh-z` to the line of your `.zshrc` that specifies `plugins=()`, e.g., `plugins=( git zsh-z )`. ### For [prezto](https://github.com/sorin-ionescu/prezto) users @@ -246,6 +260,7 @@ to install `zsh-z`. Zsh-z has environment variables (they all begin with `ZSHZ_`) that change its behavior if you set them; you can also keep your old ones if you have been using `rupa/z` (they begin with `_Z_`). * `ZSHZ_CMD` changes the command name (default: `z`) +* `ZSHZ_CD` specifies the default directory-changing command (default: `builtin cd`) * `ZSHZ_COMPLETION` can be `'frecent'` (default) or `'legacy'`, depending on whether you want your completion results sorted according to frecency or simply sorted alphabetically * `ZSHZ_DATA` changes the database file (default: `~/.z`) * `ZSHZ_ECHO` displays the new path name when changing directories (default: `0`) diff --git a/plugins/z/_z b/plugins/z/_z index 9891a52ed..a493f35ba 100644 --- a/plugins/z/_z +++ b/plugins/z/_z @@ -5,7 +5,7 @@ # # https://github.com/agkozak/zsh-z # -# Copyright (c) 2018-2022 Alexandros Kozak +# Copyright (c) 2018-2023 Alexandros Kozak # # Permission is hereby granted, free of charge, to any person obtaining a copy # of this software and associated documentation files (the "Software"), to deal diff --git a/plugins/z/img/mit_license.svg b/plugins/z/img/mit_license.svg new file mode 100644 index 000000000..1c02079d7 --- /dev/null +++ b/plugins/z/img/mit_license.svg @@ -0,0 +1 @@ +licenselicenseMITMIT \ No newline at end of file diff --git a/plugins/z/img/zsh_4.3.11_plus.svg b/plugins/z/img/zsh_4.3.11_plus.svg new file mode 100644 index 000000000..f46d947d0 --- /dev/null +++ b/plugins/z/img/zsh_4.3.11_plus.svg @@ -0,0 +1 @@ +zshzsh4.3.11+4.3.11+ \ No newline at end of file diff --git a/plugins/z/z.plugin.zsh b/plugins/z/z.plugin.zsh index 209edfea7..60a630624 100644 --- a/plugins/z/z.plugin.zsh +++ b/plugins/z/z.plugin.zsh @@ -4,7 +4,7 @@ # # https://github.com/agkozak/zsh-z # -# Copyright (c) 2018-2022 Alexandros Kozak +# Copyright (c) 2018-2023 Alexandros Kozak # # Permission is hereby granted, free of charge, to any person obtaining a copy # of this software and associated documentation files (the "Software"), to deal @@ -52,6 +52,7 @@ # ZSHZ_CASE -> if `ignore', pattern matching is case-insensitive; if `smart', # pattern matching is case-insensitive only when the pattern is all # lowercase +# ZSHZ_CD -> the directory-changing command that is used (default: builtin cd) # ZSHZ_CMD -> name of command (default: z) # ZSHZ_COMPLETION -> completion method (default: 'frecent'; 'legacy' for # alphabetic sorting) @@ -129,6 +130,7 @@ is-at-least 5.3.0 && ZSHZ[PRINTV]=1 # Globals: # ZSHZ # ZSHZ_CASE +# ZSHZ_CD # ZSHZ_COMPLETION # ZSHZ_DATA # ZSHZ_DEBUG @@ -149,9 +151,19 @@ zshz() { local REPLY local -a lines - # Allow the user to specify the datafile name in $ZSHZ_DATA (default: ~/.z) + # Allow the user to specify a custom datafile in $ZSHZ_DATA (or legacy $_Z_DATA) + local custom_datafile="${ZSHZ_DATA:-$_Z_DATA}" + + # If a datafile was provided as a standalone file without a directory path + # print a warning and exit + if [[ -n ${custom_datafile} && ${custom_datafile} != */* ]]; then + print "ERROR: You configured a custom Zsh-z datafile (${custom_datafile}), but have not specified its directory." >&2 + exit + fi + + # If the user specified a datafile, use that or default to ~/.z # If the datafile is a symlink, it gets dereferenced - local datafile=${${ZSHZ_DATA:-${_Z_DATA:-${HOME}/.z}}:A} + local datafile=${${custom_datafile:-$HOME/.z}:A} # If the datafile is a directory, print a warning and exit if [[ -d $datafile ]]; then @@ -161,7 +173,7 @@ zshz() { # Make sure that the datafile exists before attempting to read it or lock it # for writing - [[ -f $datafile ]] || touch "$datafile" + [[ -f $datafile ]] || { mkdir -p "${datafile:h}" && touch "$datafile" } # Bail if we don't own the datafile and $ZSHZ_OWNER is not set [[ -z ${ZSHZ_OWNER:-${_Z_OWNER}} && -f $datafile && ! -O $datafile ]] && @@ -620,7 +632,7 @@ zshz() { *) # Frecency routine (( dx = EPOCHSECONDS - time_field )) - rank=$(( 10000 * rank_field * (3.75/((0.0001 * dx + 1) + 0.25)) )) + rank=$(( 10000 * rank_field * (3.75/( (0.0001 * dx + 1) + 0.25)) )) ;; esac @@ -756,6 +768,26 @@ zshz() { [[ $output_format != 'completion' ]] && output_format='list' } + ######################################################### + # Allow the user to specify directory-changing command + # using $ZSHZ_CD (default: builtin cd). + # + # Globals: + # ZSHZ_CD + # + # Arguments: + # $* Path + ######################################################### + zshz_cd() { + setopt LOCAL_OPTIONS NO_WARN_CREATE_GLOBAL + + if [[ -z $ZSHZ_CD ]]; then + builtin cd "$*" + else + ${=ZSHZ_CD} "$*" + fi + } + ######################################################### # If $ZSHZ_ECHO == 1, display paths as you jump to them. # If it is also the case that $ZSHZ_TILDE == 1, display @@ -773,7 +805,7 @@ zshz() { if [[ ${@: -1} == /* ]] && (( ! $+opts[-e] && ! $+opts[-l] )); then # cd if possible; echo the new path if $ZSHZ_ECHO == 1 - [[ -d ${@: -1} ]] && builtin cd ${@: -1} && _zshz_echo && return + [[ -d ${@: -1} ]] && zshz_cd ${@: -1} && _zshz_echo && return fi # With option -c, make sure query string matches beginning of matches; @@ -830,12 +862,12 @@ zshz() { print -- "$cd" else # cd if possible; echo the new path if $ZSHZ_ECHO == 1 - [[ -d $cd ]] && builtin cd "$cd" && _zshz_echo + [[ -d $cd ]] && zshz_cd "$cd" && _zshz_echo fi else # if $req is a valid path, cd to it; echo the new path if $ZSHZ_ECHO == 1 if ! (( $+opts[-e] || $+opts[-l] )) && [[ -d $req ]]; then - builtin cd "$req" && _zshz_echo + zshz_cd "$req" && _zshz_echo else return $ret2 fi @@ -900,9 +932,9 @@ add-zsh-hook chpwd _zshz_chpwd ############################################################ # Standarized $0 handling -# (See https://github.com/agkozak/Zsh-100-Commits-Club/blob/master/Zsh-Plugin-Standard.adoc) -0=${${ZERO:-${0:#$ZSH_ARGZERO}}:-${(%):-%N}} -0=${${(M)0:#/*}:-$PWD/$0} +# https://zdharma-continuum.github.io/Zsh-100-Commits-Club/Zsh-Plugin-Standard.html +0="${${ZERO:-${0:#$ZSH_ARGZERO}}:-${(%):-%N}}" +0="${${(M)0:#/*}:-$PWD/$0}" (( ${fpath[(ie)${0:A:h}]} <= ${#fpath} )) || fpath=( "${0:A:h}" "${fpath[@]}" ) From b22593cf179bae479ab32700c5a7b94d3053762d Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Mon, 1 May 2023 22:21:01 +0200 Subject: [PATCH 264/672] fix(init): avoid overwriting existing aliases Fix regression introduced in #11550. If an existing alias was present in the moment of sourcing, and oh-my-zsh aliases were disabled for that file, it'd be overwritten aswell. See #11658. --- oh-my-zsh.sh | 20 +++++++++++++------- 1 file changed, 13 insertions(+), 7 deletions(-) diff --git a/oh-my-zsh.sh b/oh-my-zsh.sh index e047d4834..a577c1f41 100644 --- a/oh-my-zsh.sh +++ b/oh-my-zsh.sh @@ -159,10 +159,10 @@ _omz_source() { zstyle -T ":omz:${context}" aliases || disable_aliases=1 # Back up alias names prior to sourcing - local -a aliases_pre galiases_pre + local -A aliases_pre galiases_pre if (( disable_aliases )); then - aliases_pre=("${(@k)aliases}") - galiases_pre=("${(@k)galiases}") + aliases_pre=("${(@kv)aliases}") + galiases_pre=("${(@kv)galiases}") fi # Source file from $ZSH_CUSTOM if it exists, otherwise from $ZSH @@ -174,10 +174,16 @@ _omz_source() { # Unset all aliases that don't appear in the backed up list of aliases if (( disable_aliases )); then - local -a disabled - # ${var:|array} gets the list of items in var not in array - disabled=("${(@k)aliases:|aliases_pre}" "${(@k)galiases:|galiases_pre}") - (( $#disabled == 0 )) || unalias "${(@)disabled}" + if (( #aliases_pre )); then + aliases=("${(@kv)aliases_pre}") + else + (( #aliases )) && unalias "${(@k)aliases}" + fi + if (( #galiases_pre )); then + galiases=("${(@kv)galiases_pre}") + else + (( #galiases )) && unalias "${(@k)galiases}" + fi fi } From 693e3dcc447b5d6fa611eea43166ea2b4e0ed877 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Tue, 2 May 2023 10:03:24 +0200 Subject: [PATCH 265/672] fix(apple): replace deprecated nerdfonts icon --- themes/apple.zsh-theme | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/themes/apple.zsh-theme b/themes/apple.zsh-theme index 0c183258e..65a2b80fe 100644 --- a/themes/apple.zsh-theme +++ b/themes/apple.zsh-theme @@ -1,5 +1,5 @@ function toon { - echo -n "" + echo -n "󰐀" } autoload -Uz vcs_info From dab09cc0eec220f5c1a541ccb75449c62c20bdb4 Mon Sep 17 00:00:00 2001 From: Oleg Grigoriev Date: Tue, 2 May 2023 13:27:57 +0300 Subject: [PATCH 266/672] feat(rake-fast): show task descriptions in autocomplete (#11653) --- plugins/rake-fast/rake-fast.plugin.zsh | 39 ++++++++++++++++++++++++-- 1 file changed, 36 insertions(+), 3 deletions(-) diff --git a/plugins/rake-fast/rake-fast.plugin.zsh b/plugins/rake-fast/rake-fast.plugin.zsh index 19dab154b..86e5ed586 100644 --- a/plugins/rake-fast/rake-fast.plugin.zsh +++ b/plugins/rake-fast/rake-fast.plugin.zsh @@ -1,5 +1,28 @@ +# The version of the format of .rake_tasks. If the output of _rake_generate +# changes, incrementing this number will force it to regenerate +_rake_tasks_version=2 + _rake_does_task_list_need_generating () { - [[ ! -f .rake_tasks ]] || [[ Rakefile -nt .rake_tasks ]] || { _is_rails_app && _tasks_changed } + _rake_tasks_missing || _rake_tasks_version_changed || _rakefile_has_changes || { _is_rails_app && _tasks_changed } +} + +_rake_tasks_missing () { + [[ ! -f .rake_tasks ]] +} + +_rake_tasks_version_changed () { + local -a file_version + file_version=`head -n 1 .rake_tasks | sed "s/^version\://"` + + if ! [[ $file_version =~ '^[0-9]*$' ]]; then + return true + fi + + [[ $file_version -ne $_rake_tasks_version ]] +} + +_rakefile_has_changes () { + [[ Rakefile -nt .rake_tasks ]] } _is_rails_app () { @@ -20,7 +43,14 @@ _tasks_changed () { } _rake_generate () { - rake --silent --tasks | cut -d " " -f 2 | sed 's/\[.*\]//g' > .rake_tasks + echo "version:$_rake_tasks_version" > .rake_tasks + + rake --silent --tasks --all \ + | sed "s/^rake //" | sed "s/\:/\\\:/g" \ + | sed "s/\[[^]]*\]//g" \ + | sed "s/ *# /\:/" \ + | sed "s/\:$//" \ + >> .rake_tasks } _rake () { @@ -29,7 +59,10 @@ _rake () { echo "\nGenerating .rake_tasks..." >&2 _rake_generate fi - compadd $(cat .rake_tasks) + local -a rake_options + rake_options=("${(@f)$(cat .rake_tasks)}") + shift rake_options + _describe 'rake tasks' rake_options fi } compdef _rake rake From 85fdbfe21692a3fa7bdd7bc509163e23fb385279 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Wed, 3 May 2023 11:17:47 +0200 Subject: [PATCH 267/672] fix(apple): go back to previous icon Turns out that is a reserved unicode code that is Apple logo in Apple systems. Nerd fonts was overwritting that code to other stuff in v2 and that's why I thought it needed to be replaced. Closes #11665 This reverts commit 693e3dcc447b5d6fa611eea43166ea2b4e0ed877. --- themes/apple.zsh-theme | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/themes/apple.zsh-theme b/themes/apple.zsh-theme index 65a2b80fe..0c183258e 100644 --- a/themes/apple.zsh-theme +++ b/themes/apple.zsh-theme @@ -1,5 +1,5 @@ function toon { - echo -n "󰐀" + echo -n "" } autoload -Uz vcs_info From 5a3f565e7d4371db92ba574f231b396c2c8c9a19 Mon Sep 17 00:00:00 2001 From: kang <1115610574@qq.com> Date: Wed, 3 May 2023 23:48:37 +0800 Subject: [PATCH 268/672] feat(deno): add `dru` alias for `--unstable` (#11667) --- plugins/deno/README.md | 27 ++++++++++++++------------- plugins/deno/deno.plugin.zsh | 1 + 2 files changed, 15 insertions(+), 13 deletions(-) diff --git a/plugins/deno/README.md b/plugins/deno/README.md index 691318397..38f9f2033 100644 --- a/plugins/deno/README.md +++ b/plugins/deno/README.md @@ -4,16 +4,17 @@ This plugin sets up completion and aliases for [Deno](https://deno.land). ## Aliases -| Alias | Full command | -| ----- | ---------------- | -| db | deno bundle | -| dc | deno compile | -| dca | deno cache | -| dfmt | deno fmt | -| dh | deno help | -| dli | deno lint | -| drn | deno run | -| drA | deno run -A | -| drw | deno run --watch | -| dts | deno test | -| dup | deno upgrade | +| Alias | Full command | +| ----- | ------------------- | +| db | deno bundle | +| dc | deno compile | +| dca | deno cache | +| dfmt | deno fmt | +| dh | deno help | +| dli | deno lint | +| drn | deno run | +| drA | deno run -A | +| drw | deno run --watch | +| dru | deno run --unstable | +| dts | deno test | +| dup | deno upgrade | diff --git a/plugins/deno/deno.plugin.zsh b/plugins/deno/deno.plugin.zsh index 7708f84df..bf97d6f03 100644 --- a/plugins/deno/deno.plugin.zsh +++ b/plugins/deno/deno.plugin.zsh @@ -8,6 +8,7 @@ alias dli='deno lint' alias drn='deno run' alias drA='deno run -A' alias drw='deno run --watch' +alias dru='deno run --unstable' alias dts='deno test' alias dup='deno upgrade' From c5208867f1eb46f722e040b239150817abec87a6 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Tue, 2 May 2023 12:41:01 +0200 Subject: [PATCH 269/672] feat(theme-and-appearance): allow disabling gnu-ls in bsd To disable gnu-ls (`gls`) even if it's installed in freeBSD and macOS you can set it up with: ```zsh zstyle ':omz:lib:theme-and-appearance' gnu-ls no ``` Closes #11647 --- README.md | 13 +++++++++++++ lib/theme-and-appearance.zsh | 36 +++++++++++++++++------------------- 2 files changed, 30 insertions(+), 19 deletions(-) diff --git a/README.md b/README.md index 556d4c8c5..650fb00ea 100644 --- a/README.md +++ b/README.md @@ -40,6 +40,7 @@ To learn more, visit [ohmyz.sh](https://ohmyz.sh), follow [@ohmyzsh](https://twi - [Manual Installation](#manual-installation) - [Installation Problems](#installation-problems) - [Custom Plugins and Themes](#custom-plugins-and-themes) + - [Disable GNU ls in macOS and freeBSD systems](#disable-gnu-ls) - [Skip aliases](#skip-aliases) - [Getting Updates](#getting-updates) - [Updates verbosity](#updates-verbosity) @@ -278,6 +279,18 @@ If you have many functions that go well together, you can put them as a `XYZ.plu If you would like to override the functionality of a plugin distributed with Oh My Zsh, create a plugin of the same name in the `custom/plugins/` directory and it will be loaded instead of the one in `plugins/`. +### Disable GNU ls in macOS and freeBSD systems + + + +The default behaviour in Oh My Zsh is to use GNU `ls` even in macOS and freeBSD systems if it's installed (as +`gls` command) when enabling colorized `ls` in `lib/theme-and-appearance.zsh`. If you want to disable this +behaviour you can use zstyle-based config before sourcing `oh-my-zsh.sh`: + +```zsh +zstyle ':omz:lib:theme-and-appearance' gnu-ls no +``` + ### Skip aliases diff --git a/lib/theme-and-appearance.zsh b/lib/theme-and-appearance.zsh index d8859b04c..96bdb00e5 100644 --- a/lib/theme-and-appearance.zsh +++ b/lib/theme-and-appearance.zsh @@ -20,10 +20,25 @@ if command diff --color /dev/null{,} &>/dev/null; then } fi - # Don't set ls coloring if disabled [[ "$DISABLE_LS_COLORS" != true ]] || return 0 +# Default coloring for BSD-based ls +export LSCOLORS="Gxfxcxdxbxegedabagacad" + +# Default coloring for GNU-based ls +if [[ -z "$LS_COLORS" ]]; then + # Define LS_COLORS via dircolors if available. Otherwise, set a default + # equivalent to LSCOLORS (generated via https://geoff.greer.fm/lscolors) + if (( $+commands[dircolors] )); then + [[ -f "$HOME/.dircolors" ]] \ + && source <(dircolors -b "$HOME/.dircolors") \ + || source <(dircolors -b) + else + export LS_COLORS="di=1;36:ln=35:so=32:pi=33:ex=31:bd=34;46:cd=34;43:su=30;41:sg=30;46:tw=30;42:ow=30;43" + fi +fi + function test-ls-args { local cmd="$1" # ls, gls, colorls, ... local args="${@[2,-1]}" # arguments except the first one @@ -50,7 +65,7 @@ case "$OSTYPE" in test-ls-args ls -G && alias ls='ls -G' # Only use GNU ls if installed and there are user defaults for $LS_COLORS, # as the default coloring scheme is not very pretty - [[ -n "$LS_COLORS" || -f "$HOME/.dircolors" ]] \ + zstyle -T ':omz:lib:theme-and-appearance' gnu-ls \ && test-ls-args gls --color \ && alias ls='gls --color=tty' ;; @@ -64,20 +79,3 @@ case "$OSTYPE" in esac unfunction test-ls-args - - -# Default coloring for BSD-based ls -export LSCOLORS="Gxfxcxdxbxegedabagacad" - -# Default coloring for GNU-based ls -if [[ -z "$LS_COLORS" ]]; then - # Define LS_COLORS via dircolors if available. Otherwise, set a default - # equivalent to LSCOLORS (generated via https://geoff.greer.fm/lscolors) - if (( $+commands[dircolors] )); then - [[ -f "$HOME/.dircolors" ]] \ - && source <(dircolors -b "$HOME/.dircolors") \ - || source <(dircolors -b) - else - export LS_COLORS="di=1;36:ln=35:so=32:pi=33:ex=31:bd=34;46:cd=34;43:su=30;41:sg=30;46:tw=30;42:ow=30;43" - fi -fi From 017e288560ef7bdfb8835516d6b3b77bbdcdde6c Mon Sep 17 00:00:00 2001 From: Mark Keisler Date: Sat, 6 May 2023 06:40:06 -0500 Subject: [PATCH 270/672] fix(aws): correct access key disable command (#11671) --- plugins/aws/aws.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/aws/aws.plugin.zsh b/plugins/aws/aws.plugin.zsh index a437dc8e8..b2415b737 100644 --- a/plugins/aws/aws.plugin.zsh +++ b/plugins/aws/aws.plugin.zsh @@ -180,7 +180,7 @@ function aws_change_access_key() { case $yn in [Yy]*) echo -n "\nDisabling access key ${original_aws_access_key_id}..." - if aws --no-cli-pager update-access-key --access-key-id ${original_aws_access_key_id} --status Inactive; then + if aws --no-cli-pager iam update-access-key --access-key-id ${original_aws_access_key_id} --status Inactive; then echo "done." else echo "\nFailed to disable ${original_aws_access_key_id} key." From dcff7a7f0854591ee1b4f25266f292ec1b1904eb Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Tue, 9 May 2023 12:05:15 +0200 Subject: [PATCH 271/672] fix(theme-and-appearance): make bsd `ls` to be default --- lib/theme-and-appearance.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/theme-and-appearance.zsh b/lib/theme-and-appearance.zsh index 96bdb00e5..585e969d8 100644 --- a/lib/theme-and-appearance.zsh +++ b/lib/theme-and-appearance.zsh @@ -65,7 +65,7 @@ case "$OSTYPE" in test-ls-args ls -G && alias ls='ls -G' # Only use GNU ls if installed and there are user defaults for $LS_COLORS, # as the default coloring scheme is not very pretty - zstyle -T ':omz:lib:theme-and-appearance' gnu-ls \ + zstyle -t ':omz:lib:theme-and-appearance' gnu-ls \ && test-ls-args gls --color \ && alias ls='gls --color=tty' ;; From aaf83d37aa1cc5ed2cb96dd29328502003a70848 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Tue, 9 May 2023 12:10:05 +0200 Subject: [PATCH 272/672] docs(theme-and-appearance): reflect properly dcff7a7 changes --- README.md | 14 ++++++++------ 1 file changed, 8 insertions(+), 6 deletions(-) diff --git a/README.md b/README.md index 650fb00ea..2249b49dd 100644 --- a/README.md +++ b/README.md @@ -40,7 +40,7 @@ To learn more, visit [ohmyz.sh](https://ohmyz.sh), follow [@ohmyzsh](https://twi - [Manual Installation](#manual-installation) - [Installation Problems](#installation-problems) - [Custom Plugins and Themes](#custom-plugins-and-themes) - - [Disable GNU ls in macOS and freeBSD systems](#disable-gnu-ls) + - [Enable GNU ls in macOS and freeBSD systems](#enable-gnu-ls) - [Skip aliases](#skip-aliases) - [Getting Updates](#getting-updates) - [Updates verbosity](#updates-verbosity) @@ -279,18 +279,20 @@ If you have many functions that go well together, you can put them as a `XYZ.plu If you would like to override the functionality of a plugin distributed with Oh My Zsh, create a plugin of the same name in the `custom/plugins/` directory and it will be loaded instead of the one in `plugins/`. -### Disable GNU ls in macOS and freeBSD systems +### Enable GNU ls in macOS and freeBSD systems - + -The default behaviour in Oh My Zsh is to use GNU `ls` even in macOS and freeBSD systems if it's installed (as -`gls` command) when enabling colorized `ls` in `lib/theme-and-appearance.zsh`. If you want to disable this -behaviour you can use zstyle-based config before sourcing `oh-my-zsh.sh`: +The default behaviour in Oh My Zsh is to use BSD `ls` in macOS and freeBSD systems. If GNU `ls` is installed +(as `gls` command), you can choose to use it instead. To do it, you can use zstyle-based config before +sourcing `oh-my-zsh.sh`: ```zsh zstyle ':omz:lib:theme-and-appearance' gnu-ls no ``` +_Note: this is not compatible with `DISABLE_LS_COLORS=true`_ + ### Skip aliases From aab3bfff9f27a261dcd4cd4a2082a2ce3fff8c59 Mon Sep 17 00:00:00 2001 From: roodkcab Date: Tue, 9 May 2023 18:27:22 +0800 Subject: [PATCH 273/672] fix(robbyrussell) multiline command editing (#11681) Co-authored-by: chenshuoshi Closes #11680 --- themes/robbyrussell.zsh-theme | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/themes/robbyrussell.zsh-theme b/themes/robbyrussell.zsh-theme index 2fd5f2cdc..173e6d579 100644 --- a/themes/robbyrussell.zsh-theme +++ b/themes/robbyrussell.zsh-theme @@ -1,5 +1,5 @@ -PROMPT="%(?:%{$fg_bold[green]%}➜ :%{$fg_bold[red]%}➜ )" -PROMPT+=' %{$fg[cyan]%}%c%{$reset_color%} $(git_prompt_info)' +PROMPT="%(?:%{$fg_bold[green]%}➜ :%{$fg_bold[red]%}➜ ) %{$fg[cyan]%}%c%{$reset_color%}" +PROMPT+=' $(git_prompt_info)' ZSH_THEME_GIT_PROMPT_PREFIX="%{$fg_bold[blue]%}git:(%{$fg[red]%}" ZSH_THEME_GIT_PROMPT_SUFFIX="%{$reset_color%} " From f01eea76da194fef6005f53a281b6f5a998db126 Mon Sep 17 00:00:00 2001 From: ZYX Date: Fri, 12 May 2023 02:42:30 -0700 Subject: [PATCH 274/672] fix(aws): use the correct variable to assert region is defined (#11691) --- plugins/aws/aws.plugin.zsh | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/plugins/aws/aws.plugin.zsh b/plugins/aws/aws.plugin.zsh index b2415b737..c946515be 100644 --- a/plugins/aws/aws.plugin.zsh +++ b/plugins/aws/aws.plugin.zsh @@ -224,12 +224,12 @@ function aws_prompt_info() { local _aws_to_show local region="${AWS_REGION:-${AWS_DEFAULT_REGION:-$AWS_PROFILE_REGION}}" - if [[ -n $AWS_PROFILE ]];then + if [[ -n "$AWS_PROFILE" ]];then _aws_to_show+="${ZSH_THEME_AWS_PROFILE_PREFIX=""}" fi - if [[ -n $AWS_REGION ]]; then - [[ -n $AWS_PROFILE ]] && _aws_to_show+="${ZSH_THEME_AWS_DIVIDER=" "}" + if [[ -n "$region" ]]; then + [[ -n "$_aws_to_show" ]] && _aws_to_show+="${ZSH_THEME_AWS_DIVIDER=" "}" _aws_to_show+="${ZSH_THEME_AWS_REGION_PREFIX=""}" fi From 7a030f6bd6c15259052c7007020cf3ecf8a3f299 Mon Sep 17 00:00:00 2001 From: Joe Date: Mon, 15 May 2023 09:27:31 -0400 Subject: [PATCH 275/672] docs(pyenv): warn about pyenv init (#11692) --- plugins/pyenv/README.md | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/plugins/pyenv/README.md b/plugins/pyenv/README.md index b9ee937b7..f1ca3d288 100644 --- a/plugins/pyenv/README.md +++ b/plugins/pyenv/README.md @@ -10,6 +10,14 @@ To use it, add `pyenv` to the plugins array in your zshrc file: plugins=(... pyenv) ``` +If you receive a `Found pyenv, but it is badly configured.` error on startup, you may need to ensure that `pyenv` is initialized before the oh-my-zsh pyenv plugin is loaded. This can be achived by adding the following earlier in the `.zshrc` file than the `plugins=(...)` line: + +```zsh +export PYENV_ROOT="$HOME/.pyenv" +export PATH="$PYENV_ROOT/bin:$PATH" +eval "$(pyenv init --path)" +``` + ## Settings - `ZSH_PYENV_QUIET`: if set to `true`, the plugin will not print any messages if it From bfeeda1491b5366aa5798a86cf6f3621536b171c Mon Sep 17 00:00:00 2001 From: Craig Furman Date: Sun, 21 May 2023 11:47:38 +0100 Subject: [PATCH 276/672] docs(theme-and-appearance): fix gnu-ls snippet (#11701) --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index 2249b49dd..a30595581 100644 --- a/README.md +++ b/README.md @@ -288,7 +288,7 @@ The default behaviour in Oh My Zsh is to use BSD `ls` in macOS and freeBSD syste sourcing `oh-my-zsh.sh`: ```zsh -zstyle ':omz:lib:theme-and-appearance' gnu-ls no +zstyle ':omz:lib:theme-and-appearance' gnu-ls yes ``` _Note: this is not compatible with `DISABLE_LS_COLORS=true`_ From 3a01d7df82157a5f3aef01eab9a940e4cba2283a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Sun, 21 May 2023 19:58:26 +0200 Subject: [PATCH 277/672] fix(extract): fix extract dir naming conflicts Fixes #11642 --- plugins/extract/extract.plugin.zsh | 20 +++++++++++++++----- 1 file changed, 15 insertions(+), 5 deletions(-) diff --git a/plugins/extract/extract.plugin.zsh b/plugins/extract/extract.plugin.zsh index 34c080653..ee1d38b3f 100644 --- a/plugins/extract/extract.plugin.zsh +++ b/plugins/extract/extract.plugin.zsh @@ -27,12 +27,20 @@ EOF fi local success=0 - local extract_dir="${1:t:r}" local file="$1" full_path="${1:A}" + local extract_dir="${1:t:r}" + + # If there's a file or directory with the same name as the archive + # add a random string to the end of the extract directory + if [[ -e "$extract_dir" ]]; then + local rnd="${(L)"${$(( [##36]$RANDOM*$RANDOM ))}":1:5}" + extract_dir="${extract_dir}-${rnd}" + fi # Create an extraction directory based on the file name command mkdir -p "$extract_dir" builtin cd -q "$extract_dir" + echo "extract: extracting to $extract_dir" >&2 case "${file:l}" in (*.tar.gz|*.tgz) @@ -107,11 +115,13 @@ EOF if [[ "${content[1]:t}" == "$extract_dir" ]]; then # =(:) gives /tmp/zsh, with :t it gives zsh local tmp_dir==(:); tmp_dir="${tmp_dir:t}" - command mv -f "${content[1]}" "$tmp_dir" \ + command mv "${content[1]}" "$tmp_dir" \ && command rmdir "$extract_dir" \ - && command mv -f "$tmp_dir" "$extract_dir" - else - command mv -f "${content[1]}" . \ + && command mv "$tmp_dir" "$extract_dir" + # Otherwise, if the extracted folder name already exists in the current + # directory (because of a previous file / folder), keep the extract_dir + elif [[ ! -e "${content[1]:t}" ]]; then + command mv "${content[1]}" . \ && command rmdir "$extract_dir" fi elif [[ ${#content} -eq 0 ]]; then From b06663df23b2910a6e542dc114dc7adc2cdce22f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Sun, 21 May 2023 20:14:32 +0200 Subject: [PATCH 278/672] feat(extract): add support for `.zlib` and `.exe` files (#11085) Fixes #11085 --- plugins/extract/README.md | 3 +++ plugins/extract/extract.plugin.zsh | 3 ++- 2 files changed, 5 insertions(+), 1 deletion(-) diff --git a/plugins/extract/README.md b/plugins/extract/README.md index ac4a8e197..c8d98b229 100644 --- a/plugins/extract/README.md +++ b/plugins/extract/README.md @@ -25,6 +25,7 @@ plugins=(... extract) | `cpio` | Cpio archive | | `deb` | Debian package | | `ear` | Enterprise Application aRchive | +| `exe` | Windows executable file | | `gz` | Gzip file | | `ipa` | iOS app package | | `ipsw` | iOS firmware file | @@ -52,9 +53,11 @@ plugins=(... extract) | `txz` | Tarball with lzma2 compression | | `tzst` | Tarball with zstd compression | | `war` | Web Application archive (Java-based) | +| `whl` | Python wheel file | | `xpi` | Mozilla XPI module file | | `xz` | LZMA2 archive | | `zip` | Zip archive | +| `zlib` | zlib archive | | `zst` | Zstandard file (zstd) | | `zpaq` | Zpaq file | diff --git a/plugins/extract/extract.plugin.zsh b/plugins/extract/extract.plugin.zsh index ee1d38b3f..b7a823c9f 100644 --- a/plugins/extract/extract.plugin.zsh +++ b/plugins/extract/extract.plugin.zsh @@ -83,9 +83,10 @@ EOF builtin cd -q ../data; extract ../data.tar.* builtin cd -q ..; command rm *.tar.* debian-binary ;; (*.zst) unzstd "$full_path" ;; - (*.cab) cabextract "$full_path" ;; + (*.cab|*.exe) cabextract "$full_path" ;; (*.cpio|*.obscpio) cpio -idmvF "$full_path" ;; (*.zpaq) zpaq x "$full_path" ;; + (*.zlib) zlib-flate -uncompress < "$full_path" > "${file:r}" ;; (*) echo "extract: '$file' cannot be extracted" >&2 success=1 ;; From 444e715766c4a8b267dba82f3f0f562584d61adc Mon Sep 17 00:00:00 2001 From: rogarb <69053978+rogarb@users.noreply.github.com> Date: Mon, 22 May 2023 10:49:10 +0000 Subject: [PATCH 279/672] feat(bureau): ignore hidden git repos (#11707) The git_prompt_info() function in lib/git.zsh ignores git repos which contains a specific config key, allowing to effectively "hide" them from the prompt. Unfortunately, the bureau theme doesn't use the library function to build its prompt. This commit modifies the specific prompt generation function in the bureau theme in order to achieve the same behaviour. --- themes/bureau.zsh-theme | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/themes/bureau.zsh-theme b/themes/bureau.zsh-theme index 698aa2ff8..9943a0c8c 100644 --- a/themes/bureau.zsh-theme +++ b/themes/bureau.zsh-theme @@ -67,6 +67,12 @@ bureau_git_status() { } bureau_git_prompt() { + # ignore non git folders and hidden repos (adapted from lib/git.zsh) + if ! command git rev-parse --git-dir &> /dev/null \ + || [[ "$(command git config --get oh-my-zsh.hide-info 2>/dev/null)" == 1 ]]; then + return + fi + # check git information local gitinfo=$(bureau_git_info) if [[ -z "$gitinfo" ]]; then From 902b79e635fedf4a12542d2ed8bd29665d3d281c Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Tue, 23 May 2023 08:43:47 +0200 Subject: [PATCH 280/672] fix(functions): use `command` env Closes #11709 --- lib/functions.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/functions.zsh b/lib/functions.zsh index 1d85ea38a..a252d0a33 100644 --- a/lib/functions.zsh +++ b/lib/functions.zsh @@ -5,7 +5,7 @@ function zsh_stats() { } function uninstall_oh_my_zsh() { - env ZSH="$ZSH" sh "$ZSH/tools/uninstall.sh" + command env ZSH="$ZSH" sh "$ZSH/tools/uninstall.sh" } function upgrade_oh_my_zsh() { From 1bbe4d8d2431b5ac06d7402b570431884786db58 Mon Sep 17 00:00:00 2001 From: Felipe Francisco Date: Tue, 23 May 2023 03:46:46 -0300 Subject: [PATCH 281/672] feat(half-life): add virtualenv prompt (#11708) --- themes/half-life.zsh-theme | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/themes/half-life.zsh-theme b/themes/half-life.zsh-theme index c4d785126..2ad84ac83 100644 --- a/themes/half-life.zsh-theme +++ b/themes/half-life.zsh-theme @@ -89,5 +89,9 @@ ZSH_THEME_RUBY_PROMPT_PREFIX="with%F{red} " ZSH_THEME_RUBY_PROMPT_SUFFIX="%{$reset_color%}" ZSH_THEME_RVM_PROMPT_OPTIONS="v g" +# virtualenv prompt settings +ZSH_THEME_VIRTUALENV_PREFIX=" with%F{red} " +ZSH_THEME_VIRTUALENV_SUFFIX="%{$reset_color%}" + setopt prompt_subst -PROMPT="${purple}%n%{$reset_color%} in ${limegreen}%~%{$reset_color%}\$(ruby_prompt_info)\$vcs_info_msg_0_${orange} λ%{$reset_color%} " +PROMPT="${purple}%n%{$reset_color%} in ${limegreen}%~%{$reset_color%}\$(virtualenv_prompt_info)\$(ruby_prompt_info)\$vcs_info_msg_0_${orange} λ%{$reset_color%} " From ec369bb38e873fa2e8954bc45bc192fdb0051313 Mon Sep 17 00:00:00 2001 From: rogarb <69053978+rogarb@users.noreply.github.com> Date: Wed, 24 May 2023 12:32:26 +0000 Subject: [PATCH 282/672] fix(bureau): properly display git stash info (#11711) --- themes/bureau.zsh-theme | 1 + 1 file changed, 1 insertion(+) diff --git a/themes/bureau.zsh-theme b/themes/bureau.zsh-theme index 9943a0c8c..e87a594cd 100644 --- a/themes/bureau.zsh-theme +++ b/themes/bureau.zsh-theme @@ -15,6 +15,7 @@ ZSH_THEME_GIT_PROMPT_BEHIND="%{$fg[magenta]%}▾%{$reset_color%}" ZSH_THEME_GIT_PROMPT_STAGED="%{$fg_bold[green]%}●%{$reset_color%}" ZSH_THEME_GIT_PROMPT_UNSTAGED="%{$fg_bold[yellow]%}●%{$reset_color%}" ZSH_THEME_GIT_PROMPT_UNTRACKED="%{$fg_bold[red]%}●%{$reset_color%}" +ZSH_THEME_GIT_PROMPT_STASHED="(%{$fg_bold[blue]%}✹%{$reset_color%})" bureau_git_info () { local ref From 5901f30b44fc5a3055e6b801d3d71af6d2359ee8 Mon Sep 17 00:00:00 2001 From: WH-2099 Date: Thu, 25 May 2023 18:43:01 +0800 Subject: [PATCH 283/672] feat(archlinux): optimize `paclist` and `pacdisowned` (#11398) Co-authored-by: ratijas --- plugins/archlinux/README.md | 1 + plugins/archlinux/archlinux.plugin.zsh | 23 ++++++++++++----------- 2 files changed, 13 insertions(+), 11 deletions(-) diff --git a/plugins/archlinux/README.md b/plugins/archlinux/README.md index fd772c61a..5e015dbaa 100644 --- a/plugins/archlinux/README.md +++ b/plugins/archlinux/README.md @@ -181,3 +181,4 @@ whether the package manager is installed, checked in the following order: - Ybalrid (Arthur Brainville) - ybalrid@ybalrid.info - Jeff M. Hubbard - jeffmhubbard@gmail.com - K. Harishankar(harishnkr) - hari2menon1234@gmail.com +- WH-2099 - wh2099@outlook.com \ No newline at end of file diff --git a/plugins/archlinux/archlinux.plugin.zsh b/plugins/archlinux/archlinux.plugin.zsh index da170f488..796ff7adf 100644 --- a/plugins/archlinux/archlinux.plugin.zsh +++ b/plugins/archlinux/archlinux.plugin.zsh @@ -25,27 +25,28 @@ alias pacown='pacman -Qo' alias pacupd="sudo pacman -Sy" function paclist() { - # Based on https://bbs.archlinux.org/viewtopic.php?id=93683 - pacman -Qqe | \ - xargs -I '{}' \ - expac "${bold_color}% 20n ${fg_no_bold[white]}%d${reset_color}" '{}' + local pkgs=$(LC_ALL=C pacman -Qqe) + for pkg in ${(f)pkgs}; do + pacman -Qs --color=auto "^${pkg}\$" || break + done } function pacdisowned() { - local tmp db fs - tmp=${TMPDIR-/tmp}/pacman-disowned-$UID-$$ - db=$tmp/db - fs=$tmp/fs + local tmp_dir db fs + tmp_dir=$(mktemp --directory) + db=$tmp_dir/db + fs=$tmp_dir/fs - mkdir "$tmp" - trap 'rm -rf "$tmp"' EXIT + trap "rm -rf $tmp_dir" EXIT pacman -Qlq | sort -u > "$db" - find /bin /etc /lib /sbin /usr ! -name lost+found \ + find /etc /usr ! -name lost+found \ \( -type d -printf '%p/\n' -o -print \) | sort > "$fs" comm -23 "$fs" "$db" + + rm -rf $tmp_dir } alias pacmanallkeys='sudo pacman-key --refresh-keys' From fb4213c34ff8ec83cbe6251f432fdac383378562 Mon Sep 17 00:00:00 2001 From: Tom D Date: Fri, 26 May 2023 09:43:17 +0200 Subject: [PATCH 284/672] perf(git): improve `gunwip` alias (#11714) --- plugins/git/README.md | 2 +- plugins/git/git.plugin.zsh | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/plugins/git/README.md b/plugins/git/README.md index f87d3fbca..2742aa539 100644 --- a/plugins/git/README.md +++ b/plugins/git/README.md @@ -186,7 +186,7 @@ plugins=(... git) | gtv | git tag \| sort -V | | gtl | gtl(){ git tag --sort=-v:refname -n --list ${1}\* }; noglob gtl | | gunignore | git update-index --no-assume-unchanged | -| gunwip | git log --max-count=1 \| grep -q -c "\-\-wip\-\-" && git reset HEAD~1 | +| gunwip | git rev-list --max-count=1 --format="%s" HEAD \| grep -q "\-\-wip\-\-" && git reset HEAD~1 | | gup | git pull --rebase | | gupv | git pull --rebase --verbose | | gupa | git pull --rebase --autostash | diff --git a/plugins/git/git.plugin.zsh b/plugins/git/git.plugin.zsh index 3c8d53c8c..4be865f6a 100644 --- a/plugins/git/git.plugin.zsh +++ b/plugins/git/git.plugin.zsh @@ -312,7 +312,7 @@ alias gtv='git tag | sort -V' alias gtl='gtl(){ git tag --sort=-v:refname -n --list "${1}*" }; noglob gtl' alias gunignore='git update-index --no-assume-unchanged' -alias gunwip='git log --max-count=1 | grep -q -c "\--wip--" && git reset HEAD~1' +alias gunwip='git rev-list --max-count=1 --format="%s" HEAD | grep -q "\--wip--" && git reset HEAD~1' alias gup='git pull --rebase' alias gupv='git pull --rebase --verbose' alias gupa='git pull --rebase --autostash' From 00241073105643874531e1826b7df6d2cb3cadfb Mon Sep 17 00:00:00 2001 From: William Snyders Date: Wed, 31 May 2023 14:59:41 -0700 Subject: [PATCH 285/672] fix(gcloud): update AUR default location (#11718) --- plugins/gcloud/gcloud.plugin.zsh | 1 + 1 file changed, 1 insertion(+) diff --git a/plugins/gcloud/gcloud.plugin.zsh b/plugins/gcloud/gcloud.plugin.zsh index 30f1dba8f..9c26aea10 100644 --- a/plugins/gcloud/gcloud.plugin.zsh +++ b/plugins/gcloud/gcloud.plugin.zsh @@ -14,6 +14,7 @@ if [[ -z "${CLOUDSDK_HOME}" ]]; then "/usr/lib/google-cloud-sdk" "/usr/lib64/google-cloud-sdk" "/opt/google-cloud-sdk" + "/opt/google-cloud-cli" "/opt/local/libexec/google-cloud-sdk" ) From 6101106916147b1716ff2d5de4a53260e7607bae Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Fri, 2 Jun 2023 21:37:48 +0200 Subject: [PATCH 286/672] feat(install): deploy installer to install.ohmyz.sh (#11722) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Co-authored-by: Marc Cornellà --- .github/workflows/installer.yml | 55 +++++++++++++++++++++++ .github/workflows/installer/.gitignore | 1 + .github/workflows/installer/.vercelignore | 2 + .github/workflows/installer/vercel.json | 14 ++++++ .github/workflows/main.yml | 2 - 5 files changed, 72 insertions(+), 2 deletions(-) create mode 100644 .github/workflows/installer.yml create mode 100644 .github/workflows/installer/.gitignore create mode 100644 .github/workflows/installer/.vercelignore create mode 100644 .github/workflows/installer/vercel.json diff --git a/.github/workflows/installer.yml b/.github/workflows/installer.yml new file mode 100644 index 000000000..ac88d10b0 --- /dev/null +++ b/.github/workflows/installer.yml @@ -0,0 +1,55 @@ +name: Test and Deploy installer +on: + workflow_dispatch: {} + push: + paths: + - tools/install.sh + - .github/workflows/installer + - .github/workflows/installer.yml + +concurrency: + group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }} + cancel-in-progress: false + +permissions: + contents: read # to checkout + +jobs: + test: + name: Test installer + runs-on: ${{ matrix.os }} + strategy: + matrix: + os: + - ubuntu-latest + - macos-latest + steps: + - name: Set up git repository + uses: actions/checkout@v3 + - name: Install zsh + if: runner.os == 'Linux' + run: sudo apt-get update; sudo apt-get install zsh + - name: Test installer + run: sh ./tools/install.sh + + deploy: + name: Deploy installer in install.ohmyz.sh + if: github.ref == 'refs/heads/master' + runs-on: ubuntu-latest + environment: vercel + needs: + - test + steps: + - name: Checkout + uses: actions/checkout@v3 + - name: Install Vercel CLI + run: npm install -g vercel + - name: Setup project and deploy + env: + VERCEL_ORG_ID: ${{ secrets.VERCEL_ORG_ID }} + VERCEL_PROJECT_ID: ${{ secrets.VERCEL_PROJECT_ID }} + run: | + cp tools/install.sh .github/workflows/installer/install.sh + cd .github/workflows/installer + vc link --yes -t ${{ secrets.VERCEL_TOKEN }} + vc deploy --prod -t ${{ secrets.VERCEL_TOKEN }} diff --git a/.github/workflows/installer/.gitignore b/.github/workflows/installer/.gitignore new file mode 100644 index 000000000..f66fce310 --- /dev/null +++ b/.github/workflows/installer/.gitignore @@ -0,0 +1 @@ +install.sh diff --git a/.github/workflows/installer/.vercelignore b/.github/workflows/installer/.vercelignore new file mode 100644 index 000000000..41b233364 --- /dev/null +++ b/.github/workflows/installer/.vercelignore @@ -0,0 +1,2 @@ +/* +!/install.sh diff --git a/.github/workflows/installer/vercel.json b/.github/workflows/installer/vercel.json new file mode 100644 index 000000000..8c5aec5e0 --- /dev/null +++ b/.github/workflows/installer/vercel.json @@ -0,0 +1,14 @@ +{ + "headers": [ + { + "source": "/((?!favicon.ico).*)", + "headers": [{ "key": "Content-Type", "value": "text/plain" }] + } + ], + "rewrites": [ + { + "source": "/((?!favicon.ico|install.sh).*)", + "destination": "/install.sh" + } + ] +} diff --git a/.github/workflows/main.yml b/.github/workflows/main.yml index 8ee2df3d8..57403629c 100644 --- a/.github/workflows/main.yml +++ b/.github/workflows/main.yml @@ -31,8 +31,6 @@ jobs: - name: Install zsh if: runner.os == 'Linux' run: sudo apt-get update; sudo apt-get install zsh - - name: Test installer - run: sh ./tools/install.sh - name: Check syntax run: | for file in ./oh-my-zsh.sh \ From 62ab5406dd89848bb26e8c6e648eb7d860e9dce5 Mon Sep 17 00:00:00 2001 From: Lawrence Shah Date: Mon, 5 Jun 2023 01:20:32 -0700 Subject: [PATCH 287/672] docs(custom): update comments in example files (#11727) --- custom/example.zsh | 18 ++++++++++-------- custom/plugins/example/example.plugin.zsh | 1 + custom/themes/example.zsh-theme | 2 ++ 3 files changed, 13 insertions(+), 8 deletions(-) diff --git a/custom/example.zsh b/custom/example.zsh index c505a9673..21a8d8be7 100644 --- a/custom/example.zsh +++ b/custom/example.zsh @@ -1,10 +1,12 @@ -# You can put files here to add functionality separated per file, which -# will be ignored by git. -# Files on the custom/ directory will be automatically loaded by the init -# script, in alphabetical order. - -# For example: add yourself some shortcuts to projects you often work on. -# +# Put files in this folder to add your own custom functionality. +# See: https://github.com/ohmyzsh/ohmyzsh/wiki/Customization +# +# Files in the custom/ directory will be: +# - loaded automatically by the init script, in alphabetical order +# - loaded last, after all built-ins in the lib/ directory, to override them +# - ignored by git by default +# +# Example: add custom/shortcuts.zsh for shortcuts to your local projects +# # brainstormr=~/Projects/development/planetargon/brainstormr # cd $brainstormr -# diff --git a/custom/plugins/example/example.plugin.zsh b/custom/plugins/example/example.plugin.zsh index 406f27445..83611fe3f 100644 --- a/custom/plugins/example/example.plugin.zsh +++ b/custom/plugins/example/example.plugin.zsh @@ -1,2 +1,3 @@ # Add your own custom plugins in the custom/plugins directory. Plugins placed # here will override ones with the same name in the main plugins directory. +# See: https://github.com/ohmyzsh/ohmyzsh/wiki/Customization#overriding-and-adding-plugins diff --git a/custom/themes/example.zsh-theme b/custom/themes/example.zsh-theme index ef8f1c630..494d029e8 100644 --- a/custom/themes/example.zsh-theme +++ b/custom/themes/example.zsh-theme @@ -1,4 +1,6 @@ # Put your custom themes in this folder. +# See: https://github.com/ohmyzsh/ohmyzsh/wiki/Customization#overriding-and-adding-themes +# # Example: PROMPT="%{$fg[red]%}%n%{$reset_color%}@%{$fg[blue]%}%m %{$fg[yellow]%}%~ %{$reset_color%}%% " From b36c90d9abd2fd2ffe53d19b11e47077dfdb38a8 Mon Sep 17 00:00:00 2001 From: Diego Costa R <62116423+diegocostares@users.noreply.github.com> Date: Mon, 5 Jun 2023 04:25:17 -0400 Subject: [PATCH 288/672] feat(autoenv): macOS compatibility, add more dirs (#11724) Co-authored-by: Carlo Sala --- plugins/autoenv/autoenv.plugin.zsh | 16 ++++++++++++---- 1 file changed, 12 insertions(+), 4 deletions(-) diff --git a/plugins/autoenv/autoenv.plugin.zsh b/plugins/autoenv/autoenv.plugin.zsh index 229a8a834..cbf7cefbb 100644 --- a/plugins/autoenv/autoenv.plugin.zsh +++ b/plugins/autoenv/autoenv.plugin.zsh @@ -17,9 +17,13 @@ if ! type autoenv_init >/dev/null; then /usr/local/bin /usr/share/autoenv-git ~/Library/Python/bin + .venv/bin + venv/bin + env/bin + .env/bin ) for d ( $install_locations ); do - if [[ -e $d/activate.sh ]]; then + if [[ -e $d/activate || -e $d/activate.sh ]]; then autoenv_dir=$d break fi @@ -29,13 +33,13 @@ if ! type autoenv_init >/dev/null; then # Look for Homebrew path as a last resort if [[ -z "$autoenv_dir" ]] && (( $+commands[brew] )); then d=$(brew --prefix)/opt/autoenv - if [[ -e $d/activate.sh ]]; then + if [[ -e $d/activate || -e $d/activate.sh ]]; then autoenv_dir=$d fi fi # Complain if autoenv is not installed - if [[ -z $autoenv_dir ]]; then + if [[ -z $autoenv_dir ]]; then cat <&2 -------- AUTOENV --------- Could not locate autoenv installation. @@ -46,7 +50,11 @@ END return 1 fi # Load autoenv - source $autoenv_dir/activate.sh + if [[ -e $autoenv_dir/activate ]]; + source $autoenv_dir/activate + else + source $autoenv_dir/activate.sh + fi fi } [[ $? != 0 ]] && return $? From d1c64bfda30ad56bac09f11c920b93b94dab7f9f Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Mon, 5 Jun 2023 10:26:36 +0200 Subject: [PATCH 289/672] fix(autoenv): typo --- plugins/autoenv/autoenv.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/autoenv/autoenv.plugin.zsh b/plugins/autoenv/autoenv.plugin.zsh index cbf7cefbb..2f84f0acf 100644 --- a/plugins/autoenv/autoenv.plugin.zsh +++ b/plugins/autoenv/autoenv.plugin.zsh @@ -50,7 +50,7 @@ END return 1 fi # Load autoenv - if [[ -e $autoenv_dir/activate ]]; + if [[ -e $autoenv_dir/activate ]]; then source $autoenv_dir/activate else source $autoenv_dir/activate.sh From 115cee17015e4b5665e16dc4fd15c53e06a22f9a Mon Sep 17 00:00:00 2001 From: Ihor Date: Mon, 5 Jun 2023 10:38:54 +0200 Subject: [PATCH 290/672] feat(git): add `gunwipall` function (#11725) Co-authored-by: Carlo Sala --- plugins/git/README.md | 1 + plugins/git/git.plugin.zsh | 14 ++++++++++++++ 2 files changed, 15 insertions(+) diff --git a/plugins/git/README.md b/plugins/git/README.md index 2742aa539..bf4b19f39 100644 --- a/plugins/git/README.md +++ b/plugins/git/README.md @@ -254,6 +254,7 @@ These features allow to pause a branch development and switch to another one (_" | work_in_progress | Echoes a warning if the current branch is a wip | | gwip | Commit wip branch | | gunwip | Uncommit wip branch | +| gunwipall | Uncommit `--wip--` commits recursively | ### Deprecated functions diff --git a/plugins/git/git.plugin.zsh b/plugins/git/git.plugin.zsh index 4be865f6a..192124301 100644 --- a/plugins/git/git.plugin.zsh +++ b/plugins/git/git.plugin.zsh @@ -27,6 +27,20 @@ function work_in_progress() { command git -c log.showSignature=false log -n 1 2>/dev/null | grep -q -- "--wip--" && echo "WIP!!" } +# Same as `gunwip` but recursive +# "Unwips" all recent `--wip--` commits in loop until there is no left +function gunwipall() { + while true; do + commit_message=$(git rev-list --max-count=1 --format="%s" HEAD) + if [[ $commit_message =~ "--wip--" ]]; then + git reset "HEAD~1" + (( $? )) && return 1 + else + break + fi + done +} + # Check if main exists and use instead of master function git_main_branch() { command git rev-parse --git-dir &>/dev/null || return From 46c70406dd0b26bbd61210873ad6c86d9e8ee5da Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Wed, 7 Jun 2023 18:43:47 +0200 Subject: [PATCH 291/672] feat(nvm): add `npx` to lazy trigger list Closes #11740 --- plugins/nvm/README.md | 2 +- plugins/nvm/nvm.plugin.zsh | 4 ++-- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/plugins/nvm/README.md b/plugins/nvm/README.md index d3fd980be..6830c14d0 100644 --- a/plugins/nvm/README.md +++ b/plugins/nvm/README.md @@ -26,7 +26,7 @@ These settings should go in your zshrc file, before Oh My Zsh is sourced: #### Lazy startup This option will help you to defer nvm's load until you use it to speed-up your zsh startup. This will source -nvm script only when using it, and will create a function for `node`, `npm`, `pnpm`, `yarn`, and the +nvm script only when using it, and will create a function for `node`, `npm`, `npx`, `pnpm`, `yarn`, and the command(s) specified by `lazy-cmd` option, so when you call either of them, nvm will be loaded and run with default version. To enable it, you can add this snippet to your zshrc, before Oh My Zsh is sourced: diff --git a/plugins/nvm/nvm.plugin.zsh b/plugins/nvm/nvm.plugin.zsh index 20697d67d..31d275415 100644 --- a/plugins/nvm/nvm.plugin.zsh +++ b/plugins/nvm/nvm.plugin.zsh @@ -43,8 +43,8 @@ if zstyle -t ':omz:plugins:nvm' lazy; then # Call nvm when first using nvm, node, npm, pnpm, yarn or other commands in lazy-cmd zstyle -a ':omz:plugins:nvm' lazy-cmd nvm_lazy_cmd eval " - function nvm node npm pnpm yarn $nvm_lazy_cmd { - unfunction nvm node npm pnpm yarn $nvm_lazy_cmd + function nvm node npm npx pnpm yarn $nvm_lazy_cmd { + unfunction nvm node npm npx pnpm yarn $nvm_lazy_cmd # Load nvm if it exists in \$NVM_DIR [[ -f \"\$NVM_DIR/nvm.sh\" ]] && source \"\$NVM_DIR/nvm.sh\" \"\$0\" \"\$@\" From 50c678687e73d1433f278b7bb7f168e8fa817670 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Thu, 8 Jun 2023 18:47:05 +0200 Subject: [PATCH 292/672] fix(termsupport): fix pwd report for Konsole (#11730) The Konsole terminal shows an error if the host is provided in the OSC 7 sequence. Fixes #11730 --- lib/termsupport.zsh | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/lib/termsupport.zsh b/lib/termsupport.zsh index cf8f08741..145982705 100644 --- a/lib/termsupport.zsh +++ b/lib/termsupport.zsh @@ -150,8 +150,11 @@ function omz_termsupport_cwd { URL_HOST="$(omz_urlencode -P $HOST)" || return 1 URL_PATH="$(omz_urlencode -P $PWD)" || return 1 + # Konsole errors if the HOST is provided + [[ -z "$KONSOLE_VERSION" ]] || URL_HOST="" + # common control sequence (OSC 7) to set current host and path - printf "\e]7;%s\a" "file://${URL_HOST}${URL_PATH}" + printf "\e]7;file://%s%s\e\\" "${URL_HOST}" "${URL_PATH}" } # Use a precmd hook instead of a chpwd hook to avoid contaminating output From cb8b677488c7a20278917af58dfccd72cd40e1b1 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Sun, 11 Jun 2023 17:02:48 +0200 Subject: [PATCH 293/672] fix(termsupport): don't report current working directory in SSH sessions (#11703) --- lib/termsupport.zsh | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/lib/termsupport.zsh b/lib/termsupport.zsh index 145982705..6d969503d 100644 --- a/lib/termsupport.zsh +++ b/lib/termsupport.zsh @@ -121,8 +121,8 @@ fi # # As of May 2021 mlterm, PuTTY, rxvt, screen, termux & xterm simply ignore the unknown OSC. -# Don't define the function if we're inside Emacs -if [[ -n "$INSIDE_EMACS" ]]; then +# Don't define the function if we're inside Emacs or in an SSH session (#11696) +if [[ -n "$INSIDE_EMACS" || -n "$SSH_CLIENT" || -n "$SSH_TTY" ]]; then return fi From 14f0f2971f42952e2eb78fdc2535538e98323b2b Mon Sep 17 00:00:00 2001 From: Oleg Voronkovich Date: Thu, 15 Jun 2023 12:01:02 +0300 Subject: [PATCH 294/672] feat(brew): autoconfigure completions (#11152) --- plugins/brew/README.md | 2 ++ plugins/brew/brew.plugin.zsh | 4 ++++ 2 files changed, 6 insertions(+) diff --git a/plugins/brew/README.md b/plugins/brew/README.md index 412daae63..4730194bc 100644 --- a/plugins/brew/README.md +++ b/plugins/brew/README.md @@ -33,6 +33,8 @@ defined for convenience. ## Completion +This plugin configures paths with Homebrew's completion functions automatically, so you don't need to do it manually. See: https://docs.brew.sh/Shell-Completion#configuring-completions-in-zsh. + With the release of Homebrew 1.0, they decided to bundle the zsh completion as part of the brew installation, so we no longer ship it with the brew plugin; now it only has brew aliases. If you find that brew completion no longer works, make sure you have your Homebrew diff --git a/plugins/brew/brew.plugin.zsh b/plugins/brew/brew.plugin.zsh index f6abe0875..b52664a39 100644 --- a/plugins/brew/brew.plugin.zsh +++ b/plugins/brew/brew.plugin.zsh @@ -25,6 +25,10 @@ if [[ -z "$HOMEBREW_PREFIX" ]]; then export HOMEBREW_PREFIX="$(brew --prefix)" fi +if [[ -d "$HOMEBREW_PREFIX/share/zsh/site-functions" ]]; then + fpath+=("$HOMEBREW_PREFIX/share/zsh/site-functions") +fi + alias bcubc='brew upgrade --cask && brew cleanup' alias bcubo='brew update && brew outdated --cask' alias bcubc='brew upgrade --cask && brew cleanup' From b1b3a020ecb1b4b322efbf8e08ad7fb55e2e687a Mon Sep 17 00:00:00 2001 From: Josh Powell Date: Thu, 15 Jun 2023 05:03:45 -0400 Subject: [PATCH 295/672] feat(rails): add some aliases (#11739) --- plugins/rails/README.md | 5 ++++- plugins/rails/rails.plugin.zsh | 5 ++++- 2 files changed, 8 insertions(+), 2 deletions(-) diff --git a/plugins/rails/README.md b/plugins/rails/README.md index b2425aabc..c0c37ff3d 100644 --- a/plugins/rails/README.md +++ b/plugins/rails/README.md @@ -40,7 +40,10 @@ plugins=(... rails) | `rn` | `rails notes` | Search for notes (`FIXME`, `TODO`) in code comments | | `rp` | `rails plugin` | Run a Rails plugin command | | `rr` | `rails routes` | List all defined routes | -| `rrg` | `rails routes \| grep` | List and filter the defined routes | +| `rrc` | `rails routes --controller` | List and filter routes mapped to specific controller | +| `rre` | `rails routes --expanded` | List all defined routes in expanded table mode | +| `rrg` | `rails routes --grep` | List and filter the defined routes | +| `rru` | `rails routes --unused` | List unused routes | | `rs` | `rails server` | Launch a web server | | `rsb` | `rails server --bind` | Launch a web server binding it to a specific IP | | `rsd` | `rails server --debugger` | Launch a web server with debugger | diff --git a/plugins/rails/rails.plugin.zsh b/plugins/rails/rails.plugin.zsh index 015dc9ecb..75dd9b0c6 100644 --- a/plugins/rails/rails.plugin.zsh +++ b/plugins/rails/rails.plugin.zsh @@ -68,7 +68,10 @@ alias rmd='rails middleware' alias rn='rails notes' alias rp='rails plugin' alias rr='rails routes' -alias rrg='rails routes | grep' +alias rrc='rails routes --controller' +alias rre='rails routes --expanded' +alias rrg='rails routes --grep' +alias rru='rails routes --unused' alias rs='rails server' alias rsb='rails server --bind' alias rsd='rails server --debugger' From 68f3ebb4de11aa2013ccc5252d4415840e0d7342 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Thu, 15 Jun 2023 11:16:25 +0200 Subject: [PATCH 296/672] feat(docker): generate completion function Closes #10825 Closes #10912 Closes #11751 --- plugins/docker/_docker | 3123 ------------------------------ plugins/docker/docker.plugin.zsh | 10 + 2 files changed, 10 insertions(+), 3123 deletions(-) delete mode 100644 plugins/docker/_docker diff --git a/plugins/docker/_docker b/plugins/docker/_docker deleted file mode 100644 index e6a12d774..000000000 --- a/plugins/docker/_docker +++ /dev/null @@ -1,3123 +0,0 @@ -#compdef docker dockerd -# -# zsh completion for docker (http://docker.com) -# -# version: 0.3.0 -# github: https://github.com/felixr/docker-zsh-completion -# -# contributors: -# - Felix Riedel -# - Steve Durrheimer -# - Vincent Bernat -# - Rohan Verma -# -# license: -# -# Copyright (c) 2013, Felix Riedel -# All rights reserved. -# -# Redistribution and use in source and binary forms, with or without -# modification, are permitted provided that the following conditions are met: -# * Redistributions of source code must retain the above copyright -# notice, this list of conditions and the following disclaimer. -# * Redistributions in binary form must reproduce the above copyright -# notice, this list of conditions and the following disclaimer in the -# documentation and/or other materials provided with the distribution. -# * Neither the name of the nor the -# names of its contributors may be used to endorse or promote products -# derived from this software without specific prior written permission. -# -# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND -# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED -# WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE -# DISCLAIMED. IN NO EVENT SHALL BE LIABLE FOR ANY -# DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES -# (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; -# LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND -# ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS -# SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -# - -# Short-option stacking can be enabled with: -# zstyle ':completion:*:*:docker:*' option-stacking yes -# zstyle ':completion:*:*:docker-*:*' option-stacking yes -__docker_arguments() { - if zstyle -t ":completion:${curcontext}:" option-stacking; then - print -- -s - fi -} - -__docker_get_containers() { - [[ $PREFIX = -* ]] && return 1 - integer ret=1 - local kind type line s - declare -a running stopped lines args names - - kind=$1; shift - type=$1; shift - [[ $kind = (stopped|all) ]] && args=($args -a) - - lines=(${(f)${:-"$(_call_program commands docker $docker_options ps --format 'table' --no-trunc $args)"$'\n'}}) - - # Parse header line to find columns - local i=1 j=1 k header=${lines[1]} - declare -A begin end - while (( j < ${#header} - 1 )); do - i=$(( j + ${${header[$j,-1]}[(i)[^ ]]} - 1 )) - j=$(( i + ${${header[$i,-1]}[(i) ]} - 1 )) - k=$(( j + ${${header[$j,-1]}[(i)[^ ]]} - 2 )) - begin[${header[$i,$((j-1))]}]=$i - end[${header[$i,$((j-1))]}]=$k - done - end[${header[$i,$((j-1))]}]=-1 # Last column, should go to the end of the line - lines=(${lines[2,-1]}) - - # Container ID - if [[ $type = (ids|all) ]]; then - for line in $lines; do - s="${${line[${begin[CONTAINER ID]},${end[CONTAINER ID]}]%% ##}[0,12]}" - s="$s:${(l:15:: :::)${${line[${begin[CREATED]},${end[CREATED]}]/ ago/}%% ##}}" - s="$s, ${${${line[${begin[IMAGE]},${end[IMAGE]}]}/:/\\:}%% ##}" - if [[ ${line[${begin[STATUS]},${end[STATUS]}]} = (Exit*|Created*) ]]; then - stopped=($stopped $s) - else - running=($running $s) - fi - done - fi - - # Names: we only display the one without slash. All other names - # are generated and may clutter the completion. However, with - # Swarm, all names may be prefixed by the swarm node name. - if [[ $type = (names|all) ]]; then - for line in $lines; do - names=(${(ps:,:)${${line[${begin[NAMES]},${end[NAMES]}]}%% *}}) - # First step: find a common prefix and strip it (swarm node case) - (( ${#${(u)names%%/*}} == 1 )) && names=${names#${names[1]%%/*}/} - # Second step: only keep the first name without a / - s=${${names:#*/*}[1]} - # If no name, well give up. - (( $#s != 0 )) || continue - s="$s:${(l:15:: :::)${${line[${begin[CREATED]},${end[CREATED]}]/ ago/}%% ##}}" - s="$s, ${${${line[${begin[IMAGE]},${end[IMAGE]}]}/:/\\:}%% ##}" - if [[ ${line[${begin[STATUS]},${end[STATUS]}]} = (Exit*|Created*) ]]; then - stopped=($stopped $s) - else - running=($running $s) - fi - done - fi - - [[ $kind = (running|all) ]] && _describe -t containers-running "running containers" running "$@" && ret=0 - [[ $kind = (stopped|all) ]] && _describe -t containers-stopped "stopped containers" stopped "$@" && ret=0 - return ret -} - -__docker_complete_stopped_containers() { - [[ $PREFIX = -* ]] && return 1 - __docker_get_containers stopped all "$@" -} - -__docker_complete_running_containers() { - [[ $PREFIX = -* ]] && return 1 - __docker_get_containers running all "$@" -} - -__docker_complete_containers() { - [[ $PREFIX = -* ]] && return 1 - __docker_get_containers all all "$@" -} - -__docker_complete_containers_ids() { - [[ $PREFIX = -* ]] && return 1 - __docker_get_containers all ids "$@" -} - -__docker_complete_containers_names() { - [[ $PREFIX = -* ]] && return 1 - __docker_get_containers all names "$@" -} - -__docker_complete_info_plugins() { - [[ $PREFIX = -* ]] && return 1 - integer ret=1 - emulate -L zsh - setopt extendedglob - local -a plugins - plugins=(${(ps: :)${(M)${(f)${${"$(_call_program commands docker $docker_options info)"##*$'\n'Plugins:}%%$'\n'^ *}}:# $1: *}## $1: }) - _describe -t plugins "$1 plugins" plugins && ret=0 - return ret -} - -__docker_complete_images() { - [[ $PREFIX = -* ]] && return 1 - integer ret=1 - declare -a images - images=(${${${(f)${:-"$(_call_program commands docker $docker_options images)"$'\n'}}[2,-1]}/(#b)([^ ]##) ##([^ ]##) ##([^ ]##)*/${match[3]}:${(r:15:: :::)match[2]} in ${match[1]}}) - _describe -t docker-images "images" images && ret=0 - __docker_complete_repositories_with_tags && ret=0 - return ret -} - -__docker_complete_repositories() { - [[ $PREFIX = -* ]] && return 1 - integer ret=1 - declare -a repos - repos=(${${${(f)${:-"$(_call_program commands docker $docker_options images)"$'\n'}}%% *}[2,-1]}) - repos=(${repos#}) - _describe -t docker-repos "repositories" repos && ret=0 - return ret -} - -__docker_complete_repositories_with_tags() { - [[ $PREFIX = -* ]] && return 1 - integer ret=1 - declare -a repos onlyrepos matched - declare m - repos=(${${${${(f)${:-"$(_call_program commands docker $docker_options images)"$'\n'}}[2,-1]}/ ##/:::}%% *}) - repos=(${${repos%:::}#}) - # Check if we have a prefix-match for the current prefix. - onlyrepos=(${repos%::*}) - for m in $onlyrepos; do - [[ ${PREFIX##${~~m}} != ${PREFIX} ]] && { - # Yes, complete with tags - repos=(${${repos/:::/:}/:/\\:}) - _describe -t docker-repos-with-tags "repositories with tags" repos && ret=0 - return ret - } - done - # No, only complete repositories - onlyrepos=(${${repos%:::*}/:/\\:}) - _describe -t docker-repos "repositories" onlyrepos -qS : && ret=0 - - return ret -} - -__docker_search() { - [[ $PREFIX = -* ]] && return 1 - local cache_policy - zstyle -s ":completion:${curcontext}:" cache-policy cache_policy - if [[ -z "$cache_policy" ]]; then - zstyle ":completion:${curcontext}:" cache-policy __docker_caching_policy - fi - - local searchterm cachename - searchterm="${words[$CURRENT]%/}" - cachename=_docker-search-$searchterm - - local expl - local -a result - if ( [[ ${(P)+cachename} -eq 0 ]] || _cache_invalid ${cachename#_} ) \ - && ! _retrieve_cache ${cachename#_}; then - _message "Searching for ${searchterm}..." - result=(${${${(f)${:-"$(_call_program commands docker $docker_options search $searchterm)"$'\n'}}%% *}[2,-1]}) - _store_cache ${cachename#_} result - fi - _wanted dockersearch expl 'available images' compadd -a result -} - -__docker_get_log_options() { - [[ $PREFIX = -* ]] && return 1 - - integer ret=1 - local log_driver=${opt_args[--log-driver]:-"all"} - local -a common_options common_options2 awslogs_options fluentd_options gelf_options journald_options json_file_options logentries_options syslog_options splunk_options - - common_options=("max-buffer-size" "mode") - common_options2=("env" "env-regex" "labels") - awslogs_options=($common_options "awslogs-create-group" "awslogs-datetime-format" "awslogs-group" "awslogs-multiline-pattern" "awslogs-region" "awslogs-stream" "tag") - fluentd_options=($common_options $common_options2 "fluentd-address" "fluentd-async-connect" "fluentd-buffer-limit" "fluentd-retry-wait" "fluentd-max-retries" "fluentd-sub-second-precision" "tag") - gcplogs_options=($common_options $common_options2 "gcp-log-cmd" "gcp-meta-id" "gcp-meta-name" "gcp-meta-zone" "gcp-project") - gelf_options=($common_options $common_options2 "gelf-address" "gelf-compression-level" "gelf-compression-type" "tag") - journald_options=($common_options $common_options2 "tag") - json_file_options=($common_options $common_options2 "max-file" "max-size") - logentries_options=($common_options $common_options2 "logentries-token" "tag") - syslog_options=($common_options $common_options2 "syslog-address" "syslog-facility" "syslog-format" "syslog-tls-ca-cert" "syslog-tls-cert" "syslog-tls-key" "syslog-tls-skip-verify" "tag") - splunk_options=($common_options $common_options2 "splunk-caname" "splunk-capath" "splunk-format" "splunk-gzip" "splunk-gzip-level" "splunk-index" "splunk-insecureskipverify" "splunk-source" "splunk-sourcetype" "splunk-token" "splunk-url" "splunk-verify-connection" "tag") - - [[ $log_driver = (awslogs|all) ]] && _describe -t awslogs-options "awslogs options" awslogs_options "$@" && ret=0 - [[ $log_driver = (fluentd|all) ]] && _describe -t fluentd-options "fluentd options" fluentd_options "$@" && ret=0 - [[ $log_driver = (gcplogs|all) ]] && _describe -t gcplogs-options "gcplogs options" gcplogs_options "$@" && ret=0 - [[ $log_driver = (gelf|all) ]] && _describe -t gelf-options "gelf options" gelf_options "$@" && ret=0 - [[ $log_driver = (journald|all) ]] && _describe -t journald-options "journald options" journald_options "$@" && ret=0 - [[ $log_driver = (json-file|all) ]] && _describe -t json-file-options "json-file options" json_file_options "$@" && ret=0 - [[ $log_driver = (logentries|all) ]] && _describe -t logentries-options "logentries options" logentries_options "$@" && ret=0 - [[ $log_driver = (syslog|all) ]] && _describe -t syslog-options "syslog options" syslog_options "$@" && ret=0 - [[ $log_driver = (splunk|all) ]] && _describe -t splunk-options "splunk options" splunk_options "$@" && ret=0 - - return ret -} - -__docker_complete_log_drivers() { - [[ $PREFIX = -* ]] && return 1 - integer ret=1 - drivers=(awslogs etwlogs fluentd gcplogs gelf journald json-file none splunk syslog) - _describe -t log-drivers "log drivers" drivers && ret=0 - return ret -} - -__docker_complete_log_options() { - [[ $PREFIX = -* ]] && return 1 - integer ret=1 - - if compset -P '*='; then - case "${${words[-1]%=*}#*=}" in - (syslog-format) - local opts=('rfc3164' 'rfc5424' 'rfc5424micro') - _describe -t syslog-format-opts "syslog format options" opts && ret=0 - ;; - (mode) - local opts=('blocking' 'non-blocking') - _describe -t mode-opts "mode options" opts && ret=0 - ;; - *) - _message 'value' && ret=0 - ;; - esac - else - __docker_get_log_options -qS "=" && ret=0 - fi - - return ret -} - -__docker_complete_detach_keys() { - [[ $PREFIX = -* ]] && return 1 - integer ret=1 - - compset -P "*," - keys=(${:-{a-z}}) - ctrl_keys=(${:-ctrl-{{a-z},{@,'[','\\','^',']',_}}}) - _describe -t detach_keys "[a-z]" keys -qS "," && ret=0 - _describe -t detach_keys-ctrl "'ctrl-' + 'a-z @ [ \\\\ ] ^ _'" ctrl_keys -qS "," && ret=0 -} - -__docker_complete_pid() { - [[ $PREFIX = -* ]] && return 1 - integer ret=1 - local -a opts vopts - - opts=('host') - vopts=('container') - - if compset -P '*:'; then - case "${${words[-1]%:*}#*=}" in - (container) - __docker_complete_running_containers && ret=0 - ;; - *) - _message 'value' && ret=0 - ;; - esac - else - _describe -t pid-value-opts "PID Options with value" vopts -qS ":" && ret=0 - _describe -t pid-opts "PID Options" opts && ret=0 - fi - - return ret -} - -__docker_complete_runtimes() { - [[ $PREFIX = -* ]] && return 1 - integer ret=1 - - emulate -L zsh - setopt extendedglob - local -a runtimes_opts - runtimes_opts=(${(ps: :)${(f)${${"$(_call_program commands docker $docker_options info)"##*$'\n'Runtimes: }%%$'\n'^ *}}}) - _describe -t runtimes-opts "runtimes options" runtimes_opts && ret=0 -} - -__docker_complete_ps_filters() { - [[ $PREFIX = -* ]] && return 1 - integer ret=1 - - if compset -P '*='; then - case "${${words[-1]%=*}#*=}" in - (ancestor) - __docker_complete_images && ret=0 - ;; - (before|since) - __docker_complete_containers && ret=0 - ;; - (health) - health_opts=('healthy' 'none' 'starting' 'unhealthy') - _describe -t health-filter-opts "health filter options" health_opts && ret=0 - ;; - (id) - __docker_complete_containers_ids && ret=0 - ;; - (is-task) - _describe -t boolean-filter-opts "filter options" boolean_opts && ret=0 - ;; - (name) - __docker_complete_containers_names && ret=0 - ;; - (network) - __docker_complete_networks && ret=0 - ;; - (status) - status_opts=('created' 'dead' 'exited' 'paused' 'restarting' 'running' 'removing') - _describe -t status-filter-opts "status filter options" status_opts && ret=0 - ;; - (volume) - __docker_complete_volumes && ret=0 - ;; - *) - _message 'value' && ret=0 - ;; - esac - else - opts=('ancestor' 'before' 'exited' 'expose' 'health' 'id' 'label' 'name' 'network' 'publish' 'since' 'status' 'volume') - _describe -t filter-opts "Filter Options" opts -qS "=" && ret=0 - fi - - return ret -} - -__docker_complete_search_filters() { - [[ $PREFIX = -* ]] && return 1 - integer ret=1 - declare -a boolean_opts opts - - boolean_opts=('true' 'false') - opts=('is-automated' 'is-official' 'stars') - - if compset -P '*='; then - case "${${words[-1]%=*}#*=}" in - (is-automated|is-official) - _describe -t boolean-filter-opts "filter options" boolean_opts && ret=0 - ;; - *) - _message 'value' && ret=0 - ;; - esac - else - _describe -t filter-opts "filter options" opts -qS "=" && ret=0 - fi - - return ret -} - -__docker_complete_images_filters() { - [[ $PREFIX = -* ]] && return 1 - integer ret=1 - declare -a boolean_opts opts - - boolean_opts=('true' 'false') - opts=('before' 'dangling' 'label' 'reference' 'since') - - if compset -P '*='; then - case "${${words[-1]%=*}#*=}" in - (before|reference|since) - __docker_complete_images && ret=0 - ;; - (dangling) - _describe -t boolean-filter-opts "filter options" boolean_opts && ret=0 - ;; - *) - _message 'value' && ret=0 - ;; - esac - else - _describe -t filter-opts "Filter Options" opts -qS "=" && ret=0 - fi - - return ret -} - -__docker_complete_events_filter() { - [[ $PREFIX = -* ]] && return 1 - integer ret=1 - declare -a opts - - opts=('container' 'daemon' 'event' 'image' 'label' 'network' 'scope' 'type' 'volume') - - if compset -P '*='; then - case "${${words[-1]%=*}#*=}" in - (container) - __docker_complete_containers && ret=0 - ;; - (daemon) - emulate -L zsh - setopt extendedglob - local -a daemon_opts - daemon_opts=( - ${(f)${${"$(_call_program commands docker $docker_options info)"##*$'\n'Name: }%%$'\n'^ *}} - ${${(f)${${"$(_call_program commands docker $docker_options info)"##*$'\n'ID: }%%$'\n'^ *}}//:/\\:} - ) - _describe -t daemon-filter-opts "daemon filter options" daemon_opts && ret=0 - ;; - (event) - local -a event_opts - event_opts=('attach' 'commit' 'connect' 'copy' 'create' 'delete' 'destroy' 'detach' 'die' 'disable' 'disconnect' 'enable' 'exec_create' 'exec_detach' - 'exec_start' 'export' 'health_status' 'import' 'install' 'kill' 'load' 'mount' 'oom' 'pause' 'pull' 'push' 'reload' 'remove' 'rename' 'resize' - 'restart' 'save' 'start' 'stop' 'tag' 'top' 'unmount' 'unpause' 'untag' 'update') - _describe -t event-filter-opts "event filter options" event_opts && ret=0 - ;; - (image) - __docker_complete_images && ret=0 - ;; - (network) - __docker_complete_networks && ret=0 - ;; - (scope) - local -a scope_opts - scope_opts=('local' 'swarm') - _describe -t scope-filter-opts "scope filter options" scope_opts && ret=0 - ;; - (type) - local -a type_opts - type_opts=('container' 'daemon' 'image' 'network' 'volume') - _describe -t type-filter-opts "type filter options" type_opts && ret=0 - ;; - (volume) - __docker_complete_volumes && ret=0 - ;; - *) - _message 'value' && ret=0 - ;; - esac - else - _describe -t filter-opts "filter options" opts -qS "=" && ret=0 - fi - - return ret -} - -__docker_complete_prune_filters() { - [[ $PREFIX = -* ]] && return 1 - integer ret=1 - declare -a opts - - opts=('until') - - if compset -P '*='; then - case "${${words[-1]%=*}#*=}" in - *) - _message 'value' && ret=0 - ;; - esac - else - _describe -t filter-opts "filter options" opts -qS "=" && ret=0 - fi - - return ret -} - -# BO checkpoint - -__docker_checkpoint_commands() { - local -a _docker_checkpoint_subcommands - _docker_checkpoint_subcommands=( - "create:Create a checkpoint from a running container" - "ls:List checkpoints for a container" - "rm:Remove a checkpoint" - ) - _describe -t docker-checkpoint-commands "docker checkpoint command" _docker_checkpoint_subcommands -} - -__docker_checkpoint_subcommand() { - local -a _command_args opts_help - local expl help="--help" - integer ret=1 - - opts_help=("(: -)--help[Print usage]") - - case "$words[1]" in - (create) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help)--checkpoint-dir=[Use a custom checkpoint storage directory]:dir:_directories" \ - "($help)--leave-running[Leave the container running after checkpoint]" \ - "($help -)1:container:__docker_complete_running_containers" \ - "($help -)2:checkpoint: " && ret=0 - ;; - (ls|list) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help)--checkpoint-dir=[Use a custom checkpoint storage directory]:dir:_directories" \ - "($help -)1:container:__docker_complete_containers" && ret=0 - ;; - (rm|remove) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help)--checkpoint-dir=[Use a custom checkpoint storage directory]:dir:_directories" \ - "($help -)1:container:__docker_complete_containers" \ - "($help -)2:checkpoint: " && ret=0 - ;; - (help) - _arguments $(__docker_arguments) ":subcommand:__docker_checkpoint_commands" && ret=0 - ;; - esac - - return ret -} - -# EO checkpoint - -# BO container - -__docker_container_commands() { - local -a _docker_container_subcommands - _docker_container_subcommands=( - "attach:Attach to a running container" - "commit:Create a new image from a container's changes" - "cp:Copy files/folders between a container and the local filesystem" - "create:Create a new container" - "diff:Inspect changes on a container's filesystem" - "exec:Execute a command in a running container" - "export:Export a container's filesystem as a tar archive" - "inspect:Display detailed information on one or more containers" - "kill:Kill one or more running containers" - "logs:Fetch the logs of a container" - "ls:List containers" - "pause:Pause all processes within one or more containers" - "port:List port mappings or a specific mapping for the container" - "prune:Remove all stopped containers" - "rename:Rename a container" - "restart:Restart one or more containers" - "rm:Remove one or more containers" - "run:Create and run a new container from an image" - "start:Start one or more stopped containers" - "stats:Display a live stream of container(s) resource usage statistics" - "stop:Stop one or more running containers" - "top:Display the running processes of a container" - "unpause:Unpause all processes within one or more containers" - "update:Update configuration of one or more containers" - "wait:Block until one or more containers stop, then print their exit codes" - ) - _describe -t docker-container-commands "docker container command" _docker_container_subcommands -} - -__docker_container_subcommand() { - local -a _command_args opts_help opts_attach_exec_run_start opts_create_run opts_create_run_update - local expl help="--help" - integer ret=1 - - opts_attach_exec_run_start=( - "($help)--detach-keys=[Escape key sequence used to detach a container]:sequence:__docker_complete_detach_keys" - ) - opts_create_run=( - "($help -a --attach)"{-a=,--attach=}"[Attach to stdin, stdout or stderr]:device:(STDIN STDOUT STDERR)" - "($help)*--add-host=[Add a custom host-to-IP mapping]:host\:ip mapping: " - "($help)*--blkio-weight-device=[Block IO (relative device weight)]:device:Block IO weight: " - "($help)*--cap-add=[Add Linux capabilities]:capability: " - "($help)*--cap-drop=[Drop Linux capabilities]:capability: " - "($help)--cgroupns=[Cgroup namespace mode to use]:cgroup namespace mode: " - "($help)--cgroup-parent=[Parent cgroup for the container]:cgroup: " - "($help)--cidfile=[Write the container ID to the file]:CID file:_files" - "($help)--cpus=[Number of CPUs (default 0.000)]:cpus: " - "($help)*--device=[Add a host device to the container]:device:_files" - "($help)*--device-cgroup-rule=[Add a rule to the cgroup allowed devices list]:device:cgroup: " - "($help)*--device-read-bps=[Limit the read rate (bytes per second) from a device]:device:IO rate: " - "($help)*--device-read-iops=[Limit the read rate (IO per second) from a device]:device:IO rate: " - "($help)*--device-write-bps=[Limit the write rate (bytes per second) to a device]:device:IO rate: " - "($help)*--device-write-iops=[Limit the write rate (IO per second) to a device]:device:IO rate: " - "($help)--disable-content-trust[Skip image verification]" - "($help)*--dns=[Custom DNS servers]:DNS server: " - "($help)*--dns-option=[Custom DNS options]:DNS option: " - "($help)*--dns-search=[Custom DNS search domains]:DNS domains: " - "($help)*--domainname=[Container NIS domain name]:domainname:_hosts" - "($help)*"{-e=,--env=}"[Environment variables]:environment variable: " - "($help)--entrypoint=[Overwrite the default entrypoint of the image]:entry point: " - "($help)*--env-file=[Read environment variables from a file]:environment file:_files" - "($help)*--expose=[Expose a port from the container without publishing it]: " - "($help)*--gpus=[GPU devices to add to the container ('all' to pass all GPUs)]:device: " - "($help)*--group-add=[Set one or more supplementary user groups for the container]:group:_groups" - "($help -h --hostname)"{-h=,--hostname=}"[Container host name]:hostname:_hosts" - "($help -i --interactive)"{-i,--interactive}"[Keep stdin open even if not attached]" - "($help)--init[Run an init inside the container that forwards signals and reaps processes]" - "($help)--ip=[IPv4 address]:IPv4: " - "($help)--ip6=[IPv6 address]:IPv6: " - "($help)--ipc=[IPC namespace to use]:IPC namespace: " - "($help)--isolation=[Container isolation technology]:isolation:(default hyperv process)" - "($help)*--link=[Add link to another container]:link:->link" - "($help)*--link-local-ip=[Container IPv4/IPv6 link-local addresses]:IPv4/IPv6: " - "($help)*"{-l=,--label=}"[Container metadata]:label: " - "($help)--log-driver=[Default driver for container logs]:logging driver:__docker_complete_log_drivers" - "($help)*--log-opt=[Log driver specific options]:log driver options:__docker_complete_log_options" - "($help)--mac-address=[Container MAC address]:MAC address: " - "($help)*--mount=[Attach a filesystem mount to the container]:mount: " - "($help)--name=[Container name]:name: " - "($help)--network=[Connect a container to a network]:network mode:(bridge none container host)" - "($help)*--network-alias=[Add network-scoped alias for the container]:alias: " - "($help)--oom-kill-disable[Disable OOM Killer]" - "($help)--oom-score-adj[Tune the host's OOM preferences for containers (accepts -1000 to 1000)]" - "($help)--pids-limit[Tune container pids limit (set -1 for unlimited)]" - "($help -P --publish-all)"{-P,--publish-all}"[Publish all exposed ports]" - "($help)*"{-p=,--publish=}"[Expose a container's port to the host]:port:_ports" - "($help)--pid=[PID namespace to use]:PID namespace:__docker_complete_pid" - "($help)--privileged[Give extended privileges to this container]" - "($help -q --quiet)"{-q,--quiet}"[Suppress the pull output]" - "($help)--read-only[Mount the container's root filesystem as read only]" - "($help)*--security-opt=[Security options]:security option: " - "($help)*--shm-size=[Size of '/dev/shm' (format is '')]:shm size: " - "($help)--stop-signal=[Signal to kill a container]:signal:_signals" - "($help)--stop-timeout=[Timeout (in seconds) to stop a container]:time: " - "($help)*--sysctl=-[sysctl options]:sysctl: " - "($help -t --tty)"{-t,--tty}"[Allocate a pseudo-tty]" - "($help -u --user)"{-u=,--user=}"[Username or UID]:user:_users" - "($help)*--ulimit=[ulimit options]:ulimit: " - "($help)--userns=[Container user namespace]:user namespace:(host)" - "($help)--tmpfs[mount tmpfs]" - "($help)*-v[Bind mount a volume]:volume: " - "($help)--volume-driver=[Optional volume driver for the container]:volume driver:(local)" - "($help)*--volumes-from=[Mount volumes from the specified container]:volume: " - "($help -w --workdir)"{-w=,--workdir=}"[Working directory inside the container]:directory:_directories" - ) - opts_create_run_update=( - "($help)--blkio-weight=[Block IO (relative weight), between 10 and 1000]:Block IO weight:(10 100 500 1000)" - "($help -c --cpu-shares)"{-c=,--cpu-shares=}"[CPU shares (relative weight)]:CPU shares:(0 10 100 200 500 800 1000)" - "($help)--cpu-period=[Limit the CPU CFS (Completely Fair Scheduler) period]:CPU period: " - "($help)--cpu-quota=[Limit the CPU CFS (Completely Fair Scheduler) quota]:CPU quota: " - "($help)--cpu-rt-period=[Limit the CPU real-time period]:CPU real-time period in microseconds: " - "($help)--cpu-rt-runtime=[Limit the CPU real-time runtime]:CPU real-time runtime in microseconds: " - "($help)--cpuset-cpus=[CPUs in which to allow execution]:CPUs: " - "($help)--cpuset-mems=[MEMs in which to allow execution]:MEMs: " - "($help)--kernel-memory=[Kernel memory limit in bytes]:Memory limit: " - "($help -m --memory)"{-m=,--memory=}"[Memory limit]:Memory limit: " - "($help)--memory-reservation=[Memory soft limit]:Memory limit: " - "($help)--memory-swap=[Total memory limit with swap]:Memory limit: " - "($help)--pids-limit[Tune container pids limit (set -1 for unlimited)]" - "($help)--restart=[Restart policy]:restart policy:(no on-failure always unless-stopped)" - ) - opts_help=("(: -)--help[Print usage]") - - case "$words[1]" in - (attach) - _arguments $(__docker_arguments) \ - $opts_help \ - $opts_attach_exec_run_start \ - "($help)--no-stdin[Do not attach stdin]" \ - "($help)--sig-proxy[Proxy all received signals to the process (non-TTY mode only)]" \ - "($help -):containers:__docker_complete_running_containers" && ret=0 - ;; - (commit) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -a --author)"{-a=,--author=}"[Author]:author: " \ - "($help)*"{-c=,--change=}"[Apply Dockerfile instruction to the created image]:Dockerfile:_files" \ - "($help -m --message)"{-m=,--message=}"[Commit message]:message: " \ - "($help -p --pause)"{-p,--pause}"[Pause container during commit]" \ - "($help -):container:__docker_complete_containers" \ - "($help -): :__docker_complete_repositories_with_tags" && ret=0 - ;; - (cp) - local state - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -L --follow-link)"{-L,--follow-link}"[Always follow symbol link]" \ - "($help -)1:container:->container" \ - "($help -)2:hostpath:_files" && ret=0 - case $state in - (container) - if compset -P "*:"; then - _files && ret=0 - else - __docker_complete_containers -qS ":" && ret=0 - fi - ;; - esac - ;; - (create) - local state - _arguments $(__docker_arguments) \ - $opts_help \ - $opts_create_run \ - $opts_create_run_update \ - "($help -): :__docker_complete_images" \ - "($help -):command: _command_names -e" \ - "($help -)*::arguments: _normal" && ret=0 - case $state in - (link) - if compset -P "*:"; then - _wanted alias expl "Alias" compadd -E "" && ret=0 - else - __docker_complete_running_containers -qS ":" && ret=0 - fi - ;; - esac - ;; - (diff) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -)*:containers:__docker_complete_containers" && ret=0 - ;; - (exec) - local state - _arguments $(__docker_arguments) \ - $opts_help \ - $opts_attach_exec_run_start \ - "($help -d --detach)"{-d,--detach}"[Detached mode: leave the container running in the background]" \ - "($help)*"{-e=,--env=}"[Set environment variables]:environment variable: " \ - "($help)*--env-file=[Read environment variables from a file]:environment file:_files" \ - "($help -i --interactive)"{-i,--interactive}"[Keep stdin open even if not attached]" \ - "($help)--privileged[Give extended Linux capabilities to the command]" \ - "($help -t --tty)"{-t,--tty}"[Allocate a pseudo-tty]" \ - "($help -u --user)"{-u=,--user=}"[Username or UID]:user:_users" \ - "($help -w --workdir)"{-w=,--workdir=}"[Working directory inside the container]:directory:_directories" \ - "($help -):containers:__docker_complete_running_containers" \ - "($help -)*::command:->anycommand" && ret=0 - case $state in - (anycommand) - shift 1 words - (( CURRENT-- )) - _normal && ret=0 - ;; - esac - ;; - (export) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -o --output)"{-o=,--output=}"[Write to a file, instead of stdout]:output file:_files" \ - "($help -)*:containers:__docker_complete_containers" && ret=0 - ;; - (inspect) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -f --format)"{-f=,--format=}"[Format the output using the given go template]:template: " \ - "($help -s --size)"{-s,--size}"[Display total file sizes]" \ - "($help -)*:containers:__docker_complete_containers" && ret=0 - ;; - (kill) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -s --signal)"{-s=,--signal=}"[Signal to send]:signal:_signals" \ - "($help -)*:containers:__docker_complete_running_containers" && ret=0 - ;; - (logs) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help)--details[Show extra details provided to logs]" \ - "($help -f --follow)"{-f,--follow}"[Follow log output]" \ - "($help -s --since)"{-s=,--since=}"[Show logs since this timestamp]:timestamp: " \ - "($help -t --timestamps)"{-t,--timestamps}"[Show timestamps]" \ - "($help -n --tail)"{-n=,--tail=}"[Number of lines to show from the end of the logs]:lines:(1 10 20 50 all)" \ - "($help -)*:containers:__docker_complete_containers" && ret=0 - ;; - (ls|list) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -a --all)"{-a,--all}"[Show all containers]" \ - "($help)--before=[Show only container created before...]:containers:__docker_complete_containers" \ - "($help)*"{-f=,--filter=}"[Filter values]:filter:__docker_complete_ps_filters" \ - "($help)--format=[Format the output using the given Go template]:template: " \ - "($help -l --latest)"{-l,--latest}"[Show only the latest created container]" \ - "($help -n --last)"{-n=,--last=}"[Show n last created containers (includes all states)]:n:(1 5 10 25 50)" \ - "($help)--no-trunc[Do not truncate output]" \ - "($help -q --quiet)"{-q,--quiet}"[Only show container IDs]" \ - "($help -s --size)"{-s,--size}"[Display total file sizes]" \ - "($help)--since=[Show only containers created since...]:containers:__docker_complete_containers" && ret=0 - ;; - (pause|unpause) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -)*:containers:__docker_complete_running_containers" && ret=0 - ;; - (port) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -)1:containers:__docker_complete_running_containers" \ - "($help -)2:port:_ports" && ret=0 - ;; - (prune) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help)*--filter=[Filter values]:filter:__docker_complete_prune_filters" \ - "($help -f --force)"{-f,--force}"[Do not prompt for confirmation]" && ret=0 - ;; - (rename) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -):old name:__docker_complete_containers" \ - "($help -):new name: " && ret=0 - ;; - (restart) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -t --time)"{-t=,--time=}"[Number of seconds to try to stop for before killing the container]:seconds to before killing:(1 5 10 30 60)" \ - "($help -)*:containers:__docker_complete_containers" && ret=0 - ;; - (rm) - local state - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -f --force)"{-f,--force}"[Force removal]" \ - "($help -l --link)"{-l,--link}"[Remove the specified link and not the underlying container]" \ - "($help -v --volumes)"{-v,--volumes}"[Remove the volumes associated to the container]" \ - "($help -)*:containers:->values" && ret=0 - case $state in - (values) - if [[ ${words[(r)-f]} == -f || ${words[(r)--force]} == --force ]]; then - __docker_complete_containers && ret=0 - else - __docker_complete_stopped_containers && ret=0 - fi - ;; - esac - ;; - (run) - local state - _arguments $(__docker_arguments) \ - $opts_help \ - $opts_create_run \ - $opts_create_run_update \ - $opts_attach_exec_run_start \ - "($help -d --detach)"{-d,--detach}"[Detached mode: leave the container running in the background]" \ - "($help)--health-cmd=[Command to run to check health]:command: " \ - "($help)--health-interval=[Time between running the check]:time: " \ - "($help)--health-retries=[Consecutive failures needed to report unhealthy]:retries:(1 2 3 4 5)" \ - "($help)--health-timeout=[Maximum time to allow one check to run]:time: " \ - "($help)--no-healthcheck[Disable any container-specified HEALTHCHECK]" \ - "($help)--rm[Remove intermediate containers when it exits]" \ - "($help)--runtime=[Name of the runtime to be used for that container]:runtime:__docker_complete_runtimes" \ - "($help)--sig-proxy[Proxy all received signals to the process (non-TTY mode only)]" \ - "($help)--storage-opt=[Storage driver options for the container]:storage options:->storage-opt" \ - "($help -): :__docker_complete_images" \ - "($help -):command: _command_names -e" \ - "($help -)*::arguments: _normal" && ret=0 - case $state in - (link) - if compset -P "*:"; then - _wanted alias expl "Alias" compadd -E "" && ret=0 - else - __docker_complete_running_containers -qS ":" && ret=0 - fi - ;; - (storage-opt) - if compset -P "*="; then - _message "value" && ret=0 - else - opts=('size') - _describe -t filter-opts "storage options" opts -qS "=" && ret=0 - fi - ;; - esac - ;; - (start) - _arguments $(__docker_arguments) \ - $opts_help \ - $opts_attach_exec_run_start \ - "($help -a --attach)"{-a,--attach}"[Attach container's stdout/stderr and forward all signals]" \ - "($help -i --interactive)"{-i,--interactive}"[Attach container's stdin]" \ - "($help -)*:containers:__docker_complete_stopped_containers" && ret=0 - ;; - (stats) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -a --all)"{-a,--all}"[Show all containers (default shows just running)]" \ - "($help)--format=[Format the output using the given Go template]:template: " \ - "($help)--no-stream[Disable streaming stats and only pull the first result]" \ - "($help)--no-trunc[Do not truncate output]" \ - "($help -)*:containers:__docker_complete_running_containers" && ret=0 - ;; - (stop) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -t --time)"{-t=,--time=}"[Number of seconds to try to stop for before killing the container]:seconds to before killing:(1 5 10 30 60)" \ - "($help -)*:containers:__docker_complete_running_containers" && ret=0 - ;; - (top) - local state - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -)1:containers:__docker_complete_running_containers" \ - "($help -)*:: :->ps-arguments" && ret=0 - case $state in - (ps-arguments) - _ps && ret=0 - ;; - esac - ;; - (update) - local state - _arguments $(__docker_arguments) \ - $opts_help \ - $opts_create_run_update \ - "($help -)*: :->values" && ret=0 - case $state in - (values) - if [[ ${words[(r)--kernel-memory*]} = (--kernel-memory*) ]]; then - __docker_complete_stopped_containers && ret=0 - else - __docker_complete_containers && ret=0 - fi - ;; - esac - ;; - (wait) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -)*:containers:__docker_complete_running_containers" && ret=0 - ;; - (help) - _arguments $(__docker_arguments) ":subcommand:__docker_container_commands" && ret=0 - ;; - esac - - return ret -} - -# EO container - -# BO image - -__docker_image_commands() { - local -a _docker_image_subcommands - _docker_image_subcommands=( - "build:Build an image from a Dockerfile" - "history:Show the history of an image" - "import:Import the contents from a tarball to create a filesystem image" - "inspect:Display detailed information on one or more images" - "load:Load an image from a tar archive or STDIN" - "ls:List images" - "prune:Remove unused images" - "pull:Download an image from a registry" - "push:Upload an image to a registry" - "rm:Remove one or more images" - "save:Save one or more images to a tar archive (streamed to STDOUT by default)" - "tag:Tag an image into a repository" - ) - _describe -t docker-image-commands "docker image command" _docker_image_subcommands -} - -__docker_image_subcommand() { - local -a _command_args opts_help - local expl help="--help" - integer ret=1 - - opts_help=("(: -)--help[Print usage]") - - case "$words[1]" in - (build) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help)*--add-host=[Add a custom host-to-IP mapping]:host\:ip mapping: " \ - "($help)*--build-arg=[Build-time variables]:=: " \ - "($help)*--cache-from=[Images to consider as cache sources]: :__docker_complete_repositories_with_tags" \ - "($help -c --cpu-shares)"{-c=,--cpu-shares=}"[CPU shares (relative weight)]:CPU shares:(0 10 100 200 500 800 1000)" \ - "($help)--cgroup-parent=[Parent cgroup for the container]:cgroup: " \ - "($help)--compress[Compress the build context using gzip]" \ - "($help)--cpu-period=[Limit the CPU CFS (Completely Fair Scheduler) period]:CPU period: " \ - "($help)--cpu-quota=[Limit the CPU CFS (Completely Fair Scheduler) quota]:CPU quota: " \ - "($help)--cpu-rt-period=[Limit the CPU real-time period]:CPU real-time period in microseconds: " \ - "($help)--cpu-rt-runtime=[Limit the CPU real-time runtime]:CPU real-time runtime in microseconds: " \ - "($help)--cpuset-cpus=[CPUs in which to allow execution]:CPUs: " \ - "($help)--cpuset-mems=[MEMs in which to allow execution]:MEMs: " \ - "($help)--disable-content-trust[Skip image verification]" \ - "($help -f --file)"{-f=,--file=}"[Name of the Dockerfile]:Dockerfile:_files" \ - "($help)--force-rm[Always remove intermediate containers]" \ - "($help)--isolation=[Container isolation technology]:isolation:(default hyperv process)" \ - "($help)*--label=[Set metadata for an image]:label=value: " \ - "($help -m --memory)"{-m=,--memory=}"[Memory limit]:Memory limit: " \ - "($help)--memory-swap=[Total memory limit with swap]:Memory limit: " \ - "($help)--network=[Connect a container to a network]:network mode:(bridge none container host)" \ - "($help)--no-cache[Do not use cache when building the image]" \ - "($help)--pull[Attempt to pull a newer version of the image]" \ - "($help -q --quiet)"{-q,--quiet}"[Suppress verbose build output]" \ - "($help)--rm[Remove intermediate containers after a successful build]" \ - "($help)*--shm-size=[Size of '/dev/shm' (format is '')]:shm size: " \ - "($help)--squash[Squash newly built layers into a single new layer]" \ - "($help -t --tag)*"{-t=,--tag=}"[Repository, name and tag for the image]: :__docker_complete_repositories_with_tags" \ - "($help)--target=[Set the target build stage to build.]" \ - "($help)*--ulimit=[ulimit options]:ulimit: " \ - "($help)--userns=[Container user namespace]:user namespace:(host)" \ - "($help -):path or URL:_directories" && ret=0 - ;; - (history) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -H --human)"{-H,--human}"[Print sizes and dates in human readable format]" \ - "($help)--no-trunc[Do not truncate output]" \ - "($help -q --quiet)"{-q,--quiet}"[Only show image IDs]" \ - "($help -)*: :__docker_complete_images" && ret=0 - ;; - (import) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help)*"{-c=,--change=}"[Apply Dockerfile instruction to the created image]:Dockerfile:_files" \ - "($help -m --message)"{-m=,--message=}"[Commit message for imported image]:message: " \ - "($help -):URL:(- http:// file://)" \ - "($help -): :__docker_complete_repositories_with_tags" && ret=0 - ;; - (inspect) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -f --format)"{-f=,--format=}"[Format the output using the given go template]:template: " \ - "($help -)*:images:__docker_complete_images" && ret=0 - ;; - (load) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -i --input)"{-i=,--input=}"[Read from tar archive file]:archive file:_files -g \"*.((tar|TAR)(.gz|.GZ|.Z|.bz2|.lzma|.xz|)|(tbz|tgz|txz))(-.)\"" \ - "($help -q --quiet)"{-q,--quiet}"[Suppress the load output]" && ret=0 - ;; - (ls|list) - local state - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -a --all)"{-a,--all}"[Show all images]" \ - "($help)--digests[Show digests]" \ - "($help)*"{-f=,--filter=}"[Filter values]:filter:__docker_complete_images_filters" \ - "($help)--format=[Format the output using the given Go template]:template: " \ - "($help)--no-trunc[Do not truncate output]" \ - "($help -q --quiet)"{-q,--quiet}"[Only show image IDs]" \ - "($help -): :__docker_complete_repositories" && ret=0 - ;; - (prune) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -a --all)"{-a,--all}"[Remove all unused images, not just dangling ones]" \ - "($help)*--filter=[Filter values]:filter:__docker_complete_prune_filters" \ - "($help -f --force)"{-f,--force}"[Do not prompt for confirmation]" && ret=0 - ;; - (pull) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -a --all-tags)"{-a,--all-tags}"[Download all tagged images]" \ - "($help)--disable-content-trust[Skip image verification]" \ - "($help -):name:__docker_search" && ret=0 - ;; - (push) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -a --all-tags)"{-a,--all-tags}"[Push all tags of an image to the repository]" \ - "($help)--disable-content-trust[Skip image signing]" \ - "($help -): :__docker_complete_images" && ret=0 - ;; - (rm) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -f --force)"{-f,--force}"[Force removal]" \ - "($help)--no-prune[Do not delete untagged parents]" \ - "($help -)*: :__docker_complete_images" && ret=0 - ;; - (save) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -o --output)"{-o=,--output=}"[Write to file]:file:_files" \ - "($help -)*: :__docker_complete_images" && ret=0 - ;; - (tag) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -):source:__docker_complete_images"\ - "($help -):destination:__docker_complete_repositories_with_tags" && ret=0 - ;; - (help) - _arguments $(__docker_arguments) ":subcommand:__docker_container_commands" && ret=0 - ;; - esac - - return ret -} - -# EO image - -# BO network - -__docker_network_complete_ls_filters() { - [[ $PREFIX = -* ]] && return 1 - integer ret=1 - - if compset -P '*='; then - case "${${words[-1]%=*}#*=}" in - (driver) - __docker_complete_info_plugins Network && ret=0 - ;; - (id) - __docker_complete_networks_ids && ret=0 - ;; - (name) - __docker_complete_networks_names && ret=0 - ;; - (scope) - opts=('global' 'local' 'swarm') - _describe -t scope-filter-opts "Scope filter options" opts && ret=0 - ;; - (type) - opts=('builtin' 'custom') - _describe -t type-filter-opts "Type filter options" opts && ret=0 - ;; - *) - _message 'value' && ret=0 - ;; - esac - else - opts=('driver' 'id' 'label' 'name' 'scope' 'type') - _describe -t filter-opts "Filter Options" opts -qS "=" && ret=0 - fi - - return ret -} - -__docker_get_networks() { - [[ $PREFIX = -* ]] && return 1 - integer ret=1 - local line s - declare -a lines networks - - type=$1; shift - - lines=(${(f)${:-"$(_call_program commands docker $docker_options network ls)"$'\n'}}) - - # Parse header line to find columns - local i=1 j=1 k header=${lines[1]} - declare -A begin end - while (( j < ${#header} - 1 )); do - i=$(( j + ${${header[$j,-1]}[(i)[^ ]]} - 1 )) - j=$(( i + ${${header[$i,-1]}[(i) ]} - 1 )) - k=$(( j + ${${header[$j,-1]}[(i)[^ ]]} - 2 )) - begin[${header[$i,$((j-1))]}]=$i - end[${header[$i,$((j-1))]}]=$k - done - end[${header[$i,$((j-1))]}]=-1 - lines=(${lines[2,-1]}) - - # Network ID - if [[ $type = (ids|all) ]]; then - for line in $lines; do - s="${line[${begin[NETWORK ID]},${end[NETWORK ID]}]%% ##}" - s="$s:${(l:7:: :::)${${line[${begin[DRIVER]},${end[DRIVER]}]}%% ##}}" - s="$s, ${${line[${begin[SCOPE]},${end[SCOPE]}]}%% ##}" - networks=($networks $s) - done - fi - - # Names - if [[ $type = (names|all) ]]; then - for line in $lines; do - s="${line[${begin[NAME]},${end[NAME]}]%% ##}" - s="$s:${(l:7:: :::)${${line[${begin[DRIVER]},${end[DRIVER]}]}%% ##}}" - s="$s, ${${line[${begin[SCOPE]},${end[SCOPE]}]}%% ##}" - networks=($networks $s) - done - fi - - _describe -t networks-list "networks" networks "$@" && ret=0 - return ret -} - -__docker_complete_networks() { - [[ $PREFIX = -* ]] && return 1 - __docker_get_networks all "$@" -} - -__docker_complete_networks_ids() { - [[ $PREFIX = -* ]] && return 1 - __docker_get_networks ids "$@" -} - -__docker_complete_networks_names() { - [[ $PREFIX = -* ]] && return 1 - __docker_get_networks names "$@" -} - -__docker_network_commands() { - local -a _docker_network_subcommands - _docker_network_subcommands=( - "connect:Connect a container to a network" - "create:Creates a new network with a name specified by the user" - "disconnect:Disconnects a container from a network" - "inspect:Displays detailed information on a network" - "ls:Lists all the networks created by the user" - "prune:Remove all unused networks" - "rm:Deletes one or more networks" - ) - _describe -t docker-network-commands "docker network command" _docker_network_subcommands -} - -__docker_network_subcommand() { - local -a _command_args opts_help - local expl help="--help" - integer ret=1 - - opts_help=("(: -)--help[Print usage]") - - case "$words[1]" in - (connect) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help)*--alias=[Add network-scoped alias for the container]:alias: " \ - "($help)--ip=[IPv4 address]:IPv4: " \ - "($help)--ip6=[IPv6 address]:IPv6: " \ - "($help)*--link=[Add a link to another container]:link:->link" \ - "($help)*--link-local-ip=[Add a link-local address for the container]:IPv4/IPv6: " \ - "($help -)1:network:__docker_complete_networks" \ - "($help -)2:containers:__docker_complete_containers" && ret=0 - - case $state in - (link) - if compset -P "*:"; then - _wanted alias expl "Alias" compadd -E "" && ret=0 - else - __docker_complete_running_containers -qS ":" && ret=0 - fi - ;; - esac - ;; - (create) - _arguments $(__docker_arguments) -A '-*' \ - $opts_help \ - "($help)--attachable[Enable manual container attachment]" \ - "($help)*--aux-address[Auxiliary IPv4 or IPv6 addresses used by network driver]:key=IP: " \ - "($help -d --driver)"{-d=,--driver=}"[Driver to manage the Network]:driver:(null host bridge overlay)" \ - "($help)*--gateway=[IPv4 or IPv6 Gateway for the master subnet]:IP: " \ - "($help)--internal[Restricts external access to the network]" \ - "($help)*--ip-range=[Allocate container ip from a sub-range]:IP/mask: " \ - "($help)--ipam-driver=[IP Address Management Driver]:driver:(default)" \ - "($help)*--ipam-opt=[Custom IPAM plugin options]:opt=value: " \ - "($help)--ipv6[Enable IPv6 networking]" \ - "($help)*--label=[Set metadata on a network]:label=value: " \ - "($help)*"{-o=,--opt=}"[Driver specific options]:opt=value: " \ - "($help)*--subnet=[Subnet in CIDR format that represents a network segment]:IP/mask: " \ - "($help -)1:Network Name: " && ret=0 - ;; - (disconnect) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -)1:network:__docker_complete_networks" \ - "($help -)2:containers:__docker_complete_containers" && ret=0 - ;; - (inspect) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -f --format)"{-f=,--format=}"[Format the output using the given go template]:template: " \ - "($help)--verbose[Show detailed information]" \ - "($help -)*:network:__docker_complete_networks" && ret=0 - ;; - (ls) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help)--no-trunc[Do not truncate the output]" \ - "($help)*"{-f=,--filter=}"[Provide filter values]:filter:__docker_network_complete_ls_filters" \ - "($help)--format=[Format the output using the given Go template]:template: " \ - "($help -q --quiet)"{-q,--quiet}"[Only display network IDs]" && ret=0 - ;; - (prune) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help)*--filter=[Filter values]:filter:__docker_complete_prune_filters" \ - "($help -f --force)"{-f,--force}"[Do not prompt for confirmation]" && ret=0 - ;; - (rm) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -)*:network:__docker_complete_networks" && ret=0 - ;; - (help) - _arguments $(__docker_arguments) ":subcommand:__docker_network_commands" && ret=0 - ;; - esac - - return ret -} - -# EO network - -# BO node - -__docker_node_complete_ls_filters() { - [[ $PREFIX = -* ]] && return 1 - integer ret=1 - - if compset -P '*='; then - case "${${words[-1]%=*}#*=}" in - (id) - __docker_complete_nodes_ids && ret=0 - ;; - (membership) - membership_opts=('accepted' 'pending' 'rejected') - _describe -t membership-opts "membership options" membership_opts && ret=0 - ;; - (name) - __docker_complete_nodes_names && ret=0 - ;; - (role) - role_opts=('manager' 'worker') - _describe -t role-opts "role options" role_opts && ret=0 - ;; - *) - _message 'value' && ret=0 - ;; - esac - else - opts=('id' 'label' 'membership' 'name' 'node.label' 'role') - _describe -t filter-opts "filter options" opts -qS "=" && ret=0 - fi - - return ret -} - -__docker_node_complete_ps_filters() { - [[ $PREFIX = -* ]] && return 1 - integer ret=1 - - if compset -P '*='; then - case "${${words[-1]%=*}#*=}" in - (desired-state) - state_opts=('accepted' 'running' 'shutdown') - _describe -t state-opts "desired state options" state_opts && ret=0 - ;; - *) - _message 'value' && ret=0 - ;; - esac - else - opts=('desired-state' 'id' 'label' 'name') - _describe -t filter-opts "filter options" opts -qS "=" && ret=0 - fi - - return ret -} - -__docker_nodes() { - [[ $PREFIX = -* ]] && return 1 - integer ret=1 - local line s - declare -a lines nodes args - - type=$1; shift - filter=$1; shift - [[ $filter != "none" ]] && args=("-f $filter") - - lines=(${(f)${:-"$(_call_program commands docker $docker_options node ls $args)"$'\n'}}) - # Parse header line to find columns - local i=1 j=1 k header=${lines[1]} - declare -A begin end - while (( j < ${#header} - 1 )); do - i=$(( j + ${${header[$j,-1]}[(i)[^ ]]} - 1 )) - j=$(( i + ${${header[$i,-1]}[(i) ]} - 1 )) - k=$(( j + ${${header[$j,-1]}[(i)[^ ]]} - 2 )) - begin[${header[$i,$((j-1))]}]=$i - end[${header[$i,$((j-1))]}]=$k - done - end[${header[$i,$((j-1))]}]=-1 - lines=(${lines[2,-1]}) - - # Node ID - if [[ $type = (ids|all) ]]; then - for line in $lines; do - s="${line[${begin[ID]},${end[ID]}]%% ##}" - nodes=($nodes $s) - done - fi - - # Names - if [[ $type = (names|all) ]]; then - for line in $lines; do - s="${line[${begin[HOSTNAME]},${end[HOSTNAME]}]%% ##}" - nodes=($nodes $s) - done - fi - - _describe -t nodes-list "nodes" nodes "$@" && ret=0 - return ret -} - -__docker_complete_nodes() { - [[ $PREFIX = -* ]] && return 1 - __docker_nodes all none "$@" -} - -__docker_complete_nodes_ids() { - [[ $PREFIX = -* ]] && return 1 - __docker_nodes ids none "$@" -} - -__docker_complete_nodes_names() { - [[ $PREFIX = -* ]] && return 1 - __docker_nodes names none "$@" -} - -__docker_complete_pending_nodes() { - [[ $PREFIX = -* ]] && return 1 - __docker_nodes all "membership=pending" "$@" -} - -__docker_complete_manager_nodes() { - [[ $PREFIX = -* ]] && return 1 - __docker_nodes all "role=manager" "$@" -} - -__docker_complete_worker_nodes() { - [[ $PREFIX = -* ]] && return 1 - __docker_nodes all "role=worker" "$@" -} - -__docker_node_commands() { - local -a _docker_node_subcommands - _docker_node_subcommands=( - "demote:Demote a node as manager in the swarm" - "inspect:Display detailed information on one or more nodes" - "ls:List nodes in the swarm" - "promote:Promote a node as manager in the swarm" - "rm:Remove one or more nodes from the swarm" - "ps:List tasks running on one or more nodes, defaults to current node" - "update:Update a node" - ) - _describe -t docker-node-commands "docker node command" _docker_node_subcommands -} - -__docker_node_subcommand() { - local -a _command_args opts_help - local expl help="--help" - integer ret=1 - - opts_help=("(: -)--help[Print usage]") - - case "$words[1]" in - (rm|remove) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -f --force)"{-f,--force}"[Force remove a node from the swarm]" \ - "($help -)*:node:__docker_complete_pending_nodes" && ret=0 - ;; - (demote) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -)*:node:__docker_complete_manager_nodes" && ret=0 - ;; - (inspect) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -f --format)"{-f=,--format=}"[Format the output using the given go template]:template: " \ - "($help)--pretty[Print the information in a human friendly format]" \ - "($help -)*:node:__docker_complete_nodes" && ret=0 - ;; - (ls|list) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help)*"{-f=,--filter=}"[Provide filter values]:filter:__docker_node_complete_ls_filters" \ - "($help -q --quiet)"{-q,--quiet}"[Only display IDs]" && ret=0 - ;; - (promote) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -)*:node:__docker_complete_worker_nodes" && ret=0 - ;; - (ps) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -a --all)"{-a,--all}"[Display all instances]" \ - "($help)*"{-f=,--filter=}"[Provide filter values]:filter:__docker_node_complete_ps_filters" \ - "($help)--format=[Format the output using the given go template]:template: " \ - "($help)--no-resolve[Do not map IDs to Names]" \ - "($help)--no-trunc[Do not truncate output]" \ - "($help -q --quiet)"{-q,--quiet}"[Only display IDs]" \ - "($help -)*:node:__docker_complete_nodes" && ret=0 - ;; - (update) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help)--availability=[Availability of the node]:availability:(active pause drain)" \ - "($help)*--label-add=[Add or update a node label]:key=value: " \ - "($help)*--label-rm=[Remove a node label if exists]:label: " \ - "($help)--role=[Role of the node]:role:(manager worker)" \ - "($help -)1:node:__docker_complete_nodes" && ret=0 - ;; - (help) - _arguments $(__docker_arguments) ":subcommand:__docker_node_commands" && ret=0 - ;; - esac - - return ret -} - -# EO node - -# BO plugin - -__docker_plugin_complete_ls_filters() { - [[ $PREFIX = -* ]] && return 1 - integer ret=1 - - if compset -P '*='; then - case "${${words[-1]%=*}#*=}" in - (capability) - opts=('authz' 'ipamdriver' 'logdriver' 'metricscollector' 'networkdriver' 'volumedriver') - _describe -t capability-opts "capability options" opts && ret=0 - ;; - (enabled) - opts=('false' 'true') - _describe -t enabled-opts "enabled options" opts && ret=0 - ;; - *) - _message 'value' && ret=0 - ;; - esac - else - opts=('capability' 'enabled') - _describe -t filter-opts "filter options" opts -qS "=" && ret=0 - fi - - return ret -} - -__docker_plugins() { - [[ $PREFIX = -* ]] && return 1 - integer ret=1 - local line s - declare -a lines plugins args - - filter=$1; shift - [[ $filter != "none" ]] && args=("-f $filter") - - lines=(${(f)${:-"$(_call_program commands docker $docker_options plugin ls $args)"$'\n'}}) - - # Parse header line to find columns - local i=1 j=1 k header=${lines[1]} - declare -A begin end - while (( j < ${#header} - 1 )); do - i=$(( j + ${${header[$j,-1]}[(i)[^ ]]} - 1 )) - j=$(( i + ${${header[$i,-1]}[(i) ]} - 1 )) - k=$(( j + ${${header[$j,-1]}[(i)[^ ]]} - 2 )) - begin[${header[$i,$((j-1))]}]=$i - end[${header[$i,$((j-1))]}]=$k - done - end[${header[$i,$((j-1))]}]=-1 - lines=(${lines[2,-1]}) - - # Name - for line in $lines; do - s="${line[${begin[NAME]},${end[NAME]}]%% ##}" - s="$s:${(l:7:: :::)${${line[${begin[TAG]},${end[TAG]}]}%% ##}}" - plugins=($plugins $s) - done - - _describe -t plugins-list "plugins" plugins "$@" && ret=0 - return ret -} - -__docker_complete_plugins() { - [[ $PREFIX = -* ]] && return 1 - __docker_plugins none "$@" -} - -__docker_complete_enabled_plugins() { - [[ $PREFIX = -* ]] && return 1 - __docker_plugins enabled=true "$@" -} - -__docker_complete_disabled_plugins() { - [[ $PREFIX = -* ]] && return 1 - __docker_plugins enabled=false "$@" -} - -__docker_plugin_commands() { - local -a _docker_plugin_subcommands - _docker_plugin_subcommands=( - "disable:Disable a plugin" - "enable:Enable a plugin" - "inspect:Return low-level information about a plugin" - "install:Install a plugin" - "ls:List plugins" - "push:Push a plugin" - "rm:Remove a plugin" - "set:Change settings for a plugin" - "upgrade:Upgrade an existing plugin" - ) - _describe -t docker-plugin-commands "docker plugin command" _docker_plugin_subcommands -} - -__docker_plugin_subcommand() { - local -a _command_args opts_help - local expl help="--help" - integer ret=1 - - opts_help=("(: -)--help[Print usage]") - - case "$words[1]" in - (disable) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -f --force)"{-f,--force}"[Force the disable of an active plugin]" \ - "($help -)1:plugin:__docker_complete_enabled_plugins" && ret=0 - ;; - (enable) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help)--timeout=[HTTP client timeout (in seconds)]:timeout: " \ - "($help -)1:plugin:__docker_complete_disabled_plugins" && ret=0 - ;; - (inspect) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -f --format)"{-f=,--format=}"[Format the output using the given Go template]:template: " \ - "($help -)*:plugin:__docker_complete_plugins" && ret=0 - ;; - (install) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help)--alias=[Local name for plugin]:alias: " \ - "($help)--disable[Do not enable the plugin on install]" \ - "($help)--disable-content-trust[Skip image verification (default true)]" \ - "($help)--grant-all-permissions[Grant all permissions necessary to run the plugin]" \ - "($help -)1:plugin:__docker_complete_plugins" \ - "($help -)*:key=value: " && ret=0 - ;; - (ls|list) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help)*"{-f=,--filter=}"[Filter output based on conditions provided]:filter:__docker_plugin_complete_ls_filters" \ - "($help --format)--format=[Format the output using the given Go template]:template: " \ - "($help)--no-trunc[Don't truncate output]" \ - "($help -q --quiet)"{-q,--quiet}"[Only display IDs]" && ret=0 - ;; - (push) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help)--disable-content-trust[Skip image verification (default true)]" \ - "($help -)1:plugin:__docker_complete_plugins" && ret=0 - ;; - (rm|remove) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -f --force)"{-f,--force}"[Force the removal of an active plugin]" \ - "($help -)*:plugin:__docker_complete_plugins" && ret=0 - ;; - (set) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -)1:plugin:__docker_complete_plugins" \ - "($help -)*:key=value: " && ret=0 - ;; - (upgrade) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help)--disable-content-trust[Skip image verification (default true)]" \ - "($help)--grant-all-permissions[Grant all permissions necessary to run the plugin]" \ - "($help)--skip-remote-check[Do not check if specified remote plugin matches existing plugin image]" \ - "($help -)1:plugin:__docker_complete_plugins" \ - "($help -):remote: " && ret=0 - ;; - (help) - _arguments $(__docker_arguments) ":subcommand:__docker_plugin_commands" && ret=0 - ;; - esac - - return ret -} - -# EO plugin - -# BO secret - -__docker_secrets() { - [[ $PREFIX = -* ]] && return 1 - integer ret=1 - local line s - declare -a lines secrets - - type=$1; shift - - lines=(${(f)${:-"$(_call_program commands docker $docker_options secret ls)"$'\n'}}) - - # Parse header line to find columns - local i=1 j=1 k header=${lines[1]} - declare -A begin end - while (( j < ${#header} - 1 )); do - i=$(( j + ${${header[$j,-1]}[(i)[^ ]]} - 1 )) - j=$(( i + ${${header[$i,-1]}[(i) ]} - 1 )) - k=$(( j + ${${header[$j,-1]}[(i)[^ ]]} - 2 )) - begin[${header[$i,$((j-1))]}]=$i - end[${header[$i,$((j-1))]}]=$k - done - end[${header[$i,$((j-1))]}]=-1 - lines=(${lines[2,-1]}) - - # ID - if [[ $type = (ids|all) ]]; then - for line in $lines; do - s="${line[${begin[ID]},${end[ID]}]%% ##}" - secrets=($secrets $s) - done - fi - - # Names - if [[ $type = (names|all) ]]; then - for line in $lines; do - s="${line[${begin[NAME]},${end[NAME]}]%% ##}" - secrets=($secrets $s) - done - fi - - _describe -t secrets-list "secrets" secrets "$@" && ret=0 - return ret -} - -__docker_complete_secrets() { - [[ $PREFIX = -* ]] && return 1 - __docker_secrets all "$@" -} - -__docker_secret_commands() { - local -a _docker_secret_subcommands - _docker_secret_subcommands=( - "create:Create a secret using stdin as content" - "inspect:Display detailed information on one or more secrets" - "ls:List secrets" - "rm:Remove one or more secrets" - ) - _describe -t docker-secret-commands "docker secret command" _docker_secret_subcommands -} - -__docker_secret_subcommand() { - local -a _command_args opts_help - local expl help="--help" - integer ret=1 - - opts_help=("(: -)--help[Print usage]") - - case "$words[1]" in - (create) - _arguments $(__docker_arguments) -A '-*' \ - $opts_help \ - "($help)*"{-l=,--label=}"[Secret labels]:label: " \ - "($help -):secret: " && ret=0 - ;; - (inspect) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -f --format)"{-f=,--format=}"[Format the output using the given Go template]:template: " \ - "($help -)*:secret:__docker_complete_secrets" && ret=0 - ;; - (ls|list) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help)--format=[Format the output using the given go template]:template: " \ - "($help -q --quiet)"{-q,--quiet}"[Only display IDs]" && ret=0 - ;; - (rm|remove) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -)*:secret:__docker_complete_secrets" && ret=0 - ;; - (help) - _arguments $(__docker_arguments) ":subcommand:__docker_secret_commands" && ret=0 - ;; - esac - - return ret -} - -# EO secret - -# BO service - -__docker_service_complete_ls_filters() { - [[ $PREFIX = -* ]] && return 1 - integer ret=1 - - if compset -P '*='; then - case "${${words[-1]%=*}#*=}" in - (id) - __docker_complete_services_ids && ret=0 - ;; - (mode) - opts=('global' 'replicated') - _describe -t mode-opts "mode options" opts && ret=0 - ;; - (name) - __docker_complete_services_names && ret=0 - ;; - *) - _message 'value' && ret=0 - ;; - esac - else - opts=('id' 'label' 'mode' 'name') - _describe -t filter-opts "filter options" opts -qS "=" && ret=0 - fi - - return ret -} - -__docker_service_complete_ps_filters() { - [[ $PREFIX = -* ]] && return 1 - integer ret=1 - - if compset -P '*='; then - case "${${words[-1]%=*}#*=}" in - (desired-state) - state_opts=('accepted' 'running' 'shutdown') - _describe -t state-opts "desired state options" state_opts && ret=0 - ;; - *) - _message 'value' && ret=0 - ;; - esac - else - opts=('desired-state' 'id' 'label' 'name') - _describe -t filter-opts "filter options" opts -qS "=" && ret=0 - fi - - return ret -} - -__docker_service_complete_placement_pref() { - [[ $PREFIX = -* ]] && return 1 - integer ret=1 - - if compset -P '*='; then - case "${${words[-1]%=*}#*=}" in - (spread) - opts=('engine.labels' 'node.labels') - _describe -t spread-opts "spread options" opts -qS "." && ret=0 - ;; - *) - _message 'value' && ret=0 - ;; - esac - else - opts=('spread') - _describe -t pref-opts "placement pref options" opts -qS "=" && ret=0 - fi - - return ret -} - -__docker_services() { - [[ $PREFIX = -* ]] && return 1 - integer ret=1 - local line s - declare -a lines services - - type=$1; shift - - lines=(${(f)${:-"$(_call_program commands docker $docker_options service ls)"$'\n'}}) - - # Parse header line to find columns - local i=1 j=1 k header=${lines[1]} - declare -A begin end - while (( j < ${#header} - 1 )); do - i=$(( j + ${${header[$j,-1]}[(i)[^ ]]} - 1 )) - j=$(( i + ${${header[$i,-1]}[(i) ]} - 1 )) - k=$(( j + ${${header[$j,-1]}[(i)[^ ]]} - 2 )) - begin[${header[$i,$((j-1))]}]=$i - end[${header[$i,$((j-1))]}]=$k - done - end[${header[$i,$((j-1))]}]=-1 - lines=(${lines[2,-1]}) - - # Service ID - if [[ $type = (ids|all) ]]; then - for line in $lines; do - s="${line[${begin[ID]},${end[ID]}]%% ##}" - s="$s:${(l:7:: :::)${${line[${begin[IMAGE]},${end[IMAGE]}]}%% ##}}" - services=($services $s) - done - fi - - # Names - if [[ $type = (names|all) ]]; then - for line in $lines; do - s="${line[${begin[NAME]},${end[NAME]}]%% ##}" - s="$s:${(l:7:: :::)${${line[${begin[IMAGE]},${end[IMAGE]}]}%% ##}}" - services=($services $s) - done - fi - - _describe -t services-list "services" services "$@" && ret=0 - return ret -} - -__docker_complete_services() { - [[ $PREFIX = -* ]] && return 1 - __docker_services all "$@" -} - -__docker_complete_services_ids() { - [[ $PREFIX = -* ]] && return 1 - __docker_services ids "$@" -} - -__docker_complete_services_names() { - [[ $PREFIX = -* ]] && return 1 - __docker_services names "$@" -} - -__docker_service_commands() { - local -a _docker_service_subcommands - _docker_service_subcommands=( - "create:Create a new service" - "inspect:Display detailed information on one or more services" - "logs:Fetch the logs of a service or task" - "ls:List services" - "rm:Remove one or more services" - "rollback:Revert changes to a service's configuration" - "scale:Scale one or multiple replicated services" - "ps:List the tasks of a service" - "update:Update a service" - ) - _describe -t docker-service-commands "docker service command" _docker_service_subcommands -} - -__docker_service_subcommand() { - local -a _command_args opts_help opts_create_update - local expl help="--help" - integer ret=1 - - opts_help=("(: -)--help[Print usage]") - opts_create_update=( - "($help)*--cap-add=[Add Linux capabilities]:capability: " - "($help)*--cap-drop=[Drop Linux capabilities]:capability: " - "($help)*--constraint=[Placement constraints]:constraint: " - "($help)--endpoint-mode=[Placement constraints]:mode:(dnsrr vip)" - "($help)*"{-e=,--env=}"[Set environment variables]:env: " - "($help)--health-cmd=[Command to run to check health]:command: " - "($help)--health-interval=[Time between running the check]:time: " - "($help)--health-retries=[Consecutive failures needed to report unhealthy]:retries:(1 2 3 4 5)" - "($help)--health-timeout=[Maximum time to allow one check to run]:time: " - "($help)--hostname=[Service container hostname]:hostname: " \ - "($help)--isolation=[Service container isolation mode]:isolation:(default process hyperv)" \ - "($help)*--label=[Service labels]:label: " - "($help)--limit-cpu=[Limit CPUs]:value: " - "($help)--limit-memory=[Limit Memory]:value: " - "($help)--limit-pids[Limit maximum number of processes (default 0 = unlimited)]" - "($help)--log-driver=[Logging driver for service]:logging driver:__docker_complete_log_drivers" - "($help)*--log-opt=[Logging driver options]:log driver options:__docker_complete_log_options" - "($help)*--mount=[Attach a filesystem mount to the service]:mount: " - "($help)*--network=[Network attachments]:network: " - "($help)--no-healthcheck[Disable any container-specified HEALTHCHECK]" - "($help)--read-only[Mount the container's root filesystem as read only]" - "($help)--replicas=[Number of tasks]:replicas: " - "($help)--reserve-cpu=[Reserve CPUs]:value: " - "($help)--reserve-memory=[Reserve Memory]:value: " - "($help)--restart-condition=[Restart when condition is met]:mode:(any none on-failure)" - "($help)--restart-delay=[Delay between restart attempts]:delay: " - "($help)--restart-max-attempts=[Maximum number of restarts before giving up]:max-attempts: " - "($help)--restart-window=[Window used to evaluate the restart policy]:duration: " - "($help)--rollback-delay=[Delay between task rollbacks]:duration: " - "($help)--rollback-failure-action=[Action on rollback failure]:action:(continue pause)" - "($help)--rollback-max-failure-ratio=[Failure rate to tolerate during a rollback]:failure rate: " - "($help)--rollback-monitor=[Duration after each task rollback to monitor for failure]:duration: " - "($help)--rollback-parallelism=[Maximum number of tasks rolled back simultaneously]:number: " - "($help)*--secret=[Specify secrets to expose to the service]:secret:__docker_complete_secrets" - "($help)--stop-grace-period=[Time to wait before force killing a container]:grace period: " - "($help)--stop-signal=[Signal to stop the container]:signal:_signals" - "($help -t --tty)"{-t,--tty}"[Allocate a pseudo-TTY]" - "($help)--update-delay=[Delay between updates]:delay: " - "($help)--update-failure-action=[Action on update failure]:mode:(continue pause rollback)" - "($help)--update-max-failure-ratio=[Failure rate to tolerate during an update]:fraction: " - "($help)--update-monitor=[Duration after each task update to monitor for failure]:window: " - "($help)--update-parallelism=[Maximum number of tasks updated simultaneously]:number: " - "($help -u --user)"{-u=,--user=}"[Username or UID]:user:_users" - "($help)--with-registry-auth[Send registry authentication details to swarm agents]" - "($help -w --workdir)"{-w=,--workdir=}"[Working directory inside the container]:directory:_directories" - ) - - case "$words[1]" in - (create) - _arguments $(__docker_arguments) \ - $opts_help \ - $opts_create_update \ - "($help)*--container-label=[Container labels]:label: " \ - "($help)*--dns=[Set custom DNS servers]:DNS: " \ - "($help)*--dns-option=[Set DNS options]:DNS option: " \ - "($help)*--dns-search=[Set custom DNS search domains]:DNS search: " \ - "($help)*--env-file=[Read environment variables from a file]:environment file:_files" \ - "($help)*--group=[Set one or more supplementary user groups for the container]:group: _groups " \ - "($help)--mode=[Service Mode]:mode:(global replicated)" \ - "($help)--name=[Service name]:name: " \ - "($help)*--placement-pref=[Add a placement preference]:pref:__docker_service_complete_placement_pref" \ - "($help)*"{-p=,--publish=}"[Publish a port as a node port]:port: " \ - "($help -): :__docker_complete_images" \ - "($help -):command: _command_names -e" \ - "($help -)*::arguments: _normal" && ret=0 - ;; - (inspect) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -f --format)"{-f=,--format=}"[Format the output using the given go template]:template: " \ - "($help)--pretty[Print the information in a human friendly format]" \ - "($help -)*:service:__docker_complete_services" && ret=0 - ;; - (logs) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -f --follow)"{-f,--follow}"[Follow log output]" \ - "($help)--no-resolve[Do not map IDs to Names]" \ - "($help)--no-task-ids[Do not include task IDs]" \ - "($help)--no-trunc[Do not truncate output]" \ - "($help)--since=[Show logs since timestamp]:timestamp: " \ - "($help -n --tail)"{-n=,--tail=}"[Number of lines to show from the end of the logs]:lines:(1 10 20 50 all)" \ - "($help -t --timestamps)"{-t,--timestamps}"[Show timestamps]" \ - "($help -)1:service:__docker_complete_services" && ret=0 - ;; - (ls|list) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help)*"{-f=,--filter=}"[Filter output based on conditions provided]:filter:__docker_service_complete_ls_filters" \ - "($help)--format=[Format the output using the given Go template]:template: " \ - "($help -q --quiet)"{-q,--quiet}"[Only display IDs]" && ret=0 - ;; - (rm|remove) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -)*:service:__docker_complete_services" && ret=0 - ;; - (rollback) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -d --detach)"{-d=false,--detach=false}"[Disable detached mode]" \ - "($help -q --quiet)"{-q,--quiet}"[Suppress progress output]" \ - "($help -)*:service:__docker_complete_services" && ret=0 - ;; - (scale) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -d --detach)"{-d=false,--detach=false}"[Disable detached mode]" \ - "($help -)*:service:->values" && ret=0 - case $state in - (values) - if compset -P '*='; then - _message 'replicas' && ret=0 - else - __docker_complete_services -qS "=" - fi - ;; - esac - ;; - (ps) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help)*"{-f=,--filter=}"[Provide filter values]:filter:__docker_service_complete_ps_filters" \ - "($help)--format=[Format the output using the given go template]:template: " \ - "($help)--no-resolve[Do not map IDs to Names]" \ - "($help)--no-trunc[Do not truncate output]" \ - "($help -q --quiet)"{-q,--quiet}"[Only display task IDs]" \ - "($help -)*:service:__docker_complete_services" && ret=0 - ;; - (update) - _arguments $(__docker_arguments) \ - $opts_help \ - $opts_create_update \ - "($help)--arg=[Service command args]:arguments: _normal" \ - "($help)*--container-label-add=[Add or update container labels]:label: " \ - "($help)*--container-label-rm=[Remove a container label by its key]:label: " \ - "($help)*--dns-add=[Add or update custom DNS servers]:DNS: " \ - "($help)*--dns-rm=[Remove custom DNS servers]:DNS: " \ - "($help)*--dns-option-add=[Add or update DNS options]:DNS option: " \ - "($help)*--dns-option-rm=[Remove DNS options]:DNS option: " \ - "($help)*--dns-search-add=[Add or update custom DNS search domains]:DNS search: " \ - "($help)*--dns-search-rm=[Remove DNS search domains]:DNS search: " \ - "($help)--force[Force update]" \ - "($help)*--group-add=[Add additional supplementary user groups to the container]:group:_groups" \ - "($help)*--group-rm=[Remove previously added supplementary user groups from the container]:group:_groups" \ - "($help)--image=[Service image tag]:image:__docker_complete_repositories" \ - "($help)*--placement-pref-add=[Add a placement preference]:pref:__docker_service_complete_placement_pref" \ - "($help)*--placement-pref-rm=[Remove a placement preference]:pref:__docker_service_complete_placement_pref" \ - "($help)*--publish-add=[Add or update a port]:port: " \ - "($help)*--publish-rm=[Remove a port(target-port mandatory)]:port: " \ - "($help)--rollback[Rollback to previous specification]" \ - "($help -)1:service:__docker_complete_services" && ret=0 - ;; - (help) - _arguments $(__docker_arguments) ":subcommand:__docker_service_commands" && ret=0 - ;; - esac - - return ret -} - -# EO service - -# BO stack - -__docker_stack_complete_ps_filters() { - [[ $PREFIX = -* ]] && return 1 - integer ret=1 - - if compset -P '*='; then - case "${${words[-1]%=*}#*=}" in - (desired-state) - state_opts=('accepted' 'running' 'shutdown') - _describe -t state-opts "desired state options" state_opts && ret=0 - ;; - *) - _message 'value' && ret=0 - ;; - esac - else - opts=('desired-state' 'id' 'name') - _describe -t filter-opts "filter options" opts -qS "=" && ret=0 - fi - - return ret -} - -__docker_stack_complete_services_filters() { - [[ $PREFIX = -* ]] && return 1 - integer ret=1 - - if compset -P '*='; then - case "${${words[-1]%=*}#*=}" in - *) - _message 'value' && ret=0 - ;; - esac - else - opts=('id' 'label' 'name') - _describe -t filter-opts "filter options" opts -qS "=" && ret=0 - fi - - return ret -} - -__docker_stacks() { - [[ $PREFIX = -* ]] && return 1 - integer ret=1 - local line s - declare -a lines stacks - - lines=(${(f)${:-"$(_call_program commands docker $docker_options stack ls)"$'\n'}}) - - # Parse header line to find columns - local i=1 j=1 k header=${lines[1]} - declare -A begin end - while (( j < ${#header} - 1 )); do - i=$(( j + ${${header[$j,-1]}[(i)[^ ]]} - 1 )) - j=$(( i + ${${header[$i,-1]}[(i) ]} - 1 )) - k=$(( j + ${${header[$j,-1]}[(i)[^ ]]} - 2 )) - begin[${header[$i,$((j-1))]}]=$i - end[${header[$i,$((j-1))]}]=$k - done - end[${header[$i,$((j-1))]}]=-1 - lines=(${lines[2,-1]}) - - # Service NAME - for line in $lines; do - s="${line[${begin[NAME]},${end[NAME]}]%% ##}" - stacks=($stacks $s) - done - - _describe -t stacks-list "stacks" stacks "$@" && ret=0 - return ret -} - -__docker_complete_stacks() { - [[ $PREFIX = -* ]] && return 1 - __docker_stacks "$@" -} - -__docker_stack_commands() { - local -a _docker_stack_subcommands - _docker_stack_subcommands=( - "deploy:Deploy a new stack or update an existing stack" - "ls:List stacks" - "ps:List the tasks in the stack" - "rm:Remove the stack" - "services:List the services in the stack" - ) - _describe -t docker-stack-commands "docker stack command" _docker_stack_subcommands -} - -__docker_stack_subcommand() { - local -a _command_args opts_help - local expl help="--help" - integer ret=1 - - opts_help=("(: -)--help[Print usage]") - - case "$words[1]" in - (deploy|up) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -c --compose-file)"{-c=,--compose-file=}"[Path to a Compose file, or '-' to read from stdin]:compose file:_files -g \"*.(yml|yaml)\"" \ - "($help)--with-registry-auth[Send registry authentication details to Swarm agents]" \ - "($help -):stack:__docker_complete_stacks" && ret=0 - ;; - (ls|list) - _arguments $(__docker_arguments) \ - $opts_help && ret=0 - ;; - (ps) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -a --all)"{-a,--all}"[Display all tasks]" \ - "($help)*"{-f=,--filter=}"[Filter output based on conditions provided]:filter:__docker_stack_complete_ps_filters" \ - "($help)--format=[Format the output using the given go template]:template: " \ - "($help)--no-resolve[Do not map IDs to Names]" \ - "($help)--no-trunc[Do not truncate output]" \ - "($help -q --quiet)"{-q,--quiet}"[Only display task IDs]" \ - "($help -):stack:__docker_complete_stacks" && ret=0 - ;; - (rm|remove|down) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -):stack:__docker_complete_stacks" && ret=0 - ;; - (services) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help)*"{-f=,--filter=}"[Filter output based on conditions provided]:filter:__docker_stack_complete_services_filters" \ - "($help)--format=[Format the output using the given Go template]:template: " \ - "($help -q --quiet)"{-q,--quiet}"[Only display IDs]" \ - "($help -):stack:__docker_complete_stacks" && ret=0 - ;; - (help) - _arguments $(__docker_arguments) ":subcommand:__docker_stack_commands" && ret=0 - ;; - esac - - return ret -} - -# EO stack - -# BO swarm - -__docker_swarm_commands() { - local -a _docker_swarm_subcommands - _docker_swarm_subcommands=( - "init:Initialize a swarm" - "join:Join a swarm as a node and/or manager" - "join-token:Manage join tokens" - "leave:Leave a swarm" - "unlock:Unlock swarm" - "unlock-key:Manage the unlock key" - "update:Update the swarm" - ) - _describe -t docker-swarm-commands "docker swarm command" _docker_swarm_subcommands -} - -__docker_swarm_subcommand() { - local -a _command_args opts_help - local expl help="--help" - integer ret=1 - - opts_help=("(: -)--help[Print usage]") - - case "$words[1]" in - (init) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help)--advertise-addr=[Advertised address]:ip\:port: " \ - "($help)--data-path-addr=[Data path IP or interface]:ip " \ - "($help)--data-path-port=[Data Path Port]:port " \ - "($help)--default-addr-pool=[Default address pool]" \ - "($help)--default-addr-pool-mask-length=[Default address pool subnet mask length]" \ - "($help)--autolock[Enable manager autolocking]" \ - "($help)--availability=[Availability of the node]:availability:(active drain pause)" \ - "($help)--cert-expiry=[Validity period for node certificates]:duration: " \ - "($help)--dispatcher-heartbeat=[Dispatcher heartbeat period]:duration: " \ - "($help)*--external-ca=[Specifications of one or more certificate signing endpoints]:endpoint: " \ - "($help)--force-new-cluster[Force create a new cluster from current state]" \ - "($help)--listen-addr=[Listen address]:ip\:port: " \ - "($help)--max-snapshots[Number of additional Raft snapshots to retain]" \ - "($help)--snapshot-interval[Number of log entries between Raft snapshots]" \ - "($help)--task-history-limit=[Task history retention limit]:limit: " && ret=0 - ;; - (join) - _arguments $(__docker_arguments) -A '-*' \ - $opts_help \ - "($help)--advertise-addr=[Advertised address]:ip\:port: " \ - "($help)--data-path-addr=[Data path IP or interface]:ip " \ - "($help)--availability=[Availability of the node]:availability:(active drain pause)" \ - "($help)--listen-addr=[Listen address]:ip\:port: " \ - "($help)--token=[Token for entry into the swarm]:secret: " \ - "($help -):host\:port: " && ret=0 - ;; - (join-token) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -q --quiet)"{-q,--quiet}"[Only display token]" \ - "($help)--rotate[Rotate join token]" \ - "($help -):role:(manager worker)" && ret=0 - ;; - (leave) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -f --force)"{-f,--force}"[Force this node to leave the swarm, ignoring warnings]" && ret=0 - ;; - (unlock) - _arguments $(__docker_arguments) \ - $opts_help && ret=0 - ;; - (unlock-key) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -q --quiet)"{-q,--quiet}"[Only display token]" \ - "($help)--rotate[Rotate unlock token]" && ret=0 - ;; - (update) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help)--autolock[Enable manager autolocking]" \ - "($help)--cert-expiry=[Validity period for node certificates]:duration: " \ - "($help)--dispatcher-heartbeat=[Dispatcher heartbeat period]:duration: " \ - "($help)*--external-ca=[Specifications of one or more certificate signing endpoints]:endpoint: " \ - "($help)--max-snapshots[Number of additional Raft snapshots to retain]" \ - "($help)--snapshot-interval[Number of log entries between Raft snapshots]" \ - "($help)--task-history-limit=[Task history retention limit]:limit: " && ret=0 - ;; - (help) - _arguments $(__docker_arguments) ":subcommand:__docker_network_commands" && ret=0 - ;; - esac - - return ret -} - -# EO swarm - -# BO system - -__docker_system_commands() { - local -a _docker_system_subcommands - _docker_system_subcommands=( - "df:Show docker filesystem usage" - "events:Get real time events from the server" - "info:Display system-wide information" - "prune:Remove unused data" - ) - _describe -t docker-system-commands "docker system command" _docker_system_subcommands -} - -__docker_system_subcommand() { - local -a _command_args opts_help - local expl help="--help" - integer ret=1 - - opts_help=("(: -)--help[Print usage]") - - case "$words[1]" in - (df) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -v --verbose)"{-v,--verbose}"[Show detailed information on space usage]" && ret=0 - ;; - (events) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help)*"{-f=,--filter=}"[Filter values]:filter:__docker_complete_events_filter" \ - "($help)--since=[Events created since this timestamp]:timestamp: " \ - "($help)--until=[Events created until this timestamp]:timestamp: " \ - "($help)--format=[Format the output using the given go template]:template: " && ret=0 - ;; - (info) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -f --format)"{-f=,--format=}"[Format the output using the given go template]:template: " && ret=0 - ;; - (prune) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -a --all)"{-a,--all}"[Remove all unused data, not just dangling ones]" \ - "($help)*--filter=[Filter values]:filter:__docker_complete_prune_filters" \ - "($help -f --force)"{-f,--force}"[Do not prompt for confirmation]" \ - "($help)--volumes=[Remove all unused volumes]" && ret=0 - ;; - (help) - _arguments $(__docker_arguments) ":subcommand:__docker_volume_commands" && ret=0 - ;; - esac - - return ret -} - -# EO system - -# BO volume - -__docker_volume_complete_ls_filters() { - [[ $PREFIX = -* ]] && return 1 - integer ret=1 - - if compset -P '*='; then - case "${${words[-1]%=*}#*=}" in - (dangling) - dangling_opts=('true' 'false') - _describe -t dangling-filter-opts "Dangling Filter Options" dangling_opts && ret=0 - ;; - (driver) - __docker_complete_info_plugins Volume && ret=0 - ;; - (name) - __docker_complete_volumes && ret=0 - ;; - *) - _message 'value' && ret=0 - ;; - esac - else - opts=('dangling' 'driver' 'label' 'name') - _describe -t filter-opts "Filter Options" opts -qS "=" && ret=0 - fi - - return ret -} - -__docker_complete_volumes() { - [[ $PREFIX = -* ]] && return 1 - integer ret=1 - declare -a lines volumes - - lines=(${(f)${:-"$(_call_program commands docker $docker_options volume ls)"$'\n'}}) - - # Parse header line to find columns - local i=1 j=1 k header=${lines[1]} - declare -A begin end - while (( j < ${#header} - 1 )); do - i=$(( j + ${${header[$j,-1]}[(i)[^ ]]} - 1 )) - j=$(( i + ${${header[$i,-1]}[(i) ]} - 1 )) - k=$(( j + ${${header[$j,-1]}[(i)[^ ]]} - 2 )) - begin[${header[$i,$((j-1))]}]=$i - end[${header[$i,$((j-1))]}]=$k - done - end[${header[$i,$((j-1))]}]=-1 - lines=(${lines[2,-1]}) - - # Names - local line s - for line in $lines; do - s="${line[${begin[VOLUME NAME]},${end[VOLUME NAME]}]%% ##}" - s="$s:${(l:7:: :::)${${line[${begin[DRIVER]},${end[DRIVER]}]}%% ##}}" - volumes=($volumes $s) - done - - _describe -t volumes-list "volumes" volumes && ret=0 - return ret -} - -__docker_volume_commands() { - local -a _docker_volume_subcommands - _docker_volume_subcommands=( - "create:Create a volume" - "inspect:Display detailed information on one or more volumes" - "ls:List volumes" - "prune:Remove all unused volumes" - "rm:Remove one or more volumes" - ) - _describe -t docker-volume-commands "docker volume command" _docker_volume_subcommands -} - -__docker_volume_subcommand() { - local -a _command_args opts_help - local expl help="--help" - integer ret=1 - - opts_help=("(: -)--help[Print usage]") - - case "$words[1]" in - (create) - _arguments $(__docker_arguments) -A '-*' \ - $opts_help \ - "($help -d --driver)"{-d=,--driver=}"[Volume driver name]:Driver name:(local)" \ - "($help)*--label=[Set metadata for a volume]:label=value: " \ - "($help)*"{-o=,--opt=}"[Driver specific options]:Driver option: " \ - "($help -)1:Volume name: " && ret=0 - ;; - (inspect) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -f --format)"{-f=,--format=}"[Format the output using the given go template]:template: " \ - "($help -)1:volume:__docker_complete_volumes" && ret=0 - ;; - (ls) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help)*"{-f=,--filter=}"[Provide filter values]:filter:__docker_volume_complete_ls_filters" \ - "($help)--format=[Format the output using the given Go template]:template: " \ - "($help -q --quiet)"{-q,--quiet}"[Only display volume names]" && ret=0 - ;; - (prune) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -f --force)"{-f,--force}"[Do not prompt for confirmation]" && ret=0 - ;; - (rm) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -f --force)"{-f,--force}"[Force the removal of one or more volumes]" \ - "($help -):volume:__docker_complete_volumes" && ret=0 - ;; - (help) - _arguments $(__docker_arguments) ":subcommand:__docker_volume_commands" && ret=0 - ;; - esac - - return ret -} - -# EO volume - -# BO context - -__docker_complete_contexts() { - [[ $PREFIX = -* ]] && return 1 - integer ret=1 - declare -a contexts - - contexts=(${(f)${:-"$(_call_program commands docker $docker_options context ls -q)"$'\n'}}) - - _describe -t context-list "context" contexts && ret=0 - return ret -} - -__docker_context_commands() { - local -a _docker_context_subcommands - _docker_context_subcommands=( - "create:Create new context" - "inspect:Display detailed information on one or more contexts" - "list:List available contexts" - "rm:Remove one or more contexts" - "show:Print the current context" - "update:Update a context" - "use:Set the default context" - ) - _describe -t docker-context-commands "docker context command" _docker_context_subcommands -} - -__docker_context_subcommand() { - local -a _command_args opts_help - local expl help="--help" - integer ret=1 - - opts_help=("(: -)--help[Print usage]") - - case "$words[1]" in - (create) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help)--description=[Description of the context]:description:" \ - "($help)--docker=[Set the docker endpoint]:docker:" \ - "($help)--from=[Create context from a named context]:from:__docker_complete_contexts" \ - "($help -):name: " && ret=0 - ;; - (use) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -)1:context:__docker_complete_contexts" && ret=0 - ;; - (inspect) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -)1:context:__docker_complete_contexts" && ret=0 - ;; - (rm) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -)1:context:__docker_complete_contexts" && ret=0 - ;; - (update) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help)--description=[Description of the context]:description:" \ - "($help)--docker=[Set the docker endpoint]:docker:" \ - "($help -):name:" && ret=0 - ;; - esac - - return ret -} - -# EO context - -__docker_caching_policy() { - oldp=( "$1"(Nmh+1) ) # 1 hour - (( $#oldp )) -} - -__docker_commands() { - local cache_policy - integer force_invalidation=0 - - zstyle -s ":completion:${curcontext}:" cache-policy cache_policy - if [[ -z "$cache_policy" ]]; then - zstyle ":completion:${curcontext}:" cache-policy __docker_caching_policy - fi - - if ( (( ! ${+_docker_hide_legacy_commands} )) || _cache_invalid docker_hide_legacy_commands ) \ - && ! _retrieve_cache docker_hide_legacy_commands; - then - _docker_hide_legacy_commands="${DOCKER_HIDE_LEGACY_COMMANDS}" - _store_cache docker_hide_legacy_commands _docker_hide_legacy_commands - fi - - if [[ "${_docker_hide_legacy_commands}" != "${DOCKER_HIDE_LEGACY_COMMANDS}" ]]; then - force_invalidation=1 - _docker_hide_legacy_commands="${DOCKER_HIDE_LEGACY_COMMANDS}" - _store_cache docker_hide_legacy_commands _docker_hide_legacy_commands - fi - - if ( [[ ${+_docker_subcommands} -eq 0 ]] || _cache_invalid docker_subcommands ) \ - && ! _retrieve_cache docker_subcommands || [[ ${force_invalidation} -eq 1 ]]; - then - local -a lines - lines=(${(f)"$(_call_program commands docker 2>&1)"}) - _docker_subcommands=(${${${(M)${lines[$((${lines[(i)*Commands:]} + 1)),-1]}:# *}## #}/\*# ##/:}) - _docker_subcommands=($_docker_subcommands 'daemon:Enable daemon mode' 'help:Show help for a command') - (( $#_docker_subcommands > 2 )) && _store_cache docker_subcommands _docker_subcommands - fi - _describe -t docker-commands "docker command" _docker_subcommands -} - -__docker_subcommand() { - local -a _command_args opts_help - local expl help="--help" - integer ret=1 - - opts_help=("(: -)--help[Print usage]") - - case "$words[1]" in - (attach|commit|cp|create|diff|exec|export|kill|logs|pause|unpause|port|rename|restart|rm|run|start|stats|stop|top|update|wait) - __docker_container_subcommand && ret=0 - ;; - (build|history|import|load|pull|push|save|tag) - __docker_image_subcommand && ret=0 - ;; - (checkpoint) - local curcontext="$curcontext" state - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -): :->command" \ - "($help -)*:: :->option-or-argument" && ret=0 - - case $state in - (command) - __docker_checkpoint_commands && ret=0 - ;; - (option-or-argument) - curcontext=${curcontext%:*:*}:docker-${words[-1]}: - __docker_checkpoint_subcommand && ret=0 - ;; - esac - ;; - (container) - local curcontext="$curcontext" state - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -): :->command" \ - "($help -)*:: :->option-or-argument" && ret=0 - - case $state in - (command) - __docker_container_commands && ret=0 - ;; - (option-or-argument) - curcontext=${curcontext%:*:*}:docker-${words[-1]}: - __docker_container_subcommand && ret=0 - ;; - esac - ;; - (context) - local curcontext="$curcontext" state - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -): :->command" \ - "($help -)*:: :->option-or-argument" && ret=0 - - case $state in - (command) - __docker_context_commands && ret=0 - ;; - (option-or-argument) - curcontext=${curcontext%:*:*}:docker-${words[-1]}: - __docker_context_subcommand && ret=0 - ;; - esac - ;; - (daemon) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help)*--add-runtime=[Register an additional OCI compatible runtime]:runtime:__docker_complete_runtimes" \ - "($help)*--allow-nondistributable-artifacts=[Push nondistributable artifacts to specified registries]:registry: " \ - "($help)--api-cors-header=[CORS headers in the Engine API]:CORS headers: " \ - "($help)*--authorization-plugin=[Authorization plugins to load]" \ - "($help -b --bridge)"{-b=,--bridge=}"[Attach containers to a network bridge]:bridge:_net_interfaces" \ - "($help)--bip=[Network bridge IP]:IP address: " \ - "($help)--cgroup-parent=[Parent cgroup for all containers]:cgroup: " \ - "($help)--config-file=[Path to daemon configuration file]:Config File:_files" \ - "($help)--containerd=[Path to containerd socket]:socket:_files -g \"*.sock\"" \ - "($help)--containerd-namespace=[Containerd namespace to use]:containerd namespace:" \ - "($help)--containerd-plugins-namespace=[Containerd namespace to use for plugins]:containerd namespace:" \ - "($help)--data-root=[Root directory of persisted Docker data]:path:_directories" \ - "($help -D --debug)"{-D,--debug}"[Enable debug mode]" \ - "($help)--default-gateway[Container default gateway IPv4 address]:IPv4 address: " \ - "($help)--default-gateway-v6[Container default gateway IPv6 address]:IPv6 address: " \ - "($help)--default-shm-size=[Default shm size for containers]:size:" \ - "($help)*--default-ulimit=[Default ulimits for containers]:ulimit: " \ - "($help)*--dns=[DNS server to use]:DNS: " \ - "($help)*--dns-opt=[DNS options to use]:DNS option: " \ - "($help)*--dns-search=[DNS search domains to use]:DNS search: " \ - "($help)*--exec-opt=[Runtime execution options]:runtime execution options: " \ - "($help)--exec-root=[Root directory for execution state files]:path:_directories" \ - "($help)--experimental[Enable experimental features]" \ - "($help)--fixed-cidr=[IPv4 subnet for fixed IPs]:IPv4 subnet: " \ - "($help)--fixed-cidr-v6=[IPv6 subnet for fixed IPs]:IPv6 subnet: " \ - "($help -G --group)"{-G=,--group=}"[Group for the unix socket]:group:_groups" \ - "($help -H --host)"{-H=,--host=}"[tcp://host:port to bind/connect to]:host: " \ - "($help)--icc[Enable inter-container communication]" \ - "($help)--init[Run an init inside containers to forward signals and reap processes]" \ - "($help)--init-path=[Path to the docker-init binary]:docker-init binary:_files" \ - "($help)*--insecure-registry=[Enable insecure registry communication]:registry: " \ - "($help)--ip=[Default IP when binding container ports]" \ - "($help)--ip-forward[Enable net.ipv4.ip_forward]" \ - "($help)--ip-masq[Enable IP masquerading]" \ - "($help)--iptables[Enable addition of iptables rules]" \ - "($help)--ipv6[Enable IPv6 networking]" \ - "($help -l --log-level)"{-l=,--log-level=}"[Logging level]:level:(debug info warn error fatal)" \ - "($help)*--label=[Key=value labels]:label: " \ - "($help)--live-restore[Enable live restore of docker when containers are still running]" \ - "($help)--log-driver=[Default driver for container logs]:logging driver:__docker_complete_log_drivers" \ - "($help)*--log-opt=[Default log driver options for containers]:log driver options:__docker_complete_log_options" \ - "($help)--max-concurrent-downloads[Set the max concurrent downloads for each pull]" \ - "($help)--max-concurrent-uploads[Set the max concurrent uploads for each push]" \ - "($help)--max-download-attempts[Set the max download attempts for each pull]" \ - "($help)--mtu=[Network MTU]:mtu:(0 576 1420 1500 9000)" \ - "($help)--oom-score-adjust=[Set the oom_score_adj for the daemon]:oom-score:(-500)" \ - "($help -p --pidfile)"{-p=,--pidfile=}"[Path to use for daemon PID file]:PID file:_files" \ - "($help)--raw-logs[Full timestamps without ANSI coloring]" \ - "($help)*--registry-mirror=[Preferred registry mirror]:registry mirror: " \ - "($help)--seccomp-profile=[Path to seccomp profile]:path:_files -g \"*.json\"" \ - "($help -s --storage-driver)"{-s=,--storage-driver=}"[Storage driver to use]:driver:(aufs btrfs devicemapper overlay overlay2 vfs zfs)" \ - "($help)--selinux-enabled[Enable selinux support]" \ - "($help)--shutdown-timeout=[Set the shutdown timeout value in seconds]:time: " \ - "($help)*--storage-opt=[Storage driver options]:storage driver options: " \ - "($help)--tls[Use TLS]" \ - "($help)--tlscacert=[Trust certs signed only by this CA]:PEM file:_files -g \"*.(pem|crt)\"" \ - "($help)--tlscert=[Path to TLS certificate file]:PEM file:_files -g \"*.(pem|crt)\"" \ - "($help)--tlskey=[Path to TLS key file]:Key file:_files -g \"*.(pem|key)\"" \ - "($help)--tlsverify[Use TLS and verify the remote]" \ - "($help)--userns-remap=[User/Group setting for user namespaces]:user\:group:->users-groups" \ - "($help)--userland-proxy[Use userland proxy for loopback traffic]" \ - "($help)--userland-proxy-path=[Path to the userland proxy binary]:binary:_files" \ - "($help)--validate[Validate daemon configuration and exit]" && ret=0 - - case $state in - (users-groups) - if compset -P '*:'; then - _groups && ret=0 - else - _describe -t userns-default "default Docker user management" '(default)' && ret=0 - _users && ret=0 - fi - ;; - esac - ;; - (events|info) - __docker_system_subcommand && ret=0 - ;; - (image) - local curcontext="$curcontext" state - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -): :->command" \ - "($help -)*:: :->option-or-argument" && ret=0 - - case $state in - (command) - __docker_image_commands && ret=0 - ;; - (option-or-argument) - curcontext=${curcontext%:*:*}:docker-${words[-1]}: - __docker_image_subcommand && ret=0 - ;; - esac - ;; - (images) - words[1]='ls' - __docker_image_subcommand && ret=0 - ;; - (inspect) - local state - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -f --format)"{-f=,--format=}"[Format the output using the given go template]:template: " \ - "($help -s --size)"{-s,--size}"[Display total file sizes if the type is container]" \ - "($help)--type=[Return JSON for specified type]:type:(container image network node plugin service volume)" \ - "($help -)*: :->values" && ret=0 - - case $state in - (values) - if [[ ${words[(r)--type=container]} == --type=container ]]; then - __docker_complete_containers && ret=0 - elif [[ ${words[(r)--type=image]} == --type=image ]]; then - __docker_complete_images && ret=0 - elif [[ ${words[(r)--type=network]} == --type=network ]]; then - __docker_complete_networks && ret=0 - elif [[ ${words[(r)--type=node]} == --type=node ]]; then - __docker_complete_nodes && ret=0 - elif [[ ${words[(r)--type=plugin]} == --type=plugin ]]; then - __docker_complete_plugins && ret=0 - elif [[ ${words[(r)--type=service]} == --type=secrets ]]; then - __docker_complete_secrets && ret=0 - elif [[ ${words[(r)--type=service]} == --type=service ]]; then - __docker_complete_services && ret=0 - elif [[ ${words[(r)--type=volume]} == --type=volume ]]; then - __docker_complete_volumes && ret=0 - else - __docker_complete_containers - __docker_complete_images - __docker_complete_networks - __docker_complete_nodes - __docker_complete_plugins - __docker_complete_secrets - __docker_complete_services - __docker_complete_volumes && ret=0 - fi - ;; - esac - ;; - (login) - _arguments $(__docker_arguments) -A '-*' \ - $opts_help \ - "($help -p --password)"{-p=,--password=}"[Password]:password: " \ - "($help)--password-stdin[Read password from stdin]" \ - "($help -u --username)"{-u=,--username=}"[Username]:username: " \ - "($help -)1:server: " && ret=0 - ;; - (logout) - _arguments $(__docker_arguments) -A '-*' \ - $opts_help \ - "($help -)1:server: " && ret=0 - ;; - (network) - local curcontext="$curcontext" state - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -): :->command" \ - "($help -)*:: :->option-or-argument" && ret=0 - - case $state in - (command) - __docker_network_commands && ret=0 - ;; - (option-or-argument) - curcontext=${curcontext%:*:*}:docker-${words[-1]}: - __docker_network_subcommand && ret=0 - ;; - esac - ;; - (node) - local curcontext="$curcontext" state - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -): :->command" \ - "($help -)*:: :->option-or-argument" && ret=0 - - case $state in - (command) - __docker_node_commands && ret=0 - ;; - (option-or-argument) - curcontext=${curcontext%:*:*}:docker-${words[-1]}: - __docker_node_subcommand && ret=0 - ;; - esac - ;; - (plugin) - local curcontext="$curcontext" state - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -): :->command" \ - "($help -)*:: :->option-or-argument" && ret=0 - - case $state in - (command) - __docker_plugin_commands && ret=0 - ;; - (option-or-argument) - curcontext=${curcontext%:*:*}:docker-${words[-1]}: - __docker_plugin_subcommand && ret=0 - ;; - esac - ;; - (ps) - words[1]='ls' - __docker_container_subcommand && ret=0 - ;; - (rmi) - words[1]='rm' - __docker_image_subcommand && ret=0 - ;; - (search) - _arguments $(__docker_arguments) -A '-*' \ - $opts_help \ - "($help)*"{-f=,--filter=}"[Filter values]:filter:__docker_complete_search_filters" \ - "($help)--limit=[Maximum returned search results]:limit:(1 5 10 25 50)" \ - "($help)--no-trunc[Do not truncate output]" \ - "($help -):term: " && ret=0 - ;; - (secret) - local curcontext="$curcontext" state - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -): :->command" \ - "($help -)*:: :->option-or-argument" && ret=0 - - case $state in - (command) - __docker_secret_commands && ret=0 - ;; - (option-or-argument) - curcontext=${curcontext%:*:*}:docker-${words[-1]}: - __docker_secret_subcommand && ret=0 - ;; - esac - ;; - (service) - local curcontext="$curcontext" state - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -): :->command" \ - "($help -)*:: :->option-or-argument" && ret=0 - - case $state in - (command) - __docker_service_commands && ret=0 - ;; - (option-or-argument) - curcontext=${curcontext%:*:*}:docker-${words[-1]}: - __docker_service_subcommand && ret=0 - ;; - esac - ;; - (stack) - local curcontext="$curcontext" state - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -): :->command" \ - "($help -)*:: :->option-or-argument" && ret=0 - - case $state in - (command) - __docker_stack_commands && ret=0 - ;; - (option-or-argument) - curcontext=${curcontext%:*:*}:docker-${words[-1]}: - __docker_stack_subcommand && ret=0 - ;; - esac - ;; - (swarm) - local curcontext="$curcontext" state - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -): :->command" \ - "($help -)*:: :->option-or-argument" && ret=0 - - case $state in - (command) - __docker_swarm_commands && ret=0 - ;; - (option-or-argument) - curcontext=${curcontext%:*:*}:docker-${words[-1]}: - __docker_swarm_subcommand && ret=0 - ;; - esac - ;; - (system) - local curcontext="$curcontext" state - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -): :->command" \ - "($help -)*:: :->option-or-argument" && ret=0 - - case $state in - (command) - __docker_system_commands && ret=0 - ;; - (option-or-argument) - curcontext=${curcontext%:*:*}:docker-${words[-1]}: - __docker_system_subcommand && ret=0 - ;; - esac - ;; - (version) - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -f --format)"{-f=,--format=}"[Format the output using the given go template]:template: " && ret=0 - ;; - (volume) - local curcontext="$curcontext" state - _arguments $(__docker_arguments) \ - $opts_help \ - "($help -): :->command" \ - "($help -)*:: :->option-or-argument" && ret=0 - - case $state in - (command) - __docker_volume_commands && ret=0 - ;; - (option-or-argument) - curcontext=${curcontext%:*:*}:docker-${words[-1]}: - __docker_volume_subcommand && ret=0 - ;; - esac - ;; - (help) - _arguments $(__docker_arguments) ":subcommand:__docker_commands" && ret=0 - ;; - esac - - return ret -} - -_docker() { - # Support for subservices, which allows for `compdef _docker docker-shell=_docker_containers`. - # Based on /usr/share/zsh/functions/Completion/Unix/_git without support for `ret`. - if [[ $service != docker ]]; then - _call_function - _$service - return - fi - - local curcontext="$curcontext" state line help="-h --help" - integer ret=1 - typeset -A opt_args - - _arguments $(__docker_arguments) -C \ - "(: -)"{-h,--help}"[Print usage]" \ - "($help)--config[Location of client config files]:path:_directories" \ - "($help -c --context)"{-c=,--context=}"[Execute the command in a docker context]:context:__docker_complete_contexts" \ - "($help -D --debug)"{-D,--debug}"[Enable debug mode]" \ - "($help -H --host)"{-H=,--host=}"[tcp://host:port to bind/connect to]:host: " \ - "($help -l --log-level)"{-l=,--log-level=}"[Logging level]:level:(debug info warn error fatal)" \ - "($help)--tls[Use TLS]" \ - "($help)--tlscacert=[Trust certs signed only by this CA]:PEM file:_files -g "*.(pem|crt)"" \ - "($help)--tlscert=[Path to TLS certificate file]:PEM file:_files -g "*.(pem|crt)"" \ - "($help)--tlskey=[Path to TLS key file]:Key file:_files -g "*.(pem|key)"" \ - "($help)--tlsverify[Use TLS and verify the remote]" \ - "($help)--userland-proxy[Use userland proxy for loopback traffic]" \ - "($help -v --version)"{-v,--version}"[Print version information and quit]" \ - "($help -): :->command" \ - "($help -)*:: :->option-or-argument" && ret=0 - - local host=${opt_args[-H]}${opt_args[--host]} - local config=${opt_args[--config]} - local context=${opt_args[-c]}${opt_args[--context]} - local docker_options="${host:+--host $host} ${config:+--config $config} ${context:+--context $context} " - - case $state in - (command) - __docker_commands && ret=0 - ;; - (option-or-argument) - curcontext=${curcontext%:*:*}:docker-$words[1]: - __docker_subcommand && ret=0 - ;; - esac - - return ret -} - -_dockerd() { - integer ret=1 - words[1]='daemon' - __docker_subcommand && ret=0 - return ret -} - -_docker "$@" - -# Local Variables: -# mode: Shell-Script -# sh-indentation: 4 -# indent-tabs-mode: nil -# sh-basic-offset: 4 -# End: -# vim: ft=zsh sw=4 ts=4 et diff --git a/plugins/docker/docker.plugin.zsh b/plugins/docker/docker.plugin.zsh index 8684a9785..06a191a10 100644 --- a/plugins/docker/docker.plugin.zsh +++ b/plugins/docker/docker.plugin.zsh @@ -1,3 +1,13 @@ +# If the completion file doesn't exist yet, we need to autoload it and +# bind it to `docker`. Otherwise, compinit will have already done that. +if [[ ! -f "$ZSH_CACHE_DIR/completions/_docker" ]]; then + typeset -g -A _comps + autoload -Uz _docker + _comps[docker]=_docker +fi + +docker completion zsh >| "$ZSH_CACHE_DIR/completions/_docker" &| + alias dbl='docker build' alias dcin='docker container inspect' alias dcls='docker container ls' From 6bffaab2904d4bb37edad90e00b6f6e842d3811d Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Thu, 15 Jun 2023 20:06:56 +0200 Subject: [PATCH 297/672] fix(docker): only generate completion for docker >23 (#11754) --- plugins/docker/docker.plugin.zsh | 29 +++++++++++++++++++---------- 1 file changed, 19 insertions(+), 10 deletions(-) diff --git a/plugins/docker/docker.plugin.zsh b/plugins/docker/docker.plugin.zsh index 06a191a10..e8aad9230 100644 --- a/plugins/docker/docker.plugin.zsh +++ b/plugins/docker/docker.plugin.zsh @@ -1,13 +1,3 @@ -# If the completion file doesn't exist yet, we need to autoload it and -# bind it to `docker`. Otherwise, compinit will have already done that. -if [[ ! -f "$ZSH_CACHE_DIR/completions/_docker" ]]; then - typeset -g -A _comps - autoload -Uz _docker - _comps[docker]=_docker -fi - -docker completion zsh >| "$ZSH_CACHE_DIR/completions/_docker" &| - alias dbl='docker build' alias dcin='docker container inspect' alias dcls='docker container ls' @@ -41,3 +31,22 @@ alias dvls='docker volume ls' alias dvprune='docker volume prune' alias dxc='docker container exec' alias dxcit='docker container exec -it' + +if (( ! $+commands[docker] )); then + return +fi + +{ + # `docker completion` is only available from 23.0.0 on + local _docker_version=$(docker version --format '{{.Client.Version}}' 2>/dev/null) + if is-at-least 23.0.0 $_docker_version; then + # If the completion file doesn't exist yet, we need to autoload it and + # bind it to `docker`. Otherwise, compinit will have already done that. + if [[ ! -f "$ZSH_CACHE_DIR/completions/_docker" ]]; then + typeset -g -A _comps + autoload -Uz _docker + _comps[docker]=_docker + fi + docker completion zsh >| "$ZSH_CACHE_DIR/completions/_docker" + fi +} &| From 42b86327ed875ee182f8fc394b90ae9328a5ac00 Mon Sep 17 00:00:00 2001 From: rfigueroa <41128440+rfigueroa@users.noreply.github.com> Date: Fri, 16 Jun 2023 02:52:12 -0500 Subject: [PATCH 298/672] fix(mvn)!: rename `mvnd` to `mvndp` alias (#11756) BREAKING CHANGE: Rename alias to prevent conflicts with Apache Maven Daemon. --- plugins/mvn/README.md | 2 +- plugins/mvn/mvn.plugin.zsh | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/plugins/mvn/README.md b/plugins/mvn/README.md index 815dfd57c..4181fedc5 100644 --- a/plugins/mvn/README.md +++ b/plugins/mvn/README.md @@ -33,7 +33,7 @@ if it's found, or the mvn command otherwise. | `mvnct` | `mvn clean test` | | `mvncv` | `mvn clean verify` | | `mvncvst` | `mvn clean verify -DskipTests` | -| `mvnd` | `mvn deploy` | +| `mvndp` | `mvn deploy` | | `mvndocs` | `mvn dependency:resolve -Dclassifier=javadoc` | | `mvndt` | `mvn dependency:tree` | | `mvne` | `mvn eclipse:eclipse` | diff --git a/plugins/mvn/mvn.plugin.zsh b/plugins/mvn/mvn.plugin.zsh index da51f74df..a569a87fa 100644 --- a/plugins/mvn/mvn.plugin.zsh +++ b/plugins/mvn/mvn.plugin.zsh @@ -62,7 +62,7 @@ alias mvncp='mvn clean package' alias mvnct='mvn clean test' alias mvncv='mvn clean verify' alias mvncvst='mvn clean verify -DskipTests' -alias mvnd='mvn deploy' +alias mvndp='mvn deploy' alias mvndocs='mvn dependency:resolve -Dclassifier=javadoc' alias mvndt='mvn dependency:tree' alias mvne='mvn eclipse:eclipse' From f5cb9a6c978693c9570206f4267ba2589bef1b4c Mon Sep 17 00:00:00 2001 From: Ihor Date: Sat, 17 Jun 2023 13:28:55 +0200 Subject: [PATCH 299/672] fix(git): `gunwipall` now only resets once (#11758) Closes #11750 Co-authored-by: Carlo Sala --- plugins/git/README.md | 2 +- plugins/git/git.plugin.zsh | 18 +++++++----------- 2 files changed, 8 insertions(+), 12 deletions(-) diff --git a/plugins/git/README.md b/plugins/git/README.md index bf4b19f39..05cba8586 100644 --- a/plugins/git/README.md +++ b/plugins/git/README.md @@ -254,7 +254,7 @@ These features allow to pause a branch development and switch to another one (_" | work_in_progress | Echoes a warning if the current branch is a wip | | gwip | Commit wip branch | | gunwip | Uncommit wip branch | -| gunwipall | Uncommit `--wip--` commits recursively | +| gunwipall | Uncommit all recent `--wip--` commits | ### Deprecated functions diff --git a/plugins/git/git.plugin.zsh b/plugins/git/git.plugin.zsh index 192124301..66877df4f 100644 --- a/plugins/git/git.plugin.zsh +++ b/plugins/git/git.plugin.zsh @@ -27,18 +27,14 @@ function work_in_progress() { command git -c log.showSignature=false log -n 1 2>/dev/null | grep -q -- "--wip--" && echo "WIP!!" } -# Same as `gunwip` but recursive -# "Unwips" all recent `--wip--` commits in loop until there is no left +# Similar to `gunwip` but recursive "Unwips" all recent `--wip--` commits not just the last one function gunwipall() { - while true; do - commit_message=$(git rev-list --max-count=1 --format="%s" HEAD) - if [[ $commit_message =~ "--wip--" ]]; then - git reset "HEAD~1" - (( $? )) && return 1 - else - break - fi - done + local _commit=$(git log --grep='--wip--' --invert-grep --max-count=1 --format=format:%H) + + # Check if a commit without "--wip--" was found and it's not the same as HEAD + if [[ "$_commit" != "$(git rev-parse HEAD)" ]]; then + git reset $_commit || return 1 + fi } # Check if main exists and use instead of master From c0e811c90df387eca4223c7d4dbb3f2d32a684c7 Mon Sep 17 00:00:00 2001 From: WH-2099 Date: Mon, 19 Jun 2023 18:32:37 +0800 Subject: [PATCH 300/672] perf(archlinux): improve `paclist` performance (#11764) --- plugins/archlinux/archlinux.plugin.zsh | 5 +---- 1 file changed, 1 insertion(+), 4 deletions(-) diff --git a/plugins/archlinux/archlinux.plugin.zsh b/plugins/archlinux/archlinux.plugin.zsh index 796ff7adf..fca6548c0 100644 --- a/plugins/archlinux/archlinux.plugin.zsh +++ b/plugins/archlinux/archlinux.plugin.zsh @@ -25,10 +25,7 @@ alias pacown='pacman -Qo' alias pacupd="sudo pacman -Sy" function paclist() { - local pkgs=$(LC_ALL=C pacman -Qqe) - for pkg in ${(f)pkgs}; do - pacman -Qs --color=auto "^${pkg}\$" || break - done + pacman -Qqe | xargs -I{} -P0 --no-run-if-empty pacman -Qs --color=auto "^{}\$" } function pacdisowned() { From 8ace453f37acf0568bdb2e40920edb7598ad873a Mon Sep 17 00:00:00 2001 From: kang Date: Tue, 20 Jun 2023 08:49:56 +0200 Subject: [PATCH 301/672] feat(git-extras): update completion (2023-06-19 3a258cb) Closes #11712 --- plugins/git-extras/git-extras.plugin.zsh | 176 +++++++---------------- 1 file changed, 48 insertions(+), 128 deletions(-) diff --git a/plugins/git-extras/git-extras.plugin.zsh b/plugins/git-extras/git-extras.plugin.zsh index 6b96e12af..f5fd387d1 100644 --- a/plugins/git-extras/git-extras.plugin.zsh +++ b/plugins/git-extras/git-extras.plugin.zsh @@ -80,22 +80,10 @@ __gitex_specific_branch_names() { _wanted branch-names expl branch-name compadd - $branch_names } -__gitex_chore_branch_names() { - __gitex_specific_branch_names 'chore' -} - __gitex_feature_branch_names() { __gitex_specific_branch_names 'feature' } -__gitex_refactor_branch_names() { - __gitex_specific_branch_names 'refactor' -} - -__gitex_bug_branch_names() { - __gitex_specific_branch_names 'bug' -} - __gitex_submodule_names() { local expl declare -a submodule_names @@ -114,88 +102,29 @@ __gitex_author_names() { } # subcommands +# new subcommand should be added in alphabetical order _git-authors() { _arguments -C \ '(--list -l)'{--list,-l}'[show authors]' \ '--no-email[without email]' \ } -_git-bug() { - local curcontext=$curcontext state line ret=1 - declare -A opt_args - - _arguments -C \ - ': :->command' \ - '*:: :->option-or-argument' && ret=0 - - case $state in - (command) - declare -a commands - commands=( - 'finish:merge bug into the current branch' - ) - _describe -t commands command commands && ret=0 - ;; - (option-or-argument) - curcontext=${curcontext%:*}-$line[1]: - case $line[1] in - (finish) - _arguments -C \ - ':branch-name:__gitex_bug_branch_names' - ;; - -r|--remote ) - _arguments -C \ - ':remote-name:__gitex_remote_names' - ;; - esac - return 0 - esac - - _arguments \ - '(--remote -r)'{--remote,-r}'[setup remote tracking branch]' -} - - _git-changelog() { _arguments \ '(-l --list)'{-l,--list}'[list commits]' \ } -_git-chore() { - local curcontext=$curcontext state line ret=1 - declare -A opt_args - - _arguments -C \ - ': :->command' \ - '*:: :->option-or-argument' && ret=0 - - case $state in - (command) - declare -a commands - commands=( - 'finish:merge and delete the chore branch' - ) - _describe -t commands command commands && ret=0 - ;; - (option-or-argument) - curcontext=${curcontext%:*}-$line[1]: - case $line[1] in - (finish) - _arguments -C \ - ':branch-name:__gitex_chore_branch_names' - ;; - -r|--remote ) - _arguments -C \ - ':remote-name:__gitex_remote_names' - ;; - esac - return 0 - esac - +_git-clear() { _arguments \ - '(--remote -r)'{--remote,-r}'[setup remote tracking branch]' + '(-f --force)'{-f,--force}'[force clear]' \ + '(-h --help)'{-h,--help}'[help message]' \ } +_git-coauthor() { + _arguments \ + ':co-author[co-author to add]' \ + ':co-author-email[email address of co-author to add]' +} _git-contrib() { _arguments \ @@ -235,6 +164,11 @@ _git-delete-branch() { ':branch-name:__gitex_branch_names' } +_git-delete-squashed-branches() { + _arguments \ + ':branch-name:__gitex_branch_names' +} + _git-delete-submodule() { _arguments \ @@ -298,6 +232,7 @@ _git-feature() { case $line[1] in (finish) _arguments -C \ + '--squash[Use squash merge]' \ ':branch-name:__gitex_feature_branch_names' ;; -r|--remote ) @@ -327,20 +262,17 @@ _git-guilt() { } _git-ignore() { - _arguments -C \ + _arguments -C \ '(--local -l)'{--local,-l}'[show local gitignore]' \ '(--global -g)'{--global,-g}'[show global gitignore]' \ '(--private -p)'{--private,-p}'[show repo gitignore]' } -_git-ignore() { - _arguments -C \ - '(--append -a)'{--append,-a}'[append .gitignore]' \ - '(--replace -r)'{--replace,-r}'[replace .gitignore]' \ - '(--list-in-table -l)'{--list-in-table,-l}'[print available types in table format]' \ - '(--list-alphabetically -L)'{--list-alphabetically,-L}'[print available types in alphabetical order]' \ - '(--search -s)'{--search,-s}'[search word in available types]' +_git-info() { + _arguments -C \ + '(--color -c)'{--color,-c}'[use color for information titles]' \ + '--no-config[do not show list all variables set in config file, along with their values]' } @@ -357,50 +289,27 @@ _git-missing() { ':second-branch-name:__gitex_branch_names' } - -_git-refactor() { - local curcontext=$curcontext state line ret=1 - declare -A opt_args - +_git-release() { _arguments -C \ - ': :->command' \ - '*:: :->option-or-argument' && ret=0 - - case $state in - (command) - declare -a commands - commands=( - 'finish:merge refactor into the current branch' - ) - _describe -t commands command commands && ret=0 - ;; - (option-or-argument) - curcontext=${curcontext%:*}-$line[1]: - case $line[1] in - (finish) - _arguments -C \ - ':branch-name:__gitex_refactor_branch_names' - ;; - -r|--remote ) - _arguments -C \ - ':remote-name:__gitex_remote_names' - ;; - esac - return 0 - esac - - _arguments \ - '(--remote -r)'{--remote,-r}'[setup remote tracking branch]' + '-c[Generates/populates the changelog with all commit message since the last tag.]' \ + '-r[The "remote" repository that is destination of a push operation.]' \ + '-m[use the custom commit information instead of the default message.]' \ + '-s[Create a signed and annotated tag.]' \ + '-u[Create a tag, annotated and signed with the given key.]' \ + '--semver[If the latest tag in your repo matches the semver format requirement, you could increase part of it as the new release tag.]' \ + '--prefix[Add a prefix string to semver to allow more complex tags.]' \ + '--no-empty-commit[Avoid creating empty commit if nothing could be committed.]' \ + '--[The arguments listed after "--" separator will be passed to pre/post-release hook.]' } - _git-squash() { + _arguments '--squash-msg[commit with the squashed commit messages]' _arguments \ ':branch-name:__gitex_branch_names' } _git-stamp() { - _arguments -C \ + _arguments -C \ '(--replace -r)'{--replace,-r}'[replace stamps with same id]' } @@ -413,17 +322,19 @@ _git-standup() { '-g[Display GPG signed info]' \ '-h[Display help message]' \ '-L[Enable the inclusion of symbolic links]' \ - '-m[The depth of recursive directory search]' + '-m[The depth of recursive directory search]' \ + '-B[Display the commits in branch groups]' } _git-summary() { _arguments '--line[summarize with lines rather than commits]' + _arguments '--dedup-by-email[remove duplicate users by the email address]' + _arguments '--no-merges[exclude merge commits]' __gitex_commits } - _git-undo(){ - _arguments -C \ + _arguments -C \ '(--soft -s)'{--soft,-s}'[only rolls back the commit but changes remain un-staged]' \ '(--hard -h)'{--hard,-h}'[wipes your commit(s)]' } @@ -432,21 +343,26 @@ zstyle -g existing_user_commands ':completion:*:*:git:*' user-commands zstyle ':completion:*:*:git:*' user-commands $existing_user_commands \ alias:'define, search and show aliases' \ + abort:'abort current revert, merge, rebase, or cherry-pick process' \ archive-file:'export the current head of the git repository to an archive' \ authors:'generate authors report' \ - back:'undo and stage latest commits' \ + browse:'open repo website in browser' \ + browse-ci:'open repo CI page in browser' \ bug:'create bug branch' \ bulk:'run bulk commands' \ + brv:'list branches sorted by their last commit date'\ changelog:'generate a changelog report' \ chore:'create chore branch' \ clear-soft:'soft clean up a repository' \ clear:'rigorously clean up a repository' \ + coauthor:'add a co-author to the last commit' \ commits-since:'show commit logs since some date' \ contrib:'show user contributions' \ count:'show commit count' \ create-branch:'create branches' \ delete-branch:'delete branches' \ delete-merged-branches:'delete merged branches' \ + delete-squashed-branches:'delete squashed branches' \ delete-submodule:'delete submodules' \ delete-tag:'delete tags' \ delta:'lists changed files' \ @@ -465,11 +381,13 @@ zstyle ':completion:*:*:git:*' user-commands $existing_user_commands \ local-commits:'list local commits' \ lock:'lock a file excluded from version control' \ locked:'ls files that have been locked' \ + magic:'commits everything with a generated message' \ merge-into:'merge one branch into another' \ merge-repo:'merge two repo histories' \ missing:'show commits missing from another branch' \ mr:'checks out a merge request locally' \ obliterate:'rewrite past commits to remove some files' \ + paste:'send patches to pastebin sites' \ pr:'checks out a pull request locally' \ psykorebase:'rebase a branch with a merge commit' \ pull-request:'create pull request to GitHub project' \ @@ -479,6 +397,7 @@ zstyle ':completion:*:*:git:*' user-commands $existing_user_commands \ release:'commit, tag and push changes to the repository' \ rename-branch:'rename a branch' \ rename-tag:'rename a tag' \ + rename-remote:'rename a remote' \ repl:'git read-eval-print-loop' \ reset-file:'reset one file' \ root:'show path of root' \ @@ -495,4 +414,5 @@ zstyle ':completion:*:*:git:*' user-commands $existing_user_commands \ sync:'sync local branch with remote branch' \ touch:'touch and add file to the index' \ undo:'remove latest commits' \ - unlock:'unlock a file excluded from version control' + unlock:'unlock a file excluded from version control' \ + utimes:'change files modification time to their last commit date' From 4ba17232dae591f67b8e474fb013d2cb6555696e Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Tue, 20 Jun 2023 08:54:35 +0200 Subject: [PATCH 302/672] feat(nvm)!: remove soft-deprecated code BREAKING CHANGE: $NVM_LAZY, $NVM_LAZY_CMD, AND $NVM_AUTOLOAD cannot be used anymore to tweak nvm plugin. Use zstyle-based configurations instead. --- plugins/nvm/nvm.plugin.zsh | 23 ----------------------- 1 file changed, 23 deletions(-) diff --git a/plugins/nvm/nvm.plugin.zsh b/plugins/nvm/nvm.plugin.zsh index 31d275415..943678f7a 100644 --- a/plugins/nvm/nvm.plugin.zsh +++ b/plugins/nvm/nvm.plugin.zsh @@ -16,29 +16,6 @@ fi # Note: nvm is a function so we need to use `which` which nvm &>/dev/null && return -# TODO: 2022-11-11: Remove soft-deprecate options -if (( ${+NVM_LAZY} + ${+NVM_LAZY_CMD} + ${+NVM_AUTOLOAD} )); then - # Get list of NVM_* variable settings defined - local -a used_vars - used_vars=(${(o)parameters[(I)NVM_(AUTOLOAD|LAZY|LAZY_CMD)]}) - # Nicely print the list in the style `var1, var2 and var3` - echo "${fg[yellow]}[nvm plugin] Variable-style settings are deprecated. Instead of ${(j:, :)used_vars[1,-2]}${used_vars[-2]+ and }${used_vars[-1]}, use:\n" - if (( $+NVM_AUTOLOAD )); then - echo " zstyle ':omz:plugins:nvm' autoload yes" - zstyle ':omz:plugins:nvm' autoload yes - fi - if (( $+NVM_LAZY )); then - echo " zstyle ':omz:plugins:nvm' lazy yes" - zstyle ':omz:plugins:nvm' lazy yes - fi - if (( $+NVM_LAZY_CMD )); then - echo " zstyle ':omz:plugins:nvm' lazy-cmd $NVM_LAZY_CMD" - zstyle ':omz:plugins:nvm' lazy-cmd $NVM_LAZY_CMD - fi - echo "$reset_color" - unset used_vars NVM_AUTOLOAD NVM_LAZY NVM_LAZY_CMD -fi - if zstyle -t ':omz:plugins:nvm' lazy; then # Call nvm when first using nvm, node, npm, pnpm, yarn or other commands in lazy-cmd zstyle -a ':omz:plugins:nvm' lazy-cmd nvm_lazy_cmd From b5be2d39e2d2a598f7bba26d0bae2cce8c7d3d64 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Tue, 20 Jun 2023 09:36:11 +0200 Subject: [PATCH 303/672] fix(nvm): disable lazy-loading if autoload is set Closes #11748 --- plugins/nvm/README.md | 3 +++ plugins/nvm/nvm.plugin.zsh | 18 +++++++++++++----- 2 files changed, 16 insertions(+), 5 deletions(-) diff --git a/plugins/nvm/README.md b/plugins/nvm/README.md index 6830c14d0..eee3bf717 100644 --- a/plugins/nvm/README.md +++ b/plugins/nvm/README.md @@ -43,6 +43,9 @@ zstyle ':omz:plugins:nvm' lazy-cmd eslint prettier typescript ... #### `.nvmrc` autoload +Note: _this option cannot be used at the same time as `lazy`. `autoload` will override it and load `nvm` at +startup._ + If set, the plugin will automatically load a node version when if finds a [`.nvmrc` file](https://github.com/nvm-sh/nvm#nvmrc) in the current working directory indicating which node version to load. This can be done, similar as previous options, adding: diff --git a/plugins/nvm/nvm.plugin.zsh b/plugins/nvm/nvm.plugin.zsh index 943678f7a..484ef2964 100644 --- a/plugins/nvm/nvm.plugin.zsh +++ b/plugins/nvm/nvm.plugin.zsh @@ -16,7 +16,18 @@ fi # Note: nvm is a function so we need to use `which` which nvm &>/dev/null && return -if zstyle -t ':omz:plugins:nvm' lazy; then +if [[ -z "$NVM_DIR" ]]; then + echo "[oh-my-zsh] nvm installation cannot be found" + echo "[oh-my-zsh] set NVM_DIR to your installation" + return +fi +if [[ ! -f "$NVM_DIR/nvm.sh" ]]; then + echo "[oh-my-zsh] nvm.sh does not exist in $NVM_DIR" + return +fi + +if zstyle -t ':omz:plugins:nvm' lazy && \ + ! zstyle -t ':omz:plugins:nvm' autoload; then # Call nvm when first using nvm, node, npm, pnpm, yarn or other commands in lazy-cmd zstyle -a ':omz:plugins:nvm' lazy-cmd nvm_lazy_cmd eval " @@ -28,11 +39,8 @@ if zstyle -t ':omz:plugins:nvm' lazy; then } " unset nvm_lazy_cmd -elif [[ -f "$NVM_DIR/nvm.sh" ]]; then - # Load nvm if it exists in $NVM_DIR - source "$NVM_DIR/nvm.sh" else - return + source "$NVM_DIR/nvm.sh" fi # Autoload nvm when finding a .nvmrc file in the current directory From 8a6fc5c16d49368dc8f9ddd965a9e25ef652e129 Mon Sep 17 00:00:00 2001 From: Haltarys <45515869+Haltarys@users.noreply.github.com> Date: Tue, 20 Jun 2023 22:27:14 +0200 Subject: [PATCH 304/672] fix(docker): use `command docker` (#11766) --- plugins/docker/docker.plugin.zsh | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/plugins/docker/docker.plugin.zsh b/plugins/docker/docker.plugin.zsh index e8aad9230..434b1fc60 100644 --- a/plugins/docker/docker.plugin.zsh +++ b/plugins/docker/docker.plugin.zsh @@ -38,7 +38,7 @@ fi { # `docker completion` is only available from 23.0.0 on - local _docker_version=$(docker version --format '{{.Client.Version}}' 2>/dev/null) + local _docker_version=$(command docker version --format '{{.Client.Version}}' 2>/dev/null) if is-at-least 23.0.0 $_docker_version; then # If the completion file doesn't exist yet, we need to autoload it and # bind it to `docker`. Otherwise, compinit will have already done that. @@ -47,6 +47,6 @@ fi autoload -Uz _docker _comps[docker]=_docker fi - docker completion zsh >| "$ZSH_CACHE_DIR/completions/_docker" + command docker completion zsh >| "$ZSH_CACHE_DIR/completions/_docker" fi } &| From 22e710b4e4c8934706ef5047506b3b7594af9138 Mon Sep 17 00:00:00 2001 From: Gustavo Perdomo Date: Mon, 26 Jun 2023 04:35:38 -0400 Subject: [PATCH 305/672] fix(gcloud): add support for `brew` installations (#11772) --- plugins/gcloud/gcloud.plugin.zsh | 1 + 1 file changed, 1 insertion(+) diff --git a/plugins/gcloud/gcloud.plugin.zsh b/plugins/gcloud/gcloud.plugin.zsh index 9c26aea10..5c57302d3 100644 --- a/plugins/gcloud/gcloud.plugin.zsh +++ b/plugins/gcloud/gcloud.plugin.zsh @@ -6,6 +6,7 @@ if [[ -z "${CLOUDSDK_HOME}" ]]; then search_locations=( "$HOME/google-cloud-sdk" + "/usr/local/share/google-cloud-sdk" "/usr/local/Caskroom/google-cloud-sdk/latest/google-cloud-sdk" "/opt/homebrew/Caskroom/google-cloud-sdk/latest/google-cloud-sdk" "/usr/share/google-cloud-sdk" From d5f1f50ad2d62363785464d5b6eef1a009243d7a Mon Sep 17 00:00:00 2001 From: Richard Mitchell Date: Mon, 26 Jun 2023 04:48:17 -0400 Subject: [PATCH 306/672] docs(git-extras): clarify readme (#11776) --- plugins/git-extras/README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/git-extras/README.md b/plugins/git-extras/README.md index 2adc9d477..7eb53fcfd 100644 --- a/plugins/git-extras/README.md +++ b/plugins/git-extras/README.md @@ -1,6 +1,6 @@ # git-extras -This plugin provides completion definitions for some of the commands defined by [git-extras](https://github.com/tj/git-extras). +This plugin provides completion definitions for some of the commands defined by [git-extras](https://github.com/tj/git-extras), which must already be installed. To use it, add `git-extras` to the plugins array in your zshrc file: From 8cbe98469d9862d37d43ca4229dc8e915ec377a9 Mon Sep 17 00:00:00 2001 From: Devraj Mehta Date: Mon, 26 Jun 2023 13:05:22 -0400 Subject: [PATCH 307/672] fix(git): remove color codes from some aliases (#11770) --- plugins/git/README.md | 4 ++-- plugins/git/git.plugin.zsh | 4 ++-- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/plugins/git/README.md b/plugins/git/README.md index 05cba8586..d18531955 100644 --- a/plugins/git/README.md +++ b/plugins/git/README.md @@ -26,8 +26,8 @@ plugins=(... git) | gbda | git branch --no-color --merged \| grep -vE "^([+*]\|\s*($(git_main_branch)\|$(git_develop_branch))\s*$)" \| xargs git branch --delete 2>/dev/null | | gbD | git branch --delete --force | | gbg | git branch -vv | grep ": gone\]" | -| gbgd | local res=$(git branch -vv | grep ": gone\]" | awk '{print $1}') && [[ $res ]] && echo $res | xargs git branch -d | -| gbgD | local res=$(git branch -vv | grep ": gone\]" | awk '{print $1}') && [[ $res ]] && echo $res | xargs git branch -D | +| gbgd | git branch --no-color -vv | grep ": gone\]" | awk '"'"'{print $1}'"'"' | xargs git branch -d | +| gbgD | git branch --no-color -vv | grep ": gone\]" | awk '"'"'{print $1}'"'"' | xargs git branch -D | | gbl | git blame -b -w | | gbnm | git branch --no-merged | | gbr | git branch --remote | diff --git a/plugins/git/git.plugin.zsh b/plugins/git/git.plugin.zsh index 66877df4f..d04edea5e 100644 --- a/plugins/git/git.plugin.zsh +++ b/plugins/git/git.plugin.zsh @@ -84,8 +84,8 @@ alias gbd='git branch --delete' alias gbda='git branch --no-color --merged | command grep -vE "^([+*]|\s*($(git_main_branch)|$(git_develop_branch))\s*$)" | command xargs git branch --delete 2>/dev/null' alias gbD='git branch --delete --force' alias gbg='git branch -vv | grep ": gone\]"' -alias gbgd='local res=$(gbg | awk '"'"'{print $1}'"'"') && [[ $res ]] && echo $res | xargs git branch -d' -alias gbgD='local res=$(gbg | awk '"'"'{print $1}'"'"') && [[ $res ]] && echo $res | xargs git branch -D' +alias gbgd='git branch --no-color -vv | grep ": gone\]" | awk '"'"'{print $1}'"'"' | xargs git branch -d' +alias gbgD='git branch --no-color -vv | grep ": gone\]" | awk '"'"'{print $1}'"'"' | xargs git branch -D' alias gbl='git blame -b -w' alias gbnm='git branch --no-merged' alias gbr='git branch --remote' From 723af07a566cbadc26e61f69c44a1a67ed1ba0c8 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Thu, 29 Jun 2023 13:25:05 +0200 Subject: [PATCH 308/672] fix(docker): add static completion script --- plugins/docker/_docker | 3126 ++++++++++++++++++++++++++++++++++++++++ 1 file changed, 3126 insertions(+) create mode 100644 plugins/docker/_docker diff --git a/plugins/docker/_docker b/plugins/docker/_docker new file mode 100644 index 000000000..466b09d94 --- /dev/null +++ b/plugins/docker/_docker @@ -0,0 +1,3126 @@ +#compdef docker dockerd +# +# zsh completion for docker (http://docker.com) +# +# version: 0.3.0 +# github: https://github.com/felixr/docker-zsh-completion +# +# contributors: +# - Felix Riedel +# - Steve Durrheimer +# - Vincent Bernat +# - Rohan Verma +# +# license: +# +# Copyright (c) 2013, Felix Riedel +# All rights reserved. +# +# Redistribution and use in source and binary forms, with or without +# modification, are permitted provided that the following conditions are met: +# * Redistributions of source code must retain the above copyright +# notice, this list of conditions and the following disclaimer. +# * Redistributions in binary form must reproduce the above copyright +# notice, this list of conditions and the following disclaimer in the +# documentation and/or other materials provided with the distribution. +# * Neither the name of the nor the +# names of its contributors may be used to endorse or promote products +# derived from this software without specific prior written permission. +# +# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND +# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED +# WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE +# DISCLAIMED. IN NO EVENT SHALL BE LIABLE FOR ANY +# DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES +# (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; +# LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND +# ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT +# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS +# SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. +# + +# Short-option stacking can be enabled with: +# zstyle ':completion:*:*:docker:*' option-stacking yes +# zstyle ':completion:*:*:docker-*:*' option-stacking yes +__docker_arguments() { + if zstyle -t ":completion:${curcontext}:" option-stacking; then + print -- -s + fi +} + +__docker_get_containers() { + [[ $PREFIX = -* ]] && return 1 + integer ret=1 + local kind type line s + declare -a running stopped lines args names + + kind=$1; shift + type=$1; shift + [[ $kind = (stopped|all) ]] && args=($args -a) + + lines=(${(f)${:-"$(_call_program commands docker $docker_options ps --format 'table' --no-trunc $args)"$'\n'}}) + + # Parse header line to find columns + local i=1 j=1 k header=${lines[1]} + declare -A begin end + while (( j < ${#header} - 1 )); do + i=$(( j + ${${header[$j,-1]}[(i)[^ ]]} - 1 )) + j=$(( i + ${${header[$i,-1]}[(i) ]} - 1 )) + k=$(( j + ${${header[$j,-1]}[(i)[^ ]]} - 2 )) + begin[${header[$i,$((j-1))]}]=$i + end[${header[$i,$((j-1))]}]=$k + done + end[${header[$i,$((j-1))]}]=-1 # Last column, should go to the end of the line + lines=(${lines[2,-1]}) + + # Container ID + if [[ $type = (ids|all) ]]; then + for line in $lines; do + s="${${line[${begin[CONTAINER ID]},${end[CONTAINER ID]}]%% ##}[0,12]}" + s="$s:${(l:15:: :::)${${line[${begin[CREATED]},${end[CREATED]}]/ ago/}%% ##}}" + s="$s, ${${${line[${begin[IMAGE]},${end[IMAGE]}]}/:/\\:}%% ##}" + if [[ ${line[${begin[STATUS]},${end[STATUS]}]} = (Exit*|Created*) ]]; then + stopped=($stopped $s) + else + running=($running $s) + fi + done + fi + + # Names: we only display the one without slash. All other names + # are generated and may clutter the completion. However, with + # Swarm, all names may be prefixed by the swarm node name. + if [[ $type = (names|all) ]]; then + for line in $lines; do + names=(${(ps:,:)${${line[${begin[NAMES]},${end[NAMES]}]}%% *}}) + # First step: find a common prefix and strip it (swarm node case) + (( ${#${(u)names%%/*}} == 1 )) && names=${names#${names[1]%%/*}/} + # Second step: only keep the first name without a / + s=${${names:#*/*}[1]} + # If no name, well give up. + (( $#s != 0 )) || continue + s="$s:${(l:15:: :::)${${line[${begin[CREATED]},${end[CREATED]}]/ ago/}%% ##}}" + s="$s, ${${${line[${begin[IMAGE]},${end[IMAGE]}]}/:/\\:}%% ##}" + if [[ ${line[${begin[STATUS]},${end[STATUS]}]} = (Exit*|Created*) ]]; then + stopped=($stopped $s) + else + running=($running $s) + fi + done + fi + + [[ $kind = (running|all) ]] && _describe -t containers-running "running containers" running "$@" && ret=0 + [[ $kind = (stopped|all) ]] && _describe -t containers-stopped "stopped containers" stopped "$@" && ret=0 + return ret +} + +__docker_complete_stopped_containers() { + [[ $PREFIX = -* ]] && return 1 + __docker_get_containers stopped all "$@" +} + +__docker_complete_running_containers() { + [[ $PREFIX = -* ]] && return 1 + __docker_get_containers running all "$@" +} + +__docker_complete_containers() { + [[ $PREFIX = -* ]] && return 1 + __docker_get_containers all all "$@" +} + +__docker_complete_containers_ids() { + [[ $PREFIX = -* ]] && return 1 + __docker_get_containers all ids "$@" +} + +__docker_complete_containers_names() { + [[ $PREFIX = -* ]] && return 1 + __docker_get_containers all names "$@" +} + +__docker_complete_info_plugins() { + [[ $PREFIX = -* ]] && return 1 + integer ret=1 + emulate -L zsh + setopt extendedglob + local -a plugins + plugins=(${(ps: :)${(M)${(f)${${"$(_call_program commands docker $docker_options info)"##*$'\n'Plugins:}%%$'\n'^ *}}:# $1: *}## $1: }) + _describe -t plugins "$1 plugins" plugins && ret=0 + return ret +} + +__docker_complete_images() { + [[ $PREFIX = -* ]] && return 1 + integer ret=1 + declare -a images + images=(${${${(f)${:-"$(_call_program commands docker $docker_options images)"$'\n'}}[2,-1]}/(#b)([^ ]##) ##([^ ]##) ##([^ ]##)*/${match[3]}:${(r:15:: :::)match[2]} in ${match[1]}}) + _describe -t docker-images "images" images && ret=0 + __docker_complete_repositories_with_tags && ret=0 + return ret +} + +__docker_complete_repositories() { + [[ $PREFIX = -* ]] && return 1 + integer ret=1 + declare -a repos + repos=(${${${(f)${:-"$(_call_program commands docker $docker_options images)"$'\n'}}%% *}[2,-1]}) + repos=(${repos#}) + _describe -t docker-repos "repositories" repos && ret=0 + return ret +} + +__docker_complete_repositories_with_tags() { + [[ $PREFIX = -* ]] && return 1 + integer ret=1 + declare -a repos onlyrepos matched + declare m + repos=(${${${${(f)${:-"$(_call_program commands docker $docker_options images)"$'\n'}}[2,-1]}/ ##/:::}%% *}) + repos=(${${repos%:::}#}) + # Check if we have a prefix-match for the current prefix. + onlyrepos=(${repos%::*}) + for m in $onlyrepos; do + [[ ${PREFIX##${~~m}} != ${PREFIX} ]] && { + # Yes, complete with tags + repos=(${${repos/:::/:}/:/\\:}) + _describe -t docker-repos-with-tags "repositories with tags" repos && ret=0 + return ret + } + done + # No, only complete repositories + onlyrepos=(${${repos%:::*}/:/\\:}) + _describe -t docker-repos "repositories" onlyrepos -qS : && ret=0 + + return ret +} + +__docker_search() { + [[ $PREFIX = -* ]] && return 1 + local cache_policy + zstyle -s ":completion:${curcontext}:" cache-policy cache_policy + if [[ -z "$cache_policy" ]]; then + zstyle ":completion:${curcontext}:" cache-policy __docker_caching_policy + fi + + local searchterm cachename + searchterm="${words[$CURRENT]%/}" + cachename=_docker-search-$searchterm + + local expl + local -a result + if ( [[ ${(P)+cachename} -eq 0 ]] || _cache_invalid ${cachename#_} ) \ + && ! _retrieve_cache ${cachename#_}; then + _message "Searching for ${searchterm}..." + result=(${${${(f)${:-"$(_call_program commands docker $docker_options search $searchterm)"$'\n'}}%% *}[2,-1]}) + _store_cache ${cachename#_} result + fi + _wanted dockersearch expl 'available images' compadd -a result +} + +__docker_get_log_options() { + [[ $PREFIX = -* ]] && return 1 + + integer ret=1 + local log_driver=${opt_args[--log-driver]:-"all"} + local -a common_options common_options2 awslogs_options fluentd_options gelf_options journald_options json_file_options logentries_options syslog_options splunk_options + + common_options=("max-buffer-size" "mode") + common_options2=("env" "env-regex" "labels") + awslogs_options=($common_options "awslogs-create-group" "awslogs-datetime-format" "awslogs-group" "awslogs-multiline-pattern" "awslogs-region" "awslogs-stream" "tag") + fluentd_options=($common_options $common_options2 "fluentd-address" "fluentd-async-connect" "fluentd-buffer-limit" "fluentd-retry-wait" "fluentd-max-retries" "fluentd-sub-second-precision" "tag") + gcplogs_options=($common_options $common_options2 "gcp-log-cmd" "gcp-meta-id" "gcp-meta-name" "gcp-meta-zone" "gcp-project") + gelf_options=($common_options $common_options2 "gelf-address" "gelf-compression-level" "gelf-compression-type" "tag") + journald_options=($common_options $common_options2 "tag") + json_file_options=($common_options $common_options2 "max-file" "max-size") + logentries_options=($common_options $common_options2 "logentries-token" "tag") + syslog_options=($common_options $common_options2 "syslog-address" "syslog-facility" "syslog-format" "syslog-tls-ca-cert" "syslog-tls-cert" "syslog-tls-key" "syslog-tls-skip-verify" "tag") + splunk_options=($common_options $common_options2 "splunk-caname" "splunk-capath" "splunk-format" "splunk-gzip" "splunk-gzip-level" "splunk-index" "splunk-insecureskipverify" "splunk-source" "splunk-sourcetype" "splunk-token" "splunk-url" "splunk-verify-connection" "tag") + + [[ $log_driver = (awslogs|all) ]] && _describe -t awslogs-options "awslogs options" awslogs_options "$@" && ret=0 + [[ $log_driver = (fluentd|all) ]] && _describe -t fluentd-options "fluentd options" fluentd_options "$@" && ret=0 + [[ $log_driver = (gcplogs|all) ]] && _describe -t gcplogs-options "gcplogs options" gcplogs_options "$@" && ret=0 + [[ $log_driver = (gelf|all) ]] && _describe -t gelf-options "gelf options" gelf_options "$@" && ret=0 + [[ $log_driver = (journald|all) ]] && _describe -t journald-options "journald options" journald_options "$@" && ret=0 + [[ $log_driver = (json-file|all) ]] && _describe -t json-file-options "json-file options" json_file_options "$@" && ret=0 + [[ $log_driver = (logentries|all) ]] && _describe -t logentries-options "logentries options" logentries_options "$@" && ret=0 + [[ $log_driver = (syslog|all) ]] && _describe -t syslog-options "syslog options" syslog_options "$@" && ret=0 + [[ $log_driver = (splunk|all) ]] && _describe -t splunk-options "splunk options" splunk_options "$@" && ret=0 + + return ret +} + +__docker_complete_log_drivers() { + [[ $PREFIX = -* ]] && return 1 + integer ret=1 + drivers=(awslogs etwlogs fluentd gcplogs gelf journald json-file none splunk syslog) + _describe -t log-drivers "log drivers" drivers && ret=0 + return ret +} + +__docker_complete_log_options() { + [[ $PREFIX = -* ]] && return 1 + integer ret=1 + + if compset -P '*='; then + case "${${words[-1]%=*}#*=}" in + (syslog-format) + local opts=('rfc3164' 'rfc5424' 'rfc5424micro') + _describe -t syslog-format-opts "syslog format options" opts && ret=0 + ;; + (mode) + local opts=('blocking' 'non-blocking') + _describe -t mode-opts "mode options" opts && ret=0 + ;; + *) + _message 'value' && ret=0 + ;; + esac + else + __docker_get_log_options -qS "=" && ret=0 + fi + + return ret +} + +__docker_complete_detach_keys() { + [[ $PREFIX = -* ]] && return 1 + integer ret=1 + + compset -P "*," + keys=(${:-{a-z}}) + ctrl_keys=(${:-ctrl-{{a-z},{@,'[','\\','^',']',_}}}) + _describe -t detach_keys "[a-z]" keys -qS "," && ret=0 + _describe -t detach_keys-ctrl "'ctrl-' + 'a-z @ [ \\\\ ] ^ _'" ctrl_keys -qS "," && ret=0 +} + +__docker_complete_pid() { + [[ $PREFIX = -* ]] && return 1 + integer ret=1 + local -a opts vopts + + opts=('host') + vopts=('container') + + if compset -P '*:'; then + case "${${words[-1]%:*}#*=}" in + (container) + __docker_complete_running_containers && ret=0 + ;; + *) + _message 'value' && ret=0 + ;; + esac + else + _describe -t pid-value-opts "PID Options with value" vopts -qS ":" && ret=0 + _describe -t pid-opts "PID Options" opts && ret=0 + fi + + return ret +} + +__docker_complete_runtimes() { + [[ $PREFIX = -* ]] && return 1 + integer ret=1 + + emulate -L zsh + setopt extendedglob + local -a runtimes_opts + runtimes_opts=(${(ps: :)${(f)${${"$(_call_program commands docker $docker_options info)"##*$'\n'Runtimes: }%%$'\n'^ *}}}) + _describe -t runtimes-opts "runtimes options" runtimes_opts && ret=0 +} + +__docker_complete_ps_filters() { + [[ $PREFIX = -* ]] && return 1 + integer ret=1 + + if compset -P '*='; then + case "${${words[-1]%=*}#*=}" in + (ancestor) + __docker_complete_images && ret=0 + ;; + (before|since) + __docker_complete_containers && ret=0 + ;; + (health) + health_opts=('healthy' 'none' 'starting' 'unhealthy') + _describe -t health-filter-opts "health filter options" health_opts && ret=0 + ;; + (id) + __docker_complete_containers_ids && ret=0 + ;; + (is-task) + _describe -t boolean-filter-opts "filter options" boolean_opts && ret=0 + ;; + (name) + __docker_complete_containers_names && ret=0 + ;; + (network) + __docker_complete_networks && ret=0 + ;; + (status) + status_opts=('created' 'dead' 'exited' 'paused' 'restarting' 'running' 'removing') + _describe -t status-filter-opts "status filter options" status_opts && ret=0 + ;; + (volume) + __docker_complete_volumes && ret=0 + ;; + *) + _message 'value' && ret=0 + ;; + esac + else + opts=('ancestor' 'before' 'exited' 'expose' 'health' 'id' 'label' 'name' 'network' 'publish' 'since' 'status' 'volume') + _describe -t filter-opts "Filter Options" opts -qS "=" && ret=0 + fi + + return ret +} + +__docker_complete_search_filters() { + [[ $PREFIX = -* ]] && return 1 + integer ret=1 + declare -a boolean_opts opts + + boolean_opts=('true' 'false') + opts=('is-automated' 'is-official' 'stars') + + if compset -P '*='; then + case "${${words[-1]%=*}#*=}" in + (is-automated|is-official) + _describe -t boolean-filter-opts "filter options" boolean_opts && ret=0 + ;; + *) + _message 'value' && ret=0 + ;; + esac + else + _describe -t filter-opts "filter options" opts -qS "=" && ret=0 + fi + + return ret +} + +__docker_complete_images_filters() { + [[ $PREFIX = -* ]] && return 1 + integer ret=1 + declare -a boolean_opts opts + + boolean_opts=('true' 'false') + opts=('before' 'dangling' 'label' 'reference' 'since') + + if compset -P '*='; then + case "${${words[-1]%=*}#*=}" in + (before|reference|since) + __docker_complete_images && ret=0 + ;; + (dangling) + _describe -t boolean-filter-opts "filter options" boolean_opts && ret=0 + ;; + *) + _message 'value' && ret=0 + ;; + esac + else + _describe -t filter-opts "Filter Options" opts -qS "=" && ret=0 + fi + + return ret +} + +__docker_complete_events_filter() { + [[ $PREFIX = -* ]] && return 1 + integer ret=1 + declare -a opts + + opts=('container' 'daemon' 'event' 'image' 'label' 'network' 'scope' 'type' 'volume') + + if compset -P '*='; then + case "${${words[-1]%=*}#*=}" in + (container) + __docker_complete_containers && ret=0 + ;; + (daemon) + emulate -L zsh + setopt extendedglob + local -a daemon_opts + daemon_opts=( + ${(f)${${"$(_call_program commands docker $docker_options info)"##*$'\n'Name: }%%$'\n'^ *}} + ${${(f)${${"$(_call_program commands docker $docker_options info)"##*$'\n'ID: }%%$'\n'^ *}}//:/\\:} + ) + _describe -t daemon-filter-opts "daemon filter options" daemon_opts && ret=0 + ;; + (event) + local -a event_opts + event_opts=('attach' 'commit' 'connect' 'copy' 'create' 'delete' 'destroy' 'detach' 'die' 'disable' 'disconnect' 'enable' 'exec_create' 'exec_detach' + 'exec_start' 'export' 'health_status' 'import' 'install' 'kill' 'load' 'mount' 'oom' 'pause' 'pull' 'push' 'reload' 'remove' 'rename' 'resize' + 'restart' 'save' 'start' 'stop' 'tag' 'top' 'unmount' 'unpause' 'untag' 'update') + _describe -t event-filter-opts "event filter options" event_opts && ret=0 + ;; + (image) + __docker_complete_images && ret=0 + ;; + (network) + __docker_complete_networks && ret=0 + ;; + (scope) + local -a scope_opts + scope_opts=('local' 'swarm') + _describe -t scope-filter-opts "scope filter options" scope_opts && ret=0 + ;; + (type) + local -a type_opts + type_opts=('container' 'daemon' 'image' 'network' 'volume') + _describe -t type-filter-opts "type filter options" type_opts && ret=0 + ;; + (volume) + __docker_complete_volumes && ret=0 + ;; + *) + _message 'value' && ret=0 + ;; + esac + else + _describe -t filter-opts "filter options" opts -qS "=" && ret=0 + fi + + return ret +} + +__docker_complete_prune_filters() { + [[ $PREFIX = -* ]] && return 1 + integer ret=1 + declare -a opts + + opts=('until') + + if compset -P '*='; then + case "${${words[-1]%=*}#*=}" in + *) + _message 'value' && ret=0 + ;; + esac + else + _describe -t filter-opts "filter options" opts -qS "=" && ret=0 + fi + + return ret +} + +# BO checkpoint + +__docker_checkpoint_commands() { + local -a _docker_checkpoint_subcommands + _docker_checkpoint_subcommands=( + "create:Create a checkpoint from a running container" + "ls:List checkpoints for a container" + "rm:Remove a checkpoint" + ) + _describe -t docker-checkpoint-commands "docker checkpoint command" _docker_checkpoint_subcommands +} + +__docker_checkpoint_subcommand() { + local -a _command_args opts_help + local expl help="--help" + integer ret=1 + + opts_help=("(: -)--help[Print usage]") + + case "$words[1]" in + (create) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help)--checkpoint-dir=[Use a custom checkpoint storage directory]:dir:_directories" \ + "($help)--leave-running[Leave the container running after checkpoint]" \ + "($help -)1:container:__docker_complete_running_containers" \ + "($help -)2:checkpoint: " && ret=0 + ;; + (ls|list) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help)--checkpoint-dir=[Use a custom checkpoint storage directory]:dir:_directories" \ + "($help -)1:container:__docker_complete_containers" && ret=0 + ;; + (rm|remove) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help)--checkpoint-dir=[Use a custom checkpoint storage directory]:dir:_directories" \ + "($help -)1:container:__docker_complete_containers" \ + "($help -)2:checkpoint: " && ret=0 + ;; + (help) + _arguments $(__docker_arguments) ":subcommand:__docker_checkpoint_commands" && ret=0 + ;; + esac + + return ret +} + +# EO checkpoint + +# BO container + +__docker_container_commands() { + local -a _docker_container_subcommands + _docker_container_subcommands=( + "attach:Attach to a running container" + "commit:Create a new image from a container's changes" + "cp:Copy files/folders between a container and the local filesystem" + "create:Create a new container" + "diff:Inspect changes on a container's filesystem" + "exec:Execute a command in a running container" + "export:Export a container's filesystem as a tar archive" + "inspect:Display detailed information on one or more containers" + "kill:Kill one or more running containers" + "logs:Fetch the logs of a container" + "ls:List containers" + "pause:Pause all processes within one or more containers" + "port:List port mappings or a specific mapping for the container" + "prune:Remove all stopped containers" + "rename:Rename a container" + "restart:Restart one or more containers" + "rm:Remove one or more containers" + "run:Create and run a new container from an image" + "start:Start one or more stopped containers" + "stats:Display a live stream of container(s) resource usage statistics" + "stop:Stop one or more running containers" + "top:Display the running processes of a container" + "unpause:Unpause all processes within one or more containers" + "update:Update configuration of one or more containers" + "wait:Block until one or more containers stop, then print their exit codes" + ) + _describe -t docker-container-commands "docker container command" _docker_container_subcommands +} + +__docker_container_subcommand() { + local -a _command_args opts_help opts_attach_exec_run_start opts_create_run opts_create_run_update + local expl help="--help" + integer ret=1 + + opts_attach_exec_run_start=( + "($help)--detach-keys=[Escape key sequence used to detach a container]:sequence:__docker_complete_detach_keys" + ) + opts_create_run=( + "($help -a --attach)"{-a=,--attach=}"[Attach to stdin, stdout or stderr]:device:(STDIN STDOUT STDERR)" + "($help)*--add-host=[Add a custom host-to-IP mapping]:host\:ip mapping: " + "($help)*--annotation=[Add an annotation to the container (passed through to the OCI runtime)]:annotations: " + "($help)*--blkio-weight-device=[Block IO (relative device weight)]:device:Block IO weight: " + "($help)*--cap-add=[Add Linux capabilities]:capability: " + "($help)*--cap-drop=[Drop Linux capabilities]:capability: " + "($help)--cgroupns=[Cgroup namespace mode to use]:cgroup namespace mode: " + "($help)--cgroup-parent=[Parent cgroup for the container]:cgroup: " + "($help)--cidfile=[Write the container ID to the file]:CID file:_files" + "($help)--cpus=[Number of CPUs (default 0.000)]:cpus: " + "($help)*--device=[Add a host device to the container]:device:_files" + "($help)*--device-cgroup-rule=[Add a rule to the cgroup allowed devices list]:device:cgroup: " + "($help)*--device-read-bps=[Limit the read rate (bytes per second) from a device]:device:IO rate: " + "($help)*--device-read-iops=[Limit the read rate (IO per second) from a device]:device:IO rate: " + "($help)*--device-write-bps=[Limit the write rate (bytes per second) to a device]:device:IO rate: " + "($help)*--device-write-iops=[Limit the write rate (IO per second) to a device]:device:IO rate: " + "($help)--disable-content-trust[Skip image verification]" + "($help)*--dns=[Custom DNS servers]:DNS server: " + "($help)*--dns-option=[Custom DNS options]:DNS option: " + "($help)*--dns-search=[Custom DNS search domains]:DNS domains: " + "($help)*--domainname=[Container NIS domain name]:domainname:_hosts" + "($help)*"{-e=,--env=}"[Environment variables]:environment variable: " + "($help)--entrypoint=[Overwrite the default entrypoint of the image]:entry point: " + "($help)*--env-file=[Read environment variables from a file]:environment file:_files" + "($help)*--expose=[Expose a port from the container without publishing it]: " + "($help)*--gpus=[GPU devices to add to the container ('all' to pass all GPUs)]:device: " + "($help)*--group-add=[Set one or more supplementary user groups for the container]:group:_groups" + "($help -h --hostname)"{-h=,--hostname=}"[Container host name]:hostname:_hosts" + "($help -i --interactive)"{-i,--interactive}"[Keep stdin open even if not attached]" + "($help)--init[Run an init inside the container that forwards signals and reaps processes]" + "($help)--ip=[IPv4 address]:IPv4: " + "($help)--ip6=[IPv6 address]:IPv6: " + "($help)--ipc=[IPC namespace to use]:IPC namespace: " + "($help)--isolation=[Container isolation technology]:isolation:(default hyperv process)" + "($help)*--link=[Add link to another container]:link:->link" + "($help)*--link-local-ip=[Container IPv4/IPv6 link-local addresses]:IPv4/IPv6: " + "($help)*"{-l=,--label=}"[Container metadata]:label: " + "($help)--log-driver=[Default driver for container logs]:logging driver:__docker_complete_log_drivers" + "($help)*--log-opt=[Log driver specific options]:log driver options:__docker_complete_log_options" + "($help)--mac-address=[Container MAC address]:MAC address: " + "($help)*--mount=[Attach a filesystem mount to the container]:mount: " + "($help)--name=[Container name]:name: " + "($help)--network=[Connect a container to a network]:network mode:(bridge none container host)" + "($help)*--network-alias=[Add network-scoped alias for the container]:alias: " + "($help)--oom-kill-disable[Disable OOM Killer]" + "($help)--oom-score-adj[Tune the host's OOM preferences for containers (accepts -1000 to 1000)]" + "($help)--pids-limit[Tune container pids limit (set -1 for unlimited)]" + "($help -P --publish-all)"{-P,--publish-all}"[Publish all exposed ports]" + "($help)*"{-p=,--publish=}"[Expose a container's port to the host]:port:_ports" + "($help)--pid=[PID namespace to use]:PID namespace:__docker_complete_pid" + "($help)--privileged[Give extended privileges to this container]" + "($help -q --quiet)"{-q,--quiet}"[Suppress the pull output]" + "($help)--read-only[Mount the container's root filesystem as read only]" + "($help)*--security-opt=[Security options]:security option: " + "($help)*--shm-size=[Size of '/dev/shm' (format is '')]:shm size: " + "($help)--stop-signal=[Signal to kill a container]:signal:_signals" + "($help)--stop-timeout=[Timeout (in seconds) to stop a container]:time: " + "($help)*--sysctl=-[sysctl options]:sysctl: " + "($help -t --tty)"{-t,--tty}"[Allocate a pseudo-tty]" + "($help -u --user)"{-u=,--user=}"[Username or UID]:user:_users" + "($help)*--ulimit=[ulimit options]:ulimit: " + "($help)--userns=[Container user namespace]:user namespace:(host)" + "($help)--tmpfs[mount tmpfs]" + "($help)*-v[Bind mount a volume]:volume:_directories -W / -P '/' -S '\:' -r '/ '" + "($help)--volume-driver=[Optional volume driver for the container]:volume driver:(local)" + "($help)*--volumes-from=[Mount volumes from the specified container]:volume: " + "($help -w --workdir)"{-w=,--workdir=}"[Working directory inside the container]:directory:_directories" + ) + opts_create_run_update=( + "($help)--blkio-weight=[Block IO (relative weight), between 10 and 1000]:Block IO weight:(10 100 500 1000)" + "($help -c --cpu-shares)"{-c=,--cpu-shares=}"[CPU shares (relative weight)]:CPU shares:(0 10 100 200 500 800 1000)" + "($help)--cpu-period=[Limit the CPU CFS (Completely Fair Scheduler) period]:CPU period: " + "($help)--cpu-quota=[Limit the CPU CFS (Completely Fair Scheduler) quota]:CPU quota: " + "($help)--cpu-rt-period=[Limit the CPU real-time period]:CPU real-time period in microseconds: " + "($help)--cpu-rt-runtime=[Limit the CPU real-time runtime]:CPU real-time runtime in microseconds: " + "($help)--cpuset-cpus=[CPUs in which to allow execution]:CPUs: " + "($help)--cpuset-mems=[MEMs in which to allow execution]:MEMs: " + "($help)--kernel-memory=[Kernel memory limit in bytes]:Memory limit: " + "($help -m --memory)"{-m=,--memory=}"[Memory limit]:Memory limit: " + "($help)--memory-reservation=[Memory soft limit]:Memory limit: " + "($help)--memory-swap=[Total memory limit with swap]:Memory limit: " + "($help)--pids-limit[Tune container pids limit (set -1 for unlimited)]" + "($help)--restart=[Restart policy]:restart policy:(no on-failure always unless-stopped)" + ) + opts_help=("(: -)--help[Print usage]") + + case "$words[1]" in + (attach) + _arguments $(__docker_arguments) \ + $opts_help \ + $opts_attach_exec_run_start \ + "($help)--no-stdin[Do not attach stdin]" \ + "($help)--sig-proxy[Proxy all received signals to the process (non-TTY mode only)]" \ + "($help -):containers:__docker_complete_running_containers" && ret=0 + ;; + (commit) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -a --author)"{-a=,--author=}"[Author]:author: " \ + "($help)*"{-c=,--change=}"[Apply Dockerfile instruction to the created image]:Dockerfile:_files" \ + "($help -m --message)"{-m=,--message=}"[Commit message]:message: " \ + "($help -p --pause)"{-p,--pause}"[Pause container during commit]" \ + "($help -):container:__docker_complete_containers" \ + "($help -): :__docker_complete_repositories_with_tags" && ret=0 + ;; + (cp) + local state + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -L --follow-link)"{-L,--follow-link}"[Always follow symbol link]" \ + "($help -)1:container:->container" \ + "($help -)2:hostpath:_files" && ret=0 + case $state in + (container) + if compset -P "*:"; then + _files && ret=0 + else + __docker_complete_containers -qS ":" && ret=0 + fi + ;; + esac + ;; + (create) + local state + _arguments $(__docker_arguments) \ + $opts_help \ + $opts_create_run \ + $opts_create_run_update \ + "($help -): :__docker_complete_images" \ + "($help -):command: _command_names -e" \ + "($help -)*::arguments: _normal" && ret=0 + case $state in + (link) + if compset -P "*:"; then + _wanted alias expl "Alias" compadd -E "" && ret=0 + else + __docker_complete_running_containers -qS ":" && ret=0 + fi + ;; + esac + ;; + (diff) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -)*:containers:__docker_complete_containers" && ret=0 + ;; + (exec) + local state + _arguments $(__docker_arguments) \ + $opts_help \ + $opts_attach_exec_run_start \ + "($help -d --detach)"{-d,--detach}"[Detached mode: leave the container running in the background]" \ + "($help)*"{-e=,--env=}"[Set environment variables]:environment variable: " \ + "($help)*--env-file=[Read environment variables from a file]:environment file:_files" \ + "($help -i --interactive)"{-i,--interactive}"[Keep stdin open even if not attached]" \ + "($help)--privileged[Give extended Linux capabilities to the command]" \ + "($help -t --tty)"{-t,--tty}"[Allocate a pseudo-tty]" \ + "($help -u --user)"{-u=,--user=}"[Username or UID]:user:_users" \ + "($help -w --workdir)"{-w=,--workdir=}"[Working directory inside the container]:directory:_directories" \ + "($help -):containers:__docker_complete_running_containers" \ + "($help -)*::command:->anycommand" && ret=0 + case $state in + (anycommand) + shift 1 words + (( CURRENT-- )) + _normal && ret=0 + ;; + esac + ;; + (export) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -o --output)"{-o=,--output=}"[Write to a file, instead of stdout]:output file:_files" \ + "($help -)*:containers:__docker_complete_containers" && ret=0 + ;; + (inspect) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -f --format)"{-f=,--format=}"[Format the output using the given go template]:template: " \ + "($help -s --size)"{-s,--size}"[Display total file sizes]" \ + "($help -)*:containers:__docker_complete_containers" && ret=0 + ;; + (kill) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -s --signal)"{-s=,--signal=}"[Signal to send]:signal:_signals" \ + "($help -)*:containers:__docker_complete_running_containers" && ret=0 + ;; + (logs) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help)--details[Show extra details provided to logs]" \ + "($help -f --follow)"{-f,--follow}"[Follow log output]" \ + "($help -s --since)"{-s=,--since=}"[Show logs since this timestamp]:timestamp: " \ + "($help -t --timestamps)"{-t,--timestamps}"[Show timestamps]" \ + "($help -n --tail)"{-n=,--tail=}"[Number of lines to show from the end of the logs]:lines:(1 10 20 50 all)" \ + "($help -)*:containers:__docker_complete_containers" && ret=0 + ;; + (ls|list) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -a --all)"{-a,--all}"[Show all containers]" \ + "($help)--before=[Show only container created before...]:containers:__docker_complete_containers" \ + "($help)*"{-f=,--filter=}"[Filter values]:filter:__docker_complete_ps_filters" \ + "($help)--format=[Format the output using the given Go template]:template: " \ + "($help -l --latest)"{-l,--latest}"[Show only the latest created container]" \ + "($help -n --last)"{-n=,--last=}"[Show n last created containers (includes all states)]:n:(1 5 10 25 50)" \ + "($help)--no-trunc[Do not truncate output]" \ + "($help -q --quiet)"{-q,--quiet}"[Only show container IDs]" \ + "($help -s --size)"{-s,--size}"[Display total file sizes]" \ + "($help)--since=[Show only containers created since...]:containers:__docker_complete_containers" && ret=0 + ;; + (pause|unpause) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -)*:containers:__docker_complete_running_containers" && ret=0 + ;; + (port) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -)1:containers:__docker_complete_running_containers" \ + "($help -)2:port:_ports" && ret=0 + ;; + (prune) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help)*--filter=[Filter values]:filter:__docker_complete_prune_filters" \ + "($help -f --force)"{-f,--force}"[Do not prompt for confirmation]" && ret=0 + ;; + (rename) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -):old name:__docker_complete_containers" \ + "($help -):new name: " && ret=0 + ;; + (restart) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -t --time)"{-t=,--time=}"[Number of seconds to try to stop for before killing the container]:seconds to before killing:(1 5 10 30 60)" \ + "($help -)*:containers:__docker_complete_containers" && ret=0 + ;; + (rm) + local state + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -f --force)"{-f,--force}"[Force removal]" \ + "($help -l --link)"{-l,--link}"[Remove the specified link and not the underlying container]" \ + "($help -v --volumes)"{-v,--volumes}"[Remove the volumes associated to the container]" \ + "($help -)*:containers:->values" && ret=0 + case $state in + (values) + if [[ ${words[(r)-f]} == -f || ${words[(r)--force]} == --force ]]; then + __docker_complete_containers && ret=0 + else + __docker_complete_stopped_containers && ret=0 + fi + ;; + esac + ;; + (run) + local state + _arguments $(__docker_arguments) \ + $opts_help \ + $opts_create_run \ + $opts_create_run_update \ + $opts_attach_exec_run_start \ + "($help -d --detach)"{-d,--detach}"[Detached mode: leave the container running in the background]" \ + "($help)--health-cmd=[Command to run to check health]:command: " \ + "($help)--health-interval=[Time between running the check]:time: " \ + "($help)--health-retries=[Consecutive failures needed to report unhealthy]:retries:(1 2 3 4 5)" \ + "($help)--health-timeout=[Maximum time to allow one check to run]:time: " \ + "($help)--no-healthcheck[Disable any container-specified HEALTHCHECK]" \ + "($help)--rm[Remove intermediate containers when it exits]" \ + "($help)--runtime=[Name of the runtime to be used for that container]:runtime:__docker_complete_runtimes" \ + "($help)--sig-proxy[Proxy all received signals to the process (non-TTY mode only)]" \ + "($help)--storage-opt=[Storage driver options for the container]:storage options:->storage-opt" \ + "($help -): :__docker_complete_images" \ + "($help -):command: _command_names -e" \ + "($help -)*::arguments: _normal" && ret=0 + case $state in + (link) + if compset -P "*:"; then + _wanted alias expl "Alias" compadd -E "" && ret=0 + else + __docker_complete_running_containers -qS ":" && ret=0 + fi + ;; + (storage-opt) + if compset -P "*="; then + _message "value" && ret=0 + else + opts=('size') + _describe -t filter-opts "storage options" opts -qS "=" && ret=0 + fi + ;; + esac + ;; + (start) + _arguments $(__docker_arguments) \ + $opts_help \ + $opts_attach_exec_run_start \ + "($help -a --attach)"{-a,--attach}"[Attach container's stdout/stderr and forward all signals]" \ + "($help -i --interactive)"{-i,--interactive}"[Attach container's stdin]" \ + "($help -)*:containers:__docker_complete_stopped_containers" && ret=0 + ;; + (stats) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -a --all)"{-a,--all}"[Show all containers (default shows just running)]" \ + "($help)--format=[Format the output using the given Go template]:template: " \ + "($help)--no-stream[Disable streaming stats and only pull the first result]" \ + "($help)--no-trunc[Do not truncate output]" \ + "($help -)*:containers:__docker_complete_running_containers" && ret=0 + ;; + (stop) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -t --time)"{-t=,--time=}"[Number of seconds to try to stop for before killing the container]:seconds to before killing:(1 5 10 30 60)" \ + "($help -)*:containers:__docker_complete_running_containers" && ret=0 + ;; + (top) + local state + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -)1:containers:__docker_complete_running_containers" \ + "($help -)*:: :->ps-arguments" && ret=0 + case $state in + (ps-arguments) + _ps && ret=0 + ;; + esac + ;; + (update) + local state + _arguments $(__docker_arguments) \ + $opts_help \ + $opts_create_run_update \ + "($help -)*: :->values" && ret=0 + case $state in + (values) + if [[ ${words[(r)--kernel-memory*]} = (--kernel-memory*) ]]; then + __docker_complete_stopped_containers && ret=0 + else + __docker_complete_containers && ret=0 + fi + ;; + esac + ;; + (wait) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -)*:containers:__docker_complete_running_containers" && ret=0 + ;; + (help) + _arguments $(__docker_arguments) ":subcommand:__docker_container_commands" && ret=0 + ;; + esac + + return ret +} + +# EO container + +# BO image + +__docker_image_commands() { + local -a _docker_image_subcommands + _docker_image_subcommands=( + "build:Build an image from a Dockerfile" + "history:Show the history of an image" + "import:Import the contents from a tarball to create a filesystem image" + "inspect:Display detailed information on one or more images" + "load:Load an image from a tar archive or STDIN" + "ls:List images" + "prune:Remove unused images" + "pull:Download an image from a registry" + "push:Upload an image to a registry" + "rm:Remove one or more images" + "save:Save one or more images to a tar archive (streamed to STDOUT by default)" + "tag:Tag an image into a repository" + ) + _describe -t docker-image-commands "docker image command" _docker_image_subcommands +} + +__docker_image_subcommand() { + local -a _command_args opts_help + local expl help="--help" + integer ret=1 + + opts_help=("(: -)--help[Print usage]") + + case "$words[1]" in + (build) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help)*--add-host=[Add a custom host-to-IP mapping]:host\:ip mapping: " \ + "($help)*--build-arg=[Build-time variables]:=: " \ + "($help)*--cache-from=[Images to consider as cache sources]: :__docker_complete_repositories_with_tags" \ + "($help -c --cpu-shares)"{-c=,--cpu-shares=}"[CPU shares (relative weight)]:CPU shares:(0 10 100 200 500 800 1000)" \ + "($help)--cgroup-parent=[Parent cgroup for the container]:cgroup: " \ + "($help)--compress[Compress the build context using gzip]" \ + "($help)--cpu-period=[Limit the CPU CFS (Completely Fair Scheduler) period]:CPU period: " \ + "($help)--cpu-quota=[Limit the CPU CFS (Completely Fair Scheduler) quota]:CPU quota: " \ + "($help)--cpu-rt-period=[Limit the CPU real-time period]:CPU real-time period in microseconds: " \ + "($help)--cpu-rt-runtime=[Limit the CPU real-time runtime]:CPU real-time runtime in microseconds: " \ + "($help)--cpuset-cpus=[CPUs in which to allow execution]:CPUs: " \ + "($help)--cpuset-mems=[MEMs in which to allow execution]:MEMs: " \ + "($help)--disable-content-trust[Skip image verification]" \ + "($help -f --file)"{-f=,--file=}"[Name of the Dockerfile]:Dockerfile:_files" \ + "($help)--force-rm[Always remove intermediate containers]" \ + "($help)--isolation=[Container isolation technology]:isolation:(default hyperv process)" \ + "($help)*--label=[Set metadata for an image]:label=value: " \ + "($help -m --memory)"{-m=,--memory=}"[Memory limit]:Memory limit: " \ + "($help)--memory-swap=[Total memory limit with swap]:Memory limit: " \ + "($help)--network=[Connect a container to a network]:network mode:(bridge none container host)" \ + "($help)--no-cache[Do not use cache when building the image]" \ + "($help)--pull[Attempt to pull a newer version of the image]" \ + "($help -q --quiet)"{-q,--quiet}"[Suppress verbose build output]" \ + "($help)--rm[Remove intermediate containers after a successful build]" \ + "($help)*--shm-size=[Size of '/dev/shm' (format is '')]:shm size: " \ + "($help)--squash[Squash newly built layers into a single new layer]" \ + "($help -t --tag)*"{-t=,--tag=}"[Repository, name and tag for the image]: :__docker_complete_repositories_with_tags" \ + "($help)--target=[Set the target build stage to build.]" \ + "($help)*--ulimit=[ulimit options]:ulimit: " \ + "($help)--userns=[Container user namespace]:user namespace:(host)" \ + "($help -):path or URL:_directories" && ret=0 + ;; + (history) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -H --human)"{-H,--human}"[Print sizes and dates in human readable format]" \ + "($help)--no-trunc[Do not truncate output]" \ + "($help -q --quiet)"{-q,--quiet}"[Only show image IDs]" \ + "($help -)*: :__docker_complete_images" && ret=0 + ;; + (import) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help)*"{-c=,--change=}"[Apply Dockerfile instruction to the created image]:Dockerfile:_files" \ + "($help -m --message)"{-m=,--message=}"[Commit message for imported image]:message: " \ + "($help -):URL:(- http:// file://)" \ + "($help -): :__docker_complete_repositories_with_tags" && ret=0 + ;; + (inspect) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -f --format)"{-f=,--format=}"[Format the output using the given go template]:template: " \ + "($help -)*:images:__docker_complete_images" && ret=0 + ;; + (load) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -i --input)"{-i=,--input=}"[Read from tar archive file]:archive file:_files -g \"*.((tar|TAR)(.gz|.GZ|.Z|.bz2|.lzma|.xz|)|(tbz|tgz|txz))(-.)\"" \ + "($help -q --quiet)"{-q,--quiet}"[Suppress the load output]" && ret=0 + ;; + (ls|list) + local state + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -a --all)"{-a,--all}"[Show all images]" \ + "($help)--digests[Show digests]" \ + "($help)*"{-f=,--filter=}"[Filter values]:filter:__docker_complete_images_filters" \ + "($help)--format=[Format the output using the given Go template]:template: " \ + "($help)--no-trunc[Do not truncate output]" \ + "($help -q --quiet)"{-q,--quiet}"[Only show image IDs]" \ + "($help -): :__docker_complete_repositories" && ret=0 + ;; + (prune) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -a --all)"{-a,--all}"[Remove all unused images, not just dangling ones]" \ + "($help)*--filter=[Filter values]:filter:__docker_complete_prune_filters" \ + "($help -f --force)"{-f,--force}"[Do not prompt for confirmation]" && ret=0 + ;; + (pull) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -a --all-tags)"{-a,--all-tags}"[Download all tagged images]" \ + "($help)--disable-content-trust[Skip image verification]" \ + "($help -):name:__docker_search" && ret=0 + ;; + (push) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -a --all-tags)"{-a,--all-tags}"[Push all tags of an image to the repository]" \ + "($help)--disable-content-trust[Skip image signing]" \ + "($help -): :__docker_complete_images" && ret=0 + ;; + (rm) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -f --force)"{-f,--force}"[Force removal]" \ + "($help)--no-prune[Do not delete untagged parents]" \ + "($help -)*: :__docker_complete_images" && ret=0 + ;; + (save) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -o --output)"{-o=,--output=}"[Write to file]:file:_files" \ + "($help -)*: :__docker_complete_images" && ret=0 + ;; + (tag) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -):source:__docker_complete_images"\ + "($help -):destination:__docker_complete_repositories_with_tags" && ret=0 + ;; + (help) + _arguments $(__docker_arguments) ":subcommand:__docker_container_commands" && ret=0 + ;; + esac + + return ret +} + +# EO image + +# BO network + +__docker_network_complete_ls_filters() { + [[ $PREFIX = -* ]] && return 1 + integer ret=1 + + if compset -P '*='; then + case "${${words[-1]%=*}#*=}" in + (driver) + __docker_complete_info_plugins Network && ret=0 + ;; + (id) + __docker_complete_networks_ids && ret=0 + ;; + (name) + __docker_complete_networks_names && ret=0 + ;; + (scope) + opts=('global' 'local' 'swarm') + _describe -t scope-filter-opts "Scope filter options" opts && ret=0 + ;; + (type) + opts=('builtin' 'custom') + _describe -t type-filter-opts "Type filter options" opts && ret=0 + ;; + *) + _message 'value' && ret=0 + ;; + esac + else + opts=('driver' 'id' 'label' 'name' 'scope' 'type') + _describe -t filter-opts "Filter Options" opts -qS "=" && ret=0 + fi + + return ret +} + +__docker_get_networks() { + [[ $PREFIX = -* ]] && return 1 + integer ret=1 + local line s + declare -a lines networks + + type=$1; shift + + lines=(${(f)${:-"$(_call_program commands docker $docker_options network ls)"$'\n'}}) + + # Parse header line to find columns + local i=1 j=1 k header=${lines[1]} + declare -A begin end + while (( j < ${#header} - 1 )); do + i=$(( j + ${${header[$j,-1]}[(i)[^ ]]} - 1 )) + j=$(( i + ${${header[$i,-1]}[(i) ]} - 1 )) + k=$(( j + ${${header[$j,-1]}[(i)[^ ]]} - 2 )) + begin[${header[$i,$((j-1))]}]=$i + end[${header[$i,$((j-1))]}]=$k + done + end[${header[$i,$((j-1))]}]=-1 + lines=(${lines[2,-1]}) + + # Network ID + if [[ $type = (ids|all) ]]; then + for line in $lines; do + s="${line[${begin[NETWORK ID]},${end[NETWORK ID]}]%% ##}" + s="$s:${(l:7:: :::)${${line[${begin[DRIVER]},${end[DRIVER]}]}%% ##}}" + s="$s, ${${line[${begin[SCOPE]},${end[SCOPE]}]}%% ##}" + networks=($networks $s) + done + fi + + # Names + if [[ $type = (names|all) ]]; then + for line in $lines; do + s="${line[${begin[NAME]},${end[NAME]}]%% ##}" + s="$s:${(l:7:: :::)${${line[${begin[DRIVER]},${end[DRIVER]}]}%% ##}}" + s="$s, ${${line[${begin[SCOPE]},${end[SCOPE]}]}%% ##}" + networks=($networks $s) + done + fi + + _describe -t networks-list "networks" networks "$@" && ret=0 + return ret +} + +__docker_complete_networks() { + [[ $PREFIX = -* ]] && return 1 + __docker_get_networks all "$@" +} + +__docker_complete_networks_ids() { + [[ $PREFIX = -* ]] && return 1 + __docker_get_networks ids "$@" +} + +__docker_complete_networks_names() { + [[ $PREFIX = -* ]] && return 1 + __docker_get_networks names "$@" +} + +__docker_network_commands() { + local -a _docker_network_subcommands + _docker_network_subcommands=( + "connect:Connect a container to a network" + "create:Creates a new network with a name specified by the user" + "disconnect:Disconnects a container from a network" + "inspect:Displays detailed information on a network" + "ls:Lists all the networks created by the user" + "prune:Remove all unused networks" + "rm:Deletes one or more networks" + ) + _describe -t docker-network-commands "docker network command" _docker_network_subcommands +} + +__docker_network_subcommand() { + local -a _command_args opts_help + local expl help="--help" + integer ret=1 + + opts_help=("(: -)--help[Print usage]") + + case "$words[1]" in + (connect) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help)*--alias=[Add network-scoped alias for the container]:alias: " \ + "($help)--ip=[IPv4 address]:IPv4: " \ + "($help)--ip6=[IPv6 address]:IPv6: " \ + "($help)*--link=[Add a link to another container]:link:->link" \ + "($help)*--link-local-ip=[Add a link-local address for the container]:IPv4/IPv6: " \ + "($help -)1:network:__docker_complete_networks" \ + "($help -)2:containers:__docker_complete_containers" && ret=0 + + case $state in + (link) + if compset -P "*:"; then + _wanted alias expl "Alias" compadd -E "" && ret=0 + else + __docker_complete_running_containers -qS ":" && ret=0 + fi + ;; + esac + ;; + (create) + _arguments $(__docker_arguments) -A '-*' \ + $opts_help \ + "($help)--attachable[Enable manual container attachment]" \ + "($help)*--aux-address[Auxiliary IPv4 or IPv6 addresses used by network driver]:key=IP: " \ + "($help -d --driver)"{-d=,--driver=}"[Driver to manage the Network]:driver:(null host bridge overlay)" \ + "($help)*--gateway=[IPv4 or IPv6 Gateway for the master subnet]:IP: " \ + "($help)--internal[Restricts external access to the network]" \ + "($help)*--ip-range=[Allocate container ip from a sub-range]:IP/mask: " \ + "($help)--ipam-driver=[IP Address Management Driver]:driver:(default)" \ + "($help)*--ipam-opt=[Custom IPAM plugin options]:opt=value: " \ + "($help)--ipv6[Enable IPv6 networking]" \ + "($help)*--label=[Set metadata on a network]:label=value: " \ + "($help)*"{-o=,--opt=}"[Driver specific options]:opt=value: " \ + "($help)*--subnet=[Subnet in CIDR format that represents a network segment]:IP/mask: " \ + "($help -)1:Network Name: " && ret=0 + ;; + (disconnect) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -)1:network:__docker_complete_networks" \ + "($help -)2:containers:__docker_complete_containers" && ret=0 + ;; + (inspect) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -f --format)"{-f=,--format=}"[Format the output using the given go template]:template: " \ + "($help)--verbose[Show detailed information]" \ + "($help -)*:network:__docker_complete_networks" && ret=0 + ;; + (ls) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help)--no-trunc[Do not truncate the output]" \ + "($help)*"{-f=,--filter=}"[Provide filter values]:filter:__docker_network_complete_ls_filters" \ + "($help)--format=[Format the output using the given Go template]:template: " \ + "($help -q --quiet)"{-q,--quiet}"[Only display network IDs]" && ret=0 + ;; + (prune) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help)*--filter=[Filter values]:filter:__docker_complete_prune_filters" \ + "($help -f --force)"{-f,--force}"[Do not prompt for confirmation]" && ret=0 + ;; + (rm) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -)*:network:__docker_complete_networks" && ret=0 + ;; + (help) + _arguments $(__docker_arguments) ":subcommand:__docker_network_commands" && ret=0 + ;; + esac + + return ret +} + +# EO network + +# BO node + +__docker_node_complete_ls_filters() { + [[ $PREFIX = -* ]] && return 1 + integer ret=1 + + if compset -P '*='; then + case "${${words[-1]%=*}#*=}" in + (id) + __docker_complete_nodes_ids && ret=0 + ;; + (membership) + membership_opts=('accepted' 'pending' 'rejected') + _describe -t membership-opts "membership options" membership_opts && ret=0 + ;; + (name) + __docker_complete_nodes_names && ret=0 + ;; + (role) + role_opts=('manager' 'worker') + _describe -t role-opts "role options" role_opts && ret=0 + ;; + *) + _message 'value' && ret=0 + ;; + esac + else + opts=('id' 'label' 'membership' 'name' 'node.label' 'role') + _describe -t filter-opts "filter options" opts -qS "=" && ret=0 + fi + + return ret +} + +__docker_node_complete_ps_filters() { + [[ $PREFIX = -* ]] && return 1 + integer ret=1 + + if compset -P '*='; then + case "${${words[-1]%=*}#*=}" in + (desired-state) + state_opts=('accepted' 'running' 'shutdown') + _describe -t state-opts "desired state options" state_opts && ret=0 + ;; + *) + _message 'value' && ret=0 + ;; + esac + else + opts=('desired-state' 'id' 'label' 'name') + _describe -t filter-opts "filter options" opts -qS "=" && ret=0 + fi + + return ret +} + +__docker_nodes() { + [[ $PREFIX = -* ]] && return 1 + integer ret=1 + local line s + declare -a lines nodes args + + type=$1; shift + filter=$1; shift + [[ $filter != "none" ]] && args=("-f $filter") + + lines=(${(f)${:-"$(_call_program commands docker $docker_options node ls $args)"$'\n'}}) + # Parse header line to find columns + local i=1 j=1 k header=${lines[1]} + declare -A begin end + while (( j < ${#header} - 1 )); do + i=$(( j + ${${header[$j,-1]}[(i)[^ ]]} - 1 )) + j=$(( i + ${${header[$i,-1]}[(i) ]} - 1 )) + k=$(( j + ${${header[$j,-1]}[(i)[^ ]]} - 2 )) + begin[${header[$i,$((j-1))]}]=$i + end[${header[$i,$((j-1))]}]=$k + done + end[${header[$i,$((j-1))]}]=-1 + lines=(${lines[2,-1]}) + + # Node ID + if [[ $type = (ids|all) ]]; then + for line in $lines; do + s="${line[${begin[ID]},${end[ID]}]%% ##}" + nodes=($nodes $s) + done + fi + + # Names + if [[ $type = (names|all) ]]; then + for line in $lines; do + s="${line[${begin[HOSTNAME]},${end[HOSTNAME]}]%% ##}" + nodes=($nodes $s) + done + fi + + _describe -t nodes-list "nodes" nodes "$@" && ret=0 + return ret +} + +__docker_complete_nodes() { + [[ $PREFIX = -* ]] && return 1 + __docker_nodes all none "$@" +} + +__docker_complete_nodes_ids() { + [[ $PREFIX = -* ]] && return 1 + __docker_nodes ids none "$@" +} + +__docker_complete_nodes_names() { + [[ $PREFIX = -* ]] && return 1 + __docker_nodes names none "$@" +} + +__docker_complete_pending_nodes() { + [[ $PREFIX = -* ]] && return 1 + __docker_nodes all "membership=pending" "$@" +} + +__docker_complete_manager_nodes() { + [[ $PREFIX = -* ]] && return 1 + __docker_nodes all "role=manager" "$@" +} + +__docker_complete_worker_nodes() { + [[ $PREFIX = -* ]] && return 1 + __docker_nodes all "role=worker" "$@" +} + +__docker_node_commands() { + local -a _docker_node_subcommands + _docker_node_subcommands=( + "demote:Demote a node as manager in the swarm" + "inspect:Display detailed information on one or more nodes" + "ls:List nodes in the swarm" + "promote:Promote a node as manager in the swarm" + "rm:Remove one or more nodes from the swarm" + "ps:List tasks running on one or more nodes, defaults to current node" + "update:Update a node" + ) + _describe -t docker-node-commands "docker node command" _docker_node_subcommands +} + +__docker_node_subcommand() { + local -a _command_args opts_help + local expl help="--help" + integer ret=1 + + opts_help=("(: -)--help[Print usage]") + + case "$words[1]" in + (rm|remove) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -f --force)"{-f,--force}"[Force remove a node from the swarm]" \ + "($help -)*:node:__docker_complete_pending_nodes" && ret=0 + ;; + (demote) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -)*:node:__docker_complete_manager_nodes" && ret=0 + ;; + (inspect) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -f --format)"{-f=,--format=}"[Format the output using the given go template]:template: " \ + "($help)--pretty[Print the information in a human friendly format]" \ + "($help -)*:node:__docker_complete_nodes" && ret=0 + ;; + (ls|list) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help)*"{-f=,--filter=}"[Provide filter values]:filter:__docker_node_complete_ls_filters" \ + "($help -q --quiet)"{-q,--quiet}"[Only display IDs]" && ret=0 + ;; + (promote) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -)*:node:__docker_complete_worker_nodes" && ret=0 + ;; + (ps) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -a --all)"{-a,--all}"[Display all instances]" \ + "($help)*"{-f=,--filter=}"[Provide filter values]:filter:__docker_node_complete_ps_filters" \ + "($help)--format=[Format the output using the given go template]:template: " \ + "($help)--no-resolve[Do not map IDs to Names]" \ + "($help)--no-trunc[Do not truncate output]" \ + "($help -q --quiet)"{-q,--quiet}"[Only display IDs]" \ + "($help -)*:node:__docker_complete_nodes" && ret=0 + ;; + (update) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help)--availability=[Availability of the node]:availability:(active pause drain)" \ + "($help)*--label-add=[Add or update a node label]:key=value: " \ + "($help)*--label-rm=[Remove a node label if exists]:label: " \ + "($help)--role=[Role of the node]:role:(manager worker)" \ + "($help -)1:node:__docker_complete_nodes" && ret=0 + ;; + (help) + _arguments $(__docker_arguments) ":subcommand:__docker_node_commands" && ret=0 + ;; + esac + + return ret +} + +# EO node + +# BO plugin + +__docker_plugin_complete_ls_filters() { + [[ $PREFIX = -* ]] && return 1 + integer ret=1 + + if compset -P '*='; then + case "${${words[-1]%=*}#*=}" in + (capability) + opts=('authz' 'ipamdriver' 'logdriver' 'metricscollector' 'networkdriver' 'volumedriver') + _describe -t capability-opts "capability options" opts && ret=0 + ;; + (enabled) + opts=('false' 'true') + _describe -t enabled-opts "enabled options" opts && ret=0 + ;; + *) + _message 'value' && ret=0 + ;; + esac + else + opts=('capability' 'enabled') + _describe -t filter-opts "filter options" opts -qS "=" && ret=0 + fi + + return ret +} + +__docker_plugins() { + [[ $PREFIX = -* ]] && return 1 + integer ret=1 + local line s + declare -a lines plugins args + + filter=$1; shift + [[ $filter != "none" ]] && args=("-f $filter") + + lines=(${(f)${:-"$(_call_program commands docker $docker_options plugin ls $args)"$'\n'}}) + + # Parse header line to find columns + local i=1 j=1 k header=${lines[1]} + declare -A begin end + while (( j < ${#header} - 1 )); do + i=$(( j + ${${header[$j,-1]}[(i)[^ ]]} - 1 )) + j=$(( i + ${${header[$i,-1]}[(i) ]} - 1 )) + k=$(( j + ${${header[$j,-1]}[(i)[^ ]]} - 2 )) + begin[${header[$i,$((j-1))]}]=$i + end[${header[$i,$((j-1))]}]=$k + done + end[${header[$i,$((j-1))]}]=-1 + lines=(${lines[2,-1]}) + + # Name + for line in $lines; do + s="${line[${begin[NAME]},${end[NAME]}]%% ##}" + s="$s:${(l:7:: :::)${${line[${begin[TAG]},${end[TAG]}]}%% ##}}" + plugins=($plugins $s) + done + + _describe -t plugins-list "plugins" plugins "$@" && ret=0 + return ret +} + +__docker_complete_plugins() { + [[ $PREFIX = -* ]] && return 1 + __docker_plugins none "$@" +} + +__docker_complete_enabled_plugins() { + [[ $PREFIX = -* ]] && return 1 + __docker_plugins enabled=true "$@" +} + +__docker_complete_disabled_plugins() { + [[ $PREFIX = -* ]] && return 1 + __docker_plugins enabled=false "$@" +} + +__docker_plugin_commands() { + local -a _docker_plugin_subcommands + _docker_plugin_subcommands=( + "disable:Disable a plugin" + "enable:Enable a plugin" + "inspect:Return low-level information about a plugin" + "install:Install a plugin" + "ls:List plugins" + "push:Push a plugin" + "rm:Remove a plugin" + "set:Change settings for a plugin" + "upgrade:Upgrade an existing plugin" + ) + _describe -t docker-plugin-commands "docker plugin command" _docker_plugin_subcommands +} + +__docker_plugin_subcommand() { + local -a _command_args opts_help + local expl help="--help" + integer ret=1 + + opts_help=("(: -)--help[Print usage]") + + case "$words[1]" in + (disable) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -f --force)"{-f,--force}"[Force the disable of an active plugin]" \ + "($help -)1:plugin:__docker_complete_enabled_plugins" && ret=0 + ;; + (enable) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help)--timeout=[HTTP client timeout (in seconds)]:timeout: " \ + "($help -)1:plugin:__docker_complete_disabled_plugins" && ret=0 + ;; + (inspect) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -f --format)"{-f=,--format=}"[Format the output using the given Go template]:template: " \ + "($help -)*:plugin:__docker_complete_plugins" && ret=0 + ;; + (install) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help)--alias=[Local name for plugin]:alias: " \ + "($help)--disable[Do not enable the plugin on install]" \ + "($help)--disable-content-trust[Skip image verification (default true)]" \ + "($help)--grant-all-permissions[Grant all permissions necessary to run the plugin]" \ + "($help -)1:plugin:__docker_complete_plugins" \ + "($help -)*:key=value: " && ret=0 + ;; + (ls|list) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help)*"{-f=,--filter=}"[Filter output based on conditions provided]:filter:__docker_plugin_complete_ls_filters" \ + "($help --format)--format=[Format the output using the given Go template]:template: " \ + "($help)--no-trunc[Don't truncate output]" \ + "($help -q --quiet)"{-q,--quiet}"[Only display IDs]" && ret=0 + ;; + (push) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help)--disable-content-trust[Skip image verification (default true)]" \ + "($help -)1:plugin:__docker_complete_plugins" && ret=0 + ;; + (rm|remove) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -f --force)"{-f,--force}"[Force the removal of an active plugin]" \ + "($help -)*:plugin:__docker_complete_plugins" && ret=0 + ;; + (set) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -)1:plugin:__docker_complete_plugins" \ + "($help -)*:key=value: " && ret=0 + ;; + (upgrade) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help)--disable-content-trust[Skip image verification (default true)]" \ + "($help)--grant-all-permissions[Grant all permissions necessary to run the plugin]" \ + "($help)--skip-remote-check[Do not check if specified remote plugin matches existing plugin image]" \ + "($help -)1:plugin:__docker_complete_plugins" \ + "($help -):remote: " && ret=0 + ;; + (help) + _arguments $(__docker_arguments) ":subcommand:__docker_plugin_commands" && ret=0 + ;; + esac + + return ret +} + +# EO plugin + +# BO secret + +__docker_secrets() { + [[ $PREFIX = -* ]] && return 1 + integer ret=1 + local line s + declare -a lines secrets + + type=$1; shift + + lines=(${(f)${:-"$(_call_program commands docker $docker_options secret ls)"$'\n'}}) + + # Parse header line to find columns + local i=1 j=1 k header=${lines[1]} + declare -A begin end + while (( j < ${#header} - 1 )); do + i=$(( j + ${${header[$j,-1]}[(i)[^ ]]} - 1 )) + j=$(( i + ${${header[$i,-1]}[(i) ]} - 1 )) + k=$(( j + ${${header[$j,-1]}[(i)[^ ]]} - 2 )) + begin[${header[$i,$((j-1))]}]=$i + end[${header[$i,$((j-1))]}]=$k + done + end[${header[$i,$((j-1))]}]=-1 + lines=(${lines[2,-1]}) + + # ID + if [[ $type = (ids|all) ]]; then + for line in $lines; do + s="${line[${begin[ID]},${end[ID]}]%% ##}" + secrets=($secrets $s) + done + fi + + # Names + if [[ $type = (names|all) ]]; then + for line in $lines; do + s="${line[${begin[NAME]},${end[NAME]}]%% ##}" + secrets=($secrets $s) + done + fi + + _describe -t secrets-list "secrets" secrets "$@" && ret=0 + return ret +} + +__docker_complete_secrets() { + [[ $PREFIX = -* ]] && return 1 + __docker_secrets all "$@" +} + +__docker_secret_commands() { + local -a _docker_secret_subcommands + _docker_secret_subcommands=( + "create:Create a secret using stdin as content" + "inspect:Display detailed information on one or more secrets" + "ls:List secrets" + "rm:Remove one or more secrets" + ) + _describe -t docker-secret-commands "docker secret command" _docker_secret_subcommands +} + +__docker_secret_subcommand() { + local -a _command_args opts_help + local expl help="--help" + integer ret=1 + + opts_help=("(: -)--help[Print usage]") + + case "$words[1]" in + (create) + _arguments $(__docker_arguments) -A '-*' \ + $opts_help \ + "($help)*"{-l=,--label=}"[Secret labels]:label: " \ + "($help -):secret: " && ret=0 + ;; + (inspect) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -f --format)"{-f=,--format=}"[Format the output using the given Go template]:template: " \ + "($help -)*:secret:__docker_complete_secrets" && ret=0 + ;; + (ls|list) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help)--format=[Format the output using the given go template]:template: " \ + "($help -q --quiet)"{-q,--quiet}"[Only display IDs]" && ret=0 + ;; + (rm|remove) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -)*:secret:__docker_complete_secrets" && ret=0 + ;; + (help) + _arguments $(__docker_arguments) ":subcommand:__docker_secret_commands" && ret=0 + ;; + esac + + return ret +} + +# EO secret + +# BO service + +__docker_service_complete_ls_filters() { + [[ $PREFIX = -* ]] && return 1 + integer ret=1 + + if compset -P '*='; then + case "${${words[-1]%=*}#*=}" in + (id) + __docker_complete_services_ids && ret=0 + ;; + (mode) + opts=('global' 'replicated') + _describe -t mode-opts "mode options" opts && ret=0 + ;; + (name) + __docker_complete_services_names && ret=0 + ;; + *) + _message 'value' && ret=0 + ;; + esac + else + opts=('id' 'label' 'mode' 'name') + _describe -t filter-opts "filter options" opts -qS "=" && ret=0 + fi + + return ret +} + +__docker_service_complete_ps_filters() { + [[ $PREFIX = -* ]] && return 1 + integer ret=1 + + if compset -P '*='; then + case "${${words[-1]%=*}#*=}" in + (desired-state) + state_opts=('accepted' 'running' 'shutdown') + _describe -t state-opts "desired state options" state_opts && ret=0 + ;; + *) + _message 'value' && ret=0 + ;; + esac + else + opts=('desired-state' 'id' 'label' 'name') + _describe -t filter-opts "filter options" opts -qS "=" && ret=0 + fi + + return ret +} + +__docker_service_complete_placement_pref() { + [[ $PREFIX = -* ]] && return 1 + integer ret=1 + + if compset -P '*='; then + case "${${words[-1]%=*}#*=}" in + (spread) + opts=('engine.labels' 'node.labels') + _describe -t spread-opts "spread options" opts -qS "." && ret=0 + ;; + *) + _message 'value' && ret=0 + ;; + esac + else + opts=('spread') + _describe -t pref-opts "placement pref options" opts -qS "=" && ret=0 + fi + + return ret +} + +__docker_services() { + [[ $PREFIX = -* ]] && return 1 + integer ret=1 + local line s + declare -a lines services + + type=$1; shift + + lines=(${(f)${:-"$(_call_program commands docker $docker_options service ls)"$'\n'}}) + + # Parse header line to find columns + local i=1 j=1 k header=${lines[1]} + declare -A begin end + while (( j < ${#header} - 1 )); do + i=$(( j + ${${header[$j,-1]}[(i)[^ ]]} - 1 )) + j=$(( i + ${${header[$i,-1]}[(i) ]} - 1 )) + k=$(( j + ${${header[$j,-1]}[(i)[^ ]]} - 2 )) + begin[${header[$i,$((j-1))]}]=$i + end[${header[$i,$((j-1))]}]=$k + done + end[${header[$i,$((j-1))]}]=-1 + lines=(${lines[2,-1]}) + + # Service ID + if [[ $type = (ids|all) ]]; then + for line in $lines; do + s="${line[${begin[ID]},${end[ID]}]%% ##}" + s="$s:${(l:7:: :::)${${line[${begin[IMAGE]},${end[IMAGE]}]}%% ##}}" + services=($services $s) + done + fi + + # Names + if [[ $type = (names|all) ]]; then + for line in $lines; do + s="${line[${begin[NAME]},${end[NAME]}]%% ##}" + s="$s:${(l:7:: :::)${${line[${begin[IMAGE]},${end[IMAGE]}]}%% ##}}" + services=($services $s) + done + fi + + _describe -t services-list "services" services "$@" && ret=0 + return ret +} + +__docker_complete_services() { + [[ $PREFIX = -* ]] && return 1 + __docker_services all "$@" +} + +__docker_complete_services_ids() { + [[ $PREFIX = -* ]] && return 1 + __docker_services ids "$@" +} + +__docker_complete_services_names() { + [[ $PREFIX = -* ]] && return 1 + __docker_services names "$@" +} + +__docker_service_commands() { + local -a _docker_service_subcommands + _docker_service_subcommands=( + "create:Create a new service" + "inspect:Display detailed information on one or more services" + "logs:Fetch the logs of a service or task" + "ls:List services" + "rm:Remove one or more services" + "rollback:Revert changes to a service's configuration" + "scale:Scale one or multiple replicated services" + "ps:List the tasks of a service" + "update:Update a service" + ) + _describe -t docker-service-commands "docker service command" _docker_service_subcommands +} + +__docker_service_subcommand() { + local -a _command_args opts_help opts_create_update + local expl help="--help" + integer ret=1 + + opts_help=("(: -)--help[Print usage]") + opts_create_update=( + "($help)*--cap-add=[Add Linux capabilities]:capability: " + "($help)*--cap-drop=[Drop Linux capabilities]:capability: " + "($help)*--constraint=[Placement constraints]:constraint: " + "($help)--endpoint-mode=[Placement constraints]:mode:(dnsrr vip)" + "($help)*"{-e=,--env=}"[Set environment variables]:env: " + "($help)--health-cmd=[Command to run to check health]:command: " + "($help)--health-interval=[Time between running the check]:time: " + "($help)--health-retries=[Consecutive failures needed to report unhealthy]:retries:(1 2 3 4 5)" + "($help)--health-timeout=[Maximum time to allow one check to run]:time: " + "($help)--hostname=[Service container hostname]:hostname: " \ + "($help)--isolation=[Service container isolation mode]:isolation:(default process hyperv)" \ + "($help)*--label=[Service labels]:label: " + "($help)--limit-cpu=[Limit CPUs]:value: " + "($help)--limit-memory=[Limit Memory]:value: " + "($help)--limit-pids[Limit maximum number of processes (default 0 = unlimited)]" + "($help)--log-driver=[Logging driver for service]:logging driver:__docker_complete_log_drivers" + "($help)*--log-opt=[Logging driver options]:log driver options:__docker_complete_log_options" + "($help)*--mount=[Attach a filesystem mount to the service]:mount: " + "($help)*--network=[Network attachments]:network: " + "($help)--no-healthcheck[Disable any container-specified HEALTHCHECK]" + "($help)--read-only[Mount the container's root filesystem as read only]" + "($help)--replicas=[Number of tasks]:replicas: " + "($help)--reserve-cpu=[Reserve CPUs]:value: " + "($help)--reserve-memory=[Reserve Memory]:value: " + "($help)--restart-condition=[Restart when condition is met]:mode:(any none on-failure)" + "($help)--restart-delay=[Delay between restart attempts]:delay: " + "($help)--restart-max-attempts=[Maximum number of restarts before giving up]:max-attempts: " + "($help)--restart-window=[Window used to evaluate the restart policy]:duration: " + "($help)--rollback-delay=[Delay between task rollbacks]:duration: " + "($help)--rollback-failure-action=[Action on rollback failure]:action:(continue pause)" + "($help)--rollback-max-failure-ratio=[Failure rate to tolerate during a rollback]:failure rate: " + "($help)--rollback-monitor=[Duration after each task rollback to monitor for failure]:duration: " + "($help)--rollback-parallelism=[Maximum number of tasks rolled back simultaneously]:number: " + "($help)*--secret=[Specify secrets to expose to the service]:secret:__docker_complete_secrets" + "($help)--stop-grace-period=[Time to wait before force killing a container]:grace period: " + "($help)--stop-signal=[Signal to stop the container]:signal:_signals" + "($help -t --tty)"{-t,--tty}"[Allocate a pseudo-TTY]" + "($help)--update-delay=[Delay between updates]:delay: " + "($help)--update-failure-action=[Action on update failure]:mode:(continue pause rollback)" + "($help)--update-max-failure-ratio=[Failure rate to tolerate during an update]:fraction: " + "($help)--update-monitor=[Duration after each task update to monitor for failure]:window: " + "($help)--update-parallelism=[Maximum number of tasks updated simultaneously]:number: " + "($help -u --user)"{-u=,--user=}"[Username or UID]:user:_users" + "($help)--with-registry-auth[Send registry authentication details to swarm agents]" + "($help -w --workdir)"{-w=,--workdir=}"[Working directory inside the container]:directory:_directories" + ) + + case "$words[1]" in + (create) + _arguments $(__docker_arguments) \ + $opts_help \ + $opts_create_update \ + "($help)*--container-label=[Container labels]:label: " \ + "($help)*--dns=[Set custom DNS servers]:DNS: " \ + "($help)*--dns-option=[Set DNS options]:DNS option: " \ + "($help)*--dns-search=[Set custom DNS search domains]:DNS search: " \ + "($help)*--env-file=[Read environment variables from a file]:environment file:_files" \ + "($help)*--group=[Set one or more supplementary user groups for the container]:group: _groups " \ + "($help)--mode=[Service Mode]:mode:(global replicated)" \ + "($help)--name=[Service name]:name: " \ + "($help)*--placement-pref=[Add a placement preference]:pref:__docker_service_complete_placement_pref" \ + "($help)*"{-p=,--publish=}"[Publish a port as a node port]:port: " \ + "($help -): :__docker_complete_images" \ + "($help -):command: _command_names -e" \ + "($help -)*::arguments: _normal" && ret=0 + ;; + (inspect) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -f --format)"{-f=,--format=}"[Format the output using the given go template]:template: " \ + "($help)--pretty[Print the information in a human friendly format]" \ + "($help -)*:service:__docker_complete_services" && ret=0 + ;; + (logs) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -f --follow)"{-f,--follow}"[Follow log output]" \ + "($help)--no-resolve[Do not map IDs to Names]" \ + "($help)--no-task-ids[Do not include task IDs]" \ + "($help)--no-trunc[Do not truncate output]" \ + "($help)--since=[Show logs since timestamp]:timestamp: " \ + "($help -n --tail)"{-n=,--tail=}"[Number of lines to show from the end of the logs]:lines:(1 10 20 50 all)" \ + "($help -t --timestamps)"{-t,--timestamps}"[Show timestamps]" \ + "($help -)1:service:__docker_complete_services" && ret=0 + ;; + (ls|list) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help)*"{-f=,--filter=}"[Filter output based on conditions provided]:filter:__docker_service_complete_ls_filters" \ + "($help)--format=[Format the output using the given Go template]:template: " \ + "($help -q --quiet)"{-q,--quiet}"[Only display IDs]" && ret=0 + ;; + (rm|remove) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -)*:service:__docker_complete_services" && ret=0 + ;; + (rollback) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -d --detach)"{-d=false,--detach=false}"[Disable detached mode]" \ + "($help -q --quiet)"{-q,--quiet}"[Suppress progress output]" \ + "($help -)*:service:__docker_complete_services" && ret=0 + ;; + (scale) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -d --detach)"{-d=false,--detach=false}"[Disable detached mode]" \ + "($help -)*:service:->values" && ret=0 + case $state in + (values) + if compset -P '*='; then + _message 'replicas' && ret=0 + else + __docker_complete_services -qS "=" + fi + ;; + esac + ;; + (ps) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help)*"{-f=,--filter=}"[Provide filter values]:filter:__docker_service_complete_ps_filters" \ + "($help)--format=[Format the output using the given go template]:template: " \ + "($help)--no-resolve[Do not map IDs to Names]" \ + "($help)--no-trunc[Do not truncate output]" \ + "($help -q --quiet)"{-q,--quiet}"[Only display task IDs]" \ + "($help -)*:service:__docker_complete_services" && ret=0 + ;; + (update) + _arguments $(__docker_arguments) \ + $opts_help \ + $opts_create_update \ + "($help)--arg=[Service command args]:arguments: _normal" \ + "($help)*--container-label-add=[Add or update container labels]:label: " \ + "($help)*--container-label-rm=[Remove a container label by its key]:label: " \ + "($help)*--dns-add=[Add or update custom DNS servers]:DNS: " \ + "($help)*--dns-rm=[Remove custom DNS servers]:DNS: " \ + "($help)*--dns-option-add=[Add or update DNS options]:DNS option: " \ + "($help)*--dns-option-rm=[Remove DNS options]:DNS option: " \ + "($help)*--dns-search-add=[Add or update custom DNS search domains]:DNS search: " \ + "($help)*--dns-search-rm=[Remove DNS search domains]:DNS search: " \ + "($help)--force[Force update]" \ + "($help)*--group-add=[Add additional supplementary user groups to the container]:group:_groups" \ + "($help)*--group-rm=[Remove previously added supplementary user groups from the container]:group:_groups" \ + "($help)--image=[Service image tag]:image:__docker_complete_repositories" \ + "($help)*--placement-pref-add=[Add a placement preference]:pref:__docker_service_complete_placement_pref" \ + "($help)*--placement-pref-rm=[Remove a placement preference]:pref:__docker_service_complete_placement_pref" \ + "($help)*--publish-add=[Add or update a port]:port: " \ + "($help)*--publish-rm=[Remove a port(target-port mandatory)]:port: " \ + "($help)--rollback[Rollback to previous specification]" \ + "($help -)1:service:__docker_complete_services" && ret=0 + ;; + (help) + _arguments $(__docker_arguments) ":subcommand:__docker_service_commands" && ret=0 + ;; + esac + + return ret +} + +# EO service + +# BO stack + +__docker_stack_complete_ps_filters() { + [[ $PREFIX = -* ]] && return 1 + integer ret=1 + + if compset -P '*='; then + case "${${words[-1]%=*}#*=}" in + (desired-state) + state_opts=('accepted' 'running' 'shutdown') + _describe -t state-opts "desired state options" state_opts && ret=0 + ;; + *) + _message 'value' && ret=0 + ;; + esac + else + opts=('desired-state' 'id' 'name') + _describe -t filter-opts "filter options" opts -qS "=" && ret=0 + fi + + return ret +} + +__docker_stack_complete_services_filters() { + [[ $PREFIX = -* ]] && return 1 + integer ret=1 + + if compset -P '*='; then + case "${${words[-1]%=*}#*=}" in + *) + _message 'value' && ret=0 + ;; + esac + else + opts=('id' 'label' 'name') + _describe -t filter-opts "filter options" opts -qS "=" && ret=0 + fi + + return ret +} + +__docker_stacks() { + [[ $PREFIX = -* ]] && return 1 + integer ret=1 + local line s + declare -a lines stacks + + lines=(${(f)${:-"$(_call_program commands docker $docker_options stack ls)"$'\n'}}) + + # Parse header line to find columns + local i=1 j=1 k header=${lines[1]} + declare -A begin end + while (( j < ${#header} - 1 )); do + i=$(( j + ${${header[$j,-1]}[(i)[^ ]]} - 1 )) + j=$(( i + ${${header[$i,-1]}[(i) ]} - 1 )) + k=$(( j + ${${header[$j,-1]}[(i)[^ ]]} - 2 )) + begin[${header[$i,$((j-1))]}]=$i + end[${header[$i,$((j-1))]}]=$k + done + end[${header[$i,$((j-1))]}]=-1 + lines=(${lines[2,-1]}) + + # Service NAME + for line in $lines; do + s="${line[${begin[NAME]},${end[NAME]}]%% ##}" + stacks=($stacks $s) + done + + _describe -t stacks-list "stacks" stacks "$@" && ret=0 + return ret +} + +__docker_complete_stacks() { + [[ $PREFIX = -* ]] && return 1 + __docker_stacks "$@" +} + +__docker_stack_commands() { + local -a _docker_stack_subcommands + _docker_stack_subcommands=( + "deploy:Deploy a new stack or update an existing stack" + "ls:List stacks" + "ps:List the tasks in the stack" + "rm:Remove the stack" + "services:List the services in the stack" + ) + _describe -t docker-stack-commands "docker stack command" _docker_stack_subcommands +} + +__docker_stack_subcommand() { + local -a _command_args opts_help + local expl help="--help" + integer ret=1 + + opts_help=("(: -)--help[Print usage]") + + case "$words[1]" in + (deploy|up) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -c --compose-file)"{-c=,--compose-file=}"[Path to a Compose file, or '-' to read from stdin]:compose file:_files -g \"*.(yml|yaml)\"" \ + "($help)--with-registry-auth[Send registry authentication details to Swarm agents]" \ + "($help -):stack:__docker_complete_stacks" && ret=0 + ;; + (ls|list) + _arguments $(__docker_arguments) \ + $opts_help && ret=0 + ;; + (ps) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -a --all)"{-a,--all}"[Display all tasks]" \ + "($help)*"{-f=,--filter=}"[Filter output based on conditions provided]:filter:__docker_stack_complete_ps_filters" \ + "($help)--format=[Format the output using the given go template]:template: " \ + "($help)--no-resolve[Do not map IDs to Names]" \ + "($help)--no-trunc[Do not truncate output]" \ + "($help -q --quiet)"{-q,--quiet}"[Only display task IDs]" \ + "($help -):stack:__docker_complete_stacks" && ret=0 + ;; + (rm|remove|down) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -):stack:__docker_complete_stacks" && ret=0 + ;; + (services) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help)*"{-f=,--filter=}"[Filter output based on conditions provided]:filter:__docker_stack_complete_services_filters" \ + "($help)--format=[Format the output using the given Go template]:template: " \ + "($help -q --quiet)"{-q,--quiet}"[Only display IDs]" \ + "($help -):stack:__docker_complete_stacks" && ret=0 + ;; + (help) + _arguments $(__docker_arguments) ":subcommand:__docker_stack_commands" && ret=0 + ;; + esac + + return ret +} + +# EO stack + +# BO swarm + +__docker_swarm_commands() { + local -a _docker_swarm_subcommands + _docker_swarm_subcommands=( + "init:Initialize a swarm" + "join:Join a swarm as a node and/or manager" + "join-token:Manage join tokens" + "leave:Leave a swarm" + "unlock:Unlock swarm" + "unlock-key:Manage the unlock key" + "update:Update the swarm" + ) + _describe -t docker-swarm-commands "docker swarm command" _docker_swarm_subcommands +} + +__docker_swarm_subcommand() { + local -a _command_args opts_help + local expl help="--help" + integer ret=1 + + opts_help=("(: -)--help[Print usage]") + + case "$words[1]" in + (init) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help)--advertise-addr=[Advertised address]:ip\:port: " \ + "($help)--data-path-addr=[Data path IP or interface]:ip " \ + "($help)--data-path-port=[Data Path Port]:port " \ + "($help)--default-addr-pool=[Default address pool]" \ + "($help)--default-addr-pool-mask-length=[Default address pool subnet mask length]" \ + "($help)--autolock[Enable manager autolocking]" \ + "($help)--availability=[Availability of the node]:availability:(active drain pause)" \ + "($help)--cert-expiry=[Validity period for node certificates]:duration: " \ + "($help)--dispatcher-heartbeat=[Dispatcher heartbeat period]:duration: " \ + "($help)*--external-ca=[Specifications of one or more certificate signing endpoints]:endpoint: " \ + "($help)--force-new-cluster[Force create a new cluster from current state]" \ + "($help)--listen-addr=[Listen address]:ip\:port: " \ + "($help)--max-snapshots[Number of additional Raft snapshots to retain]" \ + "($help)--snapshot-interval[Number of log entries between Raft snapshots]" \ + "($help)--task-history-limit=[Task history retention limit]:limit: " && ret=0 + ;; + (join) + _arguments $(__docker_arguments) -A '-*' \ + $opts_help \ + "($help)--advertise-addr=[Advertised address]:ip\:port: " \ + "($help)--data-path-addr=[Data path IP or interface]:ip " \ + "($help)--availability=[Availability of the node]:availability:(active drain pause)" \ + "($help)--listen-addr=[Listen address]:ip\:port: " \ + "($help)--token=[Token for entry into the swarm]:secret: " \ + "($help -):host\:port: " && ret=0 + ;; + (join-token) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -q --quiet)"{-q,--quiet}"[Only display token]" \ + "($help)--rotate[Rotate join token]" \ + "($help -):role:(manager worker)" && ret=0 + ;; + (leave) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -f --force)"{-f,--force}"[Force this node to leave the swarm, ignoring warnings]" && ret=0 + ;; + (unlock) + _arguments $(__docker_arguments) \ + $opts_help && ret=0 + ;; + (unlock-key) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -q --quiet)"{-q,--quiet}"[Only display token]" \ + "($help)--rotate[Rotate unlock token]" && ret=0 + ;; + (update) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help)--autolock[Enable manager autolocking]" \ + "($help)--cert-expiry=[Validity period for node certificates]:duration: " \ + "($help)--dispatcher-heartbeat=[Dispatcher heartbeat period]:duration: " \ + "($help)*--external-ca=[Specifications of one or more certificate signing endpoints]:endpoint: " \ + "($help)--max-snapshots[Number of additional Raft snapshots to retain]" \ + "($help)--snapshot-interval[Number of log entries between Raft snapshots]" \ + "($help)--task-history-limit=[Task history retention limit]:limit: " && ret=0 + ;; + (help) + _arguments $(__docker_arguments) ":subcommand:__docker_network_commands" && ret=0 + ;; + esac + + return ret +} + +# EO swarm + +# BO system + +__docker_system_commands() { + local -a _docker_system_subcommands + _docker_system_subcommands=( + "df:Show docker filesystem usage" + "events:Get real time events from the server" + "info:Display system-wide information" + "prune:Remove unused data" + ) + _describe -t docker-system-commands "docker system command" _docker_system_subcommands +} + +__docker_system_subcommand() { + local -a _command_args opts_help + local expl help="--help" + integer ret=1 + + opts_help=("(: -)--help[Print usage]") + + case "$words[1]" in + (df) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -v --verbose)"{-v,--verbose}"[Show detailed information on space usage]" && ret=0 + ;; + (events) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help)*"{-f=,--filter=}"[Filter values]:filter:__docker_complete_events_filter" \ + "($help)--since=[Events created since this timestamp]:timestamp: " \ + "($help)--until=[Events created until this timestamp]:timestamp: " \ + "($help)--format=[Format the output using the given go template]:template: " && ret=0 + ;; + (info) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -f --format)"{-f=,--format=}"[Format the output using the given go template]:template: " && ret=0 + ;; + (prune) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -a --all)"{-a,--all}"[Remove all unused data, not just dangling ones]" \ + "($help)*--filter=[Filter values]:filter:__docker_complete_prune_filters" \ + "($help -f --force)"{-f,--force}"[Do not prompt for confirmation]" \ + "($help)--volumes=[Remove all unused volumes]" && ret=0 + ;; + (help) + _arguments $(__docker_arguments) ":subcommand:__docker_volume_commands" && ret=0 + ;; + esac + + return ret +} + +# EO system + +# BO volume + +__docker_volume_complete_ls_filters() { + [[ $PREFIX = -* ]] && return 1 + integer ret=1 + + if compset -P '*='; then + case "${${words[-1]%=*}#*=}" in + (dangling) + dangling_opts=('true' 'false') + _describe -t dangling-filter-opts "Dangling Filter Options" dangling_opts && ret=0 + ;; + (driver) + __docker_complete_info_plugins Volume && ret=0 + ;; + (name) + __docker_complete_volumes && ret=0 + ;; + *) + _message 'value' && ret=0 + ;; + esac + else + opts=('dangling' 'driver' 'label' 'name') + _describe -t filter-opts "Filter Options" opts -qS "=" && ret=0 + fi + + return ret +} + +__docker_complete_volumes() { + [[ $PREFIX = -* ]] && return 1 + integer ret=1 + declare -a lines volumes + + lines=(${(f)${:-"$(_call_program commands docker $docker_options volume ls)"$'\n'}}) + + # Parse header line to find columns + local i=1 j=1 k header=${lines[1]} + declare -A begin end + while (( j < ${#header} - 1 )); do + i=$(( j + ${${header[$j,-1]}[(i)[^ ]]} - 1 )) + j=$(( i + ${${header[$i,-1]}[(i) ]} - 1 )) + k=$(( j + ${${header[$j,-1]}[(i)[^ ]]} - 2 )) + begin[${header[$i,$((j-1))]}]=$i + end[${header[$i,$((j-1))]}]=$k + done + end[${header[$i,$((j-1))]}]=-1 + lines=(${lines[2,-1]}) + + # Names + local line s + for line in $lines; do + s="${line[${begin[VOLUME NAME]},${end[VOLUME NAME]}]%% ##}" + s="$s:${(l:7:: :::)${${line[${begin[DRIVER]},${end[DRIVER]}]}%% ##}}" + volumes=($volumes $s) + done + + _describe -t volumes-list "volumes" volumes && ret=0 + return ret +} + +__docker_volume_commands() { + local -a _docker_volume_subcommands + _docker_volume_subcommands=( + "create:Create a volume" + "inspect:Display detailed information on one or more volumes" + "ls:List volumes" + "prune:Remove all unused volumes" + "rm:Remove one or more volumes" + ) + _describe -t docker-volume-commands "docker volume command" _docker_volume_subcommands +} + +__docker_volume_subcommand() { + local -a _command_args opts_help + local expl help="--help" + integer ret=1 + + opts_help=("(: -)--help[Print usage]") + + case "$words[1]" in + (create) + _arguments $(__docker_arguments) -A '-*' \ + $opts_help \ + "($help -d --driver)"{-d=,--driver=}"[Volume driver name]:Driver name:(local)" \ + "($help)*--label=[Set metadata for a volume]:label=value: " \ + "($help)*"{-o=,--opt=}"[Driver specific options]:Driver option: " \ + "($help -)1:Volume name: " && ret=0 + ;; + (inspect) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -f --format)"{-f=,--format=}"[Format the output using the given go template]:template: " \ + "($help -)1:volume:__docker_complete_volumes" && ret=0 + ;; + (ls) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help)*"{-f=,--filter=}"[Provide filter values]:filter:__docker_volume_complete_ls_filters" \ + "($help)--format=[Format the output using the given Go template]:template: " \ + "($help -q --quiet)"{-q,--quiet}"[Only display volume names]" && ret=0 + ;; + (prune) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -a --all)"{-a,--all}"[Remove all unused local volumes, not just anonymous ones]" \ + "($help)*--filter=[Filter values]:filter:__docker_complete_prune_filters" \ + "($help -f --force)"{-f,--force}"[Do not prompt for confirmation]" && ret=0 + ;; + (rm) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -f --force)"{-f,--force}"[Force the removal of one or more volumes]" \ + "($help -):volume:__docker_complete_volumes" && ret=0 + ;; + (help) + _arguments $(__docker_arguments) ":subcommand:__docker_volume_commands" && ret=0 + ;; + esac + + return ret +} + +# EO volume + +# BO context + +__docker_complete_contexts() { + [[ $PREFIX = -* ]] && return 1 + integer ret=1 + declare -a contexts + + contexts=(${(f)${:-"$(_call_program commands docker $docker_options context ls -q)"$'\n'}}) + + _describe -t context-list "context" contexts && ret=0 + return ret +} + +__docker_context_commands() { + local -a _docker_context_subcommands + _docker_context_subcommands=( + "create:Create new context" + "inspect:Display detailed information on one or more contexts" + "list:List available contexts" + "rm:Remove one or more contexts" + "show:Print the current context" + "update:Update a context" + "use:Set the default context" + ) + _describe -t docker-context-commands "docker context command" _docker_context_subcommands +} + +__docker_context_subcommand() { + local -a _command_args opts_help + local expl help="--help" + integer ret=1 + + opts_help=("(: -)--help[Print usage]") + + case "$words[1]" in + (create) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help)--description=[Description of the context]:description:" \ + "($help)--docker=[Set the docker endpoint]:docker:" \ + "($help)--from=[Create context from a named context]:from:__docker_complete_contexts" \ + "($help -):name: " && ret=0 + ;; + (use) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -)1:context:__docker_complete_contexts" && ret=0 + ;; + (inspect) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -)1:context:__docker_complete_contexts" && ret=0 + ;; + (rm) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -)1:context:__docker_complete_contexts" && ret=0 + ;; + (update) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help)--description=[Description of the context]:description:" \ + "($help)--docker=[Set the docker endpoint]:docker:" \ + "($help -):name:" && ret=0 + ;; + esac + + return ret +} + +# EO context + +__docker_caching_policy() { + oldp=( "$1"(Nmh+1) ) # 1 hour + (( $#oldp )) +} + +__docker_commands() { + local cache_policy + integer force_invalidation=0 + + zstyle -s ":completion:${curcontext}:" cache-policy cache_policy + if [[ -z "$cache_policy" ]]; then + zstyle ":completion:${curcontext}:" cache-policy __docker_caching_policy + fi + + if ( (( ! ${+_docker_hide_legacy_commands} )) || _cache_invalid docker_hide_legacy_commands ) \ + && ! _retrieve_cache docker_hide_legacy_commands; + then + _docker_hide_legacy_commands="${DOCKER_HIDE_LEGACY_COMMANDS}" + _store_cache docker_hide_legacy_commands _docker_hide_legacy_commands + fi + + if [[ "${_docker_hide_legacy_commands}" != "${DOCKER_HIDE_LEGACY_COMMANDS}" ]]; then + force_invalidation=1 + _docker_hide_legacy_commands="${DOCKER_HIDE_LEGACY_COMMANDS}" + _store_cache docker_hide_legacy_commands _docker_hide_legacy_commands + fi + + if ( [[ ${+_docker_subcommands} -eq 0 ]] || _cache_invalid docker_subcommands ) \ + && ! _retrieve_cache docker_subcommands || [[ ${force_invalidation} -eq 1 ]]; + then + local -a lines + lines=(${(f)"$(_call_program commands docker 2>&1)"}) + _docker_subcommands=(${${${(M)${lines[$((${lines[(i)*Commands:]} + 1)),-1]}:# *}## #}/\*# ##/:}) + _docker_subcommands=($_docker_subcommands 'daemon:Enable daemon mode' 'help:Show help for a command') + (( $#_docker_subcommands > 2 )) && _store_cache docker_subcommands _docker_subcommands + fi + _describe -t docker-commands "docker command" _docker_subcommands +} + +__docker_subcommand() { + local -a _command_args opts_help + local expl help="--help" + integer ret=1 + + opts_help=("(: -)--help[Print usage]") + + case "$words[1]" in + (attach|commit|cp|create|diff|exec|export|kill|logs|pause|unpause|port|rename|restart|rm|run|start|stats|stop|top|update|wait) + __docker_container_subcommand && ret=0 + ;; + (build|history|import|load|pull|push|save|tag) + __docker_image_subcommand && ret=0 + ;; + (checkpoint) + local curcontext="$curcontext" state + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -): :->command" \ + "($help -)*:: :->option-or-argument" && ret=0 + + case $state in + (command) + __docker_checkpoint_commands && ret=0 + ;; + (option-or-argument) + curcontext=${curcontext%:*:*}:docker-${words[-1]}: + __docker_checkpoint_subcommand && ret=0 + ;; + esac + ;; + (container) + local curcontext="$curcontext" state + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -): :->command" \ + "($help -)*:: :->option-or-argument" && ret=0 + + case $state in + (command) + __docker_container_commands && ret=0 + ;; + (option-or-argument) + curcontext=${curcontext%:*:*}:docker-${words[-1]}: + __docker_container_subcommand && ret=0 + ;; + esac + ;; + (context) + local curcontext="$curcontext" state + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -): :->command" \ + "($help -)*:: :->option-or-argument" && ret=0 + + case $state in + (command) + __docker_context_commands && ret=0 + ;; + (option-or-argument) + curcontext=${curcontext%:*:*}:docker-${words[-1]}: + __docker_context_subcommand && ret=0 + ;; + esac + ;; + (daemon) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help)*--add-runtime=[Register an additional OCI compatible runtime]:runtime:__docker_complete_runtimes" \ + "($help)*--allow-nondistributable-artifacts=[Push nondistributable artifacts to specified registries]:registry: " \ + "($help)--api-cors-header=[CORS headers in the Engine API]:CORS headers: " \ + "($help)*--authorization-plugin=[Authorization plugins to load]" \ + "($help -b --bridge)"{-b=,--bridge=}"[Attach containers to a network bridge]:bridge:_net_interfaces" \ + "($help)--bip=[Network bridge IP]:IP address: " \ + "($help)--cgroup-parent=[Parent cgroup for all containers]:cgroup: " \ + "($help)--config-file=[Path to daemon configuration file]:Config File:_files" \ + "($help)--containerd=[Path to containerd socket]:socket:_files -g \"*.sock\"" \ + "($help)--containerd-namespace=[Containerd namespace to use]:containerd namespace:" \ + "($help)--containerd-plugins-namespace=[Containerd namespace to use for plugins]:containerd namespace:" \ + "($help)--data-root=[Root directory of persisted Docker data]:path:_directories" \ + "($help -D --debug)"{-D,--debug}"[Enable debug mode]" \ + "($help)--default-gateway[Container default gateway IPv4 address]:IPv4 address: " \ + "($help)--default-gateway-v6[Container default gateway IPv6 address]:IPv6 address: " \ + "($help)--default-shm-size=[Default shm size for containers]:size:" \ + "($help)*--default-ulimit=[Default ulimits for containers]:ulimit: " \ + "($help)*--dns=[DNS server to use]:DNS: " \ + "($help)*--dns-opt=[DNS options to use]:DNS option: " \ + "($help)*--dns-search=[DNS search domains to use]:DNS search: " \ + "($help)*--exec-opt=[Runtime execution options]:runtime execution options: " \ + "($help)--exec-root=[Root directory for execution state files]:path:_directories" \ + "($help)--experimental[Enable experimental features]" \ + "($help)--fixed-cidr=[IPv4 subnet for fixed IPs]:IPv4 subnet: " \ + "($help)--fixed-cidr-v6=[IPv6 subnet for fixed IPs]:IPv6 subnet: " \ + "($help -G --group)"{-G=,--group=}"[Group for the unix socket]:group:_groups" \ + "($help -H --host)"{-H=,--host=}"[tcp://host:port to bind/connect to]:host: " \ + "($help)--icc[Enable inter-container communication]" \ + "($help)--init[Run an init inside containers to forward signals and reap processes]" \ + "($help)--init-path=[Path to the docker-init binary]:docker-init binary:_files" \ + "($help)*--insecure-registry=[Enable insecure registry communication]:registry: " \ + "($help)--ip=[Default IP when binding container ports]" \ + "($help)--ip-forward[Enable net.ipv4.ip_forward]" \ + "($help)--ip-masq[Enable IP masquerading]" \ + "($help)--iptables[Enable addition of iptables rules]" \ + "($help)--ipv6[Enable IPv6 networking]" \ + "($help -l --log-level)"{-l=,--log-level=}"[Logging level]:level:(debug info warn error fatal)" \ + "($help)*--label=[Key=value labels]:label: " \ + "($help)--live-restore[Enable live restore of docker when containers are still running]" \ + "($help)--log-driver=[Default driver for container logs]:logging driver:__docker_complete_log_drivers" \ + "($help)*--log-opt=[Default log driver options for containers]:log driver options:__docker_complete_log_options" \ + "($help)--max-concurrent-downloads[Set the max concurrent downloads]" \ + "($help)--max-concurrent-uploads[Set the max concurrent uploads]" \ + "($help)--max-download-attempts[Set the max download attempts for each pull]" \ + "($help)--mtu=[Network MTU]:mtu:(0 576 1420 1500 9000)" \ + "($help)--oom-score-adjust=[Set the oom_score_adj for the daemon]:oom-score:(-500)" \ + "($help -p --pidfile)"{-p=,--pidfile=}"[Path to use for daemon PID file]:PID file:_files" \ + "($help)--raw-logs[Full timestamps without ANSI coloring]" \ + "($help)*--registry-mirror=[Preferred registry mirror]:registry mirror: " \ + "($help)--seccomp-profile=[Path to seccomp profile]:path:_files -g \"*.json\"" \ + "($help -s --storage-driver)"{-s=,--storage-driver=}"[Storage driver to use]:driver:(btrfs devicemapper overlay2 vfs zfs)" \ + "($help)--selinux-enabled[Enable selinux support]" \ + "($help)--shutdown-timeout=[Set the shutdown timeout value in seconds]:time: " \ + "($help)*--storage-opt=[Storage driver options]:storage driver options: " \ + "($help)--tls[Use TLS]" \ + "($help)--tlscacert=[Trust certs signed only by this CA]:PEM file:_files -g \"*.(pem|crt)\"" \ + "($help)--tlscert=[Path to TLS certificate file]:PEM file:_files -g \"*.(pem|crt)\"" \ + "($help)--tlskey=[Path to TLS key file]:Key file:_files -g \"*.(pem|key)\"" \ + "($help)--tlsverify[Use TLS and verify the remote]" \ + "($help)--userns-remap=[User/Group setting for user namespaces]:user\:group:->users-groups" \ + "($help)--userland-proxy[Use userland proxy for loopback traffic]" \ + "($help)--userland-proxy-path=[Path to the userland proxy binary]:binary:_files" \ + "($help)--validate[Validate daemon configuration and exit]" && ret=0 + + case $state in + (users-groups) + if compset -P '*:'; then + _groups && ret=0 + else + _describe -t userns-default "default Docker user management" '(default)' && ret=0 + _users && ret=0 + fi + ;; + esac + ;; + (events|info) + __docker_system_subcommand && ret=0 + ;; + (image) + local curcontext="$curcontext" state + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -): :->command" \ + "($help -)*:: :->option-or-argument" && ret=0 + + case $state in + (command) + __docker_image_commands && ret=0 + ;; + (option-or-argument) + curcontext=${curcontext%:*:*}:docker-${words[-1]}: + __docker_image_subcommand && ret=0 + ;; + esac + ;; + (images) + words[1]='ls' + __docker_image_subcommand && ret=0 + ;; + (inspect) + local state + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -f --format)"{-f=,--format=}"[Format the output using the given go template]:template: " \ + "($help -s --size)"{-s,--size}"[Display total file sizes if the type is container]" \ + "($help)--type=[Return JSON for specified type]:type:(container image network node plugin service volume)" \ + "($help -)*: :->values" && ret=0 + + case $state in + (values) + if [[ ${words[(r)--type=container]} == --type=container ]]; then + __docker_complete_containers && ret=0 + elif [[ ${words[(r)--type=image]} == --type=image ]]; then + __docker_complete_images && ret=0 + elif [[ ${words[(r)--type=network]} == --type=network ]]; then + __docker_complete_networks && ret=0 + elif [[ ${words[(r)--type=node]} == --type=node ]]; then + __docker_complete_nodes && ret=0 + elif [[ ${words[(r)--type=plugin]} == --type=plugin ]]; then + __docker_complete_plugins && ret=0 + elif [[ ${words[(r)--type=service]} == --type=secrets ]]; then + __docker_complete_secrets && ret=0 + elif [[ ${words[(r)--type=service]} == --type=service ]]; then + __docker_complete_services && ret=0 + elif [[ ${words[(r)--type=volume]} == --type=volume ]]; then + __docker_complete_volumes && ret=0 + else + __docker_complete_containers + __docker_complete_images + __docker_complete_networks + __docker_complete_nodes + __docker_complete_plugins + __docker_complete_secrets + __docker_complete_services + __docker_complete_volumes && ret=0 + fi + ;; + esac + ;; + (login) + _arguments $(__docker_arguments) -A '-*' \ + $opts_help \ + "($help -p --password)"{-p=,--password=}"[Password]:password: " \ + "($help)--password-stdin[Read password from stdin]" \ + "($help -u --username)"{-u=,--username=}"[Username]:username: " \ + "($help -)1:server: " && ret=0 + ;; + (logout) + _arguments $(__docker_arguments) -A '-*' \ + $opts_help \ + "($help -)1:server: " && ret=0 + ;; + (network) + local curcontext="$curcontext" state + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -): :->command" \ + "($help -)*:: :->option-or-argument" && ret=0 + + case $state in + (command) + __docker_network_commands && ret=0 + ;; + (option-or-argument) + curcontext=${curcontext%:*:*}:docker-${words[-1]}: + __docker_network_subcommand && ret=0 + ;; + esac + ;; + (node) + local curcontext="$curcontext" state + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -): :->command" \ + "($help -)*:: :->option-or-argument" && ret=0 + + case $state in + (command) + __docker_node_commands && ret=0 + ;; + (option-or-argument) + curcontext=${curcontext%:*:*}:docker-${words[-1]}: + __docker_node_subcommand && ret=0 + ;; + esac + ;; + (plugin) + local curcontext="$curcontext" state + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -): :->command" \ + "($help -)*:: :->option-or-argument" && ret=0 + + case $state in + (command) + __docker_plugin_commands && ret=0 + ;; + (option-or-argument) + curcontext=${curcontext%:*:*}:docker-${words[-1]}: + __docker_plugin_subcommand && ret=0 + ;; + esac + ;; + (ps) + words[1]='ls' + __docker_container_subcommand && ret=0 + ;; + (rmi) + words[1]='rm' + __docker_image_subcommand && ret=0 + ;; + (search) + _arguments $(__docker_arguments) -A '-*' \ + $opts_help \ + "($help)*"{-f=,--filter=}"[Filter values]:filter:__docker_complete_search_filters" \ + "($help)--limit=[Maximum returned search results]:limit:(1 5 10 25 50)" \ + "($help)--no-trunc[Do not truncate output]" \ + "($help -):term: " && ret=0 + ;; + (secret) + local curcontext="$curcontext" state + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -): :->command" \ + "($help -)*:: :->option-or-argument" && ret=0 + + case $state in + (command) + __docker_secret_commands && ret=0 + ;; + (option-or-argument) + curcontext=${curcontext%:*:*}:docker-${words[-1]}: + __docker_secret_subcommand && ret=0 + ;; + esac + ;; + (service) + local curcontext="$curcontext" state + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -): :->command" \ + "($help -)*:: :->option-or-argument" && ret=0 + + case $state in + (command) + __docker_service_commands && ret=0 + ;; + (option-or-argument) + curcontext=${curcontext%:*:*}:docker-${words[-1]}: + __docker_service_subcommand && ret=0 + ;; + esac + ;; + (stack) + local curcontext="$curcontext" state + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -): :->command" \ + "($help -)*:: :->option-or-argument" && ret=0 + + case $state in + (command) + __docker_stack_commands && ret=0 + ;; + (option-or-argument) + curcontext=${curcontext%:*:*}:docker-${words[-1]}: + __docker_stack_subcommand && ret=0 + ;; + esac + ;; + (swarm) + local curcontext="$curcontext" state + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -): :->command" \ + "($help -)*:: :->option-or-argument" && ret=0 + + case $state in + (command) + __docker_swarm_commands && ret=0 + ;; + (option-or-argument) + curcontext=${curcontext%:*:*}:docker-${words[-1]}: + __docker_swarm_subcommand && ret=0 + ;; + esac + ;; + (system) + local curcontext="$curcontext" state + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -): :->command" \ + "($help -)*:: :->option-or-argument" && ret=0 + + case $state in + (command) + __docker_system_commands && ret=0 + ;; + (option-or-argument) + curcontext=${curcontext%:*:*}:docker-${words[-1]}: + __docker_system_subcommand && ret=0 + ;; + esac + ;; + (version) + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -f --format)"{-f=,--format=}"[Format the output using the given go template]:template: " && ret=0 + ;; + (volume) + local curcontext="$curcontext" state + _arguments $(__docker_arguments) \ + $opts_help \ + "($help -): :->command" \ + "($help -)*:: :->option-or-argument" && ret=0 + + case $state in + (command) + __docker_volume_commands && ret=0 + ;; + (option-or-argument) + curcontext=${curcontext%:*:*}:docker-${words[-1]}: + __docker_volume_subcommand && ret=0 + ;; + esac + ;; + (help) + _arguments $(__docker_arguments) ":subcommand:__docker_commands" && ret=0 + ;; + esac + + return ret +} + +_docker() { + # Support for subservices, which allows for `compdef _docker docker-shell=_docker_containers`. + # Based on /usr/share/zsh/functions/Completion/Unix/_git without support for `ret`. + if [[ $service != docker ]]; then + _call_function - _$service + return + fi + + local curcontext="$curcontext" state line help="-h --help" + integer ret=1 + typeset -A opt_args + + _arguments $(__docker_arguments) -C \ + "(: -)"{-h,--help}"[Print usage]" \ + "($help)--config[Location of client config files]:path:_directories" \ + "($help -c --context)"{-c=,--context=}"[Execute the command in a docker context]:context:__docker_complete_contexts" \ + "($help -D --debug)"{-D,--debug}"[Enable debug mode]" \ + "($help -H --host)"{-H=,--host=}"[tcp://host:port to bind/connect to]:host: " \ + "($help -l --log-level)"{-l=,--log-level=}"[Logging level]:level:(debug info warn error fatal)" \ + "($help)--tls[Use TLS]" \ + "($help)--tlscacert=[Trust certs signed only by this CA]:PEM file:_files -g "*.(pem|crt)"" \ + "($help)--tlscert=[Path to TLS certificate file]:PEM file:_files -g "*.(pem|crt)"" \ + "($help)--tlskey=[Path to TLS key file]:Key file:_files -g "*.(pem|key)"" \ + "($help)--tlsverify[Use TLS and verify the remote]" \ + "($help)--userland-proxy[Use userland proxy for loopback traffic]" \ + "($help -v --version)"{-v,--version}"[Print version information and quit]" \ + "($help -): :->command" \ + "($help -)*:: :->option-or-argument" && ret=0 + + local host=${opt_args[-H]}${opt_args[--host]} + local config=${opt_args[--config]} + local context=${opt_args[-c]}${opt_args[--context]} + local docker_options="${host:+--host $host} ${config:+--config $config} ${context:+--context $context} " + + case $state in + (command) + __docker_commands && ret=0 + ;; + (option-or-argument) + curcontext=${curcontext%:*:*}:docker-$words[1]: + __docker_subcommand && ret=0 + ;; + esac + + return ret +} + +_dockerd() { + integer ret=1 + words[1]='daemon' + __docker_subcommand && ret=0 + return ret +} + +_docker "$@" + +# Local Variables: +# mode: Shell-Script +# sh-indentation: 4 +# indent-tabs-mode: nil +# sh-basic-offset: 4 +# End: +# vim: ft=zsh sw=4 ts=4 et From 73c4764e78947864c6f067df3bec4cff02866eb2 Mon Sep 17 00:00:00 2001 From: Andrei Polushin Date: Thu, 29 Jun 2023 13:25:41 +0200 Subject: [PATCH 309/672] fix(docker): use `docker --version` instead of `docker version` `docker version` subcommand is able to return both docker client and docker daemon information. To get a daemon version, it connects to a possibly remote daemon. If the remote daemon is not accessible, the client waits for some time, until it gets interrupted by timeout. As a result we can have a docker client running in background. When zsh session is rather short, a terminal application (iTerm2) starts asking if that background docker process should be stopped. On the other hand, to get a docker client version only, we can use `docker --version` instead. It does not connect to a daemon. Closes #11780 --- plugins/docker/docker.plugin.zsh | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/plugins/docker/docker.plugin.zsh b/plugins/docker/docker.plugin.zsh index 434b1fc60..3abce6466 100644 --- a/plugins/docker/docker.plugin.zsh +++ b/plugins/docker/docker.plugin.zsh @@ -37,8 +37,10 @@ if (( ! $+commands[docker] )); then fi { + # docker version returns `Docker version 24.0.2, build cb74dfcd85` + # with `s:,:` remove the comma after the version, and select third word of it + local _docker_version=${${(s:,:z)"$(command docker --version)"}[3]} # `docker completion` is only available from 23.0.0 on - local _docker_version=$(command docker version --format '{{.Client.Version}}' 2>/dev/null) if is-at-least 23.0.0 $_docker_version; then # If the completion file doesn't exist yet, we need to autoload it and # bind it to `docker`. Otherwise, compinit will have already done that. From 54779e5250f362ebd1cf6a7094657f2c894958c3 Mon Sep 17 00:00:00 2001 From: Matthias Heyman Date: Thu, 29 Jun 2023 13:29:14 +0200 Subject: [PATCH 310/672] fix(jira): support identifiers delimited with a hyphen (#11782) Co-authored-by: Matthias Heyman --- plugins/jira/jira.plugin.zsh | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/plugins/jira/jira.plugin.zsh b/plugins/jira/jira.plugin.zsh index e789fce92..b6ee9f100 100644 --- a/plugins/jira/jira.plugin.zsh +++ b/plugins/jira/jira.plugin.zsh @@ -80,7 +80,13 @@ function jira() { issue_arg=${issue_arg##*/} # Strip suffixes starting with _ issue_arg=(${(s:_:)issue_arg}) - issue_arg=${issue_arg[1]} + # If there is only one part, it means that there is a different delimiter. Try with - + if [[ ${#issue_arg[@]} = 1 && ${issue_arg} == *-* ]]; then + issue_arg=(${(s:-:)issue_arg}) + issue_arg="${issue_arg[1]}-${issue_arg[2]}" + else + issue_arg=${issue_arg[1]} + fi if [[ "${issue_arg:l}" = ${jira_prefix:l}* ]]; then issue="${issue_arg}" else From fe4b5659863c388786986d70fa6d1bb66b00afb6 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Fri, 30 Jun 2023 11:41:44 +0200 Subject: [PATCH 311/672] fix(docker): only load old completion if docker <23 --- plugins/docker/{ => completions}/_docker | 0 plugins/docker/docker.plugin.zsh | 7 +++++++ 2 files changed, 7 insertions(+) rename plugins/docker/{ => completions}/_docker (100%) diff --git a/plugins/docker/_docker b/plugins/docker/completions/_docker similarity index 100% rename from plugins/docker/_docker rename to plugins/docker/completions/_docker diff --git a/plugins/docker/docker.plugin.zsh b/plugins/docker/docker.plugin.zsh index 3abce6466..7777048a3 100644 --- a/plugins/docker/docker.plugin.zsh +++ b/plugins/docker/docker.plugin.zsh @@ -36,6 +36,11 @@ if (( ! $+commands[docker] )); then return fi +# Standarized $0 handling +# https://zdharma-continuum.github.io/Zsh-100-Commits-Club/Zsh-Plugin-Standard.html +0="${${ZERO:-${0:#$ZSH_ARGZERO}}:-${(%):-%N}}" +0="${${(M)0:#/*}:-$PWD/$0}" + { # docker version returns `Docker version 24.0.2, build cb74dfcd85` # with `s:,:` remove the comma after the version, and select third word of it @@ -50,5 +55,7 @@ fi _comps[docker]=_docker fi command docker completion zsh >| "$ZSH_CACHE_DIR/completions/_docker" + else + command cp "${0:h}/completions/_docker" "$ZSH_CACHE_DIR/completions/_docker" fi } &| From 8bdb5c959c9a5c74d3b59c05a3a0bca5e602c3cd Mon Sep 17 00:00:00 2001 From: Jarrett Lusso Date: Sat, 15 Jul 2023 16:10:48 -0400 Subject: [PATCH 312/672] docs(nvm): clarify autoload setup (#11797) --- plugins/nvm/README.md | 7 +------ 1 file changed, 1 insertion(+), 6 deletions(-) diff --git a/plugins/nvm/README.md b/plugins/nvm/README.md index eee3bf717..b5ef221d3 100644 --- a/plugins/nvm/README.md +++ b/plugins/nvm/README.md @@ -52,12 +52,7 @@ version to load. This can be done, similar as previous options, adding: ```zsh zstyle ':omz:plugins:nvm' autoload yes -``` - -To remove the output generated by NVM when autoloading, you can set the following option: - -```zsh -zstyle ':omz:plugins:nvm' silent-autoload yes +zstyle ':omz:plugins:nvm' silent-autoload yes # optionally remove the output generated by NVM when autoloading ``` Note: _this will not remove regular `nvm` output_ From b3427f0de6cf7a2ea8387366c44257663e72555c Mon Sep 17 00:00:00 2001 From: majick <125657+majick@users.noreply.github.com> Date: Wed, 19 Jul 2023 14:28:33 +0200 Subject: [PATCH 313/672] fix(ubuntu)!: rename `acse` alias to `acs` Closes #11799 This commit reverses 5bfdd0356b46dc711a8f0866eeb9b717c033d5b2 BREAKING CHANGE: reverting alias rename from `acs` to `acse`. --- plugins/debian/README.md | 2 +- plugins/debian/debian.plugin.zsh | 2 +- plugins/ubuntu/README.md | 2 +- plugins/ubuntu/ubuntu.plugin.zsh | 2 +- 4 files changed, 4 insertions(+), 4 deletions(-) diff --git a/plugins/debian/README.md b/plugins/debian/README.md index c1ebe1c50..1db534f13 100644 --- a/plugins/debian/README.md +++ b/plugins/debian/README.md @@ -21,7 +21,7 @@ Set `$apt_pref` and `$apt_upgr` to whatever command you want (before sourcing Oh | ------ | ---------------------------------------------------------------------- | ---------------------------------------------------------- | | `age` | `apt-get` | Command line tool for handling packages | | `api` | `aptitude` | Same functionality as `apt-get`, provides extra options | -| `acse` | `apt-cache search` | Command line tool for searching apt software package cache | +| `acs` | `apt-cache search` | Command line tool for searching apt software package cache | | `aps` | `aptitude search` | Searches installed packages using aptitude | | `as` | `aptitude -F '* %p -> %d \n(%v/%V)' --no-gui --disable-columns search` | Print searched packages using a custom format | | `afs` | `apt-file search --regexp` | Search file in packages | diff --git a/plugins/debian/debian.plugin.zsh b/plugins/debian/debian.plugin.zsh index bab1ae1c6..5ef4cfb67 100644 --- a/plugins/debian/debian.plugin.zsh +++ b/plugins/debian/debian.plugin.zsh @@ -26,7 +26,7 @@ alias age='apt-get' alias api='aptitude' # Some self-explanatory aliases -alias acse="apt-cache search" +alias acs="apt-cache search" alias aps='aptitude search' alias as="aptitude -F '* %p -> %d \n(%v/%V)' --no-gui --disable-columns search" diff --git a/plugins/ubuntu/README.md b/plugins/ubuntu/README.md index 2401c102b..20f5c65ee 100644 --- a/plugins/ubuntu/README.md +++ b/plugins/ubuntu/README.md @@ -15,7 +15,7 @@ Commands that use `$APT` will use `apt` if installed or defer to `apt-get` other | Alias | Command | Description | |---------|--------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------| | age | `sudo $APT` | Run apt-get with sudo | -| acse | `apt-cache search` | Search the apt-cache with the specified criteria | +| acs | `apt-cache search` | Search the apt-cache with the specified criteria | | acsp | `apt-cache showpkg` | Shows information about the listed packages | | acp | `apt-cache policy` | Display the package source priorities | | afs | `apt-file search --regexp` | Perform a regular expression apt-file search | diff --git a/plugins/ubuntu/ubuntu.plugin.zsh b/plugins/ubuntu/ubuntu.plugin.zsh index 4d35da2ac..7b765a406 100644 --- a/plugins/ubuntu/ubuntu.plugin.zsh +++ b/plugins/ubuntu/ubuntu.plugin.zsh @@ -1,6 +1,6 @@ (( $+commands[apt] )) && APT=apt || APT=apt-get -alias acse='apt-cache search' +alias acs='apt-cache search' alias afs='apt-file search --regexp' From 33fbbdbb0d46e87d76bbef94ac07ceff2cd0b47e Mon Sep 17 00:00:00 2001 From: majick <125657+majick@users.noreply.github.com> Date: Wed, 19 Jul 2023 14:28:55 +0200 Subject: [PATCH 314/672] fix(aliases)!: rename `acs` to `als` BREAKING CHANGE: rename main function from `acs` to `als` to avoid conflicts with `ubuntu` and `debian` plugins and improve semantics. --- plugins/aliases/README.md | 10 +++++----- plugins/aliases/aliases.plugin.zsh | 2 +- 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/plugins/aliases/README.md b/plugins/aliases/README.md index 6a2da3d74..419554095 100644 --- a/plugins/aliases/README.md +++ b/plugins/aliases/README.md @@ -15,14 +15,14 @@ Requirements: Python needs to be installed. ## Usage -- `acs`: show all aliases by group +- `als`: show all aliases by group -- `acs -h/--help`: print help mesage +- `als -h/--help`: print help mesage -- `acs `: filter and highlight aliases by `` +- `als `: filter and highlight aliases by `` -- `acs -g /--group `: show only aliases for group ``. Multiple uses of the flag show all groups +- `als -g /--group `: show only aliases for group ``. Multiple uses of the flag show all groups -- `acs --groups`: show only group names +- `als --groups`: show only group names ![screenshot](https://cloud.githubusercontent.com/assets/3602957/11581913/cb54fb8a-9a82-11e5-846b-5a67f67ad9ad.png) diff --git a/plugins/aliases/aliases.plugin.zsh b/plugins/aliases/aliases.plugin.zsh index 9864de957..7f1ba83b8 100644 --- a/plugins/aliases/aliases.plugin.zsh +++ b/plugins/aliases/aliases.plugin.zsh @@ -4,7 +4,7 @@ 0="${${(M)0:#/*}:-$PWD/$0}" eval ' - function acs(){ + function als(){ (( $+commands[python3] )) || { echo "[error] No python executable detected" return From 7cf00a0b5cf0f25c16fc7902f78dff480e03fe3d Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Wed, 19 Jul 2023 14:46:35 +0200 Subject: [PATCH 315/672] fix(nvm): remove nvm not found verbose message --- plugins/nvm/nvm.plugin.zsh | 8 +------- 1 file changed, 1 insertion(+), 7 deletions(-) diff --git a/plugins/nvm/nvm.plugin.zsh b/plugins/nvm/nvm.plugin.zsh index 484ef2964..1badbeab5 100644 --- a/plugins/nvm/nvm.plugin.zsh +++ b/plugins/nvm/nvm.plugin.zsh @@ -16,13 +16,7 @@ fi # Note: nvm is a function so we need to use `which` which nvm &>/dev/null && return -if [[ -z "$NVM_DIR" ]]; then - echo "[oh-my-zsh] nvm installation cannot be found" - echo "[oh-my-zsh] set NVM_DIR to your installation" - return -fi -if [[ ! -f "$NVM_DIR/nvm.sh" ]]; then - echo "[oh-my-zsh] nvm.sh does not exist in $NVM_DIR" +if [[ -z "$NVM_DIR" ]] || [[ ! -f "$NVM_DIR/nvm.sh" ]]; then return fi From c4392a4da31efee36f29a62d3951d5c0fcd7d4e6 Mon Sep 17 00:00:00 2001 From: Jokeoo <30483934+SunJun8@users.noreply.github.com> Date: Wed, 19 Jul 2023 21:03:38 +0800 Subject: [PATCH 316/672] feat(tig): add two new aliases (#11090) --- plugins/tig/tig.plugin.zsh | 2 ++ 1 file changed, 2 insertions(+) diff --git a/plugins/tig/tig.plugin.zsh b/plugins/tig/tig.plugin.zsh index 7e0c530ac..5b7d2550a 100644 --- a/plugins/tig/tig.plugin.zsh +++ b/plugins/tig/tig.plugin.zsh @@ -1,3 +1,5 @@ alias tis='tig status' alias til='tig log' alias tib='tig blame -C' +alias tif='tig reflog' +alias tia='tig --all' From 7d5e12500a2ba0b575ffafcbb516568973528730 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Thu, 20 Jul 2023 10:43:56 +0200 Subject: [PATCH 317/672] feat(docker): add `legacy-completion` option --- plugins/docker/README.md | 11 ++++++++++- plugins/docker/docker.plugin.zsh | 27 ++++++++++++++------------- 2 files changed, 24 insertions(+), 14 deletions(-) diff --git a/plugins/docker/README.md b/plugins/docker/README.md index 512b5d17c..0ab2e41fb 100644 --- a/plugins/docker/README.md +++ b/plugins/docker/README.md @@ -30,6 +30,15 @@ file**, but be aware of the side effects: > zstyle ':completion:*:*:docker-*:*' option-stacking yes > ``` +### Use old-style completion + +If the current completion does not work well for you, you can enable legacy completion instead with the +following setting. See https://github.com/ohmyzsh/ohmyzsh/issues/11789 for more information. + +```zsh +zstyle ':omz:plugins:docker' legacy-completion yes +``` + ## Aliases | Alias | Command | Description | @@ -58,7 +67,7 @@ file**, but be aware of the side effects: | drm | `docker container rm` | Remove the specified container(s) | | drm! | `docker container rm -f` | Force the removal of a running container (uses SIGKILL) | | dst | `docker container start` | Start one or more stopped containers | -| drs | `docker container restart` | Restart one or more containers +| drs | `docker container restart` | Restart one or more containers | | dsta | `docker stop $(docker ps -q)` | Stop all running containers | | dstp | `docker container stop` | Stop one or more running containers | | dtop | `docker top` | Display the running processes of a container | diff --git a/plugins/docker/docker.plugin.zsh b/plugins/docker/docker.plugin.zsh index 7777048a3..7e657f2df 100644 --- a/plugins/docker/docker.plugin.zsh +++ b/plugins/docker/docker.plugin.zsh @@ -41,21 +41,22 @@ fi 0="${${ZERO:-${0:#$ZSH_ARGZERO}}:-${(%):-%N}}" 0="${${(M)0:#/*}:-$PWD/$0}" +# If the completion file doesn't exist yet, we need to autoload it and +# bind it to `docker`. Otherwise, compinit will have already done that. +if [[ ! -f "$ZSH_CACHE_DIR/completions/_docker" ]]; then + typeset -g -A _comps + autoload -Uz _docker + _comps[docker]=_docker +fi + { + # `docker completion` is only available from 23.0.0 on # docker version returns `Docker version 24.0.2, build cb74dfcd85` # with `s:,:` remove the comma after the version, and select third word of it - local _docker_version=${${(s:,:z)"$(command docker --version)"}[3]} - # `docker completion` is only available from 23.0.0 on - if is-at-least 23.0.0 $_docker_version; then - # If the completion file doesn't exist yet, we need to autoload it and - # bind it to `docker`. Otherwise, compinit will have already done that. - if [[ ! -f "$ZSH_CACHE_DIR/completions/_docker" ]]; then - typeset -g -A _comps - autoload -Uz _docker - _comps[docker]=_docker - fi - command docker completion zsh >| "$ZSH_CACHE_DIR/completions/_docker" - else - command cp "${0:h}/completions/_docker" "$ZSH_CACHE_DIR/completions/_docker" + if zstyle -t ':omz:plugins:docker' legacy-completion || \ + ! is-at-least 23.0.0 ${${(s:,:z)"$(command docker --version)"}[3]}; then + command cp "${0:h}/completions/_docker" "$ZSH_CACHE_DIR/completions/_docker" + else + command docker completion zsh >| "$ZSH_CACHE_DIR/completions/_docker" fi } &| From b9354c5e9c29bd2d5b53731847855d25381c157c Mon Sep 17 00:00:00 2001 From: Zou Yang Date: Mon, 24 Jul 2023 01:44:30 +0800 Subject: [PATCH 318/672] fix(michelebologna): use blue instead of white (#11810) --- themes/michelebologna.zsh-theme | 11 +++++------ 1 file changed, 5 insertions(+), 6 deletions(-) diff --git a/themes/michelebologna.zsh-theme b/themes/michelebologna.zsh-theme index bb86d68db..b13b2caf1 100644 --- a/themes/michelebologna.zsh-theme +++ b/themes/michelebologna.zsh-theme @@ -29,14 +29,13 @@ local cyan="%{$fg_bold[cyan]%}" local yellow="%{$fg_bold[yellow]%}" local blue="%{$fg_bold[blue]%}" local magenta="%{$fg_bold[magenta]%}" -local white="%{$fg_bold[white]%}" local reset="%{$reset_color%}" local -a color_array -color_array=($green $red $cyan $yellow $blue $magenta $white) +color_array=($green $red $cyan $yellow $blue $magenta) -local username_color=$white -local hostname_color=$color_array[$[((#HOST))%7+1]] # choose hostname color based on first character +local username_color=$blue +local hostname_color=$color_array[$[((#HOST))%6+1]] # choose hostname color based on first character local current_dir_color=$blue local username="%n" @@ -66,10 +65,10 @@ function michelebologna_git_prompt { local out=$(git_prompt_info)$(git_prompt_status)$(git_remote_status) [[ -n $out ]] || return printf " %s(%s%s%s)%s" \ - "%{$fg_bold[white]%}" \ + "%{$fg_bold[blue]%}" \ "%{$fg_bold[green]%}" \ "$out" \ - "%{$fg_bold[white]%}" \ + "%{$fg_bold[blue]%}" \ "%{$reset_color%}" } From 338b9a615a276240deaf4b6a26bb3abda204fe3f Mon Sep 17 00:00:00 2001 From: cohml <62400541+cohml@users.noreply.github.com> Date: Sun, 23 Jul 2023 16:02:17 -0400 Subject: [PATCH 319/672] fix(per-directory-history): ^G also in vi mode (#11808) Co-authored-by: Chris Hamill --- plugins/per-directory-history/per-directory-history.zsh | 1 + 1 file changed, 1 insertion(+) diff --git a/plugins/per-directory-history/per-directory-history.zsh b/plugins/per-directory-history/per-directory-history.zsh index 7cd673cdb..acbd64757 100644 --- a/plugins/per-directory-history/per-directory-history.zsh +++ b/plugins/per-directory-history/per-directory-history.zsh @@ -81,6 +81,7 @@ function per-directory-history-toggle-history() { autoload per-directory-history-toggle-history zle -N per-directory-history-toggle-history bindkey $PER_DIRECTORY_HISTORY_TOGGLE per-directory-history-toggle-history +bindkey -M vicmd $PER_DIRECTORY_HISTORY_TOGGLE per-directory-history-toggle-history #------------------------------------------------------------------------------- # implementation details From 6925c44af4bf909a1e023aaa7243e1752db2439a Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Tue, 25 Jul 2023 01:22:33 +0200 Subject: [PATCH 320/672] fix(aliases): rename acs to als in script help Closes #11812 --- plugins/aliases/cheatsheet.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/aliases/cheatsheet.py b/plugins/aliases/cheatsheet.py index f742fba9e..61bf5f956 100644 --- a/plugins/aliases/cheatsheet.py +++ b/plugins/aliases/cheatsheet.py @@ -57,7 +57,7 @@ def pretty_print(cheatsheet, wfilter, group_list=None, groups_only=False): pretty_print_group(key, [ alias for alias in aliases if alias[0].find(wfilter)>-1 or alias[1].find(wfilter)>-1], wfilter) if __name__ == '__main__': - parser = argparse.ArgumentParser(description="Pretty print aliases.", prog="acs") + parser = argparse.ArgumentParser(description="Pretty print aliases.", prog="als") parser.add_argument('filter', nargs="*", metavar="", help="search aliases matching keywords") parser.add_argument('-g', '--group', dest="group_list", action='append', help="only print aliases in given groups") parser.add_argument('--groups', dest='groups_only', action='store_true', help="only print alias groups") From e564793939a086fc4c46628b193a38997ea4ecb3 Mon Sep 17 00:00:00 2001 From: naturedamends <120284608+naturedamends@users.noreply.github.com> Date: Tue, 25 Jul 2023 09:25:07 +0100 Subject: [PATCH 321/672] feat(fino-time): add conda environment (#11785) --- themes/fino-time.zsh-theme | 1 + 1 file changed, 1 insertion(+) diff --git a/themes/fino-time.zsh-theme b/themes/fino-time.zsh-theme index c7e2d965e..3f9360ac5 100644 --- a/themes/fino-time.zsh-theme +++ b/themes/fino-time.zsh-theme @@ -12,6 +12,7 @@ # Also borrowing from http://stevelosh.com/blog/2010/02/my-extravagant-zsh-prompt/ function virtualenv_info { + [ $CONDA_DEFAULT_ENV ] && echo "($CONDA_DEFAULT_ENV) " [ $VIRTUAL_ENV ] && echo '('`basename $VIRTUAL_ENV`') ' } From 4188b22aea3356a02768505103e42a96d18547a3 Mon Sep 17 00:00:00 2001 From: jabunovoty Date: Tue, 25 Jul 2023 10:31:24 +0200 Subject: [PATCH 322/672] feat(agnoster): add git tag to prompt (#8417) Co-authored-by: Jakub Novotny --- themes/agnoster.zsh-theme | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/themes/agnoster.zsh-theme b/themes/agnoster.zsh-theme index 88854eccd..aa274a5bb 100644 --- a/themes/agnoster.zsh-theme +++ b/themes/agnoster.zsh-theme @@ -109,7 +109,9 @@ prompt_git() { if [[ "$(git rev-parse --is-inside-work-tree 2>/dev/null)" = "true" ]]; then repo_path=$(git rev-parse --git-dir 2>/dev/null) dirty=$(parse_git_dirty) - ref=$(git symbolic-ref HEAD 2> /dev/null) || ref="➦ $(git rev-parse --short HEAD 2> /dev/null)" + ref=$(git symbolic-ref HEAD 2> /dev/null) || \ + ref="◈ $(git describe --exact-match --tags HEAD 2> /dev/null)" || \ + ref="➦ $(git rev-parse --short HEAD 2> /dev/null)" if [[ -n $dirty ]]; then prompt_segment yellow black else From 7d2aedf199d1e27b6bea8ab33212043b055b3715 Mon Sep 17 00:00:00 2001 From: David LJ Date: Wed, 9 Aug 2023 18:27:39 +0200 Subject: [PATCH 323/672] chore(gitignore): use new API endpoint from TopTal (#11835) --- plugins/gitignore/README.md | 2 +- plugins/gitignore/gitignore.plugin.zsh | 4 ++-- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/plugins/gitignore/README.md b/plugins/gitignore/README.md index 753dd31fd..23c7887cf 100644 --- a/plugins/gitignore/README.md +++ b/plugins/gitignore/README.md @@ -1,6 +1,6 @@ # gitignore -This plugin enables you the use of [gitignore.io](https://www.gitignore.io/) from the command line. You need an active internet connection. +This plugin enables you the use of [gitignore.io](https://www.toptal.com/developers/gitignore) from the command line. You need an active internet connection. To use it, add `gitignore` to the plugins array in your zshrc file: diff --git a/plugins/gitignore/gitignore.plugin.zsh b/plugins/gitignore/gitignore.plugin.zsh index a687f5cce..3271d61a9 100644 --- a/plugins/gitignore/gitignore.plugin.zsh +++ b/plugins/gitignore/gitignore.plugin.zsh @@ -1,7 +1,7 @@ -function gi() { curl -fLw '\n' https://www.gitignore.io/api/"${(j:,:)@}" } +function gi() { curl -fLw '\n' https://www.toptal.com/developers/gitignore/api/"${(j:,:)@}" } _gitignoreio_get_command_list() { - curl -sfL https://www.gitignore.io/api/list | tr "," "\n" + curl -sfL https://www.toptal.com/developers/gitignore/api/list | tr "," "\n" } _gitignoreio () { From fd219a94ab585fa699a0e842335a9f33dcbb613b Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Thu, 10 Aug 2023 15:39:40 +0200 Subject: [PATCH 324/672] docs(aliases): replace screenshot Closes #11837 Closes #11822 --- plugins/aliases/README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/aliases/README.md b/plugins/aliases/README.md index 419554095..53b68ea01 100644 --- a/plugins/aliases/README.md +++ b/plugins/aliases/README.md @@ -25,4 +25,4 @@ Requirements: Python needs to be installed. - `als --groups`: show only group names - ![screenshot](https://cloud.githubusercontent.com/assets/3602957/11581913/cb54fb8a-9a82-11e5-846b-5a67f67ad9ad.png) + ![screenshot](https://github.com/ohmyzsh/ohmyzsh/assets/66907184/5bfa00ea-5fc3-4e97-8b22-2f74f6b948c7) From b81915d3293cc4657cec64202b9fd991b96b4ba2 Mon Sep 17 00:00:00 2001 From: Jin Cheol <76617139+bik1111@users.noreply.github.com> Date: Wed, 16 Aug 2023 20:46:28 +0900 Subject: [PATCH 325/672] feat(terraform): add terraform version prompt (#11845) --- plugins/terraform/README.md | 13 ++++++++----- plugins/terraform/terraform.plugin.zsh | 7 +++++++ 2 files changed, 15 insertions(+), 5 deletions(-) diff --git a/plugins/terraform/README.md b/plugins/terraform/README.md index c19f2ad1c..fc9a9f005 100644 --- a/plugins/terraform/README.md +++ b/plugins/terraform/README.md @@ -1,7 +1,7 @@ # Terraform plugin -Plugin for Terraform, a tool from Hashicorp for managing infrastructure safely and efficiently. -It adds completion for `terraform`, as well as aliases and a prompt function. +Plugin for Terraform, a tool from Hashicorp for managing infrastructure safely and efficiently. It adds +completion for `terraform`, as well as aliases and a prompt function. To use it, add `terraform` to the plugins array of your `~/.zshrc` file: @@ -11,7 +11,7 @@ plugins=(... terraform) ## Requirements -* [Terraform](https://terraform.io/) +- [Terraform](https://terraform.io/) ## Aliases @@ -29,11 +29,12 @@ plugins=(... terraform) ## Prompt function -You can add the current Terraform workspace in your prompt by adding `$(tf_prompt_info)` -to your `PROMPT` or `RPROMPT` variable. +You can add the current Terraform workspace in your prompt by adding `$(tf_prompt_info)`, +`$(tf_version_prompt_info)` to your `PROMPT` or `RPROMPT` variable. ```sh RPROMPT='$(tf_prompt_info)' +RPROMPT='$(tf_version_prompt_info)' ``` You can also specify the PREFIX and SUFFIX for the workspace with the following variables: @@ -41,4 +42,6 @@ You can also specify the PREFIX and SUFFIX for the workspace with the following ```sh ZSH_THEME_TF_PROMPT_PREFIX="%{$fg[white]%}" ZSH_THEME_TF_PROMPT_SUFFIX="%{$reset_color%}" +ZSH_THEME_TF_VERSION_PROMPT_PREFIX="%{$fg[white]%}" +ZSH_THEME_TF_VERSION_PROMPT_SUFFIX="%{$reset_color%}" ``` diff --git a/plugins/terraform/terraform.plugin.zsh b/plugins/terraform/terraform.plugin.zsh index 7006f204b..ccca54684 100644 --- a/plugins/terraform/terraform.plugin.zsh +++ b/plugins/terraform/terraform.plugin.zsh @@ -8,6 +8,13 @@ function tf_prompt_info() { echo "${ZSH_THEME_TF_PROMPT_PREFIX-[}${workspace:gs/%/%%}${ZSH_THEME_TF_PROMPT_SUFFIX-]}" } +function tf_version_prompt_info() { + local terraform_version + terraform_version=$(terraform --version | head -n 1 | cut -d ' ' -f 2) + echo "${ZSH_THEME_TF_VERSION_PROMPT_PREFIX-[}${terraform_version:gs/%/%%}${ZSH_THEME_TF_VERSION_PROMPT_SUFFIX-]}" +} + + alias tf='terraform' alias tfa='terraform apply' alias tfc='terraform console' From 6bc4c80c7db072a0d2d265eb3589bbe52e0d2737 Mon Sep 17 00:00:00 2001 From: Ahmed Wael <73046395+ahmedwael216@users.noreply.github.com> Date: Mon, 21 Aug 2023 19:07:28 +0300 Subject: [PATCH 326/672] fix(colored-man-pages): add env GROFF_NO_SGR=1 (#11831) --- plugins/colored-man-pages/colored-man-pages.plugin.zsh | 1 + 1 file changed, 1 insertion(+) diff --git a/plugins/colored-man-pages/colored-man-pages.plugin.zsh b/plugins/colored-man-pages/colored-man-pages.plugin.zsh index 981992d88..57facbb5c 100644 --- a/plugins/colored-man-pages/colored-man-pages.plugin.zsh +++ b/plugins/colored-man-pages/colored-man-pages.plugin.zsh @@ -36,6 +36,7 @@ function colored() { # Prefer `less` whenever available, since we specifically configured # environment for it. environment+=( PAGER="${commands[less]:-$PAGER}" ) + environment+=( GROFF_NO_SGR=1 ) # See ./nroff script. if [[ "$OSTYPE" = solaris* ]]; then From dfe2f04de7e839ae0a9757c37a26b9d8710aa372 Mon Sep 17 00:00:00 2001 From: LuckyWindsck Date: Tue, 22 Aug 2023 01:09:02 +0900 Subject: [PATCH 327/672] refactor(init): rename variable (#11851) --- oh-my-zsh.sh | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/oh-my-zsh.sh b/oh-my-zsh.sh index a577c1f41..40f13f37e 100644 --- a/oh-my-zsh.sh +++ b/oh-my-zsh.sh @@ -187,12 +187,12 @@ _omz_source() { fi } -# Load all of the config files in ~/oh-my-zsh that end in .zsh +# Load all of the lib files in ~/oh-my-zsh/lib that end in .zsh # TIP: Add files you don't want in git to .gitignore -for config_file ("$ZSH"/lib/*.zsh); do - _omz_source "lib/${config_file:t}" +for lib_file ("$ZSH"/lib/*.zsh); do + _omz_source "lib/${lib_file:t}" done -unset custom_config_file +unset lib_file # Load all of the plugins that were defined in ~/.zshrc for plugin ($plugins); do From 3f477e5da5ee42356f103d2c5cdd478d23bf9f03 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Wed, 23 Aug 2023 13:25:33 +0200 Subject: [PATCH 328/672] fix(extract): extraction to directory for single-file .gz (#11852) --- plugins/extract/extract.plugin.zsh | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/plugins/extract/extract.plugin.zsh b/plugins/extract/extract.plugin.zsh index b7a823c9f..513950f33 100644 --- a/plugins/extract/extract.plugin.zsh +++ b/plugins/extract/extract.plugin.zsh @@ -64,7 +64,7 @@ EOF (*.tar.lz) (( $+commands[lzip] )) && tar xvf "$full_path" ;; (*.tar.lz4) lz4 -c -d "$full_path" | tar xvf - ;; (*.tar.lrz) (( $+commands[lrzuntar] )) && lrzuntar "$full_path" ;; - (*.gz) (( $+commands[pigz] )) && pigz -dk "$full_path" || gunzip -k "$full_path" ;; + (*.gz) (( $+commands[pigz] )) && pigz -cdk "$full_path" > "${file:t:r}" || gunzip -ck "$full_path" > "${file:t:r}" ;; (*.bz2) bunzip2 "$full_path" ;; (*.xz) unxz "$full_path" ;; (*.lrz) (( $+commands[lrunzip] )) && lrunzip "$full_path" ;; @@ -106,19 +106,19 @@ EOF # - Y2: at most give 2 files local -a content content=("${extract_dir}"/*(DNY2)) - if [[ ${#content} -eq 1 && -d "${content[1]}" ]]; then - # The extracted folder (${content[1]}) may have the same name as $extract_dir + if [[ ${#content} -eq 1 && -e "${content[1]}" ]]; then + # The extracted file/folder (${content[1]}) may have the same name as $extract_dir # If so, we need to rename it to avoid conflicts in a 3-step process # - # 1. Move and rename the extracted folder to a temporary random name + # 1. Move and rename the extracted file/folder to a temporary random name # 2. Delete the empty folder - # 3. Rename the extracted folder to the original name + # 3. Rename the extracted file/folder to the original name if [[ "${content[1]:t}" == "$extract_dir" ]]; then # =(:) gives /tmp/zsh, with :t it gives zsh - local tmp_dir==(:); tmp_dir="${tmp_dir:t}" - command mv "${content[1]}" "$tmp_dir" \ + local tmp_name==(:); tmp_name="${tmp_name:t}" + command mv "${content[1]}" "$tmp_name" \ && command rmdir "$extract_dir" \ - && command mv "$tmp_dir" "$extract_dir" + && command mv "$tmp_name" "$extract_dir" # Otherwise, if the extracted folder name already exists in the current # directory (because of a previous file / folder), keep the extract_dir elif [[ ! -e "${content[1]:t}" ]]; then From 33c0de7add12b050b94fd6f2f988e9b5547d172c Mon Sep 17 00:00:00 2001 From: Miguel Hargreaves Pimenta Date: Wed, 23 Aug 2023 12:38:32 +0100 Subject: [PATCH 329/672] refactor(git): sort git aliases alphabetically (#9743) --- plugins/git/README.md | 419 ++++++++++++------------ plugins/git/git.plugin.zsh | 634 ++++++++++++++++++------------------- 2 files changed, 527 insertions(+), 526 deletions(-) diff --git a/plugins/git/README.md b/plugins/git/README.md index d18531955..0b757c481 100644 --- a/plugins/git/README.md +++ b/plugins/git/README.md @@ -10,213 +10,214 @@ plugins=(... git) ## Aliases -| Alias | Command | -| :------------------- | :--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | -| g | git | -| ga | git add | -| gaa | git add --all | -| gapa | git add --patch | -| gau | git add --update | -| gav | git add --verbose | -| gap | git apply | -| gapt | git apply --3way | -| gb | git branch | -| gba | git branch --all | -| gbd | git branch --delete | -| gbda | git branch --no-color --merged \| grep -vE "^([+*]\|\s*($(git_main_branch)\|$(git_develop_branch))\s*$)" \| xargs git branch --delete 2>/dev/null | -| gbD | git branch --delete --force | -| gbg | git branch -vv | grep ": gone\]" | -| gbgd | git branch --no-color -vv | grep ": gone\]" | awk '"'"'{print $1}'"'"' | xargs git branch -d | -| gbgD | git branch --no-color -vv | grep ": gone\]" | awk '"'"'{print $1}'"'"' | xargs git branch -D | -| gbl | git blame -b -w | -| gbnm | git branch --no-merged | -| gbr | git branch --remote | -| gbs | git bisect | -| gbsb | git bisect bad | -| gbsg | git bisect good | -| gbsr | git bisect reset | -| gbss | git bisect start | -| gc | git commit --verbose | -| gc! | git commit --verbose --amend | -| gcn! | git commit --verbose --no-edit --amend | -| gca | git commit --verbose --all | -| gca! | git commit --verbose --all --amend | -| gcan! | git commit --verbose --all --no-edit --amend | -| gcans! | git commit --verbose --all --signoff --no-edit --amend | -| gcam | git commit --all --message | -| gcas | git commit --all --signoff | -| gcasm | git commit --all --signoff --message | -| gcsm | git commit --signoff --message | -| gcb | git checkout -b | -| gcf | git config --list | -| gcl | git clone --recurse-submodules | -| gccd | git clone --recurse-submodules "$@" && cd "$(basename $\_ .git)" | -| gclean | git clean --interactive -d | -| gpristine | git reset --hard && git clean -dffx | -| gcm | git checkout $(git_main_branch) | -| gcd | git checkout $(git_develop_branch) | -| gcmsg | git commit --message | -| gco | git checkout | -| gcor | git checkout --recurse-submodules | -| gcount | git shortlog --summary -n | -| gcp | git cherry-pick | -| gcpa | git cherry-pick --abort | -| gcpc | git cherry-pick --continue | -| gcs | git commit -S | -| gcss | git commit -S -s | -| gcssm | git commit -S -s -m | -| gd | git diff | -| gdca | git diff --cached | -| gdcw | git diff --cached --word-diff | -| gdct | git describe --tags $(git rev-list --tags --max-count=1) | -| gds | git diff --staged | -| gdt | git diff-tree --no-commit-id --name-only -r | -| gdnolock | git diff $@ ":(exclude)package-lock.json" ":(exclude)\*.lock" | -| gdup | git diff @{upstream} | -| gdv | git diff -w $@ \| view - | -| gdw | git diff --word-diff | -| gf | git fetch | -| gfa | git fetch --all --prune | -| gfg | git ls-files \| grep | -| gfo | git fetch origin | -| gg | git gui citool | -| gga | git gui citool --amend | -| ggf | git push --force origin $(current_branch) | -| ggfl | git push --force-with-lease origin $(current_branch) | -| ggl | git pull origin $(current_branch) | -| ggp | git push origin $(current_branch) | -| ggpnp | ggl && ggp | -| ggpull | git pull origin "$(git_current_branch)" | -| ggpur | ggu | -| ggpush | git push origin "$(git_current_branch)" | -| ggsup | git branch --set-upstream-to=origin/$(git_current_branch) | -| ggu | git pull --rebase origin $(current_branch) | -| gpsup | git push --set-upstream origin $(git_current_branch) | -| gpsupf | git push --set-upstream origin $(git_current_branch) --force-with-lease --force-if-includes (git version >= 2.30) | -| gpsupf | git push --set-upstream origin $(git_current_branch) --force-with-lease (git version < 2.30) | -| ghh | git help | -| gignore | git update-index --assume-unchanged | -| gignored | git ls-files -v \| grep "^[[:lower:]]" | -| git-svn-dcommit-push | git svn dcommit && git push github $(git_main_branch):svntrunk | -| gk | gitk --all --branches &! | -| gke | gitk --all $(git log --walk-reflogs --pretty=%h) &! | -| gl | git pull | -| glg | git log --stat | -| glgp | git log --stat --patch | -| glgg | git log --graph | -| glgga | git log --graph --decorate --all | -| glgm | git log --graph --max-count=10 | -| glo | git log --oneline --decorate | -| glol | git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ar) %C(bold blue)<%an>%Creset' | -| glols | git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ar) %C(bold blue)<%an>%Creset' --stat | -| glod | git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ad) %C(bold blue)<%an>%Creset' | -| glods | git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ad) %C(bold blue)<%an>%Creset' --date=short | -| glola | git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ar) %C(bold blue)<%an>%Creset' --all | -| glog | git log --oneline --decorate --graph | -| gloga | git log --oneline --decorate --graph --all | -| glp | git log --pretty=\ | -| gm | git merge | -| gms | git merge --squash | -| gmom | git merge origin/$(git_main_branch) | -| gmtl | git mergetool --no-prompt | -| gmtlvim | git mergetool --no-prompt --tool=vimdiff | -| gmum | git merge upstream/$(git_main_branch) | -| gma | git merge --abort | -| gp | git push | -| gpd | git push --dry-run | -| gpf | git push --force-with-lease --force-if-includes (git version >= 2.30) | -| gpf | git push --force-with-lease (git version < 2.30) | -| gpf! | git push --force | -| gpoat | git push origin --all && git push origin --tags | -| gpod | git push origin --delete | -| gpr | git pull --rebase | -| gpu | git push upstream | -| gpv | git push --verbose | -| gr | git remote | -| gra | git remote add | -| grb | git rebase | -| grba | git rebase --abort | -| grbc | git rebase --continue | -| grbd | git rebase $(git_develop_branch) | -| grbi | git rebase --interactive | -| grbm | git rebase $(git_main_branch) | -| grbom | git rebase origin/$(git_main_branch) | -| grbo | git rebase --onto | -| grbs | git rebase --skip | -| grev | git revert | -| grh | git reset | -| grhh | git reset --hard | -| groh | git reset origin/$(git_current_branch) --hard | -| grm | git rm | -| grmc | git rm --cached | -| grmv | git remote rename | -| grrm | git remote remove | -| grs | git restore | -| grset | git remote set-url | -| grss | git restore --source | -| grst | git restore --staged | -| grt | cd "$(git rev-parse --show-toplevel \|\| echo .)" | -| gru | git reset -- | -| grup | git remote update | -| grv | git remote --verbose | -| gsb | git status --short -b | -| gsd | git svn dcommit | -| gsh | git show | -| gsi | git submodule init | -| gsps | git show --pretty=short --show-signature | -| gsr | git svn rebase | -| gss | git status --short | -| gst | git status | -| gsta | git stash push (git version >= 2.13) | -| gsta | git stash save (git version < 2.13) | -| gstaa | git stash apply | -| gstc | git stash clear | -| gstd | git stash drop | -| gstl | git stash list | -| gstp | git stash pop | -| gsts | git stash show --text | -| gstu | git stash --include-untracked | -| gstall | git stash --all | -| gsu | git submodule update | -| gsw | git switch | -| gswc | git switch -c | -| gswm | git switch $(git_main_branch) | -| gswd | git switch $(git_develop_branch) | -| gts | git tag -s | -| gtv | git tag \| sort -V | -| gtl | gtl(){ git tag --sort=-v:refname -n --list ${1}\* }; noglob gtl | -| gunignore | git update-index --no-assume-unchanged | -| gunwip | git rev-list --max-count=1 --format="%s" HEAD \| grep -q "\-\-wip\-\-" && git reset HEAD~1 | -| gup | git pull --rebase | -| gupv | git pull --rebase --verbose | -| gupa | git pull --rebase --autostash | -| gupav | git pull --rebase --autostash --verbose | -| gupom | git pull --rebase origin $(git_main_branch) | -| gupomi | git pull --rebase=interactive origin $(git_main_branch) | -| glum | git pull upstream $(git_main_branch) | -| gluc | git pull upstream $(git_current_branch) | -| gwch | git whatchanged -p --abbrev-commit --pretty=medium | -| gwip | git add -A; git rm $(git ls-files --deleted) 2> /dev/null; git commit --no-verify --no-gpg-sign --message "--wip-- [skip ci]" | -| gam | git am | -| gamc | git am --continue | -| gams | git am --skip | -| gama | git am --abort | -| gamscp | git am --show-current-patch | -| gwt | git worktree | -| gwtls | git worktree list | -| gwtmv | git worktree move | -| gwtrm | git worktree remove | +| Alias | Command | +| :------------------- | :--------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| grt | cd "$(git rev-parse --show-toplevel || echo .)" | +| ggpnp | ggl && ggp | +| ggpur | ggu | +| g | git | +| ga | git add | +| gaa | git add --all | +| gapa | git add --patch | +| gau | git add --update | +| gav | git add --verbose | +| gwip | git add -A; git rm $(git ls-files --deleted) 2> /dev/null; git commit --no-verify --no-gpg-sign --message "--wip-- [skip ci]" | +| gam | git am | +| gama | git am --abort | +| gamc | git am --continue | +| gamscp | git am --show-current-patch | +| gams | git am --skip | +| gap | git apply | +| gapt | git apply --3way | +| gbs | git bisect | +| gbsb | git bisect bad | +| gbsg | git bisect good | +| gbsr | git bisect reset | +| gbss | git bisect start | +| gbl | git blame -b -w | +| gb | git branch | +| gba | git branch --all | +| gbd | git branch --delete | +| gbD | git branch --delete --force | +| gbda | git branch --no-color --merged | grep -vE "^([+]|\s($(git_main_branch)|$(git_develop_branch))\s\*$)" | xargs git branch --delete 2>/dev/null | +| gbgd | git branch --no-color -vv | +| gbgD | git branch --no-color -vv | +| gbnm | git branch --no-merged | +| gbr | git branch --remote | +| ggsup | git branch --set-upstream-to=origin/$(git_current_branch) | +| gbg | git branch -vv | +| gco | git checkout | +| gcor | git checkout --recurse-submodules | +| gcb | git checkout -b | +| gcd | git checkout $(git_develop_branch) | +| gcm | git checkout $(git_main_branch) | +| gcp | git cherry-pick | +| gcpa | git cherry-pick --abort | +| gcpc | git cherry-pick --continue | +| gclean | git clean --interactive -d | +| gcl | git clone --recurse-submodules | +| gccd | git clone --recurse-submodules "$@" && cd "$(basename $\_ .git)" | +| gcam | git commit --all --message | +| gcas | git commit --all --signoff | +| gcasm | git commit --all --signoff --message | +| gcmsg | git commit --message | +| gcsm | git commit --signoff --message | +| gc | git commit --verbose | +| gca | git commit --verbose --all | +| gca! | git commit --verbose --all --amend | +| gcan! | git commit --verbose --all --no-edit --amend | +| gcans! | git commit --verbose --all --signoff --no-edit --amend | +| gc! | git commit --verbose --amend | +| gcn! | git commit --verbose --no-edit --amend | +| gcs | git commit -S | +| gcss | git commit -S -s | +| gcssm | git commit -S -s -m | +| gcf | git config --list | +| gdct | git describe --tags $(git rev-list --tags --max-count=1) | +| gd | git diff | +| gdca | git diff --cached | +| gdcw | git diff --cached --word-diff | +| gds | git diff --staged | +| gdw | git diff --word-diff | +| gdv | git diff -w $@ | view - | +| gdup | git diff @{upstream} | +| gdnolock | git diff $@ ":(exclude)package-lock.json" ":(exclude)\*.lock" | +| gdt | git diff-tree --no-commit-id --name-only -r | +| gf | git fetch | +| gfa | git fetch --all --prune | +| gfo | git fetch origin | +| gg | git gui citool | +| gga | git gui citool --amend | +| ghh | git help | +| glgg | git log --graph | +| glgga | git log --graph --decorate --all | +| glgm | git log --graph --max-count=10 | +| glod | git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ad) %C(bold blue)<%an>%Creset' | +| glods | git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ad) %C(bold blue)<%an>%Creset' --date=short | +| glol | git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ar) %C(bold blue)<%an>%Creset' | +| glola | git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ar) %C(bold blue)<%an>%Creset' --all | +| glols | git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ar) %C(bold blue)<%an>%Creset' --stat | +| glo | git log --oneline --decorate | +| glog | git log --oneline --decorate --graph | +| gloga | git log --oneline --decorate --graph --all | +| glp | git log --pretty=\ | +| glg | git log --stat | +| glgp | git log --stat --patch | +| gignored | git ls-files -v | grep "^[[:lower:]]" | +| gfg | git ls-files | grep | +| gm | git merge | +| gma | git merge --abort | +| gms | git merge --squash | +| gmom | git merge origin/$(git_main_branch) | +| gmum | git merge upstream/$(git_main_branch) | +| gmtl | git mergetool --no-prompt | +| gmtlvim | git mergetool --no-prompt --tool=vimdiff | +| gl | git pull | +| gpr | git pull --rebase | +| gup | git pull --rebase | +| gupa | git pull --rebase --autostash | +| gupav | git pull --rebase --autostash --verbose | +| gupv | git pull --rebase --verbose | +| ggu | git pull --rebase origin $(current_branch) | +| gupom | git pull --rebase origin $(git_main_branch) | +| gupomi | git pull --rebase=interactive origin $(git_main_branch) | +| ggpull | git pull origin "$(git_current_branch)" | +| ggl | git pull origin $(current_branch) | +| gluc | git pull upstream $(git_current_branch) | +| glum | git pull upstream $(git_main_branch) | +| gp | git push | +| gpd | git push --dry-run | +| gpf! | git push --force | +| ggf | git push --force origin $(current_branch) | +| gpf | git push --force-with-lease --force-if-includes (git version >= 2.30) | +| gpf | git push --force-with-lease (git version < 2.30) | +| ggfl | git push --force-with-lease origin $(current_branch) | +| gpsup | git push --set-upstream origin $(git_current_branch) | +| gpsupf | git push --set-upstream origin $(git_current_branch) --force-with-lease --force-if-includes (git version >= 2.30) | +| gpsupf | git push --set-upstream origin $(git_current_branch) --force-with-lease (git version < 2.30) | +| gpv | git push --verbose | +| gpoat | git push origin --all && git push origin --tags | +| gpod | git push origin --delete | +| ggpush | git push origin "$(git_current_branch)" | +| ggp | git push origin $(current_branch) | +| gpu | git push upstream | +| grb | git rebase | +| grba | git rebase --abort | +| grbc | git rebase --continue | +| grbi | git rebase --interactive | +| grbo | git rebase --onto | +| grbs | git rebase --skip | +| grbd | git rebase $(git_develop_branch) | +| grbm | git rebase $(git_main_branch) | +| grbom | git rebase origin/$(git_main_branch) | +| gr | git remote | +| grv | git remote --verbose | +| gra | git remote add | +| grrm | git remote remove | +| grmv | git remote rename | +| grset | git remote set-url | +| grup | git remote update | +| grh | git reset | +| gru | git reset -- | +| grhh | git reset --hard | +| gpristine | git reset --hard && git clean -dffx | +| groh | git reset origin/$(git_current_branch) --hard | +| grs | git restore | +| grss | git restore --source | +| grst | git restore --staged | +| gunwip | git rev-list --max-count=1 --format="%s" HEAD | grep -q "--wip--" && git reset HEAD~1 | +| grev | git revert | +| grm | git rm | +| grmc | git rm --cached | +| gcount | git shortlog --summary -n | +| gsh | git show | +| gsps | git show --pretty=short --show-signature | +| gstall | git stash --all | +| gstu | git stash --include-untracked | +| gstaa | git stash apply | +| gstc | git stash clear | +| gstd | git stash drop | +| gstl | git stash list | +| gstp | git stash pop | +| gsta | git stash push (git version >= 2.13) | +| gsta | git stash save (git version < 2.13) | +| gsts | git stash show --text | +| gst | git status | +| gss | git status --short | +| gsb | git status --short -b | +| gsi | git submodule init | +| gsu | git submodule update | +| gsd | git svn dcommit | +| git-svn-dcommit-push | git svn dcommit && git push github $(git_main_branch):svntrunk | +| gsr | git svn rebase | +| gsw | git switch | +| gswc | git switch -c | +| gswd | git switch $(git_develop_branch) | +| gswm | git switch $(git_main_branch) | +| gts | git tag -s | +| gtv | git tag | sort -V | +| gignore | git update-index --assume-unchanged | +| gunignore | git update-index --no-assume-unchanged | +| gwch | git whatchanged -p --abbrev-commit --pretty=medium | +| gwt | git worktree | +| gwtls | git worktree list | +| gwtmv | git worktree move | +| gwtrm | git worktree remove | +| gk | gitk --all --branches &! | +| gke | gitk --all $(git log --walk-reflogs --pretty=%h) &! | +| gtl | gtl(){ git tag --sort=-v:refname -n --list ${1}\* }; noglob gtl | ### Main branch preference -Following the recent push for removing racially-charged words from our technical vocabulary, the git plugin favors using -a branch name other than `master`. In this case, we favor the shorter, neutral and descriptive term `main`. This means -that any aliases and functions that previously used `master`, will use `main` if that branch exists. We do this via the -function `git_main_branch`. +Following the recent push for removing racially-charged words from our technical vocabulary, the git plugin +favors using a branch name other than `master`. In this case, we favor the shorter, neutral and descriptive +term `main`. This means that any aliases and functions that previously used `master`, will use `main` if that +branch exists. We do this via the function `git_main_branch`. ### Deprecated aliases -These are aliases that have been removed, renamed, or otherwise modified in a way that may, or may not, receive further support. +These are aliases that have been removed, renamed, or otherwise modified in a way that may, or may not, +receive further support. | Alias | Command | Modification | | :----- | :----------------------------------------------------- | :----------------------------------------------------- | @@ -238,23 +239,27 @@ These are aliases that have been removed, renamed, or otherwise modified in a wa | Command | Description | | :--------------------- | :------------------------------------------------------------------------------------------------------- | -| `grename ` | Rename `old` branch to `new`, including in origin remote | | current_branch | Return the name of the current branch | -| git_current_user_name | Returns the `user.name` config value | -| git_current_user_email | Returns the `user.email` config value | -| git_main_branch | Returns the name of the main branch: `main` if it exists, `master` otherwise | +| git_current_user_email | Returns the `user.email` config value (lives in lib/git.zsh) | +| git_current_user_name | Returns the `user.name` config value (lives in lib/git.zsh) | | git_develop_branch | Returns the name of the develop branch: `dev`, `devel`, `development` if they exist, `develop` otherwise | +| git_main_branch | Returns the name of the main branch: `main` if it exists, `master` otherwise | +| grename \ \ | Rename `old` branch to `new`, including in origin remote | ### Work in Progress (WIP) -These features allow to pause a branch development and switch to another one (_"Work in Progress"_, or wip). When you want to go back to work, just unwip it. +These features allow to pause a branch development and switch to another one (_"Work in Progress"_, or wip). +When you want to go back to work, just unwip it. | Command | Description | | :--------------- | :---------------------------------------------- | -| work_in_progress | Echoes a warning if the current branch is a wip | | gwip | Commit wip branch | | gunwip | Uncommit wip branch | | gunwipall | Uncommit all recent `--wip--` commits | +| work_in_progress | Echoes a warning if the current branch is a wip | + +Note that `gwip` and `gunwip` are effectivly alias, but are also documented here to group all related WIP +features. ### Deprecated functions diff --git a/plugins/git/git.plugin.zsh b/plugins/git/git.plugin.zsh index d04edea5e..b321ce7b0 100644 --- a/plugins/git/git.plugin.zsh +++ b/plugins/git/git.plugin.zsh @@ -3,7 +3,9 @@ autoload -Uz is-at-least git_version="${${(As: :)$(git version 2>/dev/null)}[3]}" # -# Functions +# Functions Current +# (sorted alphabetically by function name) +# (order should follow README) # # The name of the current branch @@ -14,42 +16,6 @@ function current_branch() { git_current_branch } -# Pretty log messages -function _git_log_prettily(){ - if ! [ -z $1 ]; then - git log --pretty=$1 - fi -} -compdef _git _git_log_prettily=git-log - -# Warn if the current branch is a WIP -function work_in_progress() { - command git -c log.showSignature=false log -n 1 2>/dev/null | grep -q -- "--wip--" && echo "WIP!!" -} - -# Similar to `gunwip` but recursive "Unwips" all recent `--wip--` commits not just the last one -function gunwipall() { - local _commit=$(git log --grep='--wip--' --invert-grep --max-count=1 --format=format:%H) - - # Check if a commit without "--wip--" was found and it's not the same as HEAD - if [[ "$_commit" != "$(git rev-parse HEAD)" ]]; then - git reset $_commit || return 1 - fi -} - -# Check if main exists and use instead of master -function git_main_branch() { - command git rev-parse --git-dir &>/dev/null || return - local ref - for ref in refs/{heads,remotes/{origin,upstream}}/{main,trunk,mainline,default}; do - if command git show-ref -q --verify $ref; then - echo ${ref:t} - return - fi - done - echo master -} - # Check for develop and similarly named branches function git_develop_branch() { command git rev-parse --git-dir &>/dev/null || return @@ -63,289 +29,18 @@ function git_develop_branch() { echo develop } -# -# Aliases -# (sorted alphabetically) -# - -alias g='git' - -alias ga='git add' -alias gaa='git add --all' -alias gapa='git add --patch' -alias gau='git add --update' -alias gav='git add --verbose' -alias gap='git apply' -alias gapt='git apply --3way' - -alias gb='git branch' -alias gba='git branch --all' -alias gbd='git branch --delete' -alias gbda='git branch --no-color --merged | command grep -vE "^([+*]|\s*($(git_main_branch)|$(git_develop_branch))\s*$)" | command xargs git branch --delete 2>/dev/null' -alias gbD='git branch --delete --force' -alias gbg='git branch -vv | grep ": gone\]"' -alias gbgd='git branch --no-color -vv | grep ": gone\]" | awk '"'"'{print $1}'"'"' | xargs git branch -d' -alias gbgD='git branch --no-color -vv | grep ": gone\]" | awk '"'"'{print $1}'"'"' | xargs git branch -D' -alias gbl='git blame -b -w' -alias gbnm='git branch --no-merged' -alias gbr='git branch --remote' -alias gbs='git bisect' -alias gbsb='git bisect bad' -alias gbsg='git bisect good' -alias gbsr='git bisect reset' -alias gbss='git bisect start' - -alias gc='git commit --verbose' -alias gc!='git commit --verbose --amend' -alias gcn!='git commit --verbose --no-edit --amend' -alias gca='git commit --verbose --all' -alias gca!='git commit --verbose --all --amend' -alias gcan!='git commit --verbose --all --no-edit --amend' -alias gcans!='git commit --verbose --all --signoff --no-edit --amend' -alias gcam='git commit --all --message' -alias gcsm='git commit --signoff --message' -alias gcas='git commit --all --signoff' -alias gcasm='git commit --all --signoff --message' -alias gcb='git checkout -b' -alias gcf='git config --list' - -function gccd() { - command git clone --recurse-submodules "$@" - [[ -d "$_" ]] && cd "$_" || cd "${${_:t}%.git}" +# Check if main exists and use instead of master +function git_main_branch() { + command git rev-parse --git-dir &>/dev/null || return + local ref + for ref in refs/{heads,remotes/{origin,upstream}}/{main,trunk,mainline,default}; do + if command git show-ref -q --verify $ref; then + echo ${ref:t} + return + fi + done + echo master } -compdef _git gccd=git-clone - -alias gcl='git clone --recurse-submodules' -alias gclean='git clean --interactive -d' -alias gpristine='git reset --hard && git clean --force -dfx' -alias gcm='git checkout $(git_main_branch)' -alias gcd='git checkout $(git_develop_branch)' -alias gcmsg='git commit --message' -alias gco='git checkout' -alias gcor='git checkout --recurse-submodules' -alias gcount='git shortlog --summary --numbered' -alias gcp='git cherry-pick' -alias gcpa='git cherry-pick --abort' -alias gcpc='git cherry-pick --continue' -alias gcs='git commit --gpg-sign' -alias gcss='git commit --gpg-sign --signoff' -alias gcssm='git commit --gpg-sign --signoff --message' - -alias gd='git diff' -alias gdca='git diff --cached' -alias gdcw='git diff --cached --word-diff' -alias gdct='git describe --tags $(git rev-list --tags --max-count=1)' -alias gds='git diff --staged' -alias gdt='git diff-tree --no-commit-id --name-only -r' -alias gdup='git diff @{upstream}' -alias gdw='git diff --word-diff' - -function gdnolock() { - git diff "$@" ":(exclude)package-lock.json" ":(exclude)*.lock" -} -compdef _git gdnolock=git-diff - -function gdv() { git diff -w "$@" | view - } -compdef _git gdv=git-diff - -alias gf='git fetch' -# --jobs= was added in git 2.8 -is-at-least 2.8 "$git_version" \ - && alias gfa='git fetch --all --prune --jobs=10' \ - || alias gfa='git fetch --all --prune' -alias gfo='git fetch origin' - -alias gfg='git ls-files | grep' - -alias gg='git gui citool' -alias gga='git gui citool --amend' - -function ggf() { - [[ "$#" != 1 ]] && local b="$(git_current_branch)" - git push --force origin "${b:=$1}" -} -compdef _git ggf=git-checkout -function ggfl() { - [[ "$#" != 1 ]] && local b="$(git_current_branch)" - git push --force-with-lease origin "${b:=$1}" -} -compdef _git ggfl=git-checkout - -function ggl() { - if [[ "$#" != 0 ]] && [[ "$#" != 1 ]]; then - git pull origin "${*}" - else - [[ "$#" == 0 ]] && local b="$(git_current_branch)" - git pull origin "${b:=$1}" - fi -} -compdef _git ggl=git-checkout - -function ggp() { - if [[ "$#" != 0 ]] && [[ "$#" != 1 ]]; then - git push origin "${*}" - else - [[ "$#" == 0 ]] && local b="$(git_current_branch)" - git push origin "${b:=$1}" - fi -} -compdef _git ggp=git-checkout - -function ggpnp() { - if [[ "$#" == 0 ]]; then - ggl && ggp - else - ggl "${*}" && ggp "${*}" - fi -} -compdef _git ggpnp=git-checkout - -function ggu() { - [[ "$#" != 1 ]] && local b="$(git_current_branch)" - git pull --rebase origin "${b:=$1}" -} -compdef _git ggu=git-checkout - -alias ggpur='ggu' -alias ggpull='git pull origin "$(git_current_branch)"' -alias ggpush='git push origin "$(git_current_branch)"' - -alias ggsup='git branch --set-upstream-to=origin/$(git_current_branch)' -alias gpsup='git push --set-upstream origin $(git_current_branch)' -is-at-least 2.30 "$git_version" \ - && alias gpsupf='git push --set-upstream origin $(git_current_branch) --force-with-lease --force-if-includes' \ - || alias gpsupf='git push --set-upstream origin $(git_current_branch) --force-with-lease' - -alias ghh='git help' - -alias gignore='git update-index --assume-unchanged' -alias gignored='git ls-files -v | grep "^[[:lower:]]"' -alias git-svn-dcommit-push='git svn dcommit && git push github $(git_main_branch):svntrunk' - -alias gk='\gitk --all --branches &!' -alias gke='\gitk --all $(git log --walk-reflogs --pretty=%h) &!' - -alias gl='git pull' -alias glg='git log --stat' -alias glgp='git log --stat --patch' -alias glgg='git log --graph' -alias glgga='git log --graph --decorate --all' -alias glgm='git log --graph --max-count=10' -alias glo='git log --oneline --decorate' -alias glol="git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ar) %C(bold blue)<%an>%Creset'" -alias glols="git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ar) %C(bold blue)<%an>%Creset' --stat" -alias glod="git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ad) %C(bold blue)<%an>%Creset'" -alias glods="git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ad) %C(bold blue)<%an>%Creset' --date=short" -alias glola="git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ar) %C(bold blue)<%an>%Creset' --all" -alias glog='git log --oneline --decorate --graph' -alias gloga='git log --oneline --decorate --graph --all' -alias glp="_git_log_prettily" - -alias gm='git merge' -alias gmom='git merge origin/$(git_main_branch)' -alias gmtl='git mergetool --no-prompt' -alias gmtlvim='git mergetool --no-prompt --tool=vimdiff' -alias gmum='git merge upstream/$(git_main_branch)' -alias gma='git merge --abort' -alias gms="git merge --squash" - -alias gp='git push' -alias gpd='git push --dry-run' -is-at-least 2.30 "$git_version" \ - && alias gpf='git push --force-with-lease --force-if-includes' \ - || alias gpf='git push --force-with-lease' -alias gpf!='git push --force' -alias gpoat='git push origin --all && git push origin --tags' -alias gpod='git push origin --delete' -alias gpr='git pull --rebase' -alias gpu='git push upstream' -alias gpv='git push --verbose' - -alias gr='git remote' -alias gra='git remote add' -alias grb='git rebase' -alias grba='git rebase --abort' -alias grbc='git rebase --continue' -alias grbd='git rebase $(git_develop_branch)' -alias grbi='git rebase --interactive' -alias grbm='git rebase $(git_main_branch)' -alias grbom='git rebase origin/$(git_main_branch)' -alias grbo='git rebase --onto' -alias grbs='git rebase --skip' -alias grev='git revert' -alias grh='git reset' -alias grhh='git reset --hard' -alias groh='git reset origin/$(git_current_branch) --hard' -alias grm='git rm' -alias grmc='git rm --cached' -alias grmv='git remote rename' -alias grrm='git remote remove' -alias grs='git restore' -alias grset='git remote set-url' -alias grss='git restore --source' -alias grst='git restore --staged' -alias grt='cd "$(git rev-parse --show-toplevel || echo .)"' -alias gru='git reset --' -alias grup='git remote update' -alias grv='git remote --verbose' - -alias gsb='git status --short --branch' -alias gsd='git svn dcommit' -alias gsh='git show' -alias gsi='git submodule init' -alias gsps='git show --pretty=short --show-signature' -alias gsr='git svn rebase' -alias gss='git status --short' -alias gst='git status' - -# use the default stash push on git 2.13 and newer -is-at-least 2.13 "$git_version" \ - && alias gsta='git stash push' \ - || alias gsta='git stash save' - -alias gstaa='git stash apply' -alias gstc='git stash clear' -alias gstd='git stash drop' -alias gstl='git stash list' -alias gstp='git stash pop' -alias gsts='git stash show --text' -alias gstu='gsta --include-untracked' -alias gstall='git stash --all' -alias gsu='git submodule update' -alias gsw='git switch' -alias gswc='git switch --create' -alias gswm='git switch $(git_main_branch)' -alias gswd='git switch $(git_develop_branch)' - -alias gts='git tag --sign' -alias gtv='git tag | sort -V' -alias gtl='gtl(){ git tag --sort=-v:refname -n --list "${1}*" }; noglob gtl' - -alias gunignore='git update-index --no-assume-unchanged' -alias gunwip='git rev-list --max-count=1 --format="%s" HEAD | grep -q "\--wip--" && git reset HEAD~1' -alias gup='git pull --rebase' -alias gupv='git pull --rebase --verbose' -alias gupa='git pull --rebase --autostash' -alias gupav='git pull --rebase --autostash --verbose' -alias gupom='git pull --rebase origin $(git_main_branch)' -alias gupomi='git pull --rebase=interactive origin $(git_main_branch)' -alias glum='git pull upstream $(git_main_branch)' -alias gluc='git pull upstream $(git_current_branch)' - -alias gwch='git whatchanged -p --abbrev-commit --pretty=medium' -alias gwip='git add -A; git rm $(git ls-files --deleted) 2> /dev/null; git commit --no-verify --no-gpg-sign --message "--wip-- [skip ci]"' - -alias gwt='git worktree' -alias gwta='git worktree add' -alias gwtls='git worktree list' -alias gwtmv='git worktree move' -alias gwtrm='git worktree remove' - -alias gam='git am' -alias gamc='git am --continue' -alias gams='git am --skip' -alias gama='git am --abort' -alias gamscp='git am --show-current-patch' function grename() { if [[ -z "$1" || -z "$2" ]]; then @@ -361,4 +56,305 @@ function grename() { fi } +# +# Functions Work in Progress (WIP) +# (sorted alphabetically by function name) +# (order should follow README) +# + +# Similar to `gunwip` but recursive "Unwips" all recent `--wip--` commits not just the last one +function gunwipall() { + local _commit=$(git log --grep='--wip--' --invert-grep --max-count=1 --format=format:%H) + + # Check if a commit without "--wip--" was found and it's not the same as HEAD + if [[ "$_commit" != "$(git rev-parse HEAD)" ]]; then + git reset $_commit || return 1 + fi +} + +# Warn if the current branch is a WIP +function work_in_progress() { + command git -c log.showSignature=false log -n 1 2>/dev/null | grep -q -- "--wip--" && echo "WIP!!" +} + +# +# Aliases +# (sorted alphabetically by command) +# (order should follow README) +# (in some cases force the alisas order to match README, like for example gke and gk) +# + +alias grt='cd "$(git rev-parse --show-toplevel || echo .)"' + +function ggpnp() { + if [[ "$#" == 0 ]]; then + ggl && ggp + else + ggl "${*}" && ggp "${*}" + fi +} +compdef _git ggpnp=git-checkout + +alias ggpur='ggu' +alias g='git' +alias ga='git add' +alias gaa='git add --all' +alias gapa='git add --patch' +alias gau='git add --update' +alias gav='git add --verbose' +alias gwip='git add -A; git rm $(git ls-files --deleted) 2> /dev/null; git commit --no-verify --no-gpg-sign --message "--wip-- [skip ci]"' +alias gam='git am' +alias gama='git am --abort' +alias gamc='git am --continue' +alias gamscp='git am --show-current-patch' +alias gams='git am --skip' +alias gap='git apply' +alias gapt='git apply --3way' +alias gbs='git bisect' +alias gbsb='git bisect bad' +alias gbsg='git bisect good' +alias gbsr='git bisect reset' +alias gbss='git bisect start' +alias gbl='git blame -b -w' +alias gb='git branch' +alias gba='git branch --all' +alias gbd='git branch --delete' +alias gbD='git branch --delete --force' +alias gbda='git branch --no-color --merged | command grep -vE "^([+*]|\s*($(git_main_branch)|$(git_develop_branch))\s*$)" | command xargs git branch --delete 2>/dev/null' +alias gbgd='git branch --no-color -vv | grep ": gone\]" | awk '"'"'{print $1}'"'"' | xargs git branch -d' +alias gbgD='git branch --no-color -vv | grep ": gone\]" | awk '"'"'{print $1}'"'"' | xargs git branch -D' +alias gbnm='git branch --no-merged' +alias gbr='git branch --remote' +alias ggsup='git branch --set-upstream-to=origin/$(git_current_branch)' +alias gbg='git branch -vv | grep ": gone\]"' +alias gco='git checkout' +alias gcor='git checkout --recurse-submodules' +alias gcb='git checkout -b' +alias gcd='git checkout $(git_develop_branch)' +alias gcm='git checkout $(git_main_branch)' +alias gcp='git cherry-pick' +alias gcpa='git cherry-pick --abort' +alias gcpc='git cherry-pick --continue' +alias gclean='git clean --interactive -d' +alias gcl='git clone --recurse-submodules' + +function gccd() { + command git clone --recurse-submodules "$@" + [[ -d "$_" ]] && cd "$_" || cd "${${_:t}%.git}" +} +compdef _git gccd=git-clone + +alias gcam='git commit --all --message' +alias gcas='git commit --all --signoff' +alias gcasm='git commit --all --signoff --message' +alias gcs='git commit --gpg-sign' +alias gcss='git commit --gpg-sign --signoff' +alias gcssm='git commit --gpg-sign --signoff --message' +alias gcmsg='git commit --message' +alias gcsm='git commit --signoff --message' +alias gc='git commit --verbose' +alias gca='git commit --verbose --all' +alias gca!='git commit --verbose --all --amend' +alias gcan!='git commit --verbose --all --no-edit --amend' +alias gcans!='git commit --verbose --all --signoff --no-edit --amend' +alias gc!='git commit --verbose --amend' +alias gcn!='git commit --verbose --no-edit --amend' +alias gcf='git config --list' +alias gdct='git describe --tags $(git rev-list --tags --max-count=1)' +alias gd='git diff' +alias gdca='git diff --cached' +alias gdcw='git diff --cached --word-diff' +alias gds='git diff --staged' +alias gdw='git diff --word-diff' + +function gdv() { git diff -w "$@" | view - } +compdef _git gdv=git-diff + +alias gdup='git diff @{upstream}' + +function gdnolock() { + git diff "$@" ":(exclude)package-lock.json" ":(exclude)*.lock" +} +compdef _git gdnolock=git-diff + +alias gdt='git diff-tree --no-commit-id --name-only -r' +alias gf='git fetch' +# --jobs= was added in git 2.8 +is-at-least 2.8 "$git_version" \ + && alias gfa='git fetch --all --prune --jobs=10' \ + || alias gfa='git fetch --all --prune' +alias gfo='git fetch origin' +alias gg='git gui citool' +alias gga='git gui citool --amend' +alias ghh='git help' +alias glgg='git log --graph' +alias glgga='git log --graph --decorate --all' +alias glgm='git log --graph --max-count=10' +alias glods='git log --graph --pretty="%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ad) %C(bold blue)<%an>%Creset" --date=short' +alias glod='git log --graph --pretty="%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ad) %C(bold blue)<%an>%Creset"' +alias glola='git log --graph --pretty="%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ar) %C(bold blue)<%an>%Creset" --all' +alias glols='git log --graph --pretty="%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ar) %C(bold blue)<%an>%Creset" --stat' +alias glol='git log --graph --pretty="%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ar) %C(bold blue)<%an>%Creset"' +alias glo='git log --oneline --decorate' +alias glog='git log --oneline --decorate --graph' +alias gloga='git log --oneline --decorate --graph --all' + +# Pretty log messages +function _git_log_prettily(){ + if ! [ -z $1 ]; then + git log --pretty=$1 + fi +} +compdef _git _git_log_prettily=git-log + +alias glp='_git_log_prettily' +alias glg='git log --stat' +alias glgp='git log --stat --patch' +alias gignored='git ls-files -v | grep "^[[:lower:]]"' +alias gfg='git ls-files | grep' +alias gm='git merge' +alias gma='git merge --abort' +alias gms="git merge --squash" +alias gmom='git merge origin/$(git_main_branch)' +alias gmum='git merge upstream/$(git_main_branch)' +alias gmtl='git mergetool --no-prompt' +alias gmtlvim='git mergetool --no-prompt --tool=vimdiff' +alias gl='git pull' +alias gpr='git pull --rebase' +alias gup='git pull --rebase' +alias gupa='git pull --rebase --autostash' +alias gupav='git pull --rebase --autostash --verbose' +alias gupv='git pull --rebase --verbose' + +function ggu() { + [[ "$#" != 1 ]] && local b="$(git_current_branch)" + git pull --rebase origin "${b:=$1}" +} +compdef _git ggu=git-checkout + +alias gupom='git pull --rebase origin $(git_main_branch)' +alias gupomi='git pull --rebase=interactive origin $(git_main_branch)' +alias ggpull='git pull origin "$(git_current_branch)"' + +function ggl() { + if [[ "$#" != 0 ]] && [[ "$#" != 1 ]]; then + git pull origin "${*}" + else + [[ "$#" == 0 ]] && local b="$(git_current_branch)" + git pull origin "${b:=$1}" + fi +} +compdef _git ggl=git-checkout + +alias gluc='git pull upstream $(git_current_branch)' +alias glum='git pull upstream $(git_main_branch)' +alias gp='git push' +alias gpd='git push --dry-run' + +function ggf() { + [[ "$#" != 1 ]] && local b="$(git_current_branch)" + git push --force origin "${b:=$1}" +} +compdef _git ggf=git-checkout + +alias gpf!='git push --force' +is-at-least 2.30 "$git_version" \ + && alias gpf='git push --force-with-lease --force-if-includes' \ + || alias gpf='git push --force-with-lease' + +function ggfl() { + [[ "$#" != 1 ]] && local b="$(git_current_branch)" + git push --force-with-lease origin "${b:=$1}" +} +compdef _git ggfl=git-checkout + +alias gpsup='git push --set-upstream origin $(git_current_branch)' +is-at-least 2.30 "$git_version" \ + && alias gpsupf='git push --set-upstream origin $(git_current_branch) --force-with-lease --force-if-includes' \ + || alias gpsupf='git push --set-upstream origin $(git_current_branch) --force-with-lease' +alias gpv='git push --verbose' +alias gpoat='git push origin --all && git push origin --tags' +alias gpod='git push origin --delete' +alias ggpush='git push origin "$(git_current_branch)"' + +function ggp() { + if [[ "$#" != 0 ]] && [[ "$#" != 1 ]]; then + git push origin "${*}" + else + [[ "$#" == 0 ]] && local b="$(git_current_branch)" + git push origin "${b:=$1}" + fi +} +compdef _git ggp=git-checkout + +alias gpu='git push upstream' +alias grb='git rebase' +alias grba='git rebase --abort' +alias grbc='git rebase --continue' +alias grbi='git rebase --interactive' +alias grbo='git rebase --onto' +alias grbs='git rebase --skip' +alias grbd='git rebase $(git_develop_branch)' +alias grbm='git rebase $(git_main_branch)' +alias grbom='git rebase origin/$(git_main_branch)' +alias gr='git remote' +alias grv='git remote --verbose' +alias gra='git remote add' +alias grrm='git remote remove' +alias grmv='git remote rename' +alias grset='git remote set-url' +alias grup='git remote update' +alias grh='git reset' +alias gru='git reset --' +alias grhh='git reset --hard' +alias gpristine='git reset --hard && git clean --force -dfx' +alias groh='git reset origin/$(git_current_branch) --hard' +alias grs='git restore' +alias grss='git restore --source' +alias grst='git restore --staged' +alias gunwip='git rev-list --max-count=1 --format="%s" HEAD | grep -q "\--wip--" && git reset HEAD~1' +alias grev='git revert' +alias grm='git rm' +alias grmc='git rm --cached' +alias gcount='git shortlog --summary --numbered' +alias gsh='git show' +alias gsps='git show --pretty=short --show-signature' +alias gstall='git stash --all' +alias gstaa='git stash apply' +alias gstc='git stash clear' +alias gstd='git stash drop' +alias gstl='git stash list' +alias gstp='git stash pop' +# use the default stash push on git 2.13 and newer +is-at-least 2.13 "$git_version" \ + && alias gsta='git stash push' \ + || alias gsta='git stash save' +alias gsts='git stash show --text' +alias gst='git status' +alias gss='git status --short' +alias gsb='git status --short --branch' +alias gsi='git submodule init' +alias gsu='git submodule update' +alias gsd='git svn dcommit' +alias git-svn-dcommit-push='git svn dcommit && git push github $(git_main_branch):svntrunk' +alias gsr='git svn rebase' +alias gsw='git switch' +alias gswc='git switch --create' +alias gswd='git switch $(git_develop_branch)' +alias gswm='git switch $(git_main_branch)' +alias gts='git tag --sign' +alias gtv='git tag | sort -V' +alias gignore='git update-index --assume-unchanged' +alias gunignore='git update-index --no-assume-unchanged' +alias gwch='git whatchanged -p --abbrev-commit --pretty=medium' +alias gwt='git worktree' +alias gwta='git worktree add' +alias gwtls='git worktree list' +alias gwtmv='git worktree move' +alias gwtrm='git worktree remove' +alias gstu='gsta --include-untracked' +alias gtl='gtl(){ git tag --sort=-v:refname -n --list "${1}*" }; noglob gtl' +alias gk='\gitk --all --branches &!' +alias gke='\gitk --all $(git log --walk-reflogs --pretty=%h) &!' + unset git_version From c92af18c36c84cef0c785e1ae9cabc49a61a5c3a Mon Sep 17 00:00:00 2001 From: Zhang Visper Date: Thu, 24 Aug 2023 17:37:38 +0800 Subject: [PATCH 330/672] fix(git): some aliases under non-english LANG (#11855) --- plugins/git/README.md | 6 +++--- plugins/git/git.plugin.zsh | 6 +++--- 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/plugins/git/README.md b/plugins/git/README.md index 0b757c481..c3e6dd27d 100644 --- a/plugins/git/README.md +++ b/plugins/git/README.md @@ -40,12 +40,12 @@ plugins=(... git) | gbd | git branch --delete | | gbD | git branch --delete --force | | gbda | git branch --no-color --merged | grep -vE "^([+]|\s($(git_main_branch)|$(git_develop_branch))\s\*$)" | xargs git branch --delete 2>/dev/null | -| gbgd | git branch --no-color -vv | -| gbgD | git branch --no-color -vv | +| gbgd | LANG=C git branch --no-color -vv | grep ": gone\]" | awk '"'"'{print $1}'"'"' | xargs git branch -d | +| gbgD | LANG=C git branch --no-color -vv | grep ": gone\]" | awk '"'"'{print $1}'"'"' | xargs git branch -D | | gbnm | git branch --no-merged | | gbr | git branch --remote | | ggsup | git branch --set-upstream-to=origin/$(git_current_branch) | -| gbg | git branch -vv | +| gbg | LANG=C git branch -vv | grep ": gone\]" | | gco | git checkout | | gcor | git checkout --recurse-submodules | | gcb | git checkout -b | diff --git a/plugins/git/git.plugin.zsh b/plugins/git/git.plugin.zsh index b321ce7b0..8886aac6d 100644 --- a/plugins/git/git.plugin.zsh +++ b/plugins/git/git.plugin.zsh @@ -121,12 +121,12 @@ alias gba='git branch --all' alias gbd='git branch --delete' alias gbD='git branch --delete --force' alias gbda='git branch --no-color --merged | command grep -vE "^([+*]|\s*($(git_main_branch)|$(git_develop_branch))\s*$)" | command xargs git branch --delete 2>/dev/null' -alias gbgd='git branch --no-color -vv | grep ": gone\]" | awk '"'"'{print $1}'"'"' | xargs git branch -d' -alias gbgD='git branch --no-color -vv | grep ": gone\]" | awk '"'"'{print $1}'"'"' | xargs git branch -D' +alias gbgd='LANG=C git branch --no-color -vv | grep ": gone\]" | awk '"'"'{print $1}'"'"' | xargs git branch -d' +alias gbgD='LANG=C git branch --no-color -vv | grep ": gone\]" | awk '"'"'{print $1}'"'"' | xargs git branch -D' alias gbnm='git branch --no-merged' alias gbr='git branch --remote' alias ggsup='git branch --set-upstream-to=origin/$(git_current_branch)' -alias gbg='git branch -vv | grep ": gone\]"' +alias gbg='LANG=C git branch -vv | grep ": gone\]"' alias gco='git checkout' alias gcor='git checkout --recurse-submodules' alias gcb='git checkout -b' From 13a8e3d98aeeb4f5f0b98f92ace540067e58ba92 Mon Sep 17 00:00:00 2001 From: Roeniss Moon Date: Fri, 25 Aug 2023 00:12:59 +0900 Subject: [PATCH 331/672] feat(alias-finder): add cheaper option and apply zstyle options (#11773) --- plugins/alias-finder/.zunit.yml | 9 ++ plugins/alias-finder/README.md | 55 ++++----- plugins/alias-finder/alias-finder.plugin.zsh | 79 +++++++------ plugins/alias-finder/tests/_output/.gitkeep | 0 plugins/alias-finder/tests/_support/.gitkeep | 0 plugins/alias-finder/tests/_support/bootstrap | 2 + plugins/alias-finder/tests/test_run.sh | 107 ++++++++++++++++++ 7 files changed, 186 insertions(+), 66 deletions(-) create mode 100644 plugins/alias-finder/.zunit.yml create mode 100644 plugins/alias-finder/tests/_output/.gitkeep create mode 100644 plugins/alias-finder/tests/_support/.gitkeep create mode 100644 plugins/alias-finder/tests/_support/bootstrap create mode 100644 plugins/alias-finder/tests/test_run.sh diff --git a/plugins/alias-finder/.zunit.yml b/plugins/alias-finder/.zunit.yml new file mode 100644 index 000000000..ae65f8ef2 --- /dev/null +++ b/plugins/alias-finder/.zunit.yml @@ -0,0 +1,9 @@ +tap: false +directories: + tests: tests + output: tests/_output + support: tests/_support +time_limit: 0 +fail_fast: false +allow_risky: false +verbose: true diff --git a/plugins/alias-finder/README.md b/plugins/alias-finder/README.md index 409f4b653..6c87c723a 100644 --- a/plugins/alias-finder/README.md +++ b/plugins/alias-finder/README.md @@ -2,45 +2,32 @@ This plugin searches the defined aliases and outputs any that match the command inputted. This makes learning new aliases easier. +## Usage + To use it, add `alias-finder` to the `plugins` array of your zshrc file: ``` plugins=(... alias-finder) ``` -## Usage -To see if there is an alias defined for the command, pass it as an argument to `alias-finder`. This can also run automatically before each command you input - add `ZSH_ALIAS_FINDER_AUTOMATIC=true` to your zshrc if you want this. +To enable it for every single command, set zstyle in your `~/.zshrc`. -## Options +```zsh +# ~/.zshrc + +zstyle ':omz:plugins:alias-finder' autoload yes # disabled by default +zstyle ':omz:plugins:alias-finder' longer yes # disabled by default +zstyle ':omz:plugins:alias-finder' exact yes # disabled by default +zstyle ':omz:plugins:alias-finder' cheaper yes # disabled by default +``` + +As you can see, options are also available with zstyle. + +### Options + +> In order to clarify, let's say `alias a=abc` has source 'abc' and destination 'a'. + +- Use `--longer` or `-l` to include aliases where the source is longer than the input (in other words, the source could contain the whole input). +- Use `--exact` or `-e` to avoid aliases where the source is shorter than the input (in other words, the source must be the same with the input). +- Use `--cheaper` or `-c` to avoid aliases where the destination is longer than the input (in other words, the destination must be the shorter than the input). -- Use `--longer` or `-l` to allow the aliases to be longer than the input (match aliases if they contain the input). -- Use `--exact` or `-e` to avoid matching aliases that are shorter than the input. -## Examples -``` -$ alias-finder "git pull" -gl='git pull' -g=git -``` -``` -$ alias-finder "web_search google oh my zsh" -google='web_search google' -``` -``` -$ alias-finder "git commit -v" -gc="git commit -v" -g=git -``` -``` -$ alias-finder -e "git commit -v" -gc='git commit -v' -``` -``` -$ alias-finder -l "git commit -v" -gc='git commit -v' -'gc!'='git commit -v --amend' -gca='git commit -v -a' -'gca!'='git commit -v -a --amend' -'gcan!'='git commit -v -a --no-edit --amend' -'gcans!'='git commit -v -a -s --no-edit --amend' -'gcn!'='git commit -v --no-edit --amend' -``` diff --git a/plugins/alias-finder/alias-finder.plugin.zsh b/plugins/alias-finder/alias-finder.plugin.zsh index caee9b5a3..5fdfbc835 100644 --- a/plugins/alias-finder/alias-finder.plugin.zsh +++ b/plugins/alias-finder/alias-finder.plugin.zsh @@ -1,44 +1,59 @@ alias-finder() { - local cmd="" exact="" longer="" wordStart="" wordEnd="" multiWordEnd="" - for i in $@; do - case $i in + local cmd=" " exact="" longer="" cheaper="" wordEnd="'{0,1}$" finder="" filter="" + + # build command and options + for c in "$@"; do + case $c in + # TODO: Remove backward compatibility (other than zstyle form) + # set options if exist -e|--exact) exact=true;; -l|--longer) longer=true;; - *) - if [[ -z $cmd ]]; then - cmd=$i - else - cmd="$cmd $i" - fi - ;; + -c|--cheaper) cheaper=true;; + # concatenate cmd + *) cmd="$cmd$c " ;; esac done - cmd=$(sed 's/[].\|$(){}?+*^[]/\\&/g' <<< $cmd) # adds escaping for grep - if (( $(wc -l <<< $cmd) == 1 )); then - while [[ $cmd != "" ]]; do - if [[ $longer = true ]]; then - wordStart="'{0,1}" - else - wordEnd="$" - multiWordEnd="'$" - fi - if [[ $cmd == *" "* ]]; then - local finder="'$cmd$multiWordEnd" - else - local finder=$wordStart$cmd$wordEnd - fi - alias | grep -E "=$finder" - if [[ $exact = true || $longer = true ]]; then - break - else - cmd=$(sed -E 's/ {0,1}[^ ]*$//' <<< $cmd) # removes last word - fi - done + + zstyle -t ':omz:plugins:alias-finder' longer && longer=true + zstyle -t ':omz:plugins:alias-finder' exact && exact=true + zstyle -t ':omz:plugins:alias-finder' cheaper && cheaper=true + + # format cmd for grep + ## - replace newlines with spaces + ## - trim both ends + ## - replace multiple spaces with one space + ## - add escaping character to special characters + cmd=$(echo -n "$cmd" | tr '\n' ' ' | xargs | tr -s '[:space:]' | sed 's/[].\|$(){}?+*^[]/\\&/g') + + if [[ $longer == true ]]; then + wordEnd="" # remove wordEnd to find longer aliases fi + + # find with alias and grep, removing last word each time until no more words + while [[ $cmd != "" ]]; do + finder="'{0,1}$cmd$wordEnd" + + # make filter to find only shorter results than current cmd + if [[ $cheaper == true ]]; then + cmdLen=$(echo -n "$cmd" | wc -c) + filter="^'{0,1}.{0,$((cmdLen - 1))}=" + fi + + alias | grep -E "$filter" | grep -E "=$finder" + + if [[ $exact == true ]]; then + break # because exact case is only one + elif [[ $longer = true ]]; then + break # because above grep command already found every longer aliases during first cycle + fi + + cmd=$(sed -E 's/ {0,}[^ ]*$//' <<< "$cmd") # remove last word + done } preexec_alias-finder() { - if [[ $ZSH_ALIAS_FINDER_AUTOMATIC = true ]]; then + # TODO: Remove backward compatibility (other than zstyle form) + zstyle -t ':omz:plugins:alias-finder' autoload && alias-finder $1 || if [[ $ZSH_ALIAS_FINDER_AUTOMATIC = true ]]; then alias-finder $1 fi } diff --git a/plugins/alias-finder/tests/_output/.gitkeep b/plugins/alias-finder/tests/_output/.gitkeep new file mode 100644 index 000000000..e69de29bb diff --git a/plugins/alias-finder/tests/_support/.gitkeep b/plugins/alias-finder/tests/_support/.gitkeep new file mode 100644 index 000000000..e69de29bb diff --git a/plugins/alias-finder/tests/_support/bootstrap b/plugins/alias-finder/tests/_support/bootstrap new file mode 100644 index 000000000..01076611e --- /dev/null +++ b/plugins/alias-finder/tests/_support/bootstrap @@ -0,0 +1,2 @@ +#!/usr/bin/env zsh +# Write your bootstrap code here diff --git a/plugins/alias-finder/tests/test_run.sh b/plugins/alias-finder/tests/test_run.sh new file mode 100644 index 000000000..6b7abebb6 --- /dev/null +++ b/plugins/alias-finder/tests/test_run.sh @@ -0,0 +1,107 @@ +#!/usr/bin/env zunit + +@setup { + load ../alias-finder.plugin.zsh + + set_git_aliases() { + unalias -a # all + alias g="git" + alias gc="git commit" + alias gcv="git commit -v" + alias gcvs="git commit -v -S" + } +} + +@test 'find aliases that contain input' { + set_git_aliases + + run alias-finder "git" + + assert "${#lines[@]}" equals 1 + assert "${lines[1]}" same_as "g=git" +} + +@test 'find aliases that contain input with whitespaces at ends' { + set_git_aliases + + run alias-finder " git " + + assert "${#lines[@]}" equals 1 + assert "${lines[1]}" same_as "g=git" +} + +@test 'find aliases that contain multiple words' { + set_git_aliases + + run alias-finder "git commit -v" + + assert "${#lines[@]}" equals 3 + assert "${lines[1]}" same_as "gcv='git commit -v'" + assert "${lines[2]}" same_as "gc='git commit'" + assert "${lines[3]}" same_as "g=git" +} + +@test 'find alias that is the same with input when --exact option is set' { + set_git_aliases + + run alias-finder -e "git" + + assert "${#lines[@]}" equals 1 + assert "${lines[1]}" same_as "g=git" +} + +@test 'find alias that is the same with multiple words input when --exact option is set' { + set_git_aliases + + run alias-finder -e "git commit -v" + + assert "${#lines[@]}" equals 1 + assert "${lines[1]}" same_as "gcv='git commit -v'" +} + +@test 'find alias that is the same with or longer than input when --longer option is set' { + set_git_aliases + + run alias-finder -l "git" + + assert "${#lines[@]}" equals 4 + assert "${lines[1]}" same_as "g=git" + assert "${lines[2]}" same_as "gc='git commit'" + assert "${lines[3]}" same_as "gcv='git commit -v'" + assert "${lines[4]}" same_as "gcvs='git commit -v -S'" +} + +@test 'find alias that is the same with or longer than multiple words input when --longer option is set' { + set_git_aliases + + run alias-finder -l "git commit -v" + + assert "${#lines[@]}" equals 2 + assert "${lines[1]}" same_as "gcv='git commit -v'" + assert "${lines[2]}" same_as "gcvs='git commit -v -S'" +} + +@test 'find aliases including expensive (longer) than input' { + set_git_aliases + alias expensiveCommands="git commit" + + run alias-finder "git commit -v" + + assert "${#lines[@]}" equals 4 + assert "${lines[1]}" same_as "gcv='git commit -v'" + assert "${lines[2]}" same_as "expensiveCommands='git commit'" + assert "${lines[3]}" same_as "gc='git commit'" + assert "${lines[4]}" same_as "g=git" +} + +@test 'find aliases excluding expensive (longer) than input when --cheap option is set' { + set_git_aliases + alias expensiveCommands="git commit" + + run alias-finder -c "git commit -v" + + assert "${#lines[@]}" equals 3 + assert "${lines[1]}" same_as "gcv='git commit -v'" + assert "${lines[2]}" same_as "gc='git commit'" + assert "${lines[3]}" same_as "g=git" +} From 03a0d5bbaedc732436b5c67b166cde954817cc2f Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Thu, 24 Aug 2023 17:20:24 +0200 Subject: [PATCH 332/672] fix(clipboard): load clipboard on usage Closes #8827 --- lib/clipboard.zsh | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/lib/clipboard.zsh b/lib/clipboard.zsh index 2f3b6bcad..4b37abc9b 100644 --- a/lib/clipboard.zsh +++ b/lib/clipboard.zsh @@ -100,8 +100,8 @@ function detect-clipboard() { fi } -# Detect at startup. A non-zero exit here indicates that the dummy clipboards were set, -# which is not really an error. If the user calls them, they will attempt to redetect -# (for example, perhaps the user has now installed xclip) and then either print an error -# or proceed successfully. -detect-clipboard || true +function clipcopy clippaste { + unfunction clipcopy clippaste + detect-clipboard || true # let one retry + "$0" "$@" +} From 000be72dd0c2f668cd94b36c69e45dec7b06a23e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Tue, 29 Aug 2023 10:27:36 +0200 Subject: [PATCH 333/672] fix(updater): disable `nounset` to avoid warnings (#11856) --- tools/upgrade.sh | 1 + 1 file changed, 1 insertion(+) diff --git a/tools/upgrade.sh b/tools/upgrade.sh index 34ff3f027..f7a263d66 100755 --- a/tools/upgrade.sh +++ b/tools/upgrade.sh @@ -1,4 +1,5 @@ #!/usr/bin/env zsh +set +u # disable nounset local ret=0 # exit code From bf774211916c8a9d57b2b56c7846cd0b3d91baab Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Tom=C3=A1s=20Hern=C3=A1ndez?= Date: Tue, 29 Aug 2023 04:29:15 -0400 Subject: [PATCH 334/672] feat(bun): add plugin (#11859) --- plugins/bun/README.md | 20 ++++++++++++++++++++ plugins/bun/bun.plugin.zsh | 14 ++++++++++++++ 2 files changed, 34 insertions(+) create mode 100644 plugins/bun/README.md create mode 100644 plugins/bun/bun.plugin.zsh diff --git a/plugins/bun/README.md b/plugins/bun/README.md new file mode 100644 index 000000000..5a312370f --- /dev/null +++ b/plugins/bun/README.md @@ -0,0 +1,20 @@ +# Bun Plugin + +This plugin sets up completion for [Bun](https://bun.sh). + +To use it, add `bun` to the plugins array in your zshrc file: + +```zsh +plugins=(... bun) +``` + +This plugin does not add any aliases. + +## Cache + +This plugin caches the completion script and is automatically updated when the +plugin is loaded, which is usually when you start up a new terminal emulator. + +The cache is stored at: + +- `$ZSH_CACHE_DIR/completions/_bun_` completions script diff --git a/plugins/bun/bun.plugin.zsh b/plugins/bun/bun.plugin.zsh new file mode 100644 index 000000000..9924faa84 --- /dev/null +++ b/plugins/bun/bun.plugin.zsh @@ -0,0 +1,14 @@ +# If Bun is not found, don't do the rest of the script +if (( ! $+commands[bun] )); then + return +fi + +# If the completion file doesn't exist yet, we need to autoload it and +# bind it to `bun`. Otherwise, compinit will have already done that. +if [[ ! -f "$ZSH_CACHE_DIR/completions/_bun" ]]; then + typeset -g -A _comps + autoload -Uz _bun + _comps[bun]=_bun +fi + +bun completions >| "$ZSH_CACHE_DIR/completions/_bun" &| From 2ef7c73cc884163367279e4b586136e3335b1c53 Mon Sep 17 00:00:00 2001 From: t-aswath <119417646+t-aswath@users.noreply.github.com> Date: Wed, 30 Aug 2023 21:38:09 +0530 Subject: [PATCH 335/672] feat(web-search): add `youtube` alias (#11865) --- plugins/web-search/web-search.plugin.zsh | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/plugins/web-search/web-search.plugin.zsh b/plugins/web-search/web-search.plugin.zsh index ec176dd68..fc87a3495 100644 --- a/plugins/web-search/web-search.plugin.zsh +++ b/plugins/web-search/web-search.plugin.zsh @@ -25,6 +25,7 @@ function web_search() { archive "https://web.archive.org/web/*/" scholar "https://scholar.google.com/scholar?q=" ask "https://www.ask.com/web?q=" + youtube "https://www.youtube.com/results?search_query=" ) # check whether the search engine is supported @@ -66,11 +67,12 @@ alias wolframalpha='web_search wolframalpha' alias archive='web_search archive' alias scholar='web_search scholar' alias ask='web_search ask' +alias youtube='web_search youtube' #add your own !bang searches here alias wiki='web_search duckduckgo \!w' alias news='web_search duckduckgo \!n' -alias youtube='web_search duckduckgo \!yt' +#alias youtube='web_search duckduckgo \!yt' alias map='web_search duckduckgo \!m' alias image='web_search duckduckgo \!i' alias ducky='web_search duckduckgo \!' From ccce2e1cfdf5b9680f691a402e288d9cf6ce272a Mon Sep 17 00:00:00 2001 From: James Cuzella Date: Thu, 31 Aug 2023 15:35:33 -0600 Subject: [PATCH 336/672] fix(termsupport): match all `foot`-like terminfo (#11868) --- lib/termsupport.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/termsupport.zsh b/lib/termsupport.zsh index 6d969503d..a800e651f 100644 --- a/lib/termsupport.zsh +++ b/lib/termsupport.zsh @@ -17,7 +17,7 @@ function title { : ${2=$1} case "$TERM" in - cygwin|xterm*|putty*|rxvt*|konsole*|ansi|mlterm*|alacritty|st*|foot|contour*) + cygwin|xterm*|putty*|rxvt*|konsole*|ansi|mlterm*|alacritty|st*|foot*|contour*) print -Pn "\e]2;${2:q}\a" # set window name print -Pn "\e]1;${1:q}\a" # set tab name ;; From 0dc40e88a3f5bbe2607d958b5f0bf79e9df0c118 Mon Sep 17 00:00:00 2001 From: not pua <140790944+im-notpua@users.noreply.github.com> Date: Sat, 2 Sep 2023 11:46:59 +0000 Subject: [PATCH 337/672] feat(battery): add support for OpenBSD (#11872) --- plugins/battery/battery.plugin.zsh | 44 ++++++++++++++++++++++++++++++ 1 file changed, 44 insertions(+) diff --git a/plugins/battery/battery.plugin.zsh b/plugins/battery/battery.plugin.zsh index db5eeb93a..1d3d529a3 100644 --- a/plugins/battery/battery.plugin.zsh +++ b/plugins/battery/battery.plugin.zsh @@ -13,6 +13,10 @@ # Author: Avneet Singh (kalsi-avneet) # # Modified to add support for Android # ########################################### +# Author: Not Pua (im-notpua) # +# Modified to add support for OpenBSD # +########################################### + if [[ "$OSTYPE" = darwin* ]]; then function battery_is_charging() { @@ -139,6 +143,46 @@ elif [[ "$OSTYPE" = linux-android ]] && (( ${+commands[termux-battery-status]} ) echo "%{$fg[$color]%}${battery_pct}%%%{$reset_color%}" fi } +elif [[ "$OSTYPE" = openbsd* ]]; then + function battery_is_charging() { + [[ $(apm -b) -eq 3 ]] + } + function battery_pct() { + apm -l + } + function battery_pct_remaining() { + if ! battery_is_charging; then + battery_pct + else + echo "External Power" + fi + } + function battery_time_remaining() { + local remaining_time + remaining_time=$(apm -m) + if [[ $remaining_time -ge 0 ]]; then + ((hour = $remaining_time / 60 )) + ((minute = $remaining_time % 60 )) + printf %02d:%02d $hour $minute + fi + } + function battery_pct_prompt() { + local battery_pct color + battery_pct=$(battery_pct_remaining) + if battery_is_charging; then + echo "∞" + else + if [[ $battery_pct -gt 50 ]]; then + color='green' + elif [[ $battery_pct -gt 20 ]]; then + color='yellow' + else + color='red' + fi + echo "%{$fg[$color]%}${battery_pct}%%%{$reset_color%}" + fi + } + elif [[ "$OSTYPE" = linux* ]]; then function battery_is_charging() { if (( $+commands[acpitool] )); then From 1f56f2bdc455f2167c10fdbeca10934f5f0cbd99 Mon Sep 17 00:00:00 2001 From: Daniel Wang Date: Sun, 3 Sep 2023 23:08:19 +0800 Subject: [PATCH 338/672] fix(extract): remove extraction file extension for tar (#11873) --- plugins/extract/extract.plugin.zsh | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/plugins/extract/extract.plugin.zsh b/plugins/extract/extract.plugin.zsh index 513950f33..88d8b0740 100644 --- a/plugins/extract/extract.plugin.zsh +++ b/plugins/extract/extract.plugin.zsh @@ -30,6 +30,11 @@ EOF local file="$1" full_path="${1:A}" local extract_dir="${1:t:r}" + # Remove the .tar extension if the file name is .tar.* + if [[ $extract_dir =~ '\.tar$' ]]; then + extract_dir="${extract_dir:r}" + fi + # If there's a file or directory with the same name as the archive # add a random string to the end of the extract directory if [[ -e "$extract_dir" ]]; then From 2b1303a728afc285cc13a6710de128a050500f1e Mon Sep 17 00:00:00 2001 From: n0tr00t <106423923+0x020B@users.noreply.github.com> Date: Sun, 3 Sep 2023 15:38:32 +0000 Subject: [PATCH 339/672] feat(tmux): allow all standard config files (#11103) Closes #11803 Co-authored-by: n0tr00t <106423923+n0tr00teuorg@users.noreply.github.com> --- plugins/tmux/README.md | 26 +++++++++++++------------- plugins/tmux/tmux.plugin.zsh | 9 +++++++-- 2 files changed, 20 insertions(+), 15 deletions(-) diff --git a/plugins/tmux/README.md b/plugins/tmux/README.md index 7348f77c9..0f8473daf 100644 --- a/plugins/tmux/README.md +++ b/plugins/tmux/README.md @@ -28,16 +28,16 @@ The plugin also supports the following: ## Configuration Variables -| Variable | Description | -| ----------------------------------- | ----------------------------------------------------------------------------- | -| `ZSH_TMUX_AUTOSTART` | Automatically starts tmux (default: `false`) | -| `ZSH_TMUX_AUTOSTART_ONCE` | Autostart only if tmux hasn't been started previously (default: `true`) | -| `ZSH_TMUX_AUTOCONNECT` | Automatically connect to a previous session if it exits (default: `true`) | -| `ZSH_TMUX_AUTOQUIT` | Automatically closes terminal once tmux exits (default: `ZSH_TMUX_AUTOSTART`) | -| `ZSH_TMUX_FIXTERM` | Sets `$TERM` to 256-color term or not based on current terminal support | -| `ZSH_TMUX_ITERM2` | Sets the `-CC` option for iTerm2 tmux integration (default: `false`) | -| `ZSH_TMUX_FIXTERM_WITHOUT_256COLOR` | `$TERM` to use for non 256-color terminals (default: `screen`) | -| `ZSH_TMUX_FIXTERM_WITH_256COLOR` | `$TERM` to use for 256-color terminals (default: `screen-256color` | -| `ZSH_TMUX_CONFIG` | Set the configuration path (default: `$HOME/.tmux.conf`) | -| `ZSH_TMUX_UNICODE` | Set `tmux -u` option to support unicode | -| `ZSH_TMUX_DEFAULT_SESSION_NAME` | Set tmux default session name when autostart is enabled | +| Variable | Description | +| ----------------------------------- | ------------------------------------------------------------------------------------------- | +| `ZSH_TMUX_AUTOSTART` | Automatically starts tmux (default: `false`) | +| `ZSH_TMUX_AUTOSTART_ONCE` | Autostart only if tmux hasn't been started previously (default: `true`) | +| `ZSH_TMUX_AUTOCONNECT` | Automatically connect to a previous session if it exits (default: `true`) | +| `ZSH_TMUX_AUTOQUIT` | Automatically closes terminal once tmux exits (default: `ZSH_TMUX_AUTOSTART`) | +| `ZSH_TMUX_FIXTERM` | Sets `$TERM` to 256-color term or not based on current terminal support | +| `ZSH_TMUX_ITERM2` | Sets the `-CC` option for iTerm2 tmux integration (default: `false`) | +| `ZSH_TMUX_FIXTERM_WITHOUT_256COLOR` | `$TERM` to use for non 256-color terminals (default: `screen`) | +| `ZSH_TMUX_FIXTERM_WITH_256COLOR` | `$TERM` to use for 256-color terminals (default: `screen-256color` | +| `ZSH_TMUX_CONFIG` | Set the configuration path (default: `$HOME/.tmux.conf`, `$XDG_CONFIG_HOME/tmux/tmux.conf`) | +| `ZSH_TMUX_UNICODE` | Set `tmux -u` option to support unicode | +| `ZSH_TMUX_DEFAULT_SESSION_NAME` | Set tmux default session name when autostart is enabled | diff --git a/plugins/tmux/tmux.plugin.zsh b/plugins/tmux/tmux.plugin.zsh index 311c2e6a9..680f72598 100644 --- a/plugins/tmux/tmux.plugin.zsh +++ b/plugins/tmux/tmux.plugin.zsh @@ -26,12 +26,17 @@ fi # systems without the proper terminfo : ${ZSH_TMUX_FIXTERM_WITH_256COLOR:=screen-256color} # Set the configuration path -: ${ZSH_TMUX_CONFIG:=$HOME/.tmux.conf} +if [[ -e $HOME/.tmux.conf ]]; then + : ${ZSH_TMUX_CONFIG:=$HOME/.tmux.conf} +elif [[ -e ${XDG_CONFIG_HOME:-$HOME/.config}/tmux/tmux.conf ]]; then + : ${ZSH_TMUX_CONFIG:=${XDG_CONFIG_HOME:-$HOME/.config}/tmux/tmux.conf} +else + : ${ZSH_TMUX_CONFIG:=$HOME/.tmux.conf} +fi # Set -u option to support unicode : ${ZSH_TMUX_UNICODE:=false} # ALIASES - alias ta='tmux attach -t' alias tad='tmux attach -d -t' alias ts='tmux new-session -s' From f694d5ecc9aa45f4c394d2e15bf2bfde96eeeda6 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Peter=20Pu=C5=A1k=C3=A1r?= <93598525+puskarpeter@users.noreply.github.com> Date: Mon, 4 Sep 2023 19:17:28 +0200 Subject: [PATCH 340/672] feat(qodana): add completion plugin (#11813) --- plugins/qodana/README.md | 20 ++++++++++++++++++++ plugins/qodana/qodana.plugin.zsh | 14 ++++++++++++++ 2 files changed, 34 insertions(+) create mode 100644 plugins/qodana/README.md create mode 100644 plugins/qodana/qodana.plugin.zsh diff --git a/plugins/qodana/README.md b/plugins/qodana/README.md new file mode 100644 index 000000000..0b68bdecf --- /dev/null +++ b/plugins/qodana/README.md @@ -0,0 +1,20 @@ +# JetBrains Qodana CLI plugin + +This plugin adds completion for the [JetBrains Qodana CLI](https://github.com/JetBrains/qodana-cli). + +To use it, add `qodana` to the plugins array in your zshrc file: + +```zsh +plugins=(... qodana) +``` + +This plugin does not add any aliases. + +## Cache + +This plugin caches the completion script and is automatically updated when the +plugin is loaded, which is usually when you start up a new terminal emulator. + +The cache is stored at: + +- `$ZSH_CACHE_DIR/completions/_qodana` completions script diff --git a/plugins/qodana/qodana.plugin.zsh b/plugins/qodana/qodana.plugin.zsh new file mode 100644 index 000000000..2b92a8051 --- /dev/null +++ b/plugins/qodana/qodana.plugin.zsh @@ -0,0 +1,14 @@ +# Autocompletion for the JetBrains Qodana CLI (qodana). +if (( ! $+commands[qodana] )); then + return +fi + +# If the completion file doesn't exist yet, we need to autoload it and +# bind it to `qodana`. Otherwise, compinit will have already done that. +if [[ ! -f "$ZSH_CACHE_DIR/completions/_qodana" ]]; then + typeset -g -A _comps + autoload -Uz _qodana + _comps[qodana]=_qodana +fi + +qodana completion zsh >| "$ZSH_CACHE_DIR/completions/_qodana" &| From 1abc1d998a71efd50af30210e26bee462496e442 Mon Sep 17 00:00:00 2001 From: Oscar Lee-Vermeren Date: Mon, 4 Sep 2023 13:21:27 -0400 Subject: [PATCH 341/672] feat(git-commit): create plugin (#9646) Co-authored-by: K. Akatsuki --- plugins/git-commit/README.md | 36 ++++++++++++++++++++++++ plugins/git-commit/git-commit.plugin.zsh | 23 +++++++++++++++ 2 files changed, 59 insertions(+) create mode 100644 plugins/git-commit/README.md create mode 100644 plugins/git-commit/git-commit.plugin.zsh diff --git a/plugins/git-commit/README.md b/plugins/git-commit/README.md new file mode 100644 index 000000000..dc10d8ad5 --- /dev/null +++ b/plugins/git-commit/README.md @@ -0,0 +1,36 @@ +# git-commit plugin + +The git-commit plugin adds several [git aliases](https://www.git-scm.com/docs/git-config#Documentation/git-config.txt-alias) for [conventional commit](https://www.conventionalcommits.org/en/v1.0.0/#summary) messages. + +To use it, add `git-commit` to the plugins array in your zshrc file: + +```zsh +plugins=(... git-commit) +``` + +## Syntax + +```zshrc +git [(-s, --scope) ""] "" +``` + +> ⚠️ Single/Double quotes around the scope and message are required + +Where `type` is one of the following: + +- `build` +- `chore` +- `ci` +- `docs` +- `feat` +- `fix` +- `perf` +- `refactor` +- `revert` +- `style` +- `test` + +## Examples + +`git style "remove trailing whitespace"` -> `git commit -m "style: remove trailing whitespace"` +`git fix -s "router" "correct redirect link"` -> `git commit -m "fix(router): correct redirect link"` diff --git a/plugins/git-commit/git-commit.plugin.zsh b/plugins/git-commit/git-commit.plugin.zsh new file mode 100644 index 000000000..70d541f21 --- /dev/null +++ b/plugins/git-commit/git-commit.plugin.zsh @@ -0,0 +1,23 @@ +_register() { + if ! git config --global --get-all alias.$1 &>/dev/null; then + git config --global alias.$1 '!a() { if [[ "$1" == "-s" || "$1" == "--scope" ]]; then git commit -m "'$1'(${2}): ${@:3}"; else git commit -m "'$1': ${@}"; fi }; a' + fi +} + +aliases=( + 'build' + 'chore' + 'ci' + 'docs' + 'feat' + 'fix' + 'perf' + 'refactor' + 'revert' + 'style' + 'test' +) + +for alias in "${aliases[@]}"; do + _register $alias +done \ No newline at end of file From 30f0d591881713c4efd1482511943abca5103927 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Mon, 4 Sep 2023 19:32:38 +0200 Subject: [PATCH 342/672] fix(init): exit gracefully if on non-zsh emulation mode (#11874) Fixes #11686 --- oh-my-zsh.sh | 27 ++++++++++++++++++--------- 1 file changed, 18 insertions(+), 9 deletions(-) diff --git a/oh-my-zsh.sh b/oh-my-zsh.sh index 40f13f37e..137ca3b6f 100644 --- a/oh-my-zsh.sh +++ b/oh-my-zsh.sh @@ -1,14 +1,14 @@ +# ANSI formatting function (\033[m) +# 0: reset, 1: bold, 4: underline, 22: no bold, 24: no underline, 31: red, 33: yellow +omz_f() { + [ $# -gt 0 ] || return + IFS=";" printf "\033[%sm" $* +} +# If stdout is not a terminal ignore all formatting +[ -t 1 ] || omz_f() { :; } + # Protect against non-zsh execution of Oh My Zsh (use POSIX syntax here) [ -n "$ZSH_VERSION" ] || { - # ANSI formatting function (\033[m) - # 0: reset, 1: bold, 4: underline, 22: no bold, 24: no underline, 31: red, 33: yellow - omz_f() { - [ $# -gt 0 ] || return - IFS=";" printf "\033[%sm" $* - } - # If stdout is not a terminal ignore all formatting - [ -t 1 ] || omz_f() { :; } - omz_ptree() { # Get process tree of the current process pid=$$; pids="$pid" @@ -38,6 +38,15 @@ return 1 } +# Check if in emulation mode, if so early return +# https://github.com/ohmyzsh/ohmyzsh/issues/11686 +[[ "$(emulate)" = zsh ]] || { + printf "$(omz_f 1 31)Error:$(omz_f 22) Oh My Zsh can't be loaded in \`$(emulate)\` emulation mode.$(omz_f 0)\n" >&2 + return 1 +} + +unset -f omz_f + # If ZSH is not defined, use the current script's directory. [[ -z "$ZSH" ]] && export ZSH="${${(%):-%x}:a:h}" From c74f2a1be980c60d937046364db0c9497187457a Mon Sep 17 00:00:00 2001 From: Tjark <16938041+tjarbo@users.noreply.github.com> Date: Mon, 4 Sep 2023 19:43:06 +0200 Subject: [PATCH 343/672] feat(podman): add plugin (#11695) Closes #7489 Closes #9721 --- plugins/podman/README.md | 47 ++++++++++++++++++++++++++++++++ plugins/podman/podman.plugin.zsh | 47 ++++++++++++++++++++++++++++++++ 2 files changed, 94 insertions(+) create mode 100644 plugins/podman/README.md create mode 100644 plugins/podman/podman.plugin.zsh diff --git a/plugins/podman/README.md b/plugins/podman/README.md new file mode 100644 index 000000000..99daa28cd --- /dev/null +++ b/plugins/podman/README.md @@ -0,0 +1,47 @@ +# Podman plugin + +This plugin adds auto-completion and aliases for [podman](https://podman.io/). + +To use it add `podman` to the plugins array in your zshrc file. + +```zsh +plugins=(... podman) +``` + +## Aliases + +| Alias | Command | Description | +| :------ | :-------------------------------------------- | :--------------------------------------------------------------------------------------- | +| pbl | `podman build` | Build an image from a Dockerfile | +| pcin | `podman container inspect` | Display detailed information on one or more containers | +| pcls | `podman container ls` | List all the running podman containers | +| pclsa | `podman container ls --all` | List all running and stopped containers | +| pib | `podman image build` | Build an image from a Dockerfile (same as podman build) | +| pii | `podman image inspect` | Display detailed information on one or more images | +| pils | `podman image ls` | List podman images | +| pipu | `podman image push` | Push an image or repository to a remote registry | +| pirm | `podman image rm` | Remove one or more images | +| pit | `podman image tag` | Add a name and tag to a particular image | +| plo | `podman container logs` | Fetch the logs of a podman container | +| pnc | `podman network create` | Create a new network | +| pncn | `podman network connect` | Connect a container to a network | +| pndcn | `podman network disconnect` | Disconnect a container from a network | +| pni | `podman network inspect` | Return information about one or more networks | +| pnls | `podman network ls` | List all networks the engine daemon knows about, including those spanning multiple hosts | +| pnrm | `podman network rm` | Remove one or more networks | +| ppo | `podman container port` | List port mappings or a specific mapping for the container | +| ppu | `podman pull` | Pull an image or a repository from a registry | +| pr | `podman container run` | Create a new container and start it using the specified command | +| prit | `podman container run --interactive --tty` | Create a new container and start it in an interactive shell | +| prm | `podman container rm` | Remove the specified container(s) | +| prm! | `podman container rm --force` | Force the removal of a running container (uses SIGKILL) | +| pst | `podman container start` | Start one or more stopped containers | +| prs | `podman container restart` | Restart one or more containers | +| psta | `podman stop $(podman ps -q)` | Stop all running containers | +| pstp | `podman container stop` | Stop one or more running containers | +| ptop | `podman top` | Display the running processes of a container | +| pvi | `podman volume inspect` | Display detailed information about one or more volumes | +| pvls | `podman volume ls` | List all the volumes known to podman | +| pvprune | `podman volume prune` | Cleanup dangling volumes | +| pxc | `podman container exec` | Run a new command in a running container | +| pxcit | `podman container exec --interactive --tty` | Run a new command in a running container in an interactive shell | diff --git a/plugins/podman/podman.plugin.zsh b/plugins/podman/podman.plugin.zsh new file mode 100644 index 000000000..97cf92b2a --- /dev/null +++ b/plugins/podman/podman.plugin.zsh @@ -0,0 +1,47 @@ +if (( ! $+commands[podman] )); then + return +fi + +# If the completion file doesn't exist yet, we need to autoload it and +# bind it to `podman`. Otherwise, compinit will have already done that. +if [[ ! -f "$ZSH_CACHE_DIR/completions/_podman" ]]; then + typeset -g -A _comps + autoload -Uz _podman + _comps[podman]=_podman +fi + +podman completion zsh 2> /dev/null >| "$ZSH_CACHE_DIR/completions/_podman" &| + +alias pbl='podman build' +alias pcin='podman container inspect' +alias pcls='podman container ls' +alias pclsa='podman container ls --all' +alias pib='podman image build' +alias pii='podman image inspect' +alias pils='podman image ls' +alias pipu='podman image push' +alias pirm='podman image rm' +alias pit='podman image tag' +alias plo='podman container logs' +alias pnc='podman network create' +alias pncn='podman network connect' +alias pndcn='podman network disconnect' +alias pni='podman network inspect' +alias pnls='podman network ls' +alias pnrm='podman network rm' +alias ppo='podman container port' +alias ppu='podman pull' +alias pr='podman container run' +alias prit='podman container run --interactive --tty' +alias prm='podman container rm' +alias 'prm!'='podman container rm --force' +alias pst='podman container start' +alias prs='podman container restart' +alias psta='podman stop $(podman ps --quiet)' +alias pstp='podman container stop' +alias ptop='podman top' +alias pvi='podman volume inspect' +alias pvls='podman volume ls' +alias pvprune='podman volume prune' +alias pxc='podman container exec' +alias pxcit='podman container exec --interactive --tty' From bae577d6b2eb621fedc994d6309b6f819855c2f8 Mon Sep 17 00:00:00 2001 From: Adam Johnson Date: Tue, 5 Sep 2023 11:41:50 +0100 Subject: [PATCH 344/672] fix(git)!: remove `-b` from `blame` alias (#11864) --- plugins/git/README.md | 2 +- plugins/git/git.plugin.zsh | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/plugins/git/README.md b/plugins/git/README.md index c3e6dd27d..44ed6f320 100644 --- a/plugins/git/README.md +++ b/plugins/git/README.md @@ -34,7 +34,7 @@ plugins=(... git) | gbsg | git bisect good | | gbsr | git bisect reset | | gbss | git bisect start | -| gbl | git blame -b -w | +| gbl | git blame -w | | gb | git branch | | gba | git branch --all | | gbd | git branch --delete | diff --git a/plugins/git/git.plugin.zsh b/plugins/git/git.plugin.zsh index 8886aac6d..e20373de5 100644 --- a/plugins/git/git.plugin.zsh +++ b/plugins/git/git.plugin.zsh @@ -115,7 +115,7 @@ alias gbsb='git bisect bad' alias gbsg='git bisect good' alias gbsr='git bisect reset' alias gbss='git bisect start' -alias gbl='git blame -b -w' +alias gbl='git blame -w' alias gb='git branch' alias gba='git branch --all' alias gbd='git branch --delete' From 8e8ec1348b3d4ae5fa156e26c07040ade461c83a Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Wed, 6 Sep 2023 10:54:11 +0200 Subject: [PATCH 345/672] fix(git-commit): avoid conflict with `aliases` var Closes #11876 --- plugins/git-commit/git-commit.plugin.zsh | 16 ++++++++++------ 1 file changed, 10 insertions(+), 6 deletions(-) diff --git a/plugins/git-commit/git-commit.plugin.zsh b/plugins/git-commit/git-commit.plugin.zsh index 70d541f21..2ac8aa5f4 100644 --- a/plugins/git-commit/git-commit.plugin.zsh +++ b/plugins/git-commit/git-commit.plugin.zsh @@ -1,10 +1,11 @@ -_register() { - if ! git config --global --get-all alias.$1 &>/dev/null; then +function _git_commit_register { + if ! git config --global --get-all alias.$1 >/dev/null 2>&1; then git config --global alias.$1 '!a() { if [[ "$1" == "-s" || "$1" == "--scope" ]]; then git commit -m "'$1'(${2}): ${@:3}"; else git commit -m "'$1': ${@}"; fi }; a' fi } -aliases=( +local -a _git_commit_aliases +_git_commit_aliases=( 'build' 'chore' 'ci' @@ -18,6 +19,9 @@ aliases=( 'test' ) -for alias in "${aliases[@]}"; do - _register $alias -done \ No newline at end of file +for _alias in "${_git_commit_aliases[@]}"; do + _git_commit_register $_alias +done + +unfunction _git_commit_register +unset _alias From 76e541a3fe71075c8ef75ecf44cd60f17b5292bb Mon Sep 17 00:00:00 2001 From: Felipe Gallois Date: Wed, 6 Sep 2023 10:18:36 +0100 Subject: [PATCH 346/672] feat(gallois): big rewrite to `gallois` theme (#11867) --- themes/gallois.zsh-theme | 136 ++++++++++++++++++++++++++++++++++++--- 1 file changed, 126 insertions(+), 10 deletions(-) diff --git a/themes/gallois.zsh-theme b/themes/gallois.zsh-theme index bb97bfb17..3fc349072 100644 --- a/themes/gallois.zsh-theme +++ b/themes/gallois.zsh-theme @@ -1,24 +1,140 @@ # Depends on the git plugin for work_in_progress() (( $+functions[work_in_progress] )) || work_in_progress() {} -ZSH_THEME_GIT_PROMPT_PREFIX="%{$reset_color%}%{$fg[green]%}[" -ZSH_THEME_GIT_PROMPT_SUFFIX="]%{$reset_color%}" -ZSH_THEME_GIT_PROMPT_DIRTY="%{$fg[red]%}*%{$reset_color%}" +ZSH_THEME_GIT_PROMPT_PREFIX="%{$fg[cyan]%}[%{$fg[green]%}" +ZSH_THEME_GIT_PROMPT_SUFFIX="%{$fg[cyan]%}]" +ZSH_THEME_GIT_PROMPT_DIRTY="%{$fg[red]%}" ZSH_THEME_GIT_PROMPT_CLEAN="" # Customized git status, oh-my-zsh currently does not allow render dirty status before branch git_custom_status() { local branch=$(git_current_branch) [[ -n "$branch" ]] || return 0 - echo "$(parse_git_dirty)\ -%{${fg_bold[yellow]}%}$(work_in_progress)%{$reset_color%}\ -${ZSH_THEME_GIT_PROMPT_PREFIX}${branch}${ZSH_THEME_GIT_PROMPT_SUFFIX}" + print "%{${fg_bold[yellow]}%}$(work_in_progress)%{$reset_color%}\ +${ZSH_THEME_GIT_PROMPT_PREFIX}$(parse_git_dirty)${branch}\ +${ZSH_THEME_GIT_PROMPT_SUFFIX}" +} +autoload -U colors && colors + +#export VCS_PROMPT=hg_prompt_info +export VCS_PROMPT=git_custom_status + +base_prompt="%{$fg[cyan]%}[%~% ]%(?.%{$fg[green]%}.%{$fg[red]%})%B$%b " +custom_prompt="" +last_run_time="" +last_vcs_info="" + + +function pipestatus_parse { + PIPESTATUS="$pipestatus" + ERROR=0 + for i in "${(z)PIPESTATUS}"; do + if [[ "$i" -ne 0 ]]; then + ERROR=1 + fi + done + + if [[ "$ERROR" -ne 0 ]]; then + print "[%{$fg[red]%}$PIPESTATUS%{$fg[cyan]%}]" + fi } -# RVM component of prompt -ZSH_THEME_RUBY_PROMPT_PREFIX="%{$fg[red]%}[" -ZSH_THEME_RUBY_PROMPT_SUFFIX="]%{$reset_color%}" # Combine it all into a final right-side prompt -RPS1="\$(git_custom_status)\$(ruby_prompt_info)${RPS1:+ $RPS1}" PROMPT='%{$fg[cyan]%}[%~% ]%(?.%{$fg[green]%}.%{$fg[red]%})%B$%b ' +function preexec() { + last_run_time=$(perl -MTime::HiRes=time -e 'printf "%.9f\n", time') +} + +function duration() { + local duration + local now=$(perl -MTime::HiRes=time -e 'printf "%.9f\n", time') + local last=$1 + local last_split=("${(@s/./)last}") + local now_split=("${(@s/./)now}") + local T=$((now_split[1] - last_split[1])) + local D=$((T/60/60/24)) + local H=$((T/60/60%24)) + local M=$((T/60%60)) + local S=$((T%60)) + local s=$(((now_split[2] - last_split[2]) / 1000000000.)) + local m=$(((now_split[2] - last_split[2]) / 1000000.)) + + (( $D > 0 )) && duration+="${D}d" + (( $H > 0 )) && duration+="${H}h" + (( $M > 0 )) && duration+="${M}m" + + if [[ $S -le 0 ]]; then + printf "%ims" "$m" + else + if ! [[ -z $duration ]] && printf "%s" "$duration" + local sec_milli=$((S + s)) + printf "%.3fs" "$sec_milli" + fi +} + +function precmd() { + RETVAL=$(pipestatus_parse) + local info="" + + if [ ! -z "$last_run_time" ]; then + local elapsed=$(duration $last_run_time) + last_run_time=$(print $last_run_time | tr -d ".") + if [ $(( $(perl -MTime::HiRes=time -e 'printf "%.9f\n", time' | tr -d ".") - $last_run_time )) -gt $(( 120 * 1000 * 1000 * 1000 )) ]; then + local elapsed_color="%{$fg[magenta]%}" + elif [ $(( $(perl -MTime::HiRes=time -e 'printf "%.9f\n", time' | tr -d ".") - $last_run_time )) -gt $(( 60 * 1000 * 1000 * 1000 )) ]; then + local elapsed_color="%{$fg[red]%}" + elif [ $(( $(perl -MTime::HiRes=time -e 'printf "%.9f\n", time' | tr -d ".") - $last_run_time )) -gt $(( 10 * 1000 * 1000 * 1000 )) ]; then + local elapsed_color="%{$fg[yellow]%}" + else + local elapsed_color="%{$fg[green]%}" + fi + info=$(printf "%s%s%s%s%s" "%{$fg[cyan]%}[" "$elapsed_color" "$elapsed" "%{$fg[cyan]%}]" "$RETVAL") + unset last_run_time + fi + + if [ -z "$info" -a ! -z "$last_vcs_info" ]; then + custom_prompt="$last_vcs_info$base_prompt" + return; + fi + + if (( ${+VCS_PROMPT} )); then + last_vcs_info=$($VCS_PROMPT) + if [ ! -z "$last_vcs_info" ]; then + [ -z "$info" ] && info=$last_vcs_info || info="$info$last_vcs_info" + fi + fi + + [ -z "$info" ] && custom_prompt="$base_prompt" || custom_prompt="$info$base_prompt" +} + +function hg_prompt_info() { + unset output info parts branch_parts branch + + local output="" + if ! output="$(hg status 2> /dev/null)"; then + return + fi + + local info=$(hg log -l1 --template '{author}:{node|short}:{remotenames}:{phabdiff}') + local parts=(${(@s/:/)info}) + local branch_parts=(${(@s,/,)parts[3]}) + local branch=${branch_parts[-1]} + [ ! -z "${parts[3]}" ] && [[ "${parts[1]}" =~ "$USER@" ]] && branch=${parts[3]} + [ -z "${parts[3]}" ] && branch=${parts[2]} + + if [[ ! -z "$output" ]]; then + local color="%{$fg[red]%}" + elif [[ "${branch}" == "master" || "${branch}" == "warm" ]]; then + local color="%{$fg[yellow]%}" + else + local color="%{$fg[green]%}" + fi + + print "%{$fg[cyan]%}[${color}${branch}%{$fg[cyan]%}]" +} + +setopt PROMPT_SUBST +PROMPT='$custom_prompt' + + From 331f3c8b2e28e47af41ae309aa814dab524a3374 Mon Sep 17 00:00:00 2001 From: Adam Johnson Date: Wed, 6 Sep 2023 11:36:57 +0100 Subject: [PATCH 347/672] feat(git): add bisect aliases `gbsn` and `gbso` (#11869) --- plugins/git/README.md | 2 ++ plugins/git/git.plugin.zsh | 2 ++ 2 files changed, 4 insertions(+) diff --git a/plugins/git/README.md b/plugins/git/README.md index 44ed6f320..922cbee55 100644 --- a/plugins/git/README.md +++ b/plugins/git/README.md @@ -32,6 +32,8 @@ plugins=(... git) | gbs | git bisect | | gbsb | git bisect bad | | gbsg | git bisect good | +| gbsn | git bisect new | +| gbso | git bisect old | | gbsr | git bisect reset | | gbss | git bisect start | | gbl | git blame -w | diff --git a/plugins/git/git.plugin.zsh b/plugins/git/git.plugin.zsh index e20373de5..4afe34e99 100644 --- a/plugins/git/git.plugin.zsh +++ b/plugins/git/git.plugin.zsh @@ -113,6 +113,8 @@ alias gapt='git apply --3way' alias gbs='git bisect' alias gbsb='git bisect bad' alias gbsg='git bisect good' +alias gbsn='git bisect new' +alias gbso='git bisect old' alias gbsr='git bisect reset' alias gbss='git bisect start' alias gbl='git blame -w' From 6a7aab47dd6071b7f264477195b06efb7e7bd480 Mon Sep 17 00:00:00 2001 From: Adam Johnson Date: Wed, 6 Sep 2023 11:42:09 +0100 Subject: [PATCH 348/672] docs(git): align markdown table borders (#11878) --- plugins/git/README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/git/README.md b/plugins/git/README.md index 922cbee55..6eb63ea40 100644 --- a/plugins/git/README.md +++ b/plugins/git/README.md @@ -36,7 +36,7 @@ plugins=(... git) | gbso | git bisect old | | gbsr | git bisect reset | | gbss | git bisect start | -| gbl | git blame -w | +| gbl | git blame -w | | gb | git branch | | gba | git branch --all | | gbd | git branch --delete | From 079dbff2c4f22935a71101c511e2285327d8ab68 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Wed, 6 Sep 2023 19:01:41 +0200 Subject: [PATCH 349/672] feat(pipenv): add option to disable auto shell feature Closes #11472 --- plugins/pipenv/README.md | 15 ++++++++++++- plugins/pipenv/pipenv.plugin.zsh | 38 +++++++++++++++++--------------- 2 files changed, 34 insertions(+), 19 deletions(-) diff --git a/plugins/pipenv/README.md b/plugins/pipenv/README.md index 4329feb32..e78ef0e3b 100644 --- a/plugins/pipenv/README.md +++ b/plugins/pipenv/README.md @@ -1,6 +1,7 @@ # Pipenv ## Installation + In your `.zshrc` file, add `pipenv` to the plugins section ``` @@ -8,7 +9,9 @@ plugins=(... pipenv ...) ``` ## Features -This plugin provides some features to simplify the use of Pipenv while working on ZSH. + +This plugin provides some features to simplify the use of Pipenv while working on ZSH. + - Adds completion for pipenv - Auto activates and deactivates pipenv shell - Adds short aliases for common pipenv commands @@ -27,3 +30,13 @@ This plugin provides some features to simplify the use of Pipenv while working o - `pwh` is aliased to `pipenv --where` - `pvenv` is aliased to `pipenv --venv` - `ppy` is aliased to `pipenv --py` + +## Configuration + +### Shell activation + +If you want to disable the shell activation and deactivation feature, add the following style to your `.zshrc` before sourcing `oh-my-zsh.sh`: + +```zsh +zstyle ':omz:plugins:pipenv' auto-shell no +``` diff --git a/plugins/pipenv/pipenv.plugin.zsh b/plugins/pipenv/pipenv.plugin.zsh index 22d1a3131..f81c266a4 100644 --- a/plugins/pipenv/pipenv.plugin.zsh +++ b/plugins/pipenv/pipenv.plugin.zsh @@ -12,28 +12,30 @@ fi _PIPENV_COMPLETE=zsh_source pipenv >| "$ZSH_CACHE_DIR/completions/_pipenv" &| -# Automatic pipenv shell activation/deactivation -_togglePipenvShell() { - # deactivate shell if Pipfile doesn't exist and not in a subdir - if [[ ! -f "$PWD/Pipfile" ]]; then - if [[ "$PIPENV_ACTIVE" == 1 ]]; then - if [[ "$PWD" != "$pipfile_dir"* ]]; then - exit +if zstyle -T ':omz:plugins:pipenv' auto-shell; then + # Automatic pipenv shell activation/deactivation + _togglePipenvShell() { + # deactivate shell if Pipfile doesn't exist and not in a subdir + if [[ ! -f "$PWD/Pipfile" ]]; then + if [[ "$PIPENV_ACTIVE" == 1 ]]; then + if [[ "$PWD" != "$pipfile_dir"* ]]; then + exit + fi fi fi - fi - # activate the shell if Pipfile exists - if [[ "$PIPENV_ACTIVE" != 1 ]]; then - if [[ -f "$PWD/Pipfile" ]]; then - export pipfile_dir="$PWD" - pipenv shell + # activate the shell if Pipfile exists + if [[ "$PIPENV_ACTIVE" != 1 ]]; then + if [[ -f "$PWD/Pipfile" ]]; then + export pipfile_dir="$PWD" + pipenv shell + fi fi - fi -} -autoload -U add-zsh-hook -add-zsh-hook chpwd _togglePipenvShell -_togglePipenvShell + } + autoload -U add-zsh-hook + add-zsh-hook chpwd _togglePipenvShell + _togglePipenvShell +fi # Aliases alias pch="pipenv check" From b07c8cfe692bc6c7702f0aef5d493b12dfb43392 Mon Sep 17 00:00:00 2001 From: Haltarys <45515869+Haltarys@users.noreply.github.com> Date: Sun, 10 Sep 2023 09:28:33 +0200 Subject: [PATCH 350/672] fix(git-commit): fix compatibility of alias functions (#11883) --- plugins/git-commit/git-commit.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/git-commit/git-commit.plugin.zsh b/plugins/git-commit/git-commit.plugin.zsh index 2ac8aa5f4..4ad4c0177 100644 --- a/plugins/git-commit/git-commit.plugin.zsh +++ b/plugins/git-commit/git-commit.plugin.zsh @@ -1,6 +1,6 @@ function _git_commit_register { if ! git config --global --get-all alias.$1 >/dev/null 2>&1; then - git config --global alias.$1 '!a() { if [[ "$1" == "-s" || "$1" == "--scope" ]]; then git commit -m "'$1'(${2}): ${@:3}"; else git commit -m "'$1': ${@}"; fi }; a' + git config --global alias.$1 '!a() { if [ "$1" = "-s" ] || [ "$1" = "--scope" ]; then local scope="$2"; shift 2; git commit -m "'$1'(${scope}): ${@}"; else git commit -m "'$1': ${@}"; fi }; a' fi } From cd18bce53e01d0f614ffcbb7429053fb508cb095 Mon Sep 17 00:00:00 2001 From: AJ Jordan Date: Mon, 11 Sep 2023 03:31:53 -0400 Subject: [PATCH 351/672] feat(mortalscumbag): show toolbox info (#11884) --- themes/mortalscumbag.zsh-theme | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/themes/mortalscumbag.zsh-theme b/themes/mortalscumbag.zsh-theme index d81a7ca06..36301cb76 100644 --- a/themes/mortalscumbag.zsh-theme +++ b/themes/mortalscumbag.zsh-theme @@ -51,8 +51,14 @@ function ssh_connection() { fi } +function _toolbox_prompt_info() { + if typeset -f toolbox_prompt_info > /dev/null; then + toolbox_prompt_info + fi +} + local ret_status="%(?:%{$fg_bold[green]%}:%{$fg_bold[red]%})%?%{$reset_color%}" -PROMPT=$'\n$(ssh_connection)%{$fg_bold[green]%}%n@%m%{$reset_color%}$(my_git_prompt) : %~\n[${ret_status}] %# ' +PROMPT=$'\n$(_toolbox_prompt_info)$(ssh_connection)%{$fg_bold[green]%}%n@%m%{$reset_color%}$(my_git_prompt) : %~\n[${ret_status}] %# ' ZSH_THEME_PROMPT_RETURNCODE_PREFIX="%{$fg_bold[red]%}" ZSH_THEME_GIT_PROMPT_PREFIX=" $fg[white]‹ %{$fg_bold[yellow]%}" From 7077989d28e9cd723afcb4355874683d847278b4 Mon Sep 17 00:00:00 2001 From: Samuel Beckley Date: Mon, 11 Sep 2023 03:35:28 -0400 Subject: [PATCH 352/672] feat(macos): update spotify plugin to upstream (#11534) --- plugins/macos/spotify | 35 ++++++++++++++++++----------------- 1 file changed, 18 insertions(+), 17 deletions(-) diff --git a/plugins/macos/spotify b/plugins/macos/spotify index 5fb40517c..ae42db425 100644 --- a/plugins/macos/spotify +++ b/plugins/macos/spotify @@ -1,7 +1,7 @@ #!/usr/bin/env bash function spotify() { -# Copyright (c) 2012--2019 Harish Narayanan +# Copyright (c) 2012--2023 Harish Narayanan # # Contains numerous helpful contributions from Jorge Colindres, Thomas # Pritchard, iLan Epstein, Gabriele Bonetti, Sean Heller, Eric Martin @@ -35,6 +35,9 @@ if ! [[ -f "${USER_CONFIG_FILE}" ]]; then fi source "${USER_CONFIG_FILE}"; +# Set the percent change in volume for vol up and vol down +VOL_INCREMENT=10 + showAPIHelp() { echo; echo "Connecting to Spotify's API:"; @@ -170,12 +173,12 @@ while [ $# -gt 0 ]; do if [ -z "${CLIENT_ID}" ]; then cecho "Invalid Client ID, please update ${USER_CONFIG_FILE}"; showAPIHelp; - return 1 + return 1; fi if [ -z "${CLIENT_SECRET}" ]; then cecho "Invalid Client Secret, please update ${USER_CONFIG_FILE}"; showAPIHelp; - return 1 + return 1; fi SHPOTIFY_CREDENTIALS=$(printf "${CLIENT_ID}:${CLIENT_SECRET}" | base64 | tr -d "\n"|tr -d '\r'); SPOTIFY_PLAY_URI=""; @@ -198,7 +201,7 @@ while [ $# -gt 0 ]; do fi SPOTIFY_ACCESS_TOKEN=$( \ printf "${SPOTIFY_TOKEN_RESPONSE_DATA}" \ - | grep -E -o '"access_token":".*",' \ + | command grep -E -o '"access_token":".*",' \ | sed 's/"access_token"://g' \ | sed 's/"//g' \ | sed 's/,.*//g' \ @@ -219,9 +222,8 @@ while [ $# -gt 0 ]; do -H "Accept: application/json" \ --data-urlencode "q=$Q" \ -d "type=$type&limit=1&offset=0" \ - | grep -E -o "spotify:$type:[a-zA-Z0-9]+" -m 1 + | command grep -E -o "spotify:$type:[a-zA-Z0-9]+" -m 1 ) - echo "play uri: ${SPOTIFY_PLAY_URI}" } case $2 in @@ -235,11 +237,11 @@ while [ $# -gt 0 ]; do results=$( \ curl -s -G $SPOTIFY_SEARCH_API --data-urlencode "q=$Q" -d "type=playlist&limit=10&offset=0" -H "Accept: application/json" -H "Authorization: Bearer ${SPOTIFY_ACCESS_TOKEN}" \ - | grep -E -o "spotify:playlist:[a-zA-Z0-9]+" -m 10 \ + | command grep -E -o "spotify:playlist:[a-zA-Z0-9]+" -m 10 \ ) count=$( \ - echo "$results" | grep -c "spotify:playlist" \ + echo "$results" | command grep -c "spotify:playlist" \ ) if [ "$count" -gt 0 ]; then @@ -333,16 +335,16 @@ while [ $# -gt 0 ]; do cecho "Current Spotify volume level is $vol."; break ; elif [ "$2" = "up" ]; then - if [ $vol -le 90 ]; then - newvol=$(( vol+10 )); + if [ $vol -le $(( 100-$VOL_INCREMENT )) ]; then + newvol=$(( vol+$VOL_INCREMENT )); cecho "Increasing Spotify volume to $newvol."; else newvol=100; cecho "Spotify volume level is at max."; fi elif [ "$2" = "down" ]; then - if [ $vol -ge 10 ]; then - newvol=$(( vol-10 )); + if [ $vol -ge $(( $VOL_INCREMENT )) ]; then + newvol=$(( vol-$VOL_INCREMENT )); cecho "Reducing Spotify volume to $newvol."; else newvol=0; @@ -354,11 +356,11 @@ while [ $# -gt 0 ]; do else echo "Improper use of 'vol' command" echo "The 'vol' command should be used as follows:" - echo " vol up # Increases the volume by 10%."; - echo " vol down # Decreases the volume by 10%."; + echo " vol up # Increases the volume by $VOL_INCREMENT%."; + echo " vol down # Decreases the volume by $VOL_INCREMENT%."; echo " vol [amount] # Sets the volume to an amount between 0 and 100."; echo " vol # Shows the current Spotify volume."; - return 1 + return 1; fi osascript -e "tell application \"Spotify\" to set sound volume to $newvol"; @@ -468,10 +470,9 @@ while [ $# -gt 0 ]; do "help" ) showHelp; break ;; - * ) showHelp; - return 1 ;; + return 1; esac done From 38ef5192cb1c43159b516d15ab8fed96f847b36b Mon Sep 17 00:00:00 2001 From: Felipe Gallois Date: Mon, 11 Sep 2023 10:05:50 +0100 Subject: [PATCH 353/672] feat(oldgalois): add theme (#11880) Closes #11879 --- themes/oldgallois.zsh-theme | 24 ++++++++++++++++++++++++ 1 file changed, 24 insertions(+) create mode 100644 themes/oldgallois.zsh-theme diff --git a/themes/oldgallois.zsh-theme b/themes/oldgallois.zsh-theme new file mode 100644 index 000000000..bb97bfb17 --- /dev/null +++ b/themes/oldgallois.zsh-theme @@ -0,0 +1,24 @@ +# Depends on the git plugin for work_in_progress() +(( $+functions[work_in_progress] )) || work_in_progress() {} + +ZSH_THEME_GIT_PROMPT_PREFIX="%{$reset_color%}%{$fg[green]%}[" +ZSH_THEME_GIT_PROMPT_SUFFIX="]%{$reset_color%}" +ZSH_THEME_GIT_PROMPT_DIRTY="%{$fg[red]%}*%{$reset_color%}" +ZSH_THEME_GIT_PROMPT_CLEAN="" + +# Customized git status, oh-my-zsh currently does not allow render dirty status before branch +git_custom_status() { + local branch=$(git_current_branch) + [[ -n "$branch" ]] || return 0 + echo "$(parse_git_dirty)\ +%{${fg_bold[yellow]}%}$(work_in_progress)%{$reset_color%}\ +${ZSH_THEME_GIT_PROMPT_PREFIX}${branch}${ZSH_THEME_GIT_PROMPT_SUFFIX}" +} + +# RVM component of prompt +ZSH_THEME_RUBY_PROMPT_PREFIX="%{$fg[red]%}[" +ZSH_THEME_RUBY_PROMPT_SUFFIX="]%{$reset_color%}" + +# Combine it all into a final right-side prompt +RPS1="\$(git_custom_status)\$(ruby_prompt_info)${RPS1:+ $RPS1}" +PROMPT='%{$fg[cyan]%}[%~% ]%(?.%{$fg[green]%}.%{$fg[red]%})%B$%b ' From 01f55123118601a935f28ff6c49e625448bdd32d Mon Sep 17 00:00:00 2001 From: bretello Date: Tue, 12 Sep 2023 21:41:07 +0200 Subject: [PATCH 354/672] feat(systemd): add alias for --failed commands (#11847) --- plugins/systemd/README.md | 1 + plugins/systemd/systemd.plugin.zsh | 3 +++ 2 files changed, 4 insertions(+) diff --git a/plugins/systemd/README.md b/plugins/systemd/README.md index ffa0567a8..755c649a1 100644 --- a/plugins/systemd/README.md +++ b/plugins/systemd/README.md @@ -12,6 +12,7 @@ plugins=(... systemd) | Alias | Command | Description | |:-----------------------|:-----------------------------------|:-----------------------------------------------------------------| +| `sc-failed` | `systemctl --failed` | List failed systemd units | | `sc-list-units` | `systemctl list-units` | List all units systemd has in memory | | `sc-is-active` | `systemctl is-active` | Show whether a unit is active | | `sc-status` | `systemctl status` | Show terse runtime status information about one or more units | diff --git a/plugins/systemd/systemd.plugin.zsh b/plugins/systemd/systemd.plugin.zsh index 1270bea0e..382a57b29 100644 --- a/plugins/systemd/systemd.plugin.zsh +++ b/plugins/systemd/systemd.plugin.zsh @@ -93,6 +93,9 @@ alias scu-enable-now="scu-enable --now" alias scu-disable-now="scu-disable --now" alias scu-mask-now="scu-mask --now" +# --failed commands +alias scu-failed='systemctl --user --failed' +alias sc-failed='systemctl --failed' function systemd_prompt_info { local unit From 7e4c26860d74a01cd6d91fd10fcc28fccd740ddd Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Wed, 13 Sep 2023 10:48:16 +0200 Subject: [PATCH 355/672] feat(brew): add support for custom `BREW_LOCATION` Fixes #11888 Co-authored-by: Matt Cable --- plugins/brew/README.md | 20 +++++++++++--------- plugins/brew/brew.plugin.zsh | 7 ++++++- 2 files changed, 17 insertions(+), 10 deletions(-) diff --git a/plugins/brew/README.md b/plugins/brew/README.md index 4730194bc..299393b28 100644 --- a/plugins/brew/README.md +++ b/plugins/brew/README.md @@ -10,10 +10,12 @@ plugins=(... brew) ## Shellenv -If `brew` is not found in the PATH, this plugin will attempt to find it in common -locations, and execute `brew shellenv` to set the environment appropriately. -This plugin will also export `HOMEBREW_PREFIX="$(brew --prefix)"` if not previously -defined for convenience. +If `brew` is not found in the PATH, this plugin will attempt to find it in common locations, and execute +`brew shellenv` to set the environment appropriately. This plugin will also export +`HOMEBREW_PREFIX="$(brew --prefix)"` if not previously defined for convenience. + +In case you installed `brew` in a non-common location, you can still set `BREW_LOCATION` variable pointing to +the `brew` binary before sourcing `oh-my-zsh.sh` and it'll set up the environment. ## Aliases @@ -33,9 +35,9 @@ defined for convenience. ## Completion -This plugin configures paths with Homebrew's completion functions automatically, so you don't need to do it manually. See: https://docs.brew.sh/Shell-Completion#configuring-completions-in-zsh. +This plugin configures paths with Homebrew's completion functions automatically, so you don't need to do it +manually. See: https://docs.brew.sh/Shell-Completion#configuring-completions-in-zsh. -With the release of Homebrew 1.0, they decided to bundle the zsh completion as part of the -brew installation, so we no longer ship it with the brew plugin; now it only has brew -aliases. If you find that brew completion no longer works, make sure you have your Homebrew -installation fully up to date. +With the release of Homebrew 1.0, they decided to bundle the zsh completion as part of the brew installation, +so we no longer ship it with the brew plugin; now it only has brew aliases. If you find that brew completion +no longer works, make sure you have your Homebrew installation fully up to date. diff --git a/plugins/brew/brew.plugin.zsh b/plugins/brew/brew.plugin.zsh index b52664a39..447036376 100644 --- a/plugins/brew/brew.plugin.zsh +++ b/plugins/brew/brew.plugin.zsh @@ -1,5 +1,10 @@ if (( ! $+commands[brew] )); then - if [[ -x /opt/homebrew/bin/brew ]]; then + if [[ -n "$BREW_LOCATION" ]]; then + if [[ ! -x "$BREW_LOCATION" ]]; then + echo "[oh-my-zsh] $BREW_LOCATION is not executable" + return + fi + elif [[ -x /opt/homebrew/bin/brew ]]; then BREW_LOCATION="/opt/homebrew/bin/brew" elif [[ -x /usr/local/bin/brew ]]; then BREW_LOCATION="/usr/local/bin/brew" From 4167474f124bfc39d0e6cd612c95acf0a1ae9904 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?J=C3=A9r=C3=B4me=20Benoit?= Date: Wed, 13 Sep 2023 16:31:24 +0200 Subject: [PATCH 356/672] feat(grc): add support for arm64 macos (#11890) --- plugins/grc/grc.plugin.zsh | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/plugins/grc/grc.plugin.zsh b/plugins/grc/grc.plugin.zsh index b709b9e02..e036b8d89 100644 --- a/plugins/grc/grc.plugin.zsh +++ b/plugins/grc/grc.plugin.zsh @@ -2,8 +2,9 @@ # common grc.zsh paths files=( - /etc/grc.zsh # default - /usr/local/etc/grc.zsh # homebrew + /etc/grc.zsh # default + /usr/local/etc/grc.zsh # homebrew darwin-x64 + /opt/homebrew/etc/grc.zsh # homebrew darwin-arm64 ) # verify the file is readable and source it From bbda81fe4b338f00bbf7c7f33e6d1b12d067dc05 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Wed, 13 Sep 2023 19:23:41 +0200 Subject: [PATCH 357/672] fix(changelog): fix regression for unstyled code in commit subjects --- tools/changelog.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tools/changelog.sh b/tools/changelog.sh index 1af74e42d..6d768963e 100755 --- a/tools/changelog.sh +++ b/tools/changelog.sh @@ -366,7 +366,7 @@ function display-release { # In text mode, highlight (#) and dim text between `backticks` text) if supports_hyperlinks; then - sed -E $'s|#([0-9]+)|\e]8;;https://github.com/ohmyzsh/ohmyzsh/issues/\\1\a\e[32m#\\1\e[0m\e]8;;\a|g' <<< "$subject" + sed -E $'s|#([0-9]+)|\e]8;;https://github.com/ohmyzsh/ohmyzsh/issues/\\1\a\e[32m#\\1\e[0m\e]8;;\a|g;s|`([^`]+)`|`\e[2m\\1\e[0m`|g' <<< "$subject" else sed -E $'s|#([0-9]+)|\e[32m#\\1\e[0m|g;s|`([^`]+)`|`\e[2m\\1\e[0m`|g' <<< "$subject" fi ;; From cdd7dab5db4c668b962f908b57e244aa1ff4b574 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Sun, 17 Sep 2023 16:20:46 +0200 Subject: [PATCH 358/672] ci(installer): remove `vc link` which generates the wrong project `vc link` is not needed, as we already have `VERCEL_PROJECT_ID` defined as an env variable. Currently the `vc link` only creates a second empty project with the name `installer` as seen in logs: Linked to ohmyzsh/installer (created .vercel and added it to .gitignore) Vercel CLI 32.2.4 --- .github/workflows/installer.yml | 1 - 1 file changed, 1 deletion(-) diff --git a/.github/workflows/installer.yml b/.github/workflows/installer.yml index ac88d10b0..4a25c8079 100644 --- a/.github/workflows/installer.yml +++ b/.github/workflows/installer.yml @@ -51,5 +51,4 @@ jobs: run: | cp tools/install.sh .github/workflows/installer/install.sh cd .github/workflows/installer - vc link --yes -t ${{ secrets.VERCEL_TOKEN }} vc deploy --prod -t ${{ secrets.VERCEL_TOKEN }} From 91cd5341b9e682bf1c1be4a4051249cffdab7943 Mon Sep 17 00:00:00 2001 From: Marc-Antoine Godde Date: Wed, 20 Sep 2023 12:09:46 +0200 Subject: [PATCH 359/672] fix(gcloud): source `path.zsh.inc` always (#11901) --- plugins/gcloud/gcloud.plugin.zsh | 8 +++----- 1 file changed, 3 insertions(+), 5 deletions(-) diff --git a/plugins/gcloud/gcloud.plugin.zsh b/plugins/gcloud/gcloud.plugin.zsh index 5c57302d3..9a4213aaf 100644 --- a/plugins/gcloud/gcloud.plugin.zsh +++ b/plugins/gcloud/gcloud.plugin.zsh @@ -29,11 +29,9 @@ if [[ -z "${CLOUDSDK_HOME}" ]]; then fi if (( ${+CLOUDSDK_HOME} )); then - # Only source this if gcloud isn't already on the path - if (( ! $+commands[gcloud] )); then - if [[ -f "${CLOUDSDK_HOME}/path.zsh.inc" ]]; then - source "${CLOUDSDK_HOME}/path.zsh.inc" - fi + # Source path file + if [[ -f "${CLOUDSDK_HOME}/path.zsh.inc" ]]; then + source "${CLOUDSDK_HOME}/path.zsh.inc" fi # Look for completion file in different paths From 350427dea2293a3e23f9823b5dc2574c1b1ae2a2 Mon Sep 17 00:00:00 2001 From: Trick van Staveren Date: Wed, 20 Sep 2023 09:09:26 -0500 Subject: [PATCH 360/672] feat(hitchhiker): clean up refs to magic string (#11900) --- plugins/hitchhiker/fortunes/hitchhiker | 26 +++++++++++++------------- 1 file changed, 13 insertions(+), 13 deletions(-) diff --git a/plugins/hitchhiker/fortunes/hitchhiker b/plugins/hitchhiker/fortunes/hitchhiker index 825b86cd6..b0448b21e 100644 --- a/plugins/hitchhiker/fortunes/hitchhiker +++ b/plugins/hitchhiker/fortunes/hitchhiker @@ -194,31 +194,31 @@ ARTHUR It probably seems a terrible thing to say, but you know what I sometimes - One of the more preferable pieces of advice contained in the Guide. % -"His eyes seemed to be popping out of his head. He wasn't certain if this was because they were trying to see more clearly, or if they simply wanted to leave at this point."QUOTEHERESTRINGMAGIC1234- Arthur trying to see who had diverted him from going to a party. +"His eyes seemed to be popping out of his head. He wasn't certain if this was because they were trying to see more clearly, or if they simply wanted to leave at this point." - Arthur trying to see who had diverted him from going to a party. % -"Arthur yawed wildly as his skin tried to jump one way and his skeleton the other, whilst his brain tried to work out which of his ears it most wanted to crawl out of. `Bet you weren't expecting to see me again,' said the monster, which Arthur couldn't help thinking was a strange remark for it to make, seeing as he had never met the creature before. He could tell that he hadn't met the creature before from the simple fact that he was able to sleep at nights."QUOTEHERESTRINGMAGIC1234- Arthur discovering who had diverted him from going to a party. +"Arthur yawed wildly as his skin tried to jump one way and his skeleton the other, whilst his brain tried to work out which of his ears it most wanted to crawl out of. `Bet you weren't expecting to see me again,' said the monster, which Arthur couldn't help thinking was a strange remark for it to make, seeing as he had never met the creature before. He could tell that he hadn't met the creature before from the simple fact that he was able to sleep at nights." - Arthur discovering who had diverted him from going to a party. % -"`That young girl is one of the least benightedly unintelligent organic life forms it has been my profound lack of pleasure not to be able to avoid meeting.'"QUOTEHERESTRINGMAGIC1234- Marvin's first ever compliment about anybody. +"`That young girl is one of the least benightedly unintelligent organic life forms it has been my profound lack of pleasure not to be able to avoid meeting.'" - Marvin's first ever compliment about anybody. % -"Arthur hoped and prayed that there wasn't an afterlife. Then he realised there was a contradiction there and merely hoped that there wasn't an afterlife."QUOTEHERESTRINGMAGIC1234- Arthur realising that he's in a certain death situation with a supernova bomb that is shaped like a cricket ball. +"Arthur hoped and prayed that there wasn't an afterlife. Then he realised there was a contradiction there and merely hoped that there wasn't an afterlife." - Arthur realising that he's in a certain death situation with a supernova bomb that is shaped like a cricket ball. % -"`Credit?' he said. `Aaaargggh...' These two words are usually coupled together in the Old Pink Dog Bar."QUOTEHERESTRINGMAGIC1234- Ford in a spot of bother. +"`Credit?' he said. `Aaaargggh...' These two words are usually coupled together in the Old Pink Dog Bar." - Ford in a spot of bother. % -"`...we might as well start with where your hand is now.' Arthur said, `So which way do I go?' `Down,' said Fenchurch, `on this occasion.' He moved his hand. `Down,' she said, `is in fact the other way.' `Oh yes.'"QUOTEHERESTRINGMAGIC1234- Arthur trying to discover which part of Fenchurch is wrong. +"`...we might as well start with where your hand is now.' Arthur said, `So which way do I go?' `Down,' said Fenchurch, `on this occasion.' He moved his hand. `Down,' she said, `is in fact the other way.' `Oh yes.'" - Arthur trying to discover which part of Fenchurch is wrong. % -"There was a point to this story, but it has temporarily escaped the chronicler's mind."QUOTEHERESTRINGMAGIC1234- This line perhaps best sums up the whole book. +"There was a point to this story, but it has temporarily escaped the chronicler's mind." - This line perhaps best sums up the whole book. % -"The last time anybody made a list of the top hundred character attributes of New Yorkers, common sense snuck in at number 79. .... When it's fall in New York, the air smells as if someone's been frying goats in it, and if you are keen to breathe the best plan is to open a window and stick your head in a building."QUOTEHERESTRINGMAGIC1234- Nuff said?? +"The last time anybody made a list of the top hundred character attributes of New Yorkers, common sense snuck in at number 79. .... When it's fall in New York, the air smells as if someone's been frying goats in it, and if you are keen to breathe the best plan is to open a window and stick your head in a building." - Nuff said?? % -"`What's been happening here?' he demanded. `Oh just the nicest things, sir, just the nicest things. can I sit on your lap please?'" "`Colin, I am going to abandon you to your fate.' `I'm so happy.'" "`It will be very, very nasty for you, and that's just too bad. Got it?' `I gurgle with pleasure.'"QUOTEHERESTRINGMAGIC1234- Ford and Colin the robot. +"`What's been happening here?' he demanded. `Oh just the nicest things, sir, just the nicest things. can I sit on your lap please?'" "`Colin, I am going to abandon you to your fate.' `I'm so happy.'" "`It will be very, very nasty for you, and that's just too bad. Got it?' `I gurgle with pleasure.'" - Ford and Colin the robot. % -"What the hell, he thought, you're only young once, and threw himself out of the window. That would at least keep the element of surprise on his side."QUOTEHERESTRINGMAGIC1234- Ford outwitting a Vogon with a rocket launcher by going into another certain death situation. +"What the hell, he thought, you're only young once, and threw himself out of the window. That would at least keep the element of surprise on his side." - Ford outwitting a Vogon with a rocket launcher by going into another certain death situation. % -"The major difference between a thing that might go wrong and a thing that cannot possibly go wrong is that when a thing that cannot possibly go wrong goes wrong it usually turns out to be impossible to get at or repair."QUOTEHERESTRINGMAGIC1234- One of the laws of computers and programming revealed. +"The major difference between a thing that might go wrong and a thing that cannot possibly go wrong is that when a thing that cannot possibly go wrong goes wrong it usually turns out to be impossible to get at or repair." - One of the laws of computers and programming revealed. % -"`You know they've reintroduced the death penalty for insurance company directors?' `Really?' said Arthur. `No I didn't. For what offence?' Trillian frowned. `What do you mean, offence?' `I see.'"QUOTEHERESTRINGMAGIC1234- Evidence that there will be some justice in the Universe eventually. +"`You know they've reintroduced the death penalty for insurance company directors?' `Really?' said Arthur. `No I didn't. For what offence?' Trillian frowned. `What do you mean, offence?' `I see.'" - Evidence that there will be some justice in the Universe eventually. % -"`She hit me on the head with the rock again.' `I think I can confirm that that was my daughter.' `Sweet kid.' `You have to get to know her,' said Arthur. `She eases up does she?' `No,' said Arthur, `but you get a better sense of when to duck.'"QUOTEHERESTRINGMAGIC1234- Ford and Arthur on Random. +"`She hit me on the head with the rock again.' `I think I can confirm that that was my daughter.' `Sweet kid.' `You have to get to know her,' said Arthur. `She eases up does she?' `No,' said Arthur, `but you get a better sense of when to duck.'" - Ford and Arthur on Random. % "Far out in the uncharted backwaters of the unfashionable end of the western spiral arm of the Galaxy lies a small unregarded yellow sun. " % From 1cc32be5f632ff933b3e3f1c7bd9e612a274c095 Mon Sep 17 00:00:00 2001 From: ajatkj Date: Wed, 20 Sep 2023 20:21:27 +0530 Subject: [PATCH 361/672] feat(poetry-env): create plugin (#11069) --- plugins/poetry-env/README.md | 10 +++++++++ plugins/poetry-env/poetry-env.plugin.zsh | 27 ++++++++++++++++++++++++ 2 files changed, 37 insertions(+) create mode 100644 plugins/poetry-env/README.md create mode 100644 plugins/poetry-env/poetry-env.plugin.zsh diff --git a/plugins/poetry-env/README.md b/plugins/poetry-env/README.md new file mode 100644 index 000000000..a7d16563e --- /dev/null +++ b/plugins/poetry-env/README.md @@ -0,0 +1,10 @@ +# Poetry Environment Plugin + +This plugin automatically changes poetry environment when you cd into or out of the project directory. +Note: Script looks for pyproject.toml file to determine poetry if its a poetry environment + +To use it, add `poetry-env` to the plugins array in your zshrc file: + +```zsh +plugins=(... poetry-env) +``` diff --git a/plugins/poetry-env/poetry-env.plugin.zsh b/plugins/poetry-env/poetry-env.plugin.zsh new file mode 100644 index 000000000..86e5fad4e --- /dev/null +++ b/plugins/poetry-env/poetry-env.plugin.zsh @@ -0,0 +1,27 @@ +# Automatic poetry environment activation/deactivation +_togglePoetryShell() { + # deactivate environment if pyproject.toml doesn't exist and not in a subdir + if [[ ! -f "$PWD/pyproject.toml" ]] ; then + if [[ "$poetry_active" == 1 ]]; then + if [[ "$PWD" != "$poetry_dir"* ]]; then + export poetry_active=0 + deactivate + return + fi + fi + fi + + # activate the environment if pyproject.toml exists + if [[ "$poetry_active" != 1 ]]; then + if [[ -f "$PWD/pyproject.toml" ]]; then + if grep -q 'tool.poetry' "$PWD/pyproject.toml"; then + export poetry_active=1 + export poetry_dir="$PWD" + source "$(poetry env info --path)/bin/activate" + fi + fi + fi +} +autoload -U add-zsh-hook +add-zsh-hook chpwd _togglePoetryShell +_togglePoetryShell From 1c55a0fe5246487ec9f18e03b7f28862b76cb7ab Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marcus=20M=C3=BCller?= Date: Thu, 21 Sep 2023 12:43:00 +0200 Subject: [PATCH 362/672] feat(dnf): use `dnf5` if available (#11904) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Co-authored-by: Marcus Müller --- plugins/dnf/README.md | 3 +++ plugins/dnf/dnf.plugin.zsh | 28 ++++++++++++++++------------ 2 files changed, 19 insertions(+), 12 deletions(-) diff --git a/plugins/dnf/README.md b/plugins/dnf/README.md index dc0d1e0a0..f45c8778c 100644 --- a/plugins/dnf/README.md +++ b/plugins/dnf/README.md @@ -10,6 +10,9 @@ To use it, add `dnf` to the plugins array in your zshrc file: plugins=(... dnf) ``` +Classic `dnf` is getting superseded by `dnf5`; this plugin detects the presence +of `dnf5` and uses it as drop-in alternative to the slower `dnf`. + ## Aliases | Alias | Command | Description | diff --git a/plugins/dnf/dnf.plugin.zsh b/plugins/dnf/dnf.plugin.zsh index 653ce7dda..642422fe1 100644 --- a/plugins/dnf/dnf.plugin.zsh +++ b/plugins/dnf/dnf.plugin.zsh @@ -1,15 +1,19 @@ ## Aliases +local dnfprog="dnf" -alias dnfl="dnf list" # List packages -alias dnfli="dnf list installed" # List installed packages -alias dnfgl="dnf grouplist" # List package groups -alias dnfmc="dnf makecache" # Generate metadata cache -alias dnfp="dnf info" # Show package information -alias dnfs="dnf search" # Search package +# Prefer dnf5 if installed +command -v dnf5 > /dev/null && dnfprog=dnf5 -alias dnfu="sudo dnf upgrade" # Upgrade package -alias dnfi="sudo dnf install" # Install package -alias dnfgi="sudo dnf groupinstall" # Install package group -alias dnfr="sudo dnf remove" # Remove package -alias dnfgr="sudo dnf groupremove" # Remove package group -alias dnfc="sudo dnf clean all" # Clean cache +alias dnfl="${dnfprog} list" # List packages +alias dnfli="${dnfprog} list installed" # List installed packages +alias dnfgl="${dnfprog} grouplist" # List package groups +alias dnfmc="${dnfprog} makecache" # Generate metadata cache +alias dnfp="${dnfprog} info" # Show package information +alias dnfs="${dnfprog} search" # Search package + +alias dnfu="sudo ${dnfprog} upgrade" # Upgrade package +alias dnfi="sudo ${dnfprog} install" # Install package +alias dnfgi="sudo ${dnfprog} groupinstall" # Install package group +alias dnfr="sudo ${dnfprog} remove" # Remove package +alias dnfgr="sudo ${dnfprog} groupremove" # Remove package group +alias dnfc="sudo ${dnfprog} clean all" # Clean cache From c91684bb1b723833a96415c2c724332a6e2e620f Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Mon, 25 Sep 2023 08:20:20 +0100 Subject: [PATCH 363/672] docs(web-search): add `youtube` entry --- plugins/web-search/README.md | 62 ++++++++++++------------ plugins/web-search/web-search.plugin.zsh | 1 - 2 files changed, 30 insertions(+), 33 deletions(-) diff --git a/plugins/web-search/README.md b/plugins/web-search/README.md index 0bf9f26ad..6e4b4d7b8 100644 --- a/plugins/web-search/README.md +++ b/plugins/web-search/README.md @@ -12,8 +12,8 @@ plugins=( ... web-search) You can use the `web-search` plugin in these two forms: -* `web_search [more terms if you want]` -* ` [more terms if you want]` +- `web_search [more terms if you want]` +- ` [more terms if you want]` For example, these two are equivalent: @@ -24,43 +24,42 @@ $ google oh-my-zsh Available search contexts are: -| Context | URL | -| --------------------- | ---------------------------------------- | -| `bing` | `https://www.bing.com/search?q=` | -| `google` | `https://www.google.com/search?q=` | -| `brs` or `brave` | `https://search.brave.com/search?q=` | -| `yahoo` | `https://search.yahoo.com/search?p=` | -| `ddg` or `duckduckgo` | `https://www.duckduckgo.com/?q=` | -| `sp` or `startpage` | `https://www.startpage.com/do/search?q=` | -| `yandex` | `https://yandex.ru/yandsearch?text=` | -| `github` | `https://github.com/search?q=` | -| `baidu` | `https://www.baidu.com/s?wd=` | -| `ecosia` | `https://www.ecosia.org/search?q=` | -| `goodreads` | `https://www.goodreads.com/search?q=` | -| `qwant` | `https://www.qwant.com/?q=` | -| `givero` | `https://www.givero.com/search?q=` | -| `stackoverflow` | `https://stackoverflow.com/search?q=` | -| `wolframalpha` | `https://wolframalpha.com/input?i=` | -| `archive` | `https://web.archive.org/web/*/` | -| `scholar` | `https://scholar.google.com/scholar?q=` | -| `ask` | `https://www.ask.com/web?q=` | +| Context | URL | +| --------------------- | ----------------------------------------------- | +| `bing` | `https://www.bing.com/search?q=` | +| `google` | `https://www.google.com/search?q=` | +| `brs` or `brave` | `https://search.brave.com/search?q=` | +| `yahoo` | `https://search.yahoo.com/search?p=` | +| `ddg` or `duckduckgo` | `https://www.duckduckgo.com/?q=` | +| `sp` or `startpage` | `https://www.startpage.com/do/search?q=` | +| `yandex` | `https://yandex.ru/yandsearch?text=` | +| `github` | `https://github.com/search?q=` | +| `baidu` | `https://www.baidu.com/s?wd=` | +| `ecosia` | `https://www.ecosia.org/search?q=` | +| `goodreads` | `https://www.goodreads.com/search?q=` | +| `qwant` | `https://www.qwant.com/?q=` | +| `givero` | `https://www.givero.com/search?q=` | +| `stackoverflow` | `https://stackoverflow.com/search?q=` | +| `wolframalpha` | `https://wolframalpha.com/input?i=` | +| `archive` | `https://web.archive.org/web/*/` | +| `scholar` | `https://scholar.google.com/scholar?q=` | +| `ask` | `https://www.ask.com/web?q=` | +| `youtube` | `https://www.youtube.com/results?search_query=` | Also there are aliases for bang-searching DuckDuckGo: | Context | Bang | -|-----------|-------| +| --------- | ----- | | `wiki` | `!w` | | `news` | `!n` | -| `youtube` | `!yt` | | `map` | `!m` | | `image` | `!i` | | `ducky` | `!` | ### Custom search engines -If you want to add other search contexts to the plugin, you can use the -`$ZSH_WEB_SEARCH_ENGINES` variable. Set it before Oh My Zsh is sourced, -with the following format: +If you want to add other search contexts to the plugin, you can use the `$ZSH_WEB_SEARCH_ENGINES` variable. +Set it before Oh My Zsh is sourced, with the following format: ```zsh ZSH_WEB_SEARCH_ENGINES=( @@ -69,13 +68,12 @@ ZSH_WEB_SEARCH_ENGINES=( ) ``` -where `` is the name of the search context, and `` a URL of -the same type as the search contexts above. For example, to add `reddit`, -you'd do: +where `` is the name of the search context, and `` a URL of the same type as the search contexts +above. For example, to add `reddit`, you'd do: ```zsh ZSH_WEB_SEARCH_ENGINES=(reddit "https://www.reddit.com/search/?q=") ``` -These custom search engines will also be turned to aliases, so you can -both do `web_search reddit ` or `reddit `. +These custom search engines will also be turned to aliases, so you can both do `web_search reddit ` or +`reddit `. diff --git a/plugins/web-search/web-search.plugin.zsh b/plugins/web-search/web-search.plugin.zsh index fc87a3495..a8848fd95 100644 --- a/plugins/web-search/web-search.plugin.zsh +++ b/plugins/web-search/web-search.plugin.zsh @@ -72,7 +72,6 @@ alias youtube='web_search youtube' #add your own !bang searches here alias wiki='web_search duckduckgo \!w' alias news='web_search duckduckgo \!n' -#alias youtube='web_search duckduckgo \!yt' alias map='web_search duckduckgo \!m' alias image='web_search duckduckgo \!i' alias ducky='web_search duckduckgo \!' From a17789eedea4f6b9b5a9c970174d6d5dc0ef64ee Mon Sep 17 00:00:00 2001 From: Adam Johnson Date: Mon, 25 Sep 2023 09:49:22 +0100 Subject: [PATCH 364/672] docs(git): improve tables and language (#11895) --- plugins/git/README.md | 463 +++++++++++++++++++++--------------------- 1 file changed, 231 insertions(+), 232 deletions(-) diff --git a/plugins/git/README.md b/plugins/git/README.md index 6eb63ea40..9621a312e 100644 --- a/plugins/git/README.md +++ b/plugins/git/README.md @@ -10,204 +10,204 @@ plugins=(... git) ## Aliases -| Alias | Command | -| :------------------- | :--------------------------------------------------------------------------------------------------------------------------------------------------------------- | -| grt | cd "$(git rev-parse --show-toplevel || echo .)" | -| ggpnp | ggl && ggp | -| ggpur | ggu | -| g | git | -| ga | git add | -| gaa | git add --all | -| gapa | git add --patch | -| gau | git add --update | -| gav | git add --verbose | -| gwip | git add -A; git rm $(git ls-files --deleted) 2> /dev/null; git commit --no-verify --no-gpg-sign --message "--wip-- [skip ci]" | -| gam | git am | -| gama | git am --abort | -| gamc | git am --continue | -| gamscp | git am --show-current-patch | -| gams | git am --skip | -| gap | git apply | -| gapt | git apply --3way | -| gbs | git bisect | -| gbsb | git bisect bad | -| gbsg | git bisect good | -| gbsn | git bisect new | -| gbso | git bisect old | -| gbsr | git bisect reset | -| gbss | git bisect start | -| gbl | git blame -w | -| gb | git branch | -| gba | git branch --all | -| gbd | git branch --delete | -| gbD | git branch --delete --force | -| gbda | git branch --no-color --merged | grep -vE "^([+]|\s($(git_main_branch)|$(git_develop_branch))\s\*$)" | xargs git branch --delete 2>/dev/null | -| gbgd | LANG=C git branch --no-color -vv | grep ": gone\]" | awk '"'"'{print $1}'"'"' | xargs git branch -d | -| gbgD | LANG=C git branch --no-color -vv | grep ": gone\]" | awk '"'"'{print $1}'"'"' | xargs git branch -D | -| gbnm | git branch --no-merged | -| gbr | git branch --remote | -| ggsup | git branch --set-upstream-to=origin/$(git_current_branch) | -| gbg | LANG=C git branch -vv | grep ": gone\]" | -| gco | git checkout | -| gcor | git checkout --recurse-submodules | -| gcb | git checkout -b | -| gcd | git checkout $(git_develop_branch) | -| gcm | git checkout $(git_main_branch) | -| gcp | git cherry-pick | -| gcpa | git cherry-pick --abort | -| gcpc | git cherry-pick --continue | -| gclean | git clean --interactive -d | -| gcl | git clone --recurse-submodules | -| gccd | git clone --recurse-submodules "$@" && cd "$(basename $\_ .git)" | -| gcam | git commit --all --message | -| gcas | git commit --all --signoff | -| gcasm | git commit --all --signoff --message | -| gcmsg | git commit --message | -| gcsm | git commit --signoff --message | -| gc | git commit --verbose | -| gca | git commit --verbose --all | -| gca! | git commit --verbose --all --amend | -| gcan! | git commit --verbose --all --no-edit --amend | -| gcans! | git commit --verbose --all --signoff --no-edit --amend | -| gc! | git commit --verbose --amend | -| gcn! | git commit --verbose --no-edit --amend | -| gcs | git commit -S | -| gcss | git commit -S -s | -| gcssm | git commit -S -s -m | -| gcf | git config --list | -| gdct | git describe --tags $(git rev-list --tags --max-count=1) | -| gd | git diff | -| gdca | git diff --cached | -| gdcw | git diff --cached --word-diff | -| gds | git diff --staged | -| gdw | git diff --word-diff | -| gdv | git diff -w $@ | view - | -| gdup | git diff @{upstream} | -| gdnolock | git diff $@ ":(exclude)package-lock.json" ":(exclude)\*.lock" | -| gdt | git diff-tree --no-commit-id --name-only -r | -| gf | git fetch | -| gfa | git fetch --all --prune | -| gfo | git fetch origin | -| gg | git gui citool | -| gga | git gui citool --amend | -| ghh | git help | -| glgg | git log --graph | -| glgga | git log --graph --decorate --all | -| glgm | git log --graph --max-count=10 | -| glod | git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ad) %C(bold blue)<%an>%Creset' | -| glods | git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ad) %C(bold blue)<%an>%Creset' --date=short | -| glol | git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ar) %C(bold blue)<%an>%Creset' | -| glola | git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ar) %C(bold blue)<%an>%Creset' --all | -| glols | git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ar) %C(bold blue)<%an>%Creset' --stat | -| glo | git log --oneline --decorate | -| glog | git log --oneline --decorate --graph | -| gloga | git log --oneline --decorate --graph --all | -| glp | git log --pretty=\ | -| glg | git log --stat | -| glgp | git log --stat --patch | -| gignored | git ls-files -v | grep "^[[:lower:]]" | -| gfg | git ls-files | grep | -| gm | git merge | -| gma | git merge --abort | -| gms | git merge --squash | -| gmom | git merge origin/$(git_main_branch) | -| gmum | git merge upstream/$(git_main_branch) | -| gmtl | git mergetool --no-prompt | -| gmtlvim | git mergetool --no-prompt --tool=vimdiff | -| gl | git pull | -| gpr | git pull --rebase | -| gup | git pull --rebase | -| gupa | git pull --rebase --autostash | -| gupav | git pull --rebase --autostash --verbose | -| gupv | git pull --rebase --verbose | -| ggu | git pull --rebase origin $(current_branch) | -| gupom | git pull --rebase origin $(git_main_branch) | -| gupomi | git pull --rebase=interactive origin $(git_main_branch) | -| ggpull | git pull origin "$(git_current_branch)" | -| ggl | git pull origin $(current_branch) | -| gluc | git pull upstream $(git_current_branch) | -| glum | git pull upstream $(git_main_branch) | -| gp | git push | -| gpd | git push --dry-run | -| gpf! | git push --force | -| ggf | git push --force origin $(current_branch) | -| gpf | git push --force-with-lease --force-if-includes (git version >= 2.30) | -| gpf | git push --force-with-lease (git version < 2.30) | -| ggfl | git push --force-with-lease origin $(current_branch) | -| gpsup | git push --set-upstream origin $(git_current_branch) | -| gpsupf | git push --set-upstream origin $(git_current_branch) --force-with-lease --force-if-includes (git version >= 2.30) | -| gpsupf | git push --set-upstream origin $(git_current_branch) --force-with-lease (git version < 2.30) | -| gpv | git push --verbose | -| gpoat | git push origin --all && git push origin --tags | -| gpod | git push origin --delete | -| ggpush | git push origin "$(git_current_branch)" | -| ggp | git push origin $(current_branch) | -| gpu | git push upstream | -| grb | git rebase | -| grba | git rebase --abort | -| grbc | git rebase --continue | -| grbi | git rebase --interactive | -| grbo | git rebase --onto | -| grbs | git rebase --skip | -| grbd | git rebase $(git_develop_branch) | -| grbm | git rebase $(git_main_branch) | -| grbom | git rebase origin/$(git_main_branch) | -| gr | git remote | -| grv | git remote --verbose | -| gra | git remote add | -| grrm | git remote remove | -| grmv | git remote rename | -| grset | git remote set-url | -| grup | git remote update | -| grh | git reset | -| gru | git reset -- | -| grhh | git reset --hard | -| gpristine | git reset --hard && git clean -dffx | -| groh | git reset origin/$(git_current_branch) --hard | -| grs | git restore | -| grss | git restore --source | -| grst | git restore --staged | -| gunwip | git rev-list --max-count=1 --format="%s" HEAD | grep -q "--wip--" && git reset HEAD~1 | -| grev | git revert | -| grm | git rm | -| grmc | git rm --cached | -| gcount | git shortlog --summary -n | -| gsh | git show | -| gsps | git show --pretty=short --show-signature | -| gstall | git stash --all | -| gstu | git stash --include-untracked | -| gstaa | git stash apply | -| gstc | git stash clear | -| gstd | git stash drop | -| gstl | git stash list | -| gstp | git stash pop | -| gsta | git stash push (git version >= 2.13) | -| gsta | git stash save (git version < 2.13) | -| gsts | git stash show --text | -| gst | git status | -| gss | git status --short | -| gsb | git status --short -b | -| gsi | git submodule init | -| gsu | git submodule update | -| gsd | git svn dcommit | -| git-svn-dcommit-push | git svn dcommit && git push github $(git_main_branch):svntrunk | -| gsr | git svn rebase | -| gsw | git switch | -| gswc | git switch -c | -| gswd | git switch $(git_develop_branch) | -| gswm | git switch $(git_main_branch) | -| gts | git tag -s | -| gtv | git tag | sort -V | -| gignore | git update-index --assume-unchanged | -| gunignore | git update-index --no-assume-unchanged | -| gwch | git whatchanged -p --abbrev-commit --pretty=medium | -| gwt | git worktree | -| gwtls | git worktree list | -| gwtmv | git worktree move | -| gwtrm | git worktree remove | -| gk | gitk --all --branches &! | -| gke | gitk --all $(git log --walk-reflogs --pretty=%h) &! | -| gtl | gtl(){ git tag --sort=-v:refname -n --list ${1}\* }; noglob gtl | +| Alias | Command | +| :--------------------- | :------------------------------------------------------------------------------------------------------------------------------------------------------------------ | +| `grt` | `cd "$(git rev-parse --show-toplevel \|\| echo .)"` | +| `ggpnp` | `ggl && ggp` | +| `ggpur` | `ggu` | +| `g` | `git` | +| `ga` | `git add` | +| `gaa` | `git add --all` | +| `gapa` | `git add --patch` | +| `gau` | `git add --update` | +| `gav` | `git add --verbose` | +| `gwip` | `git add -A; git rm $(git ls-files --deleted) 2> /dev/null; git commit --no-verify --no-gpg-sign --message "--wip-- [skip ci]"` | +| `gam` | `git am` | +| `gama` | `git am --abort` | +| `gamc` | `git am --continue` | +| `gamscp` | `git am --show-current-patch` | +| `gams` | `git am --skip` | +| `gap` | `git apply` | +| `gapt` | `git apply --3way` | +| `gbs` | `git bisect` | +| `gbsb` | `git bisect bad` | +| `gbsg` | `git bisect good` | +| `gbsn` | `git bisect new` | +| `gbso` | `git bisect old` | +| `gbsr` | `git bisect reset` | +| `gbss` | `git bisect start` | +| `gbl` | `git blame -w` | +| `gb` | `git branch` | +| `gba` | `git branch --all` | +| `gbd` | `git branch --delete` | +| `gbD` | `git branch --delete --force` | +| `gbda` | `git branch --no-color --merged \| command grep -vE "^([+*]\|\s*($(git_main_branch)\|$(git_develop_branch))\s*$)" \| command xargs git branch --delete 2>/dev/null` | +| `gbgd` | `LANG=C git branch --no-color -vv \| grep ": gone\]" \| awk '"'"'{print $1}'"'"' \| xargs git branch -d` | +| `gbgD` | `LANG=C git branch --no-color -vv \| grep ": gone\]" \| awk '"'"'{print $1}'"'"' \| xargs git branch -D` | +| `gbnm` | `git branch --no-merged` | +| `gbr` | `git branch --remote` | +| `ggsup` | `git branch --set-upstream-to=origin/$(git_current_branch)` | +| `gbg` | `LANG=C git branch -vv \| grep ": gone\]"` | +| `gco` | `git checkout` | +| `gcor` | `git checkout --recurse-submodules` | +| `gcb` | `git checkout -b` | +| `gcd` | `git checkout $(git_develop_branch)` | +| `gcm` | `git checkout $(git_main_branch)` | +| `gcp` | `git cherry-pick` | +| `gcpa` | `git cherry-pick --abort` | +| `gcpc` | `git cherry-pick --continue` | +| `gclean` | `git clean --interactive -d` | +| `gcl` | `git clone --recurse-submodules` | +| `gccd` | `git clone --recurse-submodules "$@" && cd "$(basename $\_ .git)"` | +| `gcam` | `git commit --all --message` | +| `gcas` | `git commit --all --signoff` | +| `gcasm` | `git commit --all --signoff --message` | +| `gcmsg` | `git commit --message` | +| `gcsm` | `git commit --signoff --message` | +| `gc` | `git commit --verbose` | +| `gca` | `git commit --verbose --all` | +| `gca!` | `git commit --verbose --all --amend` | +| `gcan!` | `git commit --verbose --all --no-edit --amend` | +| `gcans!` | `git commit --verbose --all --signoff --no-edit --amend` | +| `gc!` | `git commit --verbose --amend` | +| `gcn!` | `git commit --verbose --no-edit --amend` | +| `gcs` | `git commit -S` | +| `gcss` | `git commit -S -s` | +| `gcssm` | `git commit -S -s -m` | +| `gcf` | `git config --list` | +| `gdct` | `git describe --tags $(git rev-list --tags --max-count=1)` | +| `gd` | `git diff` | +| `gdca` | `git diff --cached` | +| `gdcw` | `git diff --cached --word-diff` | +| `gds` | `git diff --staged` | +| `gdw` | `git diff --word-diff` | +| `gdv` | `git diff -w "$@" \| view -` | +| `gdup` | `git diff @{upstream}` | +| `gdnolock` | `git diff $@ ":(exclude)package-lock.json" ":(exclude)\*.lock"` | +| `gdt` | `git diff-tree --no-commit-id --name-only -r` | +| `gf` | `git fetch` | +| `gfa` | `git fetch --all --prune` | +| `gfo` | `git fetch origin` | +| `gg` | `git gui citool` | +| `gga` | `git gui citool --amend` | +| `ghh` | `git help` | +| `glgg` | `git log --graph` | +| `glgga` | `git log --graph --decorate --all` | +| `glgm` | `git log --graph --max-count=10` | +| `glod` | `git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ad) %C(bold blue)<%an>%Creset'` | +| `glods` | `git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ad) %C(bold blue)<%an>%Creset' --date=short` | +| `glol` | `git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ar) %C(bold blue)<%an>%Creset'` | +| `glola` | `git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ar) %C(bold blue)<%an>%Creset' --all` | +| `glols` | `git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ar) %C(bold blue)<%an>%Creset' --stat` | +| `glo` | `git log --oneline --decorate` | +| `glog` | `git log --oneline --decorate --graph` | +| `gloga` | `git log --oneline --decorate --graph --all` | +| `glp` | `git log --pretty=` | +| `glg` | `git log --stat` | +| `glgp` | `git log --stat --patch` | +| `gignored` | `git ls-files -v \| grep "^[[:lower:]]"` | +| `gfg` | `git ls-files \| grep` | +| `gm` | `git merge` | +| `gma` | `git merge --abort` | +| `gms` | `git merge --squash` | +| `gmom` | `git merge origin/$(git_main_branch)` | +| `gmum` | `git merge upstream/$(git_main_branch)` | +| `gmtl` | `git mergetool --no-prompt` | +| `gmtlvim` | `git mergetool --no-prompt --tool=vimdiff` | +| `gl` | `git pull` | +| `gpr` | `git pull --rebase` | +| `gup` | `git pull --rebase` | +| `gupa` | `git pull --rebase --autostash` | +| `gupav` | `git pull --rebase --autostash --verbose` | +| `gupv` | `git pull --rebase --verbose` | +| `ggu` | `git pull --rebase origin $(current_branch)` | +| `gupom` | `git pull --rebase origin $(git_main_branch)` | +| `gupomi` | `git pull --rebase=interactive origin $(git_main_branch)` | +| `ggpull` | `git pull origin "$(git_current_branch)"` | +| `ggl` | `git pull origin $(current_branch)` | +| `gluc` | `git pull upstream $(git_current_branch)` | +| `glum` | `git pull upstream $(git_main_branch)` | +| `gp` | `git push` | +| `gpd` | `git push --dry-run` | +| `gpf!` | `git push --force` | +| `ggf` | `git push --force origin $(current_branch)` | +| `gpf` | On Git >= 2.30: `git push --force-with-lease --force-if-includes` | +| `gpf` | On Git < 2.30: `git push --force-with-lease` | +| `ggfl` | `git push --force-with-lease origin $(current_branch)` | +| `gpsup` | `git push --set-upstream origin $(git_current_branch)` | +| `gpsupf` | On Git >= 2.30: `git push --set-upstream origin $(git_current_branch) --force-with-lease --force-if-includes` | +| `gpsupf` | On Git < 2.30: `git push --set-upstream origin $(git_current_branch) --force-with-lease` | +| `gpv` | `git push --verbose` | +| `gpoat` | `git push origin --all && git push origin --tags` | +| `gpod` | `git push origin --delete` | +| `ggpush` | `git push origin "$(git_current_branch)"` | +| `ggp` | `git push origin $(current_branch)` | +| `gpu` | `git push upstream` | +| `grb` | `git rebase` | +| `grba` | `git rebase --abort` | +| `grbc` | `git rebase --continue` | +| `grbi` | `git rebase --interactive` | +| `grbo` | `git rebase --onto` | +| `grbs` | `git rebase --skip` | +| `grbd` | `git rebase $(git_develop_branch)` | +| `grbm` | `git rebase $(git_main_branch)` | +| `grbom` | `git rebase origin/$(git_main_branch)` | +| `gr` | `git remote` | +| `grv` | `git remote --verbose` | +| `gra` | `git remote add` | +| `grrm` | `git remote remove` | +| `grmv` | `git remote rename` | +| `grset` | `git remote set-url` | +| `grup` | `git remote update` | +| `grh` | `git reset` | +| `gru` | `git reset --` | +| `grhh` | `git reset --hard` | +| `gpristine` | `git reset --hard && git clean -dffx` | +| `groh` | `git reset origin/$(git_current_branch) --hard` | +| `grs` | `git restore` | +| `grss` | `git restore --source` | +| `grst` | `git restore --staged` | +| `gunwip` | `git rev-list --max-count=1 --format="%s" HEAD \| grep -q "--wip--" && git reset HEAD~1` | +| `grev` | `git revert` | +| `grm` | `git rm` | +| `grmc` | `git rm --cached` | +| `gcount` | `git shortlog --summary -n` | +| `gsh` | `git show` | +| `gsps` | `git show --pretty=short --show-signature` | +| `gstall` | `git stash --all` | +| `gstu` | `git stash --include-untracked` | +| `gstaa` | `git stash apply` | +| `gstc` | `git stash clear` | +| `gstd` | `git stash drop` | +| `gstl` | `git stash list` | +| `gstp` | `git stash pop` | +| `gsta` | On Git >= 2.13: `git stash push` | +| `gsta` | On Git < 2.13: `git stash save` | +| `gsts` | `git stash show --text` | +| `gst` | `git status` | +| `gss` | `git status --short` | +| `gsb` | `git status --short -b` | +| `gsi` | `git submodule init` | +| `gsu` | `git submodule update` | +| `gsd` | `git svn dcommit` | +| `git-svn-dcommit-push` | `git svn dcommit && git push github $(git_main_branch):svntrunk` | +| `gsr` | `git svn rebase` | +| `gsw` | `git switch` | +| `gswc` | `git switch -c` | +| `gswd` | `git switch $(git_develop_branch)` | +| `gswm` | `git switch $(git_main_branch)` | +| `gts` | `git tag -s` | +| `gtv` | `git tag \| sort -V` | +| `gignore` | `git update-index --assume-unchanged` | +| `gunignore` | `git update-index --no-assume-unchanged` | +| `gwch` | `git whatchanged -p --abbrev-commit --pretty=medium` | +| `gwt` | `git worktree` | +| `gwtls` | `git worktree list` | +| `gwtmv` | `git worktree move` | +| `gwtrm` | `git worktree remove` | +| `gk` | `gitk --all --branches &!` | +| `gke` | `gitk --all $(git log --walk-reflogs --pretty=%h) &!` | +| `gtl` | `gtl(){ git tag --sort=-v:refname -n --list ${1}\* }; noglob gtl` | ### Main branch preference @@ -221,50 +221,49 @@ branch exists. We do this via the function `git_main_branch`. These are aliases that have been removed, renamed, or otherwise modified in a way that may, or may not, receive further support. -| Alias | Command | Modification | -| :----- | :----------------------------------------------------- | :----------------------------------------------------- | -| gap | `git add --patch` | new alias `gapa` | -| gcl | `git config --list` | new alias `gcf` | -| gdc | `git diff --cached` | new alias `gdca` | -| gdt | `git difftool` | no replacement | -| ggpull | `git pull origin $(current_branch)` | new alias `ggl` (`ggpull` still exists for now though) | -| ggpur | `git pull --rebase origin $(current_branch)` | new alias `ggu` (`ggpur` still exists for now though) | -| ggpush | `git push origin $(current_branch)` | new alias `ggp` (`ggpush` still exists for now though) | -| gk | `gitk --all --branches` | now aliased to `gitk --all --branches` | -| glg | `git log --stat --max-count = 10` | now aliased to `git log --stat --color` | -| glgg | `git log --graph --max-count = 10` | now aliased to `git log --graph --color` | -| gwc | `git whatchanged -p --abbrev-commit --pretty = medium` | new alias `gwch` | +| Alias | Command | Modification | +| :------- | :----------------------------------------------------- | :-------------------------------------------------------- | +| `gap` | `git add --patch` | New alias: `gapa`. | +| `gcl` | `git config --list` | New alias: `gcf`. | +| `gdc` | `git diff --cached` | New alias: `gdca`. | +| `gdt` | `git difftool` | No replacement. | +| `ggpull` | `git pull origin $(current_branch)` | New alias: `ggl`. (`ggpull` still exists for now though.) | +| `ggpur` | `git pull --rebase origin $(current_branch)` | New alias: `ggu`. (`ggpur` still exists for now though.) | +| `ggpush` | `git push origin $(current_branch)` | New alias: `ggp`. (`ggpush` still exists for now though.) | +| `gk` | `gitk --all --branches` | Now aliased to `gitk --all --branches`. | +| `glg` | `git log --stat --max-count=10` | Now aliased to `git log --stat --color`. | +| `glgg` | `git log --graph --max-count=10` | Now aliased to `git log --graph --color`. | +| `gwc` | `git whatchanged -p --abbrev-commit --pretty = medium` | New alias: `gwch`. | ## Functions ### Current -| Command | Description | -| :--------------------- | :------------------------------------------------------------------------------------------------------- | -| current_branch | Return the name of the current branch | -| git_current_user_email | Returns the `user.email` config value (lives in lib/git.zsh) | -| git_current_user_name | Returns the `user.name` config value (lives in lib/git.zsh) | -| git_develop_branch | Returns the name of the develop branch: `dev`, `devel`, `development` if they exist, `develop` otherwise | -| git_main_branch | Returns the name of the main branch: `main` if it exists, `master` otherwise | -| grename \ \ | Rename `old` branch to `new`, including in origin remote | +| Command | Description | +| :----------------------- | :-------------------------------------------------------------------------------------------------------------- | +| `current_branch` | Returns the name of the current branch. | +| `git_current_user_email` | Returns the `user.email` config value. (Lives in `lib/git.zsh`.) | +| `git_current_user_name` | Returns the `user.name` config value. (Lives in `lib/git.zsh`.) | +| `git_develop_branch` | Returns the name of the “development” branch: `dev`, `devel`, `development` if they exist, `develop` otherwise. | +| `git_main_branch` | Returns the name of the main branch: `main` if it exists, `master` otherwise. | +| `grename ` | Renames branch `` to ``, including on the origin remote. | ### Work in Progress (WIP) -These features allow to pause a branch development and switch to another one (_"Work in Progress"_, or wip). -When you want to go back to work, just unwip it. +These features allow you to pause developing one branch and switch to another one (_"Work in Progress"_, or +“wip”). When you want to go back to work, just “unwip” it. -| Command | Description | -| :--------------- | :---------------------------------------------- | -| gwip | Commit wip branch | -| gunwip | Uncommit wip branch | -| gunwipall | Uncommit all recent `--wip--` commits | -| work_in_progress | Echoes a warning if the current branch is a wip | +| Command | Description | +| :----------------- | :---------------------------------------------- | +| `gwip` | Commit wip branch | +| `gunwip` | Uncommit wip branch | +| `gunwipall` | Uncommit all recent `--wip--` commits | +| `work_in_progress` | Echoes a warning if the current branch is a wip | -Note that `gwip` and `gunwip` are effectivly alias, but are also documented here to group all related WIP -features. +Note that `gwip` and `gunwip` are aliases, but are also documented here to group all related WIP features. ### Deprecated functions -| Command | Description | Reason | -| :----------------- | :-------------------------------------- | :-------------------------------------------------------------- | -| current_repository | Return the names of the current remotes | Didn't work properly. Use `git remote -v` instead (`grv` alias) | +| Command | Description | Reason | +| :------------------- | :-------------------------------------- | :--------------------------------------------------------------- | +| `current_repository` | Return the names of the current remotes | Didn't work properly. Use `git remote -v` instead (`grv` alias). | From aaa74964a8f5908716f5bc8658116db096467702 Mon Sep 17 00:00:00 2001 From: Adam Johnson Date: Tue, 26 Sep 2023 08:18:54 +0100 Subject: [PATCH 365/672] fix(git): remove `--text` from `gsts` (#11897) --- plugins/git/README.md | 2 +- plugins/git/git.plugin.zsh | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/plugins/git/README.md b/plugins/git/README.md index 9621a312e..390f52001 100644 --- a/plugins/git/README.md +++ b/plugins/git/README.md @@ -183,7 +183,7 @@ plugins=(... git) | `gstp` | `git stash pop` | | `gsta` | On Git >= 2.13: `git stash push` | | `gsta` | On Git < 2.13: `git stash save` | -| `gsts` | `git stash show --text` | +| `gsts` | `git stash show` | | `gst` | `git status` | | `gss` | `git status --short` | | `gsb` | `git status --short -b` | diff --git a/plugins/git/git.plugin.zsh b/plugins/git/git.plugin.zsh index 4afe34e99..426f51979 100644 --- a/plugins/git/git.plugin.zsh +++ b/plugins/git/git.plugin.zsh @@ -331,7 +331,7 @@ alias gstp='git stash pop' is-at-least 2.13 "$git_version" \ && alias gsta='git stash push' \ || alias gsta='git stash save' -alias gsts='git stash show --text' +alias gsts='git stash show' alias gst='git status' alias gss='git status --short' alias gsb='git status --short --branch' From bca62f78e23247afdc44882111a27a7333e5acb0 Mon Sep 17 00:00:00 2001 From: Adam Johnson Date: Tue, 26 Sep 2023 08:22:32 +0100 Subject: [PATCH 366/672] feat(git): add branch rename alias `gbm` (#11909) Co-authored-by: Gabriel Akinyosoye --- plugins/git/README.md | 1 + plugins/git/git.plugin.zsh | 1 + 2 files changed, 2 insertions(+) diff --git a/plugins/git/README.md b/plugins/git/README.md index 390f52001..e7c32e97f 100644 --- a/plugins/git/README.md +++ b/plugins/git/README.md @@ -44,6 +44,7 @@ plugins=(... git) | `gbda` | `git branch --no-color --merged \| command grep -vE "^([+*]\|\s*($(git_main_branch)\|$(git_develop_branch))\s*$)" \| command xargs git branch --delete 2>/dev/null` | | `gbgd` | `LANG=C git branch --no-color -vv \| grep ": gone\]" \| awk '"'"'{print $1}'"'"' \| xargs git branch -d` | | `gbgD` | `LANG=C git branch --no-color -vv \| grep ": gone\]" \| awk '"'"'{print $1}'"'"' \| xargs git branch -D` | +| `gbm` | `git branch --move` | | `gbnm` | `git branch --no-merged` | | `gbr` | `git branch --remote` | | `ggsup` | `git branch --set-upstream-to=origin/$(git_current_branch)` | diff --git a/plugins/git/git.plugin.zsh b/plugins/git/git.plugin.zsh index 426f51979..01eab682e 100644 --- a/plugins/git/git.plugin.zsh +++ b/plugins/git/git.plugin.zsh @@ -125,6 +125,7 @@ alias gbD='git branch --delete --force' alias gbda='git branch --no-color --merged | command grep -vE "^([+*]|\s*($(git_main_branch)|$(git_develop_branch))\s*$)" | command xargs git branch --delete 2>/dev/null' alias gbgd='LANG=C git branch --no-color -vv | grep ": gone\]" | awk '"'"'{print $1}'"'"' | xargs git branch -d' alias gbgD='LANG=C git branch --no-color -vv | grep ": gone\]" | awk '"'"'{print $1}'"'"' | xargs git branch -D' +alias gbm='git branch --move' alias gbnm='git branch --no-merged' alias gbr='git branch --remote' alias ggsup='git branch --set-upstream-to=origin/$(git_current_branch)' From e2b855341bfd587590734da860d75ead7788810f Mon Sep 17 00:00:00 2001 From: Adam Johnson Date: Tue, 26 Sep 2023 08:27:48 +0100 Subject: [PATCH 367/672] feat(git): add tag aliases `gt` and `gta` (#11910) Co-authored-by: hasecilu Co-authored-by: Rik Co-authored-by: Carlo Sala --- plugins/git/README.md | 2 ++ plugins/git/git.plugin.zsh | 2 ++ 2 files changed, 4 insertions(+) diff --git a/plugins/git/README.md b/plugins/git/README.md index e7c32e97f..5a732ed63 100644 --- a/plugins/git/README.md +++ b/plugins/git/README.md @@ -197,6 +197,8 @@ plugins=(... git) | `gswc` | `git switch -c` | | `gswd` | `git switch $(git_develop_branch)` | | `gswm` | `git switch $(git_main_branch)` | +| `gt` | `git tag` | +| `gta` | `git tag --annotate` | | `gts` | `git tag -s` | | `gtv` | `git tag \| sort -V` | | `gignore` | `git update-index --assume-unchanged` | diff --git a/plugins/git/git.plugin.zsh b/plugins/git/git.plugin.zsh index 01eab682e..527093c28 100644 --- a/plugins/git/git.plugin.zsh +++ b/plugins/git/git.plugin.zsh @@ -345,6 +345,8 @@ alias gsw='git switch' alias gswc='git switch --create' alias gswd='git switch $(git_develop_branch)' alias gswm='git switch $(git_main_branch)' +alias gt='git tag' +alias gta='git tag --annotate' alias gts='git tag --sign' alias gtv='git tag | sort -V' alias gignore='git update-index --assume-unchanged' From 4fb5d02db94fa87d22afea9825bd5f866e0cd1ac Mon Sep 17 00:00:00 2001 From: Adam Johnson Date: Tue, 26 Sep 2023 08:31:32 +0100 Subject: [PATCH 368/672] feat(git): add reset aliases `grhk` and `grhs` (#11896) --- plugins/git/README.md | 2 ++ plugins/git/git.plugin.zsh | 2 ++ 2 files changed, 4 insertions(+) diff --git a/plugins/git/README.md b/plugins/git/README.md index 5a732ed63..5b2db55fa 100644 --- a/plugins/git/README.md +++ b/plugins/git/README.md @@ -163,6 +163,8 @@ plugins=(... git) | `grh` | `git reset` | | `gru` | `git reset --` | | `grhh` | `git reset --hard` | +| `grhk` | `git reset --keep` | +| `grhs` | `git reset --soft` | | `gpristine` | `git reset --hard && git clean -dffx` | | `groh` | `git reset origin/$(git_current_branch) --hard` | | `grs` | `git restore` | diff --git a/plugins/git/git.plugin.zsh b/plugins/git/git.plugin.zsh index 527093c28..ba90c936e 100644 --- a/plugins/git/git.plugin.zsh +++ b/plugins/git/git.plugin.zsh @@ -310,6 +310,8 @@ alias grup='git remote update' alias grh='git reset' alias gru='git reset --' alias grhh='git reset --hard' +alias grhk='git reset --keep' +alias grhs='git reset --soft' alias gpristine='git reset --hard && git clean --force -dfx' alias groh='git reset origin/$(git_current_branch) --hard' alias grs='git restore' From 0e1e877ea9182f87b3ab34cbc2ea944b34f5345e Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Wed, 27 Sep 2023 08:19:57 +0200 Subject: [PATCH 369/672] fix(git)!: remove `gt` alias BREAKING CHANGE: `gt` alias clashes with Graphite CLI (https://graphite.dev). See https://github.com/ohmyzsh/ohmyzsh/pull/11910#issuecomment-1736340910 --- plugins/git/README.md | 1 - plugins/git/git.plugin.zsh | 1 - 2 files changed, 2 deletions(-) diff --git a/plugins/git/README.md b/plugins/git/README.md index 5b2db55fa..9c16cb6e7 100644 --- a/plugins/git/README.md +++ b/plugins/git/README.md @@ -199,7 +199,6 @@ plugins=(... git) | `gswc` | `git switch -c` | | `gswd` | `git switch $(git_develop_branch)` | | `gswm` | `git switch $(git_main_branch)` | -| `gt` | `git tag` | | `gta` | `git tag --annotate` | | `gts` | `git tag -s` | | `gtv` | `git tag \| sort -V` | diff --git a/plugins/git/git.plugin.zsh b/plugins/git/git.plugin.zsh index ba90c936e..cb848b407 100644 --- a/plugins/git/git.plugin.zsh +++ b/plugins/git/git.plugin.zsh @@ -347,7 +347,6 @@ alias gsw='git switch' alias gswc='git switch --create' alias gswd='git switch $(git_develop_branch)' alias gswm='git switch $(git_main_branch)' -alias gt='git tag' alias gta='git tag --annotate' alias gts='git tag --sign' alias gtv='git tag | sort -V' From d3b6f1fd5e42deafb3a6458213762a492e484073 Mon Sep 17 00:00:00 2001 From: Piotr Minkina Date: Thu, 28 Sep 2023 23:43:06 +0200 Subject: [PATCH 370/672] fix(gradle): remove look for settings.gradle files (#11917) --- plugins/gradle/gradle.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/gradle/gradle.plugin.zsh b/plugins/gradle/gradle.plugin.zsh index 5bca364d1..dacc46478 100644 --- a/plugins/gradle/gradle.plugin.zsh +++ b/plugins/gradle/gradle.plugin.zsh @@ -6,7 +6,7 @@ function gradle-or-gradlew() { # taken from https://github.com/gradle/gradle-completion local dir="$PWD" project_root="$PWD" while [[ "$dir" != / ]]; do - if [[ -f "$dir/settings.gradle" || -f "$dir/settings.gradle.kts" || -f "$dir/gradlew" ]]; then + if [[ -x "$dir/gradlew" ]]; then project_root="$dir" break fi From 27402e2603b9354f419af3695bad8ff17ed33bac Mon Sep 17 00:00:00 2001 From: Jake Conway Date: Fri, 29 Sep 2023 05:24:40 -0500 Subject: [PATCH 371/672] docs(gas): update plugin url (#11918) --- plugins/gas/README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/gas/README.md b/plugins/gas/README.md index 47b3fb9df..a0a7a568f 100644 --- a/plugins/gas/README.md +++ b/plugins/gas/README.md @@ -1,6 +1,6 @@ # Gas plugin -This plugin adds autocompletion for the [gas](http://walle.github.com/gas) command, +This plugin adds autocompletion for the [gas](http://ramblingsby.me/gas/) command, a utility to manage Git authors. To use it, add `gas` to the plugins array of your zshrc file: From 278bcfc93bed91d1095a9ea7981c4a1109da7abd Mon Sep 17 00:00:00 2001 From: Thomas Faugier Date: Mon, 2 Oct 2023 20:25:17 +0200 Subject: [PATCH 372/672] feat(asdf): load zsh completions instead of bash ones Closes #11143 Closes #8779 Co-authored-by: Carlo Sala --- plugins/asdf/asdf.plugin.zsh | 35 +++++++++++++++++++---------------- 1 file 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 From fea4584cebf98fc58334b7cca841ab1ef224a35e Mon Sep 17 00:00:00 2001 From: HeroCC Date: Mon, 2 Oct 2023 14:34:57 -0400 Subject: [PATCH 373/672] fix(tmux): don't autostart inside background intelliJ (#11927) --- plugins/tmux/tmux.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/tmux/tmux.plugin.zsh b/plugins/tmux/tmux.plugin.zsh index 680f72598..6ed91c447 100644 --- a/plugins/tmux/tmux.plugin.zsh +++ b/plugins/tmux/tmux.plugin.zsh @@ -109,7 +109,7 @@ compdef _tmux _zsh_tmux_plugin_run alias tmux=_zsh_tmux_plugin_run # Autostart if not already in tmux and enabled. -if [[ -z "$TMUX" && "$ZSH_TMUX_AUTOSTART" == "true" && -z "$INSIDE_EMACS" && -z "$EMACS" && -z "$VIM" ]]; then +if [[ -z "$TMUX" && "$ZSH_TMUX_AUTOSTART" == "true" && -z "$INSIDE_EMACS" && -z "$EMACS" && -z "$VIM" && -z "$INTELLIJ_ENVIRONMENT_READER" ]]; then # Actually don't autostart if we already did and multiple autostarts are disabled. if [[ "$ZSH_TMUX_AUTOSTART_ONCE" == "false" || "$ZSH_TMUX_AUTOSTARTED" != "true" ]]; then export ZSH_TMUX_AUTOSTARTED=true From df80a2da5475fc3c068bc5f700fa176a47f7adbe Mon Sep 17 00:00:00 2001 From: bretello Date: Mon, 2 Oct 2023 20:41:01 +0200 Subject: [PATCH 374/672] feat(vi-mode): copy to clipboard when using `vi-change*` and `vi-yank*` widgets (#11861) --- plugins/vi-mode/README.md | 6 ++++++ plugins/vi-mode/vi-mode.plugin.zsh | 11 +++++++++-- 2 files changed, 15 insertions(+), 2 deletions(-) diff --git a/plugins/vi-mode/README.md b/plugins/vi-mode/README.md index 0cb516751..821c12adb 100644 --- a/plugins/vi-mode/README.md +++ b/plugins/vi-mode/README.md @@ -144,11 +144,17 @@ NOTE: this used to be bound to `v`. That is now the default (`visual-mode`). - `c{motion}` : Delete {motion} text and start insert - `cc` : Delete line and start insert - `C` : Delete to the end of the line and start insert +- `P` : Insert the contents of the clipboard before the cursor +- `p` : Insert the contents of the clipboard after the cursor - `r{char}` : Replace the character under the cursor with {char} - `R` : Enter replace mode: Each character replaces existing one - `x` : Delete `count` characters under and after the cursor - `X` : Delete `count` characters before the cursor +NOTE: delete/kill commands (`dd`, `D`, `c{motion}`, `C`, `x`,`X`) and yank commands +(`y`, `Y`) will copy to the clipboard. Contents can then be put back using paste commands +(`P`, `p`). + ## Known issues ### Low `$KEYTIMEOUT` diff --git a/plugins/vi-mode/vi-mode.plugin.zsh b/plugins/vi-mode/vi-mode.plugin.zsh index cc9817a74..d1493e02f 100644 --- a/plugins/vi-mode/vi-mode.plugin.zsh +++ b/plugins/vi-mode/vi-mode.plugin.zsh @@ -147,8 +147,15 @@ function wrap_clipboard_widgets() { done } -wrap_clipboard_widgets copy vi-yank vi-yank-eol vi-backward-kill-word vi-change-whole-line vi-delete vi-delete-char -wrap_clipboard_widgets paste vi-put-{before,after} +wrap_clipboard_widgets copy \ + vi-yank vi-yank-eol vi-yank-whole-line \ + vi-change vi-change-eol vi-change-whole-line \ + vi-kill-line vi-kill-eol vi-backward-kill-word \ + vi-delete vi-delete-char vi-backward-delete-char + +wrap_clipboard_widgets paste \ + vi-put-{before,after} + unfunction wrap_clipboard_widgets # if mode indicator wasn't setup by theme, define default, we'll leave INSERT_MODE_INDICATOR empty by default From 7400d469b67e2e72a6405df39c5f28cba646e1a8 Mon Sep 17 00:00:00 2001 From: jack Date: Tue, 3 Oct 2023 02:41:18 +0800 Subject: [PATCH 375/672] fix(ruby): add missing `-run` in `rserver` alias (#11913) --- plugins/ruby/ruby.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/ruby/ruby.plugin.zsh b/plugins/ruby/ruby.plugin.zsh index 408512110..e09b22c75 100644 --- a/plugins/ruby/ruby.plugin.zsh +++ b/plugins/ruby/ruby.plugin.zsh @@ -23,4 +23,4 @@ alias gel="gem lock" alias geo="gem open" alias geoe="gem open -e" alias rrun="ruby -e" -alias rserver="ruby -e httpd . -p 8080" # requires webrick +alias rserver="ruby -run -e httpd . -p 8080" # requires webrick From f36c6db0eac17b022eee87411e6996a5f5fc8457 Mon Sep 17 00:00:00 2001 From: Abhinav Date: Tue, 3 Oct 2023 00:28:42 +0530 Subject: [PATCH 376/672] feat(shell-proxy): allow excluding endpoints with `NO_PROXY` (#11924) --- plugins/shell-proxy/README.md | 5 +++++ plugins/shell-proxy/proxy.py | 23 +++++++++++++++++----- plugins/shell-proxy/shell-proxy.plugin.zsh | 2 +- 3 files changed, 24 insertions(+), 6 deletions(-) diff --git a/plugins/shell-proxy/README.md b/plugins/shell-proxy/README.md index b19888c56..102e46b6b 100644 --- a/plugins/shell-proxy/README.md +++ b/plugins/shell-proxy/README.md @@ -23,6 +23,7 @@ Set `SHELLPROXY_URL` environment variable to the URL of the proxy server: ```sh SHELLPROXY_URL="http://127.0.0.1:8123" +SHELLPROXY_NO_PROXY="localhost,127.0.0.1" proxy enable ``` @@ -36,11 +37,15 @@ Example: ```sh #!/bin/bash +# HTTP Proxy if [[ "$(uname)" = Darwin ]]; then echo "http://127.0.0.1:6152" # Surge Mac else echo "http://127.0.0.1:8123" # polipo fi + +# No Proxy +echo "localhost,127.0.0.1" ``` ### Method 3 diff --git a/plugins/shell-proxy/proxy.py b/plugins/shell-proxy/proxy.py index 14f2944cc..8c2aaf9f3 100755 --- a/plugins/shell-proxy/proxy.py +++ b/plugins/shell-proxy/proxy.py @@ -6,6 +6,7 @@ from subprocess import check_output, list2cmdline cwd = os.path.dirname(__file__) ssh_agent = os.path.join(cwd, "ssh-agent.py") proxy_env = "SHELLPROXY_URL" +no_proxy_env = "SHELLPROXY_NO_PROXY" proxy_config = os.environ.get("SHELLPROXY_CONFIG") or os.path.expandvars("$HOME/.config/proxy") usage="""shell-proxy: no proxy configuration found. @@ -15,18 +16,30 @@ See the plugin README for more information.""".format(env=proxy_env, config=prox def get_http_proxy(): default_proxy = os.environ.get(proxy_env) - if default_proxy: - return default_proxy + no_proxy = os.environ.get(no_proxy_env) + if default_proxy and no_proxy: + return default_proxy, no_proxy + if os.path.isfile(proxy_config): - return check_output(proxy_config).decode("utf-8").strip() + proxy_configdata = [line.strip() for line in check_output(proxy_config).decode("utf-8").splitlines()] + if len(proxy_configdata) >= 1: + if not default_proxy: + default_proxy = proxy_configdata[0] + if len(proxy_configdata) == 2 and not no_proxy: + no_proxy = proxy_configdata[1] + + if default_proxy: + return default_proxy, no_proxy print(usage, file=sys.stderr) sys.exit(1) -def make_proxies(url: str): +def make_proxies(url: str, no_proxy: str): proxies = {"%s_PROXY" % _: url for _ in ("HTTP", "HTTPS", "FTP", "RSYNC", "ALL")} proxies.update({name.lower(): value for (name, value) in proxies.items()}) proxies["GIT_SSH"] = ssh_agent + if no_proxy: + proxies.update({"NO_PROXY": no_proxy, "no_proxy": no_proxy}) return proxies @@ -35,7 +48,7 @@ def merge(mapping: dict): class CommandSet: - proxies = make_proxies(get_http_proxy()) + proxies = make_proxies(*get_http_proxy()) aliases = { _: "env __SSH_PROGRAM_NAME__=%s %s" % (_, ssh_agent) for _ in ("ssh", "sftp", "scp", "slogin", "ssh-copy-id") diff --git a/plugins/shell-proxy/shell-proxy.plugin.zsh b/plugins/shell-proxy/shell-proxy.plugin.zsh index 4fdbe9322..f6c31da45 100644 --- a/plugins/shell-proxy/shell-proxy.plugin.zsh +++ b/plugins/shell-proxy/shell-proxy.plugin.zsh @@ -27,7 +27,7 @@ eval ' # capture the output of the proxy script and bail out if it fails local output - output="$(SHELLPROXY_URL="$SHELLPROXY_URL" SHELLPROXY_CONFIG="$SHELLPROXY_CONFIG" "$proxy" "$1")" || + output="$(SHELLPROXY_URL="$SHELLPROXY_URL" SHELLPROXY_NO_PROXY="$SHELLPROXY_NO_PROXY" SHELLPROXY_CONFIG="$SHELLPROXY_CONFIG" "$proxy" "$1")" || return $? # evaluate the output generated by the proxy script From 974055f638dac907cfb10281bce9cf998641febd Mon Sep 17 00:00:00 2001 From: Robby Russell Date: Sun, 8 Oct 2023 13:47:16 +0200 Subject: [PATCH 377/672] Adding Mastadon and updating X badge --- README.md | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/README.md b/README.md index a30595581..d915bd720 100644 --- a/README.md +++ b/README.md @@ -13,7 +13,8 @@ Finally, you'll begin to get the sort of attention that you have always felt you To learn more, visit [ohmyz.sh](https://ohmyz.sh), follow [@ohmyzsh](https://twitter.com/ohmyzsh) on Twitter, and join us on [Discord](https://discord.gg/ohmyzsh). [![CI](https://github.com/ohmyzsh/ohmyzsh/workflows/CI/badge.svg)](https://github.com/ohmyzsh/ohmyzsh/actions?query=workflow%3ACI) -[![Follow @ohmyzsh](https://img.shields.io/twitter/follow/ohmyzsh?label=Follow+@ohmyzsh&style=flat)](https://twitter.com/intent/follow?screen_name=ohmyzsh) +![X (formerly Twitter) Follow](https://img.shields.io/twitter/follow/ohmyzsh?style=flat) +![Mastodon Follow](https://img.shields.io/mastodon/follow/111169632522566717?domain=https%3A%2F%2Fmstdn.social&style=flat) [![Discord server](https://img.shields.io/discord/642496866407284746)](https://discord.gg/ohmyzsh) [![Gitpod ready](https://img.shields.io/badge/Gitpod-ready-blue?logo=gitpod)](https://gitpod.io/#https://github.com/ohmyzsh/ohmyzsh) [![huntr.dev](https://cdn.huntr.dev/huntr_security_badge_mono.svg)](https://huntr.dev/bounties/disclose/?utm_campaign=ohmyzsh%2Fohmyzsh&utm_medium=social&utm_source=github&target=https%3A%2F%2Fgithub.com%2Fohmyzsh%2Fohmyzsh) From ee857e3acf4beba9e3121bc8e776a048c46fa85f Mon Sep 17 00:00:00 2001 From: Robby Russell Date: Sun, 8 Oct 2023 14:05:03 +0200 Subject: [PATCH 378/672] Adding operating system compatibility chart --- README.md | 14 +++++++++++++- 1 file changed, 13 insertions(+), 1 deletion(-) diff --git a/README.md b/README.md index d915bd720..70c4faaf0 100644 --- a/README.md +++ b/README.md @@ -59,9 +59,21 @@ To learn more, visit [ohmyz.sh](https://ohmyz.sh), follow [@ohmyzsh](https://twi ## Getting Started +### Operating System Compatibility + +| O/S | Status | +| :---------------- | :------: | +| Android | ✅ | +| FreeBSD | ✅ | +| LCARS | 🛸 | +| Linux | ✅ | +| MacOS | ✅ | +| OS/2 Warp | ❌ | +| Windows (WSL2) | ✅ | + + ### Prerequisites -- A Unix-like operating system: macOS, Linux, BSD. On Windows: WSL2 is preferred, but cygwin or msys also mostly work. - [Zsh](https://www.zsh.org) should be installed (v4.3.9 or more recent is fine but we prefer 5.0.8 and newer). If not pre-installed (run `zsh --version` to confirm), check the following wiki instructions here: [Installing ZSH](https://github.com/ohmyzsh/ohmyzsh/wiki/Installing-ZSH) - `curl` or `wget` should be installed - `git` should be installed (recommended v2.4.11 or higher) From 7105e37ef09ff890f7eca3e64d48b8b7ff94a494 Mon Sep 17 00:00:00 2001 From: DemonKiller <55846983+demonkillerr@users.noreply.github.com> Date: Sun, 8 Oct 2023 14:27:55 +0100 Subject: [PATCH 379/672] feat(rtx) Added new polyglot runtime manager (asdf rust clone) (#11932) * add readme.md for rtx * add rtx plugin * update install info * remove redundant slashes --- plugins/rtx/README.md | 30 ++++++++++++++++++++++++++++++ plugins/rtx/rtx.plugin.zsh | 30 ++++++++++++++++++++++++++++++ 2 files changed, 60 insertions(+) create mode 100644 plugins/rtx/README.md create mode 100644 plugins/rtx/rtx.plugin.zsh diff --git a/plugins/rtx/README.md b/plugins/rtx/README.md new file mode 100644 index 000000000..c6436d3a7 --- /dev/null +++ b/plugins/rtx/README.md @@ -0,0 +1,30 @@ +## rtx + + +Adds integration with [rtx](https://github.com/jdx/rtx), a runtime executor compatible with npm, nodenv, pyenv, etc. rtx is written in rust and is very fast. 20x-200x faster than asdf. With that being said, rtx is compatible with asdf plugins and .tool-versions files. It can be used as a drop-in replacement. + +### Installation + +1. [Download & install rtx](https://github.com/jdx/rtx#installation) by running the following: + + ``` + curl https://rtx.pub/install.sh | sh + ``` + + +2. [Enable rtx](https://github.com/jdx/rtx#quickstart) by adding it to your `plugins` definition in `~/.zshrc`. + + ``` + plugins=(rtx) + ``` + +### Usage + +See the [rtx readme](https://github.com/jdx/rtx#table-of-contents) for information on how to use rtx. Here are a few examples: + +``` +rtx install node Install the current version specified in .tool-versions/.rtx.toml +rtx use -g node@system Use system node as global default +rtx install node@20.0.0 Install a specific version number +rtx use -g node@20 Use node-20.x as global default +``` diff --git a/plugins/rtx/rtx.plugin.zsh b/plugins/rtx/rtx.plugin.zsh new file mode 100644 index 000000000..aaccaf015 --- /dev/null +++ b/plugins/rtx/rtx.plugin.zsh @@ -0,0 +1,30 @@ +# Find where rtx should be installed +RTX_DIR="${RTX_DIR:-$HOME/.rtx}" +RTX_COMPLETIONS="$RTX_DIR/completions" + +if [[ ! -f "$RTX_DIR/rtx.sh" || ! -f "$RTX_COMPLETIONS/_rtx" ]]; then + # If not found, check for archlinux/AUR package (/opt/rtx-vm/) + if [[ -f "/opt/rtx-vm/rtx.sh" ]]; then + RTX_DIR="/opt/rtx-vm" + RTX_COMPLETIONS="$RTX_DIR" + # If not found, check for Homebrew package + elif (( $+commands[brew] )); then + _RTX_PREFIX="$(brew --prefix rtx)" + RTX_DIR="${_RTX_PREFIX}/libexec" + RTX_COMPLETIONS="${_RTX_PREFIX}/share/zsh/site-functions" + unset _RTX_PREFIX + else + return + fi +fi + +# Load command +if [[ -f "$RTX_DIR/rtx.sh" ]]; then + source "$RTX_DIR/rtx.sh" + # Load completions + if [[ -f "$RTX_COMPLETIONS/_rtx" ]]; then + fpath+=("$RTX_COMPLETIONS") + autoload -Uz _rtx + compdef _rtx rtx # compdef is already loaded before loading plugins + fi +fi From b75b01a3092e59cd10ff01084d4a5e3ac0be3e3a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Sun, 8 Oct 2023 20:01:46 +0200 Subject: [PATCH 380/672] chore: update README badges --- README.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/README.md b/README.md index 70c4faaf0..c83e16218 100644 --- a/README.md +++ b/README.md @@ -13,8 +13,8 @@ Finally, you'll begin to get the sort of attention that you have always felt you To learn more, visit [ohmyz.sh](https://ohmyz.sh), follow [@ohmyzsh](https://twitter.com/ohmyzsh) on Twitter, and join us on [Discord](https://discord.gg/ohmyzsh). [![CI](https://github.com/ohmyzsh/ohmyzsh/workflows/CI/badge.svg)](https://github.com/ohmyzsh/ohmyzsh/actions?query=workflow%3ACI) -![X (formerly Twitter) Follow](https://img.shields.io/twitter/follow/ohmyzsh?style=flat) -![Mastodon Follow](https://img.shields.io/mastodon/follow/111169632522566717?domain=https%3A%2F%2Fmstdn.social&style=flat) +[![X (formerly Twitter) Follow](https://img.shields.io/twitter/follow/ohmyzsh?label=%40ohmyzsh&logo=x&style=flat)](https://twitter.com/intent/follow?screen_name=ohmyzsh) +[![Mastodon Follow](https://img.shields.io/mastodon/follow/111169632522566717?label=%40ohmyzsh&domain=https%3A%2F%2Fmstdn.social&logo=mastodon&style=flat)](https://mstdn.social/@ohmyzsh) [![Discord server](https://img.shields.io/discord/642496866407284746)](https://discord.gg/ohmyzsh) [![Gitpod ready](https://img.shields.io/badge/Gitpod-ready-blue?logo=gitpod)](https://gitpod.io/#https://github.com/ohmyzsh/ohmyzsh) [![huntr.dev](https://cdn.huntr.dev/huntr_security_badge_mono.svg)](https://huntr.dev/bounties/disclose/?utm_campaign=ohmyzsh%2Fohmyzsh&utm_medium=social&utm_source=github&target=https%3A%2F%2Fgithub.com%2Fohmyzsh%2Fohmyzsh) From 30a8a5d3e2f36e395c439c3346ef96e40e7bd277 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Mon, 9 Oct 2023 17:53:00 +0200 Subject: [PATCH 381/672] fix(rtx): fix `rtx` init procedure (#11949) --- plugins/rtx/rtx.plugin.zsh | 42 ++++++++++++++------------------------ 1 file changed, 15 insertions(+), 27 deletions(-) diff --git a/plugins/rtx/rtx.plugin.zsh b/plugins/rtx/rtx.plugin.zsh index aaccaf015..a01828afd 100644 --- a/plugins/rtx/rtx.plugin.zsh +++ b/plugins/rtx/rtx.plugin.zsh @@ -1,30 +1,18 @@ -# Find where rtx should be installed -RTX_DIR="${RTX_DIR:-$HOME/.rtx}" -RTX_COMPLETIONS="$RTX_DIR/completions" - -if [[ ! -f "$RTX_DIR/rtx.sh" || ! -f "$RTX_COMPLETIONS/_rtx" ]]; then - # If not found, check for archlinux/AUR package (/opt/rtx-vm/) - if [[ -f "/opt/rtx-vm/rtx.sh" ]]; then - RTX_DIR="/opt/rtx-vm" - RTX_COMPLETIONS="$RTX_DIR" - # If not found, check for Homebrew package - elif (( $+commands[brew] )); then - _RTX_PREFIX="$(brew --prefix rtx)" - RTX_DIR="${_RTX_PREFIX}/libexec" - RTX_COMPLETIONS="${_RTX_PREFIX}/share/zsh/site-functions" - unset _RTX_PREFIX - else - return - fi +# rtx needs to be in $PATH +if (( ! ${+commands[rtx]} )); then + return fi -# Load command -if [[ -f "$RTX_DIR/rtx.sh" ]]; then - source "$RTX_DIR/rtx.sh" - # Load completions - if [[ -f "$RTX_COMPLETIONS/_rtx" ]]; then - fpath+=("$RTX_COMPLETIONS") - autoload -Uz _rtx - compdef _rtx rtx # compdef is already loaded before loading plugins - fi +# Load rtx hooks +eval "$(rtx activate zsh)" + +# If the completion file doesn't exist yet, we need to autoload it and +# bind it to `rtx`. Otherwise, compinit will have already done that. +if [[ ! -f "$ZSH_CACHE_DIR/completions/_rtx" ]]; then + typeset -g -A _comps + autoload -Uz _rtx + _comps[rtx]=_rtx fi + +# Generate and load rtx completion +rtx completion zsh >! "$ZSH_CACHE_DIR/completions/_rtx" &| From 29b99c2c7b16f22f3ca2bdf9478ba700ac6c48b5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Mon, 9 Oct 2023 18:00:17 +0200 Subject: [PATCH 382/672] feat(updater): add `background-alpha` update mode (preview) (#11928) NOTE: this feature is in alpha / preview mode, it is not guaranteed to work 100% of the time in all cases. If you experience any issues, open an issue or search for an open one describing your same situation. To use this, use the zstyle update mode settings [1] with the value `background-alpha`: zstyle ':omz:update' mode background-alpha [1] https://github.com/ohmyzsh/ohmyzsh#getting-updates --- tools/check_for_upgrade.sh | 228 +++++++++++++++++++++++++------------ 1 file changed, 155 insertions(+), 73 deletions(-) diff --git a/tools/check_for_upgrade.sh b/tools/check_for_upgrade.sh index 3210e4375..1cc193bde 100644 --- a/tools/check_for_upgrade.sh +++ b/tools/check_for_upgrade.sh @@ -9,6 +9,7 @@ fi # - prompt (default): the user is asked before updating when it's time to update # - auto: the update is performed automatically when it's time # - reminder: a reminder is shown to the user when it's time to update +# - background-alpha: an experimental update-on-the-background option # - disabled: automatic update is turned off zstyle -s ':omz:update' mode update_mode || { update_mode=prompt @@ -91,13 +92,37 @@ function is_update_available() { } function update_last_updated_file() { - echo "LAST_EPOCH=$(current_epoch)" >! "${ZSH_CACHE_DIR}/.zsh-update" + local exit_status="$1" error="$2" + + if [[ -z "${1}${2}" ]]; then + echo "LAST_EPOCH=$(current_epoch)" >! "${ZSH_CACHE_DIR}/.zsh-update" + return + fi + + cat >! "${ZSH_CACHE_DIR}/.zsh-update" <&1); then + update_last_updated_file 0 "Update successful" + else + exit_status=$? + update_last_updated_file $exit_status "$error" + return $exit_status fi } @@ -126,88 +151,145 @@ function has_typed_input() { } } -() { - emulate -L zsh +function handle_update() { + () { + emulate -L zsh - local epoch_target mtime option LAST_EPOCH + local epoch_target mtime option LAST_EPOCH - # Remove lock directory if older than a day - zmodload zsh/datetime - zmodload -F zsh/stat b:zstat - if mtime=$(zstat +mtime "$ZSH/log/update.lock" 2>/dev/null); then - if (( (mtime + 3600 * 24) < EPOCHSECONDS )); then - command rm -rf "$ZSH/log/update.lock" + # Remove lock directory if older than a day + zmodload zsh/datetime + zmodload -F zsh/stat b:zstat + if mtime=$(zstat +mtime "$ZSH/log/update.lock" 2>/dev/null); then + if (( (mtime + 3600 * 24) < EPOCHSECONDS )); then + command rm -rf "$ZSH/log/update.lock" + fi fi - fi - # Check for lock directory - if ! command mkdir "$ZSH/log/update.lock" 2>/dev/null; then - return - fi + # Check for lock directory + if ! command mkdir "$ZSH/log/update.lock" 2>/dev/null; then + return + fi - # Remove lock directory on exit. `return $ret` is important for when trapping a SIGINT: - # The return status from the function is handled specially. If it is zero, the signal is - # assumed to have been handled, and execution continues normally. Otherwise, the shell - # will behave as interrupted except that the return status of the trap is retained. - # This means that for a CTRL+C, the trap needs to return the same exit status so that - # the shell actually exits what it's running. - trap " - ret=\$? - unset update_mode - unset -f current_epoch is_update_available update_last_updated_file update_ohmyzsh 2>/dev/null - command rm -rf '$ZSH/log/update.lock' - return \$ret - " EXIT INT QUIT + # Remove lock directory on exit. `return $ret` is important for when trapping a SIGINT: + # The return status from the function is handled specially. If it is zero, the signal is + # assumed to have been handled, and execution continues normally. Otherwise, the shell + # will behave as interrupted except that the return status of the trap is retained. + # This means that for a CTRL+C, the trap needs to return the same exit status so that + # the shell actually exits what it's running. + trap " + ret=\$? + unset update_mode + unset -f current_epoch is_update_available update_last_updated_file update_ohmyzsh handle_update 2>/dev/null + command rm -rf '$ZSH/log/update.lock' + return \$ret + " EXIT INT QUIT - # Create or update .zsh-update file if missing or malformed - if ! source "${ZSH_CACHE_DIR}/.zsh-update" 2>/dev/null || [[ -z "$LAST_EPOCH" ]]; then - update_last_updated_file - return - fi + # Create or update .zsh-update file if missing or malformed + if ! source "${ZSH_CACHE_DIR}/.zsh-update" 2>/dev/null || [[ -z "$LAST_EPOCH" ]]; then + update_last_updated_file + return + fi - # Number of days before trying to update again - zstyle -s ':omz:update' frequency epoch_target || epoch_target=${UPDATE_ZSH_DAYS:-13} - # Test if enough time has passed until the next update - if (( ( $(current_epoch) - $LAST_EPOCH ) < $epoch_target )); then - return - fi + # Number of days before trying to update again + zstyle -s ':omz:update' frequency epoch_target || epoch_target=${UPDATE_ZSH_DAYS:-13} + # Test if enough time has passed until the next update + if (( ( $(current_epoch) - $LAST_EPOCH ) < $epoch_target )); then + return + fi - # Test if Oh My Zsh directory is a git repository - if ! (builtin cd -q "$ZSH" && LANG= git rev-parse &>/dev/null); then - echo >&2 "[oh-my-zsh] Can't update: not a git repository." - return - fi + # Test if Oh My Zsh directory is a git repository + if ! (builtin cd -q "$ZSH" && LANG= git rev-parse &>/dev/null); then + echo >&2 "[oh-my-zsh] Can't update: not a git repository." + return + fi - # Check if there are updates available before proceeding - if ! is_update_available; then - update_last_updated_file - return - fi + # Check if there are updates available before proceeding + if ! is_update_available; then + update_last_updated_file + return + fi - # If in reminder mode or user has typed input, show reminder and exit - if [[ "$update_mode" = reminder ]] || has_typed_input; then - printf '\r\e[0K' # move cursor to first column and clear whole line - echo "[oh-my-zsh] It's time to update! You can do that by running \`omz update\`" - return 0 - fi + # If in reminder mode or user has typed input, show reminder and exit + if [[ "$update_mode" = reminder ]] || { [[ "$update_mode" != background-alpha ]] && has_typed_input }; then + printf '\r\e[0K' # move cursor to first column and clear whole line + echo "[oh-my-zsh] It's time to update! You can do that by running \`omz update\`" + return 0 + fi - # Don't ask for confirmation before updating if in auto mode - if [[ "$update_mode" = auto ]]; then - update_ohmyzsh - return $? - fi + # Don't ask for confirmation before updating if in auto mode + if [[ "$update_mode" = (auto|background-alpha) ]]; then + update_ohmyzsh + return $? + fi - # Ask for confirmation and only update on 'y', 'Y' or Enter - # Otherwise just show a reminder for how to update - echo -n "[oh-my-zsh] Would you like to update? [Y/n] " - read -r -k 1 option - [[ "$option" = $'\n' ]] || echo - case "$option" in - [yY$'\n']) update_ohmyzsh ;; - [nN]) update_last_updated_file ;& - *) echo "[oh-my-zsh] You can update manually by running \`omz update\`" ;; - esac + # Ask for confirmation and only update on 'y', 'Y' or Enter + # Otherwise just show a reminder for how to update + echo -n "[oh-my-zsh] Would you like to update? [Y/n] " + read -r -k 1 option + [[ "$option" = $'\n' ]] || echo + case "$option" in + [yY$'\n']) update_ohmyzsh ;; + [nN]) update_last_updated_file ;& + *) echo "[oh-my-zsh] You can update manually by running \`omz update\`" ;; + esac + } + + unset update_mode + unset -f current_epoch is_update_available update_last_updated_file update_ohmyzsh handle_update } -unset update_mode -unset -f current_epoch is_update_available update_last_updated_file update_ohmyzsh +case "$update_mode" in + background-alpha) + autoload -Uz add-zsh-hook + + _omz_bg_update() { + # do the update in a subshell + (handle_update) &| + + # register update results function + add-zsh-hook precmd _omz_bg_update_status + + # deregister background function + add-zsh-hook -d precmd _omz_bg_update + unset -f _omz_bg_update + } + + _omz_bg_update_status() { + { + local LAST_EPOCH EXIT_STATUS ERROR + if [[ ! -f "$ZSH_CACHE_DIR"/.zsh-update ]]; then + return 1 + fi + + # check update results until timeout is reached + . "$ZSH_CACHE_DIR/.zsh-update" + if [[ -z "$EXIT_STATUS" || -z "$ERROR" ]]; then + return 1 + fi + + if [[ "$EXIT_STATUS" -eq 0 ]]; then + print -P "\n%F{green}[oh-my-zsh] Update successful.%f" + return 0 + elif [[ "$EXIT_STATUS" -ne 0 ]]; then + print -P "\n%F{red}[oh-my-zsh] There was an error updating:%f" + printf "\n${fg[yellow]}%s${reset_color}" "$ERROR" + return 0 + fi + } always { + if (( TRY_BLOCK_ERROR == 0 )); then + # if last update results have been handled, remove them from the status file + update_last_updated_file + + # deregister background function + add-zsh-hook -d precmd _omz_bg_update_status + unset -f _omz_bg_update_status + fi + } + } + + add-zsh-hook precmd _omz_bg_update + ;; + *) + handle_update ;; +esac From 24b2600558f999dd53f0d354ad61fc07cf7d6e2b Mon Sep 17 00:00:00 2001 From: tobi1805 <66414944+tobi1805@users.noreply.github.com> Date: Mon, 9 Oct 2023 18:07:51 +0200 Subject: [PATCH 383/672] feat(git): delete squash-merged branches in `gbda` (#11948) --- plugins/git/README.md | 2 +- plugins/git/git.plugin.zsh | 17 ++++++++++++++++- 2 files changed, 17 insertions(+), 2 deletions(-) diff --git a/plugins/git/README.md b/plugins/git/README.md index 9c16cb6e7..33c10ffd0 100644 --- a/plugins/git/README.md +++ b/plugins/git/README.md @@ -41,7 +41,6 @@ plugins=(... git) | `gba` | `git branch --all` | | `gbd` | `git branch --delete` | | `gbD` | `git branch --delete --force` | -| `gbda` | `git branch --no-color --merged \| command grep -vE "^([+*]\|\s*($(git_main_branch)\|$(git_develop_branch))\s*$)" \| command xargs git branch --delete 2>/dev/null` | | `gbgd` | `LANG=C git branch --no-color -vv \| grep ": gone\]" \| awk '"'"'{print $1}'"'"' \| xargs git branch -d` | | `gbgD` | `LANG=C git branch --no-color -vv \| grep ": gone\]" \| awk '"'"'{print $1}'"'"' \| xargs git branch -D` | | `gbm` | `git branch --move` | @@ -251,6 +250,7 @@ receive further support. | `git_develop_branch` | Returns the name of the “development” branch: `dev`, `devel`, `development` if they exist, `develop` otherwise. | | `git_main_branch` | Returns the name of the main branch: `main` if it exists, `master` otherwise. | | `grename ` | Renames branch `` to ``, including on the origin remote. | +| `gbda` | Deletes all merged and squash-merged branches | ### Work in Progress (WIP) diff --git a/plugins/git/git.plugin.zsh b/plugins/git/git.plugin.zsh index cb848b407..ceb2011f9 100644 --- a/plugins/git/git.plugin.zsh +++ b/plugins/git/git.plugin.zsh @@ -122,7 +122,22 @@ alias gb='git branch' alias gba='git branch --all' alias gbd='git branch --delete' alias gbD='git branch --delete --force' -alias gbda='git branch --no-color --merged | command grep -vE "^([+*]|\s*($(git_main_branch)|$(git_develop_branch))\s*$)" | command xargs git branch --delete 2>/dev/null' + +# Copied and modified from James Roeder (jmaroeder) under MIT License +# https://github.com/jmaroeder/plugin-git/blob/216723ef4f9e8dde399661c39c80bdf73f4076c4/functions/gbda.fish +function gbda() { + git branch --no-color --merged | command grep -vE "^([+*]|\s*($(git_main_branch)|$(git_develop_branch))\s*$)" | command xargs git branch --delete 2>/dev/null + + local default_branch=$(git_main_branch) + git for-each-ref refs/heads/ "--format=%(refname:short)" | \ + while read branch; do + local merge_base=$(git merge-base $default_branch $branch) + if [[ '-*' == $(git cherry $default_branch $(git commit-tree $(git rev-parse $branch\^{tree}) -p $merge_base -m _)) ]]; then + git branch -D $branch + fi + done +} + alias gbgd='LANG=C git branch --no-color -vv | grep ": gone\]" | awk '"'"'{print $1}'"'"' | xargs git branch -d' alias gbgD='LANG=C git branch --no-color -vv | grep ": gone\]" | awk '"'"'{print $1}'"'"' | xargs git branch -D' alias gbm='git branch --move' From 38db3e16ef3266800e1a9516c0615ff04ec97cb6 Mon Sep 17 00:00:00 2001 From: Adam Henley <71472057+ajh-sr@users.noreply.github.com> Date: Tue, 10 Oct 2023 07:28:09 +1300 Subject: [PATCH 384/672] feat(kind): add plugin for Kind k8s tool (#9827) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Co-authored-by: jxlwqq Co-authored-by: Francesco Ilario Co-authored-by: Marc Cornellà --- plugins/kind/README.md | 22 ++++++++++++++++++++++ plugins/kind/kind.plugin.zsh | 23 +++++++++++++++++++++++ 2 files changed, 45 insertions(+) create mode 100644 plugins/kind/README.md create mode 100644 plugins/kind/kind.plugin.zsh diff --git a/plugins/kind/README.md b/plugins/kind/README.md new file mode 100644 index 000000000..49024648d --- /dev/null +++ b/plugins/kind/README.md @@ -0,0 +1,22 @@ +# Kind plugin + +This plugin adds completion for the [Kind](https://kind.sigs.k8s.io/) tool, as well +as a few aliases for easier use. + +To use it, add `kind` to the plugins array in your zshrc file: + +```zsh +plugins=(... kind) +``` + +## Aliases + +| Alias | Command | +| ------- | ---------------------------- | +| `kicc` | `kind create cluster` | +| `kiccn` | `kind create cluster --name` | +| `kigc` | `kind get clusters` | +| `kidc` | `kind delete cluster` | +| `kidcn` | `kind delete cluster --name` | +| `kidca` | `kind delete clusters -A` | +| `kigk` | `kind get kubeconfig` | diff --git a/plugins/kind/kind.plugin.zsh b/plugins/kind/kind.plugin.zsh new file mode 100644 index 000000000..183eb7bd6 --- /dev/null +++ b/plugins/kind/kind.plugin.zsh @@ -0,0 +1,23 @@ +if (( ! $+commands[kind] )); then + return +fi + +# If the completion file doesn't exist yet, we need to autoload it and +# bind it to `kind`. Otherwise, compinit will have already done that. +if [[ ! -f "$ZSH_CACHE_DIR/completions/_kind" ]]; then + typeset -g -A _comps + autoload -Uz _kind + _comps[kind]=_kind +fi + +# Generate and load kind completion +kind completion zsh >! "$ZSH_CACHE_DIR/completions/_kind" &| + +# Register aliases +alias kicc="kind create cluster" +alias kiccn="kind create cluster --name" +alias kigc="kind get clusters" +alias kidc="kind delete cluster" +alias kidcn="kind delete cluster --name" +alias kidca="kind delete clusters -A" +alias kigk="kind get kubeconfig" From b1821a24f0574488554de8e7f6d0735fb851de8b Mon Sep 17 00:00:00 2001 From: Adam Johnson Date: Tue, 10 Oct 2023 16:56:54 +0100 Subject: [PATCH 385/672] fix(git): restore showing patch in `gsts` (#11951) --- plugins/git/README.md | 2 +- plugins/git/git.plugin.zsh | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/plugins/git/README.md b/plugins/git/README.md index 33c10ffd0..a4e9f4c4a 100644 --- a/plugins/git/README.md +++ b/plugins/git/README.md @@ -185,7 +185,7 @@ plugins=(... git) | `gstp` | `git stash pop` | | `gsta` | On Git >= 2.13: `git stash push` | | `gsta` | On Git < 2.13: `git stash save` | -| `gsts` | `git stash show` | +| `gsts` | `git stash show --patch` | | `gst` | `git status` | | `gss` | `git status --short` | | `gsb` | `git status --short -b` | diff --git a/plugins/git/git.plugin.zsh b/plugins/git/git.plugin.zsh index ceb2011f9..b0376308f 100644 --- a/plugins/git/git.plugin.zsh +++ b/plugins/git/git.plugin.zsh @@ -349,7 +349,7 @@ alias gstp='git stash pop' is-at-least 2.13 "$git_version" \ && alias gsta='git stash push' \ || alias gsta='git stash save' -alias gsts='git stash show' +alias gsts='git stash show --patch' alias gst='git status' alias gss='git status --short' alias gsb='git status --short --branch' From da3b8fcb6a6bcf4d440b9768d2deab27f787929a Mon Sep 17 00:00:00 2001 From: Lukas Elmer Date: Wed, 11 Oct 2023 18:06:22 +0200 Subject: [PATCH 386/672] fix(yarn): output completion entries in UTF-8 (#11955) --- plugins/yarn/_yarn | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/yarn/_yarn b/plugins/yarn/_yarn index 1237ba672..f15756ff4 100644 --- a/plugins/yarn/_yarn +++ b/plugins/yarn/_yarn @@ -144,7 +144,7 @@ _yarn_scripts() { fi if [[ -n $packageJson ]]; then - scripts=("${(@f)$(cat ${packageJson} | perl -0777 -MJSON::PP -n -E '%r=%{decode_json($_)->{scripts}}; do{$k=$_;($e=$k)=~s/:/\\:/g; printf "$e:$r{$k}\n"} for sort keys %r')}") + scripts=("${(@f)$(cat ${packageJson} | perl -0777 -MJSON::PP -n -E 'binmode(STDOUT, ":encoding(UTF-8)"); %r=%{decode_json($_)->{scripts}}; do{$k=$_;($e=$k)=~s/:/\\:/g; printf "$e:$r{$k}\n"} for sort keys %r')}") fi commands=('env' $scripts $binaries) From fedef5dbd5f8ffef16815cb3a2c611eb0f7f00b1 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Wed, 11 Oct 2023 19:23:44 +0200 Subject: [PATCH 387/672] fix(xcode): open Xcode in current Desk if already open in another (#10384) Fixes #10384 --- plugins/xcode/xcode.plugin.zsh | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/plugins/xcode/xcode.plugin.zsh b/plugins/xcode/xcode.plugin.zsh index 5d1f901a3..f09434e69 100644 --- a/plugins/xcode/xcode.plugin.zsh +++ b/plugins/xcode/xcode.plugin.zsh @@ -17,6 +17,13 @@ function xc { local active_path active_path=${"$(xcode-select -p)"%%/Contents/Developer*} echo "Found ${xcode_files[1]}. Opening with ${active_path}" + + # If Xcode is already opened in another Desk, we need this double call + # with -g to open the project window in the current Desk and focus it. + # See https://github.com/ohmyzsh/ohmyzsh/issues/10384 + if command pgrep -q "^Xcode"; then + open -g -a "$active_path" "${xcode_files[1]}" + fi open -a "$active_path" "${xcode_files[1]}" } From 53cb50acb5c2c70f6ba9d26d3d2ffb37c8a19e8f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Wed, 11 Oct 2023 20:43:55 +0200 Subject: [PATCH 388/672] refactor(systemadmin): use `ss` instead of `netstat` when available (#11957) --- plugins/systemadmin/systemadmin.plugin.zsh | 116 ++++++++++++--------- 1 file changed, 67 insertions(+), 49 deletions(-) diff --git a/plugins/systemadmin/systemadmin.plugin.zsh b/plugins/systemadmin/systemadmin.plugin.zsh index 7ce62bac1..03dd995b6 100644 --- a/plugins/systemadmin/systemadmin.plugin.zsh +++ b/plugins/systemadmin/systemadmin.plugin.zsh @@ -13,11 +13,11 @@ # ------------------------------------------------------------------------------ function retlog() { - if [[ -z $1 ]];then - echo '/var/log/nginx/access.log' - else - echo $1 - fi + if [[ -z $1 ]];then + echo '/var/log/nginx/access.log' + else + echo $1 + fi } alias ping='ping -c 5' @@ -28,142 +28,160 @@ alias mkdir='mkdir -pv' alias psmem='ps -e -orss=,args= | sort -b -k1 -nr' alias psmem10='ps -e -orss=,args= | sort -b -k1 -nr | head -n 10' # get top process eating cpu if not work try execute : export LC_ALL='C' -alias pscpu='ps -e -o pcpu,cpu,nice,state,cputime,args|sort -k1,1n -nr' -alias pscpu10='ps -e -o pcpu,cpu,nice,state,cputime,args|sort -k1,1n -nr | head -n 10' +alias pscpu='ps -e -o pcpu,cpu,nice,state,cputime,args | sort -k1,1n -nr' +alias pscpu10='ps -e -o pcpu,cpu,nice,state,cputime,args | sort -k1,1n -nr | head -n 10' # top10 of the history alias hist10='print -l ${(o)history%% *} | uniq -c | sort -nr | head -n 10' function ip() { - if [ -t 1 ]; then - command ip -color "$@" - else - command ip "$@" - fi + if [ -t 1 ]; then + command ip -color "$@" + else + command ip "$@" + fi } # directory LS function dls() { - print -l *(/) + print -l *(/) } function psgrep() { - ps aux | grep "${1:-.}" | grep -v grep + ps aux | grep "${1:-.}" | grep -v grep } # Kills any process that matches a regexp passed to it function killit() { - ps aux | grep -v "grep" | grep "$@" | awk '{print $2}' | xargs sudo kill + ps aux | grep -v "grep" | grep "$@" | awk '{print $2}' | xargs sudo kill } # list contents of directories in a tree-like format if ! (( $+commands[tree] )); then - function tree() { - find $@ -print | sed -e 's;[^/]*/;|____;g;s;____|; |;g' - } + function tree() { + find $@ -print | sed -e 's;[^/]*/;|____;g;s;____|; |;g' + } fi # Sort connection state function sortcons() { - netstat -nat |awk '{print $6}'|sort|uniq -c|sort -rn + { + LANG= ss -nat | awk 'NR > 1 {print $1}' \ + || LANG= netstat -nat | awk 'NR > 2 {print $6}' + } | sort | uniq -c | sort -rn } # View all 80 Port Connections function con80() { - netstat -nat|grep -i ":80"|wc -l + { + LANG= ss -nat || LANG= netstat -nat + } | grep -E ":80[^0-9]" | wc -l } # On the connected IP sorted by the number of connections function sortconip() { - netstat -ntu | awk '{print $5}' | cut -d: -f1 | sort | uniq -c | sort -n + { + LANG= ss -ntu | awk 'NR > 1 {print $6}' \ + || LANG= netstat -ntu | awk 'NR > 2 {print $5}' + } | cut -d: -f1 | sort | uniq -c | sort -n } # top20 of Find the number of requests on 80 port function req20() { - netstat -anlp|grep 80|grep tcp|awk '{print $5}'|awk -F: '{print $1}'|sort|uniq -c|sort -nr|head -n20 + { + LANG= ss -tn | awk '$4 ~ /:80$/ {print $5}' \ + || LANG= netstat -tn | awk '$4 ~ /:80$/ {print $5}' + } | awk -F: '{print $1}' | sort | uniq -c | sort -nr | head -n 20 } # top20 of Using tcpdump port 80 access to view function http20() { - sudo tcpdump -i eth0 -tnn dst port 80 -c 1000 | awk -F"." '{print $1"."$2"."$3"."$4}' | sort | uniq -c | sort -nr |head -n 20 + sudo tcpdump -i eth0 -tnn dst port 80 -c 1000 | awk -F"." '{print $1"."$2"."$3"."$4}' | sort | uniq -c | sort -nr | head -n 20 } # top20 of Find time_wait connection function timewait20() { - netstat -n|grep TIME_WAIT|awk '{print $5}'|sort|uniq -c|sort -rn|head -n20 + { + LANG= ss -nat | awk 'NR > 1 && /TIME-WAIT/ {print $5}' \ + || LANG= netstat -nat | awk 'NR > 2 && /TIME_WAIT/ {print $5}' + } | sort | uniq -c | sort -rn | head -n 20 } # top20 of Find SYN connection function syn20() { - netstat -an | grep SYN | awk '{print $5}' | awk -F: '{print $1}' | sort | uniq -c | sort -nr|head -n20 + { + LANG= ss -an | awk '/SYN/ {print $5}' \ + || LANG= netstat -an | awk '/SYN/ {print $5}' + } | awk -F: '{print $1}' | sort | uniq -c | sort -nr | head -n20 } # Printing process according to the port number function port_pro() { - netstat -ntlp | grep "${1:-.}" | awk '{print $7}' | cut -d/ -f1 + LANG= ss -ntlp | awk "NR > 1 && /:${1:-}/ {print \$6}" | sed 's/.*pid=\([^,]*\).*/\1/' \ + || LANG= netstat -ntlp | awk "NR > 2 && /:${1:-}/ {print \$7}" | cut -d/ -f1 } # top10 of gain access to the ip address function accessip10() { - awk '{counts[$(11)]+=1}; END {for(url in counts) print counts[url], url}' "$(retlog)" + awk '{counts[$(11)]+=1}; END {for(url in counts) print counts[url], url}' "$(retlog)" } # top20 of Most Visited file or page function visitpage20() { - awk '{print $11}' "$(retlog)"|sort|uniq -c|sort -nr|head -n 20 + awk '{print $11}' "$(retlog)" | sort | uniq -c | sort -nr | head -n 20 } # top100 of Page lists the most time-consuming (more than 60 seconds) as well as the corresponding page number of occurrences function consume100() { - awk '($NF > 60 && $7~/\.php/){print $7}' "$(retlog)" |sort -n|uniq -c|sort -nr|head -n 100 - # if django website or other website make by no suffix language - # awk '{print $7}' "$(retlog)" |sort -n|uniq -c|sort -nr|head -n 100 + awk '($NF > 60 && $7~/\.php/){print $7}' "$(retlog)" | sort -n | uniq -c | sort -nr | head -n 100 + # if django website or other website make by no suffix language + # awk '{print $7}' "$(retlog)" | sort -n | uniq -c | sort -nr | head -n 100 } # Website traffic statistics (G) function webtraffic() { - awk "{sum+=$10} END {print sum/1024/1024/1024}" "$(retlog)" + awk "{sum+=$10} END {print sum/1024/1024/1024}" "$(retlog)" } # Statistical connections 404 function c404() { - awk '($9 ~/404/)' "$(retlog)" | awk '{print $9,$7}' | sort + awk '($9 ~ /404/)' "$(retlog)" | awk '{print $9,$7}' | sort } # Statistical http status. function httpstatus() { - awk '{counts[$(9)]+=1}; END {for(code in counts) print code, counts[code]}' "$(retlog)" + awk '{counts[$(9)]+=1}; END {for(code in counts) print code, counts[code]}' "$(retlog)" } # Delete 0 byte file function d0() { - find "${1:-.}" -type f -size 0 -exec rm -rf {} \; + find "${1:-.}" -type f -size 0 -exec rm -rf {} \; } # gather external ip address function geteip() { - curl -s -S -4 https://icanhazip.com + curl -s -S -4 https://icanhazip.com - # handle case when there is no IPv6 external IP, which shows error - # curl: (7) Couldn't connect to server - curl -s -S -6 https://icanhazip.com 2>/dev/null - local ret=$? - (( ret == 7 )) && print -P -u2 "%F{red}error: no IPv6 route to host%f" - return $ret + # handle case when there is no IPv6 external IP, which shows error + # curl: (7) Couldn't connect to server + curl -s -S -6 https://icanhazip.com 2>/dev/null + local ret=$? + (( ret == 7 )) && print -P -u2 "%F{red}error: no IPv6 route to host%f" + return $ret } # determine local IP address(es) function getip() { - if (( ${+commands[ip]} )); then - ip addr | awk '/inet /{print $2}' | command grep -v 127.0.0.1 - else - ifconfig | awk '/inet /{print $2}' | command grep -v 127.0.0.1 - fi + if (( ${+commands[ip]} )); then + ip addr | awk '/inet /{print $2}' | command grep -v 127.0.0.1 + else + ifconfig | awk '/inet /{print $2}' | command grep -v 127.0.0.1 + fi } # Clear zombie processes function clrz() { - ps -eal | awk '{ if ($2 == "Z") {print $4}}' | kill -9 + ps -eal | awk '{ if ($2 == "Z") {print $4}}' | kill -9 } # Second concurrent function conssec() { - awk '{if($9~/200|30|404/)COUNT[$4]++}END{for( a in COUNT) print a,COUNT[a]}' "$(retlog)"|sort -k 2 -nr|head -n10 + awk '{if($9~/200|30|404/)COUNT[$4]++}END{for( a in COUNT) print a,COUNT[a]}' "$(retlog)" | sort -k 2 -nr | head -n10 } From 408330e131110c8b86ce60ab0492b35657cb4d57 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Wed, 11 Oct 2023 20:44:46 +0200 Subject: [PATCH 389/672] ci: remove redundant macos runner for CI tests Currently the macOS runner is not needed, as we are only checking zsh syntax. We can reactivate it in the future if needed. --- .github/workflows/main.yml | 6 +----- 1 file changed, 1 insertion(+), 5 deletions(-) diff --git a/.github/workflows/main.yml b/.github/workflows/main.yml index 57403629c..de7d98262 100644 --- a/.github/workflows/main.yml +++ b/.github/workflows/main.yml @@ -20,16 +20,12 @@ permissions: jobs: tests: name: Run tests - runs-on: ${{ matrix.os }} + runs-on: ubuntu-latest if: github.repository == 'ohmyzsh/ohmyzsh' - strategy: - matrix: - os: [ubuntu-latest, macos-latest] steps: - name: Set up git repository uses: actions/checkout@v3 - name: Install zsh - if: runner.os == 'Linux' run: sudo apt-get update; sudo apt-get install zsh - name: Check syntax run: | From 6768906d07151140db901510b2c8b1ce2622f365 Mon Sep 17 00:00:00 2001 From: sattisumasri <73093486+sattisumasri@users.noreply.github.com> Date: Thu, 12 Oct 2023 00:27:01 +0530 Subject: [PATCH 390/672] chore: change headings in README to Title Case (#11956) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Co-authored-by: Marc Cornellà --- README.md | 69 ++++++++++++++++++++++++++++--------------------------- 1 file changed, 35 insertions(+), 34 deletions(-) diff --git a/README.md b/README.md index c83e16218..308d117e1 100644 --- a/README.md +++ b/README.md @@ -23,32 +23,33 @@ To learn more, visit [ohmyz.sh](https://ohmyz.sh), follow [@ohmyzsh](https://twi Table of Contents - [Getting Started](#getting-started) + - [Operating System Compatibility](#operating-system-compatibility) - [Prerequisites](#prerequisites) - [Basic Installation](#basic-installation) - - [Manual inspection](#manual-inspection) + - [Manual Inspection](#manual-inspection) - [Using Oh My Zsh](#using-oh-my-zsh) - [Plugins](#plugins) - [Enabling Plugins](#enabling-plugins) - [Using Plugins](#using-plugins) - [Themes](#themes) - - [Selecting a Theme](#selecting-a-theme) + - [Selecting A Theme](#selecting-a-theme) - [FAQ](#faq) - [Advanced Topics](#advanced-topics) - [Advanced Installation](#advanced-installation) - [Custom Directory](#custom-directory) - - [Unattended install](#unattended-install) - - [Installing from a forked repository](#installing-from-a-forked-repository) + - [Unattended Install](#unattended-install) + - [Installing From A Forked Repository](#installing-from-a-forked-repository) - [Manual Installation](#manual-installation) - [Installation Problems](#installation-problems) - - [Custom Plugins and Themes](#custom-plugins-and-themes) - - [Enable GNU ls in macOS and freeBSD systems](#enable-gnu-ls) - - [Skip aliases](#skip-aliases) + - [Custom Plugins And Themes](#custom-plugins-and-themes) + - [Enable GNU ls In macOS And freeBSD Systems](#enable-gnu-ls-in-macos-and-freebsd-systems) + - [Skip Aliases](#skip-aliases) - [Getting Updates](#getting-updates) - - [Updates verbosity](#updates-verbosity) + - [Updates Verbosity](#updates-verbosity) - [Manual Updates](#manual-updates) - [Uninstalling Oh My Zsh](#uninstalling-oh-my-zsh) -- [How do I contribute to Oh My Zsh?](#how-do-i-contribute-to-oh-my-zsh) - - [Do NOT send us themes](#do-not-send-us-themes) +- [How Do I Contribute To Oh My Zsh?](#how-do-i-contribute-to-oh-my-zsh) + - [Do Not Send Us Themes](#do-not-send-us-themes) - [Contributors](#contributors) - [Follow Us](#follow-us) - [Merchandise](#merchandise) @@ -61,15 +62,15 @@ To learn more, visit [ohmyz.sh](https://ohmyz.sh), follow [@ohmyzsh](https://twi ### Operating System Compatibility -| O/S | Status | -| :---------------- | :------: | -| Android | ✅ | -| FreeBSD | ✅ | -| LCARS | 🛸 | -| Linux | ✅ | -| MacOS | ✅ | -| OS/2 Warp | ❌ | -| Windows (WSL2) | ✅ | +| O/S | Status | +| :------------- | :-----: | +| Android | ✅ | +| freeBSD | ✅ | +| LCARS | 🛸 | +| Linux | ✅ | +| macOS | ✅ | +| OS/2 Warp | ❌ | +| Windows (WSL2) | ✅ | ### Prerequisites @@ -90,7 +91,7 @@ Oh My Zsh is installed by running one of the following commands in your terminal _Note that any previous `.zshrc` will be renamed to `.zshrc.pre-oh-my-zsh`. After installation, you can move the configuration you want to preserve into the new `.zshrc`._ -#### Manual inspection +#### Manual Inspection It's a good idea to inspect the install script from projects you don't yet know. You can do that by downloading the install script first, looking through it so everything looks normal, @@ -139,7 +140,7 @@ Each built-in plugin includes a **README**, documenting it. This README should s We'll admit it. Early in the Oh My Zsh world, we may have gotten a bit too theme happy. We have over one hundred and fifty themes now bundled. Most of them have [screenshots](https://github.com/ohmyzsh/ohmyzsh/wiki/Themes) on the wiki (We are working on updating this!). Check them out! -#### Selecting a Theme +#### Selecting A Theme _Robby's theme is the default one. It's not the fanciest one. It's not the simplest one. It's just the right one (for him)._ @@ -210,7 +211,7 @@ like this: ZSH="$HOME/.dotfiles/oh-my-zsh" sh install.sh ``` -#### Unattended install +#### Unattended Install If you're running the Oh My Zsh install script as part of an automated install, you can pass the `--unattended` flag to the `install.sh` script. This will have the effect of not trying to change @@ -220,7 +221,7 @@ the default shell, and it also won't run `zsh` when the installation has finishe sh -c "$(curl -fsSL https://raw.githubusercontent.com/ohmyzsh/ohmyzsh/master/tools/install.sh)" "" --unattended ``` -#### Installing from a forked repository +#### Installing From A Forked Repository The install script also accepts these variables to allow installation of a different repository: @@ -245,19 +246,19 @@ REPO=apjanke/oh-my-zsh BRANCH=edge sh install.sh #### Manual Installation -##### 1. Clone the repository +##### 1. Clone The Repository ```sh git clone https://github.com/ohmyzsh/ohmyzsh.git ~/.oh-my-zsh ``` -##### 2. _Optionally_, backup your existing `~/.zshrc` file +##### 2. _Optionally_, Backup Your Existing `~/.zshrc` File ```sh cp ~/.zshrc ~/.zshrc.orig ``` -##### 3. Create a new zsh configuration file +##### 3. Create A New Zsh Configuration File You can create a new zsh config file by copying the template that we have included for you. @@ -265,7 +266,7 @@ You can create a new zsh config file by copying the template that we have includ cp ~/.oh-my-zsh/templates/zshrc.zsh-template ~/.zshrc ``` -##### 4. Change your default shell +##### 4. Change Your Default Shell ```sh chsh -s $(which zsh) @@ -273,7 +274,7 @@ chsh -s $(which zsh) You must log out from your user session and log back in to see this change. -##### 5. Initialize your new zsh configuration +##### 5. Initialize Your New Zsh Configuration Once you open up a new terminal window, it should load zsh with Oh My Zsh's configuration. @@ -284,7 +285,7 @@ If you have any hiccups installing, here are a few common fixes. - You _might_ need to modify your `PATH` in `~/.zshrc` if you're not able to find some commands after switching to `oh-my-zsh`. - If you installed manually or changed the install location, check the `ZSH` environment variable in `~/.zshrc`. -### Custom Plugins and Themes +### Custom Plugins And Themes If you want to override any of the default behaviors, just add a new file (ending in `.zsh`) in the `custom/` directory. @@ -292,7 +293,7 @@ If you have many functions that go well together, you can put them as a `XYZ.plu If you would like to override the functionality of a plugin distributed with Oh My Zsh, create a plugin of the same name in the `custom/plugins/` directory and it will be loaded instead of the one in `plugins/`. -### Enable GNU ls in macOS and freeBSD systems +### Enable GNU ls In macOS And freeBSD Systems @@ -306,7 +307,7 @@ zstyle ':omz:lib:theme-and-appearance' gnu-ls yes _Note: this is not compatible with `DISABLE_LS_COLORS=true`_ -### Skip aliases +### Skip Aliases @@ -389,7 +390,7 @@ zstyle ':omz:update' frequency 7 zstyle ':omz:update' frequency 0 ``` -### Updates verbosity +### Updates Verbosity You can also limit the update verbosity with the following settings: @@ -417,7 +418,7 @@ Oh My Zsh isn't for everyone. We'll miss you, but we want to make this an easy b If you want to uninstall `oh-my-zsh`, just run `uninstall_oh_my_zsh` from the command-line. It will remove itself and revert your previous `bash` or `zsh` configuration. -## How do I contribute to Oh My Zsh? +## How Do I Contribute To Oh My Zsh? Before you participate in our delightful community, please read the [code of conduct](CODE_OF_CONDUCT.md). @@ -427,7 +428,7 @@ We also need people to test out pull requests. So take a look through [the open See [Contributing](CONTRIBUTING.md) for more details. -### Do NOT send us themes +### Do Not Send Us Themes We have (more than) enough themes for the time being. Please add your theme to the [external themes](https://github.com/ohmyzsh/ohmyzsh/wiki/External-themes) wiki page. From 5743198e0ed5de137b4aa1b948cf4c82b02bdd8e Mon Sep 17 00:00:00 2001 From: Preston Button Date: Thu, 12 Oct 2023 04:32:48 -0400 Subject: [PATCH 391/672] docs(aliases): fix typo (#11958) --- plugins/aliases/README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/aliases/README.md b/plugins/aliases/README.md index 53b68ea01..14f9c5c53 100644 --- a/plugins/aliases/README.md +++ b/plugins/aliases/README.md @@ -17,7 +17,7 @@ Requirements: Python needs to be installed. - `als`: show all aliases by group -- `als -h/--help`: print help mesage +- `als -h/--help`: print help message - `als `: filter and highlight aliases by `` From 7329b2fbb1787651d4900d5ef280b926c5696c01 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Thu, 12 Oct 2023 11:46:49 +0200 Subject: [PATCH 392/672] docs(debian): clarify override behavior for `apt_pref` and `apt_upgr` Fixes #11959 --- plugins/debian/README.md | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/plugins/debian/README.md b/plugins/debian/README.md index 1db534f13..6835ad65c 100644 --- a/plugins/debian/README.md +++ b/plugins/debian/README.md @@ -13,7 +13,12 @@ plugins=(... debian) - `$apt_pref`: use aptitude or apt if installed, fallback is apt-get. - `$apt_upgr`: use upgrade or safe-upgrade (for aptitude). -Set `$apt_pref` and `$apt_upgr` to whatever command you want (before sourcing Oh My Zsh) to override this behavior. +Set **both** `$apt_pref` and `$apt_upgr` to whatever command you want (before sourcing Oh My Zsh) to override this behavior, e.g.: + +```sh +apt_pref='apt' +apt_upgr='full-upgrade' +``` ## Common Aliases From 772b41ea5a362206e1498453dd053e638752c5dc Mon Sep 17 00:00:00 2001 From: Sandesh Pyakurel <82999440+Sandesh-Pyakurel@users.noreply.github.com> Date: Thu, 12 Oct 2023 20:09:40 +0545 Subject: [PATCH 393/672] chore(zsh-navigation-tools): fix typo (#11960) --- plugins/zsh-navigation-tools/n-list | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/zsh-navigation-tools/n-list b/plugins/zsh-navigation-tools/n-list index f25db8f60..a852b083a 100644 --- a/plugins/zsh-navigation-tools/n-list +++ b/plugins/zsh-navigation-tools/n-list @@ -467,7 +467,7 @@ while (( 1 )); do elif [ -n "$keypad" ]; then final_key="$keypad" else - _nlist_status_msg "Inproper input detected" + _nlist_status_msg "Improper input detected" zcurses refresh main inner fi From 3efdbf9e1e6663adf9d8a2d113ec62855c621ef7 Mon Sep 17 00:00:00 2001 From: Sandesh Pyakurel <82999440+Sandesh-Pyakurel@users.noreply.github.com> Date: Fri, 13 Oct 2023 13:38:48 +0545 Subject: [PATCH 394/672] chore(hitchhiker): fix typos (#11961) --- plugins/hitchhiker/fortunes/hitchhiker | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/plugins/hitchhiker/fortunes/hitchhiker b/plugins/hitchhiker/fortunes/hitchhiker index b0448b21e..94cc1c835 100644 --- a/plugins/hitchhiker/fortunes/hitchhiker +++ b/plugins/hitchhiker/fortunes/hitchhiker @@ -80,7 +80,7 @@ % "The fronting for the eighty-yard-long marble-topped bar had been made by stitching together nearly twenty thousand Antarean Mosaic Lizard skins, despite the fact that the twenty thousand lizards concerned had needed them to keep their insides in." -- The Book decribing Milliways' politically incorrect decor. +- The Book describing Milliways' politically incorrect decor. % "`...and the Universe,' continued the waiter, determined not to be deflected on his home stretch, `will explode later for your pleasure.' Ford's head swivelled slowly towards him. He spoke with feeling. `Wow,' he said, `What sort of drinks do you serve in this place?' The waiter laughed a polite little waiter's laugh. `Ah,' he said, `I think sir has perhaps misunderstood me.' `Oh, I hope not,' breathed Ford." @@ -104,7 +104,7 @@ % "`The first ten million years were the worst,' said Marvin, `and the second ten million, they were the worst too. The third ten million I didn't enjoy at all. After that I went into a bit of a decline.'" -- Marvin reflecting back on his 576,000,003,579 year career as Milliways' car park attendent. +- Marvin reflecting back on his 576,000,003,579 year career as Milliways' car park attendant. % "`Incidentally,' he said, `what does teleport mean?' Another moment passed. Slowly, the others turned to face him. `Probably the wrong moment to ask,' said Arthur, `It's just I remember you use the word a short while ago and I only bring it up because...' `Where,' said Ford quietly, `does it say teleport?' `Well, just over here in fact,' said Arthur, pointing at a dark control box in the rear of the cabin, `Just under the word "emergency", above the word "system" and beside the sign saying "out of order".'" @@ -122,7 +122,7 @@ - Ford "debating" what to do with fire with a marketing girl. % -"The story goes that I first had the idea for THHGTTG while lying drunk in a field in Innsbruck (or `Spain' as the BBC TV publicity department authoritatively has it, probably because it's easier to spell)." - Foreward by DNA. +"The story goes that I first had the idea for THHGTTG while lying drunk in a field in Innsbruck (or `Spain' as the BBC TV publicity department authoritatively has it, probably because it's easier to spell)." - Foreword by DNA. FORD Six pints of bitter. And quickly please, the world's about to end. BARMAN Oh yes, sir? Nice weather for it. % @@ -162,7 +162,7 @@ ARTHUR It probably seems a terrible thing to say, but you know what I sometimes - Arthur discovering a way of coping with life on Prehistoric Earth. % -"`... then I decided that I was a lemon for a couple of weeks. I kept myself amused all that time jumping in and out of a gin and tonic.' Arthur cleared his throat, and then did it again. `Where,' he said, `did you...?' `Find a gin and tonic?' said Ford brightly. `I found a small lake that thought it was a gin and tonic, and jumped in and out of that. At least, I think it thought it was a gin and tonic.' `I may,' he addded with a grin which would have sent sane men scampering into the trees, `have been imagining it.'" +"`... then I decided that I was a lemon for a couple of weeks. I kept myself amused all that time jumping in and out of a gin and tonic.' Arthur cleared his throat, and then did it again. `Where,' he said, `did you...?' `Find a gin and tonic?' said Ford brightly. `I found a small lake that thought it was a gin and tonic, and jumped in and out of that. At least, I think it thought it was a gin and tonic.' `I may,' he added with a grin which would have sent sane men scampering into the trees, `have been imagining it.'" - Ford updating Arthur about what he's been doing for the past four years. % From 8d9c9b6174466cc432a9946b0459c214586cb1b2 Mon Sep 17 00:00:00 2001 From: Sandesh Pyakurel <82999440+Sandesh-Pyakurel@users.noreply.github.com> Date: Fri, 13 Oct 2023 20:45:28 +0545 Subject: [PATCH 395/672] chore(postgres): fix typo (#11967) --- plugins/postgres/README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/postgres/README.md b/plugins/postgres/README.md index 59445f31c..3f59a8fe4 100644 --- a/plugins/postgres/README.md +++ b/plugins/postgres/README.md @@ -19,4 +19,4 @@ plugins=(... postgres) | stoppost | `pg_ctl -D /usr/local/var/postgres stop -s -m fast` | Stop postgres server | | restartpost | `stoppost && sleep 1 && startpost` | Restart (calls stop, then start) | | reloadpost | `pg_ctl reload -D /usr/local/var/postgres -s` | Reload postgres configuration (some setting require restart)| -| statuspost | `pg_ctl status -D /usr/local/var/postgres -s` | Check startus of postgres server (running, stopped) | +| statuspost | `pg_ctl status -D /usr/local/var/postgres -s` | Check status of postgres server (running, stopped) | From 48a62a9f713449a014d66b01afd99a4fcf1911fe Mon Sep 17 00:00:00 2001 From: Kapil Pau Date: Fri, 13 Oct 2023 23:11:47 +0100 Subject: [PATCH 396/672] feat(span): Introducing Snapcraft CLI plugin (#9357) --- plugins/snap/README.md | 18 ++++++++++++++++++ plugins/snap/snap.plugin.zsh | 10 ++++++++++ 2 files changed, 28 insertions(+) create mode 100644 plugins/snap/README.md create mode 100644 plugins/snap/snap.plugin.zsh diff --git a/plugins/snap/README.md b/plugins/snap/README.md new file mode 100644 index 000000000..75c5ec19a --- /dev/null +++ b/plugins/snap/README.md @@ -0,0 +1,18 @@ +# snap plugin + +This plugin sets up aliases for the common [snap](https://snapcraft.io/docs/getting-started) commands + +## Aliases + +| Alias | Full command | +| --- | ---| +| sv | snap version | +| sf | snap find | +| si | snap install | +| sin | snap info | +| sr | snap remove | +| sref | snap refresh | +| srev | snap revert | +| sl | snap list | +| sd | snap disable | +| se | snap enable | diff --git a/plugins/snap/snap.plugin.zsh b/plugins/snap/snap.plugin.zsh new file mode 100644 index 000000000..af2346978 --- /dev/null +++ b/plugins/snap/snap.plugin.zsh @@ -0,0 +1,10 @@ +alias sv="snap version" +alias sf="snap find" +alias si="snap install" +alias sin="snap info" +alias sr="snap remove" +alias sref="snap refresh" +alias srev="snap revert" +alias sl="snap list" +alias sd="snap disable" +alias se="snap enable" From 2db53ff1da078b2207cb98736370f1f145e5c667 Mon Sep 17 00:00:00 2001 From: Steve Lessard Jr Date: Fri, 13 Oct 2023 18:26:16 -0400 Subject: [PATCH 397/672] fix(avit): RPROMPT Fix for #10307 (#11131) Co-authored-by: Steve Lessard --- themes/avit.zsh-theme | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/themes/avit.zsh-theme b/themes/avit.zsh-theme index 1279ea919..206274462 100644 --- a/themes/avit.zsh-theme +++ b/themes/avit.zsh-theme @@ -11,7 +11,12 @@ $(_user_host)${_current_dir} $(git_prompt_info) $(ruby_prompt_info) PROMPT2='%{%(!.${fg[red]}.${fg[white]})%}◀%{$reset_color%} ' -RPROMPT='$(vi_mode_prompt_info)%{$(echotc UP 1)%}$(_git_time_since_commit) $(git_prompt_status) ${_return_status}%{$(echotc DO 1)%}' +__RPROMPT='$(vi_mode_prompt_info)%{$(echotc UP 1)%}$(_git_time_since_commit) $(git_prompt_status) ${_return_status}%{$(echotc DO 1)%}' +if [[ -z $RPROMPT ]]; then + RPROMPT=$__RPROMPT +else + RPROMPT="${RPROMPT} ${__RPROMPT}" +fi function _user_host() { local me From f7130bb529a2d15652f739c552688b34aac63315 Mon Sep 17 00:00:00 2001 From: Robby Russell Date: Fri, 13 Oct 2023 15:38:13 -0700 Subject: [PATCH 398/672] fix(gnzh): Don't show .local for local hostnames in theme Fixes #10871 --- themes/gnzh.zsh-theme | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/themes/gnzh.zsh-theme b/themes/gnzh.zsh-theme index 1e6c4e93b..ca62320e2 100644 --- a/themes/gnzh.zsh-theme +++ b/themes/gnzh.zsh-theme @@ -21,7 +21,7 @@ fi if [[ -n "$SSH_CLIENT" || -n "$SSH2_CLIENT" ]]; then PR_HOST='%F{red}%M%f' # SSH else - PR_HOST='%F{green}%M%f' # no SSH + PR_HOST='%F{green}%m%f' # no SSH fi From f93976875133409297be864ce94d50f20a9bc18d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Sat, 14 Oct 2023 16:40:45 +0200 Subject: [PATCH 399/672] fix(git): fix fallback to develop branch if `master` not found (#11966) --- plugins/git/git.plugin.zsh | 15 +++++++++++---- 1 file changed, 11 insertions(+), 4 deletions(-) diff --git a/plugins/git/git.plugin.zsh b/plugins/git/git.plugin.zsh index b0376308f..d053a7638 100644 --- a/plugins/git/git.plugin.zsh +++ b/plugins/git/git.plugin.zsh @@ -20,26 +20,31 @@ function current_branch() { function git_develop_branch() { command git rev-parse --git-dir &>/dev/null || return local branch - for branch in dev devel development; do + for branch in dev devel develop development; do if command git show-ref -q --verify refs/heads/$branch; then echo $branch - return + return 0 fi done + echo develop + return 1 } # Check if main exists and use instead of master function git_main_branch() { command git rev-parse --git-dir &>/dev/null || return local ref - for ref in refs/{heads,remotes/{origin,upstream}}/{main,trunk,mainline,default}; do + for ref in refs/{heads,remotes/{origin,upstream}}/{main,trunk,mainline,default,master}; do if command git show-ref -q --verify $ref; then echo ${ref:t} - return + return 0 fi done + + # If no main branch was found, fall back to master but return error echo master + return 1 } function grename() { @@ -129,6 +134,8 @@ function gbda() { git branch --no-color --merged | command grep -vE "^([+*]|\s*($(git_main_branch)|$(git_develop_branch))\s*$)" | command xargs git branch --delete 2>/dev/null local default_branch=$(git_main_branch) + (( ! $? )) || default_branch=$(git_develop_branch) + git for-each-ref refs/heads/ "--format=%(refname:short)" | \ while read branch; do local merge_base=$(git merge-base $default_branch $branch) From 96c976637a4112e1e72a1a449ac51d78acc67597 Mon Sep 17 00:00:00 2001 From: nishanthps-cai <123212871+nishanthps-cai@users.noreply.github.com> Date: Tue, 17 Oct 2023 00:55:05 -0700 Subject: [PATCH 400/672] feat(bazel): use completion also for bazelisk (#11984) --- plugins/bazel/_bazel | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/bazel/_bazel b/plugins/bazel/_bazel index c34c572b0..ea1f4cace 100644 --- a/plugins/bazel/_bazel +++ b/plugins/bazel/_bazel @@ -1,4 +1,4 @@ -#compdef bazel +#compdef bazel bazelisk # Copyright 2015 The Bazel Authors. All rights reserved. # From d3112d67a3eb55fc39975f917467704ebb2c296b Mon Sep 17 00:00:00 2001 From: Vyacheslav Scherbinin Date: Wed, 18 Oct 2023 14:18:05 +0700 Subject: [PATCH 401/672] feat(vscode): allow arguments to `vsc` alias (#11903) Co-authored-by: Carlo Sala --- plugins/vscode/README.md | 3 ++- plugins/vscode/vscode.plugin.zsh | 9 ++++++++- 2 files changed, 10 insertions(+), 2 deletions(-) diff --git a/plugins/vscode/README.md b/plugins/vscode/README.md index e95ed5d4f..726b23d35 100644 --- a/plugins/vscode/README.md +++ b/plugins/vscode/README.md @@ -31,7 +31,7 @@ the Command Palette via (F1 or ⇧⌘P) and type shell command to find the Shell ## Using multiple flavours -If for any reason, you ever require to use multiple flavours of VS Code i.e. VS Code (stable) and VS Code Insiders, you can +If for any reason, you ever require to use multiple flavours of VS Code i.e. VS Code (stable) and VS Code Insiders, you can manually specify the flavour's executable. Add the following line to the .zshrc file (between the `ZSH_THEME` and the `plugins=()` lines). This will make the plugin use your manually defined executable. @@ -53,6 +53,7 @@ source $ZSH/oh-my-zsh.sh | Alias | Command | Description | | ----------------------- | ------------------------------ | ----------------------------------------------------------------------------------------------------------- | | vsc | code . | Open the current folder in VS code | +| vsc `dir` | code `dir` | Open passed folder in VS code | | vsca `dir` | code --add `dir` | Add folder(s) to the last active window | | vscd `file` `file` | code --diff `file` `file` | Compare two files with each other. | | vscg `file:line[:char]` | code --goto `file:line[:char]` | Open a file at the path on the specified line and character position. | diff --git a/plugins/vscode/vscode.plugin.zsh b/plugins/vscode/vscode.plugin.zsh index 48d904377..356c62360 100644 --- a/plugins/vscode/vscode.plugin.zsh +++ b/plugins/vscode/vscode.plugin.zsh @@ -23,7 +23,14 @@ if [[ -z "$VSCODE" ]]; then fi fi -alias vsc="$VSCODE ." +function vsc { + if (( $# )); then + $VSCODE $@ + else + $VSCODE . + fi +} + alias vsca="$VSCODE --add" alias vscd="$VSCODE --diff" alias vscg="$VSCODE --goto" From f10cd5281d805bb5679dd46b304d9b8997f98981 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Patryk=20Krawaczy=C5=84ski?= Date: Wed, 18 Oct 2023 13:59:28 +0200 Subject: [PATCH 402/672] feat(history): add `hl` alias (#11990) --- plugins/history/README.md | 1 + plugins/history/history.plugin.zsh | 1 + 2 files changed, 2 insertions(+) diff --git a/plugins/history/README.md b/plugins/history/README.md index a9d480f46..73d6a5052 100644 --- a/plugins/history/README.md +++ b/plugins/history/README.md @@ -13,5 +13,6 @@ plugins=(... history) | Alias | Command | Description | |-------|----------------------|------------------------------------------------------------------| | `h` | `history` | Prints your command history | +| `hl` | `history \| less` | Pipe history output to less to search and navigate it easily | | `hs` | `history \| grep` | Use grep to search your command history | | `hsi` | `history \| grep -i` | Use grep to do a case-insensitive search of your command history | diff --git a/plugins/history/history.plugin.zsh b/plugins/history/history.plugin.zsh index 9cee48fe4..fb3e31389 100644 --- a/plugins/history/history.plugin.zsh +++ b/plugins/history/history.plugin.zsh @@ -1,3 +1,4 @@ alias h='history' +alias hl='history | less' alias hs='history | grep' alias hsi='history | grep -i' From b696288337618ca749369a679bd77989bd4cd47e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?J=C3=A9r=C3=A9my?= Date: Wed, 18 Oct 2023 19:27:47 +0200 Subject: [PATCH 403/672] feat(kubectl): add `kgdsa` alias (#11863) --- plugins/kubectl/kubectl.plugin.zsh | 1 + 1 file changed, 1 insertion(+) diff --git a/plugins/kubectl/kubectl.plugin.zsh b/plugins/kubectl/kubectl.plugin.zsh index 315d3ce93..0dd4e691a 100644 --- a/plugins/kubectl/kubectl.plugin.zsh +++ b/plugins/kubectl/kubectl.plugin.zsh @@ -162,6 +162,7 @@ alias kdelsa="kubectl delete sa" # DaemonSet management. alias kgds='kubectl get daemonset' +alias kgdsa='kubectl get daemonset --all-namespaces' alias kgdsw='kgds --watch' alias keds='kubectl edit daemonset' alias kdds='kubectl describe daemonset' From 8152dc673b14c89dc12e816583e24532ed77e8ae Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Wed, 18 Oct 2023 20:01:58 +0200 Subject: [PATCH 404/672] fix(git): move squash-merged branch deletion from `gbda` to `gbds` function (#11991) --- plugins/git/README.md | 3 ++- plugins/git/git.plugin.zsh | 6 ++++-- 2 files changed, 6 insertions(+), 3 deletions(-) diff --git a/plugins/git/README.md b/plugins/git/README.md index a4e9f4c4a..724965302 100644 --- a/plugins/git/README.md +++ b/plugins/git/README.md @@ -250,7 +250,8 @@ receive further support. | `git_develop_branch` | Returns the name of the “development” branch: `dev`, `devel`, `development` if they exist, `develop` otherwise. | | `git_main_branch` | Returns the name of the main branch: `main` if it exists, `master` otherwise. | | `grename ` | Renames branch `` to ``, including on the origin remote. | -| `gbda` | Deletes all merged and squash-merged branches | +| `gbda` | Deletes all merged branches | +| `gbds` | Deletes all squash-merged branches (**Note: performance degrades with number of branches**) | ### Work in Progress (WIP) diff --git a/plugins/git/git.plugin.zsh b/plugins/git/git.plugin.zsh index d053a7638..48937cb83 100644 --- a/plugins/git/git.plugin.zsh +++ b/plugins/git/git.plugin.zsh @@ -128,11 +128,13 @@ alias gba='git branch --all' alias gbd='git branch --delete' alias gbD='git branch --delete --force' -# Copied and modified from James Roeder (jmaroeder) under MIT License -# https://github.com/jmaroeder/plugin-git/blob/216723ef4f9e8dde399661c39c80bdf73f4076c4/functions/gbda.fish function gbda() { git branch --no-color --merged | command grep -vE "^([+*]|\s*($(git_main_branch)|$(git_develop_branch))\s*$)" | command xargs git branch --delete 2>/dev/null +} +# Copied and modified from James Roeder (jmaroeder) under MIT License +# https://github.com/jmaroeder/plugin-git/blob/216723ef4f9e8dde399661c39c80bdf73f4076c4/functions/gbda.fish +function gbds() { local default_branch=$(git_main_branch) (( ! $? )) || default_branch=$(git_develop_branch) From 0da416986aadbaf89dc5596b01f9b42403f4d9fd Mon Sep 17 00:00:00 2001 From: Vishal Sharma <106011641+vishal-sharma-369@users.noreply.github.com> Date: Wed, 18 Oct 2023 23:44:47 +0530 Subject: [PATCH 405/672] fix(ssh-agent): add error message if `~/.ssh` is not found (#11929) Closes #11829 Co-authored-by: Carlo Sala --- plugins/ssh-agent/ssh-agent.plugin.zsh | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/plugins/ssh-agent/ssh-agent.plugin.zsh b/plugins/ssh-agent/ssh-agent.plugin.zsh index 78ac46b13..49ad95a11 100644 --- a/plugins/ssh-agent/ssh-agent.plugin.zsh +++ b/plugins/ssh-agent/ssh-agent.plugin.zsh @@ -13,6 +13,11 @@ function _start_agent() { fi fi + if [[ ! -d "$HOME/.ssh" ]]; then + echo "[oh-my-zsh] ssh-agent plugin requires ~/.ssh directory" + return 1 + fi + # Set a maximum lifetime for identities added to ssh-agent local lifetime zstyle -s :omz:plugins:ssh-agent lifetime lifetime From 104041a018dc9a3eb74f93815192dba4c9386e1a Mon Sep 17 00:00:00 2001 From: Peat Bakke Date: Thu, 19 Oct 2023 02:49:38 -0700 Subject: [PATCH 406/672] feat(tmux): add `tds` alias for directory sessions (#11987) --- plugins/tmux/README.md | 1 + plugins/tmux/tmux.plugin.zsh | 13 +++++++++++++ 2 files changed, 14 insertions(+) diff --git a/plugins/tmux/README.md b/plugins/tmux/README.md index 0f8473daf..b4516ef26 100644 --- a/plugins/tmux/README.md +++ b/plugins/tmux/README.md @@ -25,6 +25,7 @@ The plugin also supports the following: | `tkss` | tmux kill-session -t | Terminate named running tmux session | | `tmux` | `_zsh_tmux_plugin_run` | Start a new tmux session | | `tmuxconf` | `$EDITOR $ZSH_TMUX_CONFIG` | Open .tmux.conf file with an editor | +| `tds` | `_tmux_directory_session` | Creates or attaches to a session for the current path | ## Configuration Variables diff --git a/plugins/tmux/tmux.plugin.zsh b/plugins/tmux/tmux.plugin.zsh index 6ed91c447..72cdd4818 100644 --- a/plugins/tmux/tmux.plugin.zsh +++ b/plugins/tmux/tmux.plugin.zsh @@ -108,6 +108,19 @@ compdef _tmux _zsh_tmux_plugin_run # Alias tmux to our wrapper function. alias tmux=_zsh_tmux_plugin_run +function _tmux_directory_session() { + # current directory without leading path + local dir=${PWD##*/} + # md5 hash for the full working directory path + local md5=$(printf '%s' "$PWD" | md5sum | cut -d ' ' -f 1) + # human friendly unique session name for this directory + local session_name="${dir}-${md5:0:6}" + # create or attach to the session + tmux new -As "$session_name" +} + +alias tds=_tmux_directory_session + # Autostart if not already in tmux and enabled. if [[ -z "$TMUX" && "$ZSH_TMUX_AUTOSTART" == "true" && -z "$INSIDE_EMACS" && -z "$EMACS" && -z "$VIM" && -z "$INTELLIJ_ENVIRONMENT_READER" ]]; then # Actually don't autostart if we already did and multiple autostarts are disabled. From a8dee63ffe8839d3bcf1066f8359fa43caccf3f2 Mon Sep 17 00:00:00 2001 From: Ryan Tvenge Date: Thu, 19 Oct 2023 09:41:36 -0500 Subject: [PATCH 407/672] feat(lando): bypass `lando` if command is not available in container (#11993) Closes #11993 --- plugins/lando/lando.plugin.zsh | 16 ++++++++++++---- 1 file changed, 12 insertions(+), 4 deletions(-) diff --git a/plugins/lando/lando.plugin.zsh b/plugins/lando/lando.plugin.zsh index af53e7e5a..b5fa80092 100644 --- a/plugins/lando/lando.plugin.zsh +++ b/plugins/lando/lando.plugin.zsh @@ -11,15 +11,23 @@ function artisan \ php \ wp \ yarn { - if checkForLandoFile; then - lando "$0" "$@" + # If the lando task is available in `lando --help`, then it means: + # + # 1. `lando` is in a project with a `.lando.yml` file. + # 2. The lando task is available for lando, based on the .lando.yml config file. + # + # This has a penalty of about 250ms, so we still want to check if the lando file + # exists before, which is the fast path. If it exists, checking help output is + # still faster than running the command and failing. + if _lando_file_exists && lando --help 2>&1 | command grep -Eq "^ +lando $0 "; then + command lando "$0" "$@" else command "$0" "$@" fi } # Check for the file in the current and parent directories. -checkForLandoFile() { +_lando_file_exists() { # Only bother checking for lando within the Sites directory. if [[ "$PWD/" != "$LANDO_ZSH_SITES_DIRECTORY"/* ]]; then # Not within $LANDO_ZSH_SITES_DIRECTORY @@ -38,4 +46,4 @@ checkForLandoFile() { # Could not find $LANDO_ZSH_CONFIG_FILE in the current directory # or in any of its parents up to $LANDO_ZSH_SITES_DIRECTORY. return 1 -} \ No newline at end of file +} From d082d87580f05cca524c546d54eb8009cf8bb10c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Thu, 19 Oct 2023 20:35:01 +0200 Subject: [PATCH 408/672] refactor(lando): add `LANDO_ZSH_WRAPPED_COMMANDS` setting and refactor --- plugins/lando/README.md | 24 +++++++++++++++++++++--- plugins/lando/lando.plugin.zsh | 19 +++++++++++-------- 2 files changed, 32 insertions(+), 11 deletions(-) diff --git a/plugins/lando/README.md b/plugins/lando/README.md index 6daeae4e4..2f881cf3d 100644 --- a/plugins/lando/README.md +++ b/plugins/lando/README.md @@ -8,7 +8,7 @@ To use it, add `lando` to the plugins array in your zshrc file: plugins=(... lando) ``` -## ALIASES: +## Wrapped Commands | Alias | Description | |:----------:|:----------------:| @@ -21,16 +21,34 @@ plugins=(... lando) | `wp` | `lando wp` | | `yarn` | `lando yarn` | +More or different commands can be wrapped by setting the `LANDO_ZSH_WRAPPED_COMMANDS` setting, see [Settings](#settings) below. + ## How It Works: This plugin removes the requirement to type `lando` before a command. It utilizes the lando version of supported commands run within directories with the following criteria: + - The `.lando.yml` file is found in the current directory or any parent directory within `$LANDO_ZSH_SITES_DIRECTORY`. - The current directory is within `$LANDO_ZSH_SITES_DIRECTORY` but is not `$LANDO_ZSH_SITES_DIRECTORY` itself. +- If the command is not a part of the commands available in the lando environment, it will run the command without `lando`. ## Settings: -- `LANDO_ZSH_SITES_DIRECTORY`: The plugin will stop searching through parents for `CONFIG_FILE` once it hits this directory. -- `LANDO_ZSH_CONFIG_FILE`: The plugin will check to see if this provided file exists to check for presence of Lando. +> NOTE: these settings must be set *before* the plugin is loaded, and any changes require a restart of the shell to be applied. + +- `LANDO_ZSH_SITES_DIRECTORY`: The plugin will stop searching through parents for `CONFIG_FILE` once it hits this directory: + ```sh + LANDO_ZSH_SITES_DIRECTORY="$HOME/Code" + ``` + +- `LANDO_ZSH_CONFIG_FILE`: The plugin will check to see if this provided file exists to check for presence of Lando: + ```sh + LANDO_ZSH_CONFIG_FILE=".lando.dev.yml" + ``` + +- `LANDO_ZSH_WRAPPED_COMMANDS`: The list of commands to wrap, as a string of commands separated by whitespace: + ```sh + LANDO_ZSH_WRAPPED_COMMANDS="mysql php composer test artisan" + ``` ## Author: diff --git a/plugins/lando/lando.plugin.zsh b/plugins/lando/lando.plugin.zsh index b5fa80092..ee796d212 100644 --- a/plugins/lando/lando.plugin.zsh +++ b/plugins/lando/lando.plugin.zsh @@ -1,16 +1,19 @@ # Settings : ${LANDO_ZSH_SITES_DIRECTORY:="$HOME/Sites"} : ${LANDO_ZSH_CONFIG_FILE:=.lando.yml} +: ${LANDO_ZSH_WRAPPED_COMMANDS:=" + artisan + composer + drush + gulp + npm + php + wp + yarn +"} # Enable multiple commands with lando. -function artisan \ - composer \ - drush \ - gulp \ - npm \ - php \ - wp \ - yarn { +function ${=LANDO_ZSH_WRAPPED_COMMANDS} { # If the lando task is available in `lando --help`, then it means: # # 1. `lando` is in a project with a `.lando.yml` file. From 9f84ba085425800dee0b4e391d8cf377806dc75e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Thu, 19 Oct 2023 20:47:26 +0200 Subject: [PATCH 409/672] feat(command-not-found): add support for Homebrew on Linux Fixes #11151 --- plugins/command-not-found/command-not-found.plugin.zsh | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/plugins/command-not-found/command-not-found.plugin.zsh b/plugins/command-not-found/command-not-found.plugin.zsh index cb8a8989c..c741e18a2 100644 --- a/plugins/command-not-found/command-not-found.plugin.zsh +++ b/plugins/command-not-found/command-not-found.plugin.zsh @@ -3,9 +3,10 @@ for file ( # Arch Linux. Must have pkgfile installed: https://wiki.archlinux.org/index.php/Pkgfile#Command_not_found /usr/share/doc/pkgfile/command-not-found.zsh - # macOS (M1 and classic Homebrew): https://github.com/Homebrew/homebrew-command-not-found + # Homebrew: https://github.com/Homebrew/homebrew-command-not-found /opt/homebrew/Library/Taps/homebrew/homebrew-command-not-found/handler.sh /usr/local/Homebrew/Library/Taps/homebrew/homebrew-command-not-found/handler.sh + /home/linuxbrew/.linuxbrew/Homebrew/Library/Taps/homebrew/homebrew-command-not-found/handler.sh ); do if [[ -r "$file" ]]; then source "$file" From 207d29b716301c77392ae140b1482eeba44e9102 Mon Sep 17 00:00:00 2001 From: Zeeshan Date: Tue, 4 Oct 2022 18:51:24 +0530 Subject: [PATCH 410/672] fix(git)!: standardize `git pull --rebase` aliases (#11224) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit BREAKING CHANGE: The alias `gup` for `git pull --rebase` and its derivatives are replaced by `gpr` for standardization. This means the previous aliases will no longer be available after a few months. Meanwhile, the original aliases are still working, with a deprecation notice. See https://github.com/ohmyzsh/ohmyzsh/blob/master/plugins/git/README.md#deprecated-aliases for the full list of deprecated aliases. Fixes #11104 Closes #11224 Co-authored-by: Marc Cornellà --- plugins/git/README.md | 434 +++++++++++++++++++------------------ plugins/git/git.plugin.zsh | 29 ++- 2 files changed, 242 insertions(+), 221 deletions(-) diff --git a/plugins/git/README.md b/plugins/git/README.md index 724965302..93dc8ccea 100644 --- a/plugins/git/README.md +++ b/plugins/git/README.md @@ -10,207 +10,205 @@ plugins=(... git) ## Aliases -| Alias | Command | -| :--------------------- | :------------------------------------------------------------------------------------------------------------------------------------------------------------------ | -| `grt` | `cd "$(git rev-parse --show-toplevel \|\| echo .)"` | -| `ggpnp` | `ggl && ggp` | -| `ggpur` | `ggu` | -| `g` | `git` | -| `ga` | `git add` | -| `gaa` | `git add --all` | -| `gapa` | `git add --patch` | -| `gau` | `git add --update` | -| `gav` | `git add --verbose` | -| `gwip` | `git add -A; git rm $(git ls-files --deleted) 2> /dev/null; git commit --no-verify --no-gpg-sign --message "--wip-- [skip ci]"` | -| `gam` | `git am` | -| `gama` | `git am --abort` | -| `gamc` | `git am --continue` | -| `gamscp` | `git am --show-current-patch` | -| `gams` | `git am --skip` | -| `gap` | `git apply` | -| `gapt` | `git apply --3way` | -| `gbs` | `git bisect` | -| `gbsb` | `git bisect bad` | -| `gbsg` | `git bisect good` | -| `gbsn` | `git bisect new` | -| `gbso` | `git bisect old` | -| `gbsr` | `git bisect reset` | -| `gbss` | `git bisect start` | -| `gbl` | `git blame -w` | -| `gb` | `git branch` | -| `gba` | `git branch --all` | -| `gbd` | `git branch --delete` | -| `gbD` | `git branch --delete --force` | -| `gbgd` | `LANG=C git branch --no-color -vv \| grep ": gone\]" \| awk '"'"'{print $1}'"'"' \| xargs git branch -d` | -| `gbgD` | `LANG=C git branch --no-color -vv \| grep ": gone\]" \| awk '"'"'{print $1}'"'"' \| xargs git branch -D` | -| `gbm` | `git branch --move` | -| `gbnm` | `git branch --no-merged` | -| `gbr` | `git branch --remote` | -| `ggsup` | `git branch --set-upstream-to=origin/$(git_current_branch)` | -| `gbg` | `LANG=C git branch -vv \| grep ": gone\]"` | -| `gco` | `git checkout` | -| `gcor` | `git checkout --recurse-submodules` | -| `gcb` | `git checkout -b` | -| `gcd` | `git checkout $(git_develop_branch)` | -| `gcm` | `git checkout $(git_main_branch)` | -| `gcp` | `git cherry-pick` | -| `gcpa` | `git cherry-pick --abort` | -| `gcpc` | `git cherry-pick --continue` | -| `gclean` | `git clean --interactive -d` | -| `gcl` | `git clone --recurse-submodules` | -| `gccd` | `git clone --recurse-submodules "$@" && cd "$(basename $\_ .git)"` | -| `gcam` | `git commit --all --message` | -| `gcas` | `git commit --all --signoff` | -| `gcasm` | `git commit --all --signoff --message` | -| `gcmsg` | `git commit --message` | -| `gcsm` | `git commit --signoff --message` | -| `gc` | `git commit --verbose` | -| `gca` | `git commit --verbose --all` | -| `gca!` | `git commit --verbose --all --amend` | -| `gcan!` | `git commit --verbose --all --no-edit --amend` | -| `gcans!` | `git commit --verbose --all --signoff --no-edit --amend` | -| `gc!` | `git commit --verbose --amend` | -| `gcn!` | `git commit --verbose --no-edit --amend` | -| `gcs` | `git commit -S` | -| `gcss` | `git commit -S -s` | -| `gcssm` | `git commit -S -s -m` | -| `gcf` | `git config --list` | -| `gdct` | `git describe --tags $(git rev-list --tags --max-count=1)` | -| `gd` | `git diff` | -| `gdca` | `git diff --cached` | -| `gdcw` | `git diff --cached --word-diff` | -| `gds` | `git diff --staged` | -| `gdw` | `git diff --word-diff` | -| `gdv` | `git diff -w "$@" \| view -` | -| `gdup` | `git diff @{upstream}` | -| `gdnolock` | `git diff $@ ":(exclude)package-lock.json" ":(exclude)\*.lock"` | -| `gdt` | `git diff-tree --no-commit-id --name-only -r` | -| `gf` | `git fetch` | -| `gfa` | `git fetch --all --prune` | -| `gfo` | `git fetch origin` | -| `gg` | `git gui citool` | -| `gga` | `git gui citool --amend` | -| `ghh` | `git help` | -| `glgg` | `git log --graph` | -| `glgga` | `git log --graph --decorate --all` | -| `glgm` | `git log --graph --max-count=10` | -| `glod` | `git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ad) %C(bold blue)<%an>%Creset'` | -| `glods` | `git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ad) %C(bold blue)<%an>%Creset' --date=short` | -| `glol` | `git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ar) %C(bold blue)<%an>%Creset'` | -| `glola` | `git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ar) %C(bold blue)<%an>%Creset' --all` | -| `glols` | `git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ar) %C(bold blue)<%an>%Creset' --stat` | -| `glo` | `git log --oneline --decorate` | -| `glog` | `git log --oneline --decorate --graph` | -| `gloga` | `git log --oneline --decorate --graph --all` | -| `glp` | `git log --pretty=` | -| `glg` | `git log --stat` | -| `glgp` | `git log --stat --patch` | -| `gignored` | `git ls-files -v \| grep "^[[:lower:]]"` | -| `gfg` | `git ls-files \| grep` | -| `gm` | `git merge` | -| `gma` | `git merge --abort` | -| `gms` | `git merge --squash` | -| `gmom` | `git merge origin/$(git_main_branch)` | -| `gmum` | `git merge upstream/$(git_main_branch)` | -| `gmtl` | `git mergetool --no-prompt` | -| `gmtlvim` | `git mergetool --no-prompt --tool=vimdiff` | -| `gl` | `git pull` | -| `gpr` | `git pull --rebase` | -| `gup` | `git pull --rebase` | -| `gupa` | `git pull --rebase --autostash` | -| `gupav` | `git pull --rebase --autostash --verbose` | -| `gupv` | `git pull --rebase --verbose` | -| `ggu` | `git pull --rebase origin $(current_branch)` | -| `gupom` | `git pull --rebase origin $(git_main_branch)` | -| `gupomi` | `git pull --rebase=interactive origin $(git_main_branch)` | -| `ggpull` | `git pull origin "$(git_current_branch)"` | -| `ggl` | `git pull origin $(current_branch)` | -| `gluc` | `git pull upstream $(git_current_branch)` | -| `glum` | `git pull upstream $(git_main_branch)` | -| `gp` | `git push` | -| `gpd` | `git push --dry-run` | -| `gpf!` | `git push --force` | -| `ggf` | `git push --force origin $(current_branch)` | -| `gpf` | On Git >= 2.30: `git push --force-with-lease --force-if-includes` | -| `gpf` | On Git < 2.30: `git push --force-with-lease` | -| `ggfl` | `git push --force-with-lease origin $(current_branch)` | -| `gpsup` | `git push --set-upstream origin $(git_current_branch)` | -| `gpsupf` | On Git >= 2.30: `git push --set-upstream origin $(git_current_branch) --force-with-lease --force-if-includes` | -| `gpsupf` | On Git < 2.30: `git push --set-upstream origin $(git_current_branch) --force-with-lease` | -| `gpv` | `git push --verbose` | -| `gpoat` | `git push origin --all && git push origin --tags` | -| `gpod` | `git push origin --delete` | -| `ggpush` | `git push origin "$(git_current_branch)"` | -| `ggp` | `git push origin $(current_branch)` | -| `gpu` | `git push upstream` | -| `grb` | `git rebase` | -| `grba` | `git rebase --abort` | -| `grbc` | `git rebase --continue` | -| `grbi` | `git rebase --interactive` | -| `grbo` | `git rebase --onto` | -| `grbs` | `git rebase --skip` | -| `grbd` | `git rebase $(git_develop_branch)` | -| `grbm` | `git rebase $(git_main_branch)` | -| `grbom` | `git rebase origin/$(git_main_branch)` | -| `gr` | `git remote` | -| `grv` | `git remote --verbose` | -| `gra` | `git remote add` | -| `grrm` | `git remote remove` | -| `grmv` | `git remote rename` | -| `grset` | `git remote set-url` | -| `grup` | `git remote update` | -| `grh` | `git reset` | -| `gru` | `git reset --` | -| `grhh` | `git reset --hard` | -| `grhk` | `git reset --keep` | -| `grhs` | `git reset --soft` | -| `gpristine` | `git reset --hard && git clean -dffx` | -| `groh` | `git reset origin/$(git_current_branch) --hard` | -| `grs` | `git restore` | -| `grss` | `git restore --source` | -| `grst` | `git restore --staged` | -| `gunwip` | `git rev-list --max-count=1 --format="%s" HEAD \| grep -q "--wip--" && git reset HEAD~1` | -| `grev` | `git revert` | -| `grm` | `git rm` | -| `grmc` | `git rm --cached` | -| `gcount` | `git shortlog --summary -n` | -| `gsh` | `git show` | -| `gsps` | `git show --pretty=short --show-signature` | -| `gstall` | `git stash --all` | -| `gstu` | `git stash --include-untracked` | -| `gstaa` | `git stash apply` | -| `gstc` | `git stash clear` | -| `gstd` | `git stash drop` | -| `gstl` | `git stash list` | -| `gstp` | `git stash pop` | -| `gsta` | On Git >= 2.13: `git stash push` | -| `gsta` | On Git < 2.13: `git stash save` | -| `gsts` | `git stash show --patch` | -| `gst` | `git status` | -| `gss` | `git status --short` | -| `gsb` | `git status --short -b` | -| `gsi` | `git submodule init` | -| `gsu` | `git submodule update` | -| `gsd` | `git svn dcommit` | -| `git-svn-dcommit-push` | `git svn dcommit && git push github $(git_main_branch):svntrunk` | -| `gsr` | `git svn rebase` | -| `gsw` | `git switch` | -| `gswc` | `git switch -c` | -| `gswd` | `git switch $(git_develop_branch)` | -| `gswm` | `git switch $(git_main_branch)` | -| `gta` | `git tag --annotate` | -| `gts` | `git tag -s` | -| `gtv` | `git tag \| sort -V` | -| `gignore` | `git update-index --assume-unchanged` | -| `gunignore` | `git update-index --no-assume-unchanged` | -| `gwch` | `git whatchanged -p --abbrev-commit --pretty=medium` | -| `gwt` | `git worktree` | -| `gwtls` | `git worktree list` | -| `gwtmv` | `git worktree move` | -| `gwtrm` | `git worktree remove` | -| `gk` | `gitk --all --branches &!` | -| `gke` | `gitk --all $(git log --walk-reflogs --pretty=%h) &!` | -| `gtl` | `gtl(){ git tag --sort=-v:refname -n --list ${1}\* }; noglob gtl` | +| Alias | Command | +| :--------------------- | :------------------------------------------------------------------------------------------------------------------------------ | +| `grt` | `cd "$(git rev-parse --show-toplevel \|\| echo .)"` | +| `ggpnp` | `ggl && ggp` | +| `ggpur` | `ggu` | +| `g` | `git` | +| `ga` | `git add` | +| `gaa` | `git add --all` | +| `gapa` | `git add --patch` | +| `gau` | `git add --update` | +| `gav` | `git add --verbose` | +| `gwip` | `git add -A; git rm $(git ls-files --deleted) 2> /dev/null; git commit --no-verify --no-gpg-sign --message "--wip-- [skip ci]"` | +| `gam` | `git am` | +| `gama` | `git am --abort` | +| `gamc` | `git am --continue` | +| `gamscp` | `git am --show-current-patch` | +| `gams` | `git am --skip` | +| `gap` | `git apply` | +| `gapt` | `git apply --3way` | +| `gbs` | `git bisect` | +| `gbsb` | `git bisect bad` | +| `gbsg` | `git bisect good` | +| `gbsn` | `git bisect new` | +| `gbso` | `git bisect old` | +| `gbsr` | `git bisect reset` | +| `gbss` | `git bisect start` | +| `gbl` | `git blame -w` | +| `gb` | `git branch` | +| `gba` | `git branch --all` | +| `gbd` | `git branch --delete` | +| `gbD` | `git branch --delete --force` | +| `gbgd` | `LANG=C git branch --no-color -vv \| grep ": gone\]" \| awk '"'"'{print $1}'"'"' \| xargs git branch -d` | +| `gbgD` | `LANG=C git branch --no-color -vv \| grep ": gone\]" \| awk '"'"'{print $1}'"'"' \| xargs git branch -D` | +| `gbm` | `git branch --move` | +| `gbnm` | `git branch --no-merged` | +| `gbr` | `git branch --remote` | +| `ggsup` | `git branch --set-upstream-to=origin/$(git_current_branch)` | +| `gbg` | `LANG=C git branch -vv \| grep ": gone\]"` | +| `gco` | `git checkout` | +| `gcor` | `git checkout --recurse-submodules` | +| `gcb` | `git checkout -b` | +| `gcd` | `git checkout $(git_develop_branch)` | +| `gcm` | `git checkout $(git_main_branch)` | +| `gcp` | `git cherry-pick` | +| `gcpa` | `git cherry-pick --abort` | +| `gcpc` | `git cherry-pick --continue` | +| `gclean` | `git clean --interactive -d` | +| `gcl` | `git clone --recurse-submodules` | +| `gccd` | `git clone --recurse-submodules "$@" && cd "$(basename $\_ .git)"` | +| `gcam` | `git commit --all --message` | +| `gcas` | `git commit --all --signoff` | +| `gcasm` | `git commit --all --signoff --message` | +| `gcmsg` | `git commit --message` | +| `gcsm` | `git commit --signoff --message` | +| `gc` | `git commit --verbose` | +| `gca` | `git commit --verbose --all` | +| `gca!` | `git commit --verbose --all --amend` | +| `gcan!` | `git commit --verbose --all --no-edit --amend` | +| `gcans!` | `git commit --verbose --all --signoff --no-edit --amend` | +| `gc!` | `git commit --verbose --amend` | +| `gcn!` | `git commit --verbose --no-edit --amend` | +| `gcs` | `git commit -S` | +| `gcss` | `git commit -S -s` | +| `gcssm` | `git commit -S -s -m` | +| `gcf` | `git config --list` | +| `gdct` | `git describe --tags $(git rev-list --tags --max-count=1)` | +| `gd` | `git diff` | +| `gdca` | `git diff --cached` | +| `gdcw` | `git diff --cached --word-diff` | +| `gds` | `git diff --staged` | +| `gdw` | `git diff --word-diff` | +| `gdv` | `git diff -w "$@" \| view -` | +| `gdup` | `git diff @{upstream}` | +| `gdnolock` | `git diff $@ ":(exclude)package-lock.json" ":(exclude)\*.lock"` | +| `gdt` | `git diff-tree --no-commit-id --name-only -r` | +| `gf` | `git fetch` | +| `gfa` | `git fetch --all --prune` | +| `gfo` | `git fetch origin` | +| `gg` | `git gui citool` | +| `gga` | `git gui citool --amend` | +| `ghh` | `git help` | +| `glgg` | `git log --graph` | +| `glgga` | `git log --graph --decorate --all` | +| `glgm` | `git log --graph --max-count=10` | +| `glod` | `git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ad) %C(bold blue)<%an>%Creset'` | +| `glods` | `git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ad) %C(bold blue)<%an>%Creset' --date=short` | +| `glol` | `git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ar) %C(bold blue)<%an>%Creset'` | +| `glola` | `git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ar) %C(bold blue)<%an>%Creset' --all` | +| `glols` | `git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ar) %C(bold blue)<%an>%Creset' --stat` | +| `glo` | `git log --oneline --decorate` | +| `glog` | `git log --oneline --decorate --graph` | +| `gloga` | `git log --oneline --decorate --graph --all` | +| `glp` | `git log --pretty=` | +| `glg` | `git log --stat` | +| `glgp` | `git log --stat --patch` | +| `gignored` | `git ls-files -v \| grep "^[[:lower:]]"` | +| `gfg` | `git ls-files \| grep` | +| `gm` | `git merge` | +| `gma` | `git merge --abort` | +| `gms` | `git merge --squash` | +| `gmom` | `git merge origin/$(git_main_branch)` | +| `gmum` | `git merge upstream/$(git_main_branch)` | +| `gmtl` | `git mergetool --no-prompt` | +| `gmtlvim` | `git mergetool --no-prompt --tool=vimdiff` | +| `gl` | `git pull` | +| `gpr` | `git pull --rebase` | +| `gprv` | `git pull --rebase -v` | +| `gpra` | `git pull --rebase --autostash` | +| `gprav` | `git pull --rebase --autostash -v` | +| `gprom` | `git pull --rebase origin $(git_main_branch)` | +| `gpromi` | `git pull --rebase=interactive origin $(git_main_branch)` | +| `ggpull` | `git pull origin "$(git_current_branch)"` | +| `ggl` | `git pull origin $(current_branch)` | +| `gluc` | `git pull upstream $(git_current_branch)` | +| `glum` | `git pull upstream $(git_main_branch)` | +| `gp` | `git push` | +| `gpd` | `git push --dry-run` | +| `gpf!` | `git push --force` | +| `ggf` | `git push --force origin $(current_branch)` | +| `gpf` | On Git >= 2.30: `git push --force-with-lease --force-if-includes` | +| `gpf` | On Git < 2.30: `git push --force-with-lease` | +| `ggfl` | `git push --force-with-lease origin $(current_branch)` | +| `gpsup` | `git push --set-upstream origin $(git_current_branch)` | +| `gpsupf` | On Git >= 2.30: `git push --set-upstream origin $(git_current_branch) --force-with-lease --force-if-includes` | +| `gpsupf` | On Git < 2.30: `git push --set-upstream origin $(git_current_branch) --force-with-lease` | +| `gpv` | `git push --verbose` | +| `gpoat` | `git push origin --all && git push origin --tags` | +| `gpod` | `git push origin --delete` | +| `ggpush` | `git push origin "$(git_current_branch)"` | +| `ggp` | `git push origin $(current_branch)` | +| `gpu` | `git push upstream` | +| `grb` | `git rebase` | +| `grba` | `git rebase --abort` | +| `grbc` | `git rebase --continue` | +| `grbi` | `git rebase --interactive` | +| `grbo` | `git rebase --onto` | +| `grbs` | `git rebase --skip` | +| `grbd` | `git rebase $(git_develop_branch)` | +| `grbm` | `git rebase $(git_main_branch)` | +| `grbom` | `git rebase origin/$(git_main_branch)` | +| `gr` | `git remote` | +| `grv` | `git remote --verbose` | +| `gra` | `git remote add` | +| `grrm` | `git remote remove` | +| `grmv` | `git remote rename` | +| `grset` | `git remote set-url` | +| `grup` | `git remote update` | +| `grh` | `git reset` | +| `gru` | `git reset --` | +| `grhh` | `git reset --hard` | +| `grhk` | `git reset --keep` | +| `grhs` | `git reset --soft` | +| `gpristine` | `git reset --hard && git clean -dffx` | +| `groh` | `git reset origin/$(git_current_branch) --hard` | +| `grs` | `git restore` | +| `grss` | `git restore --source` | +| `grst` | `git restore --staged` | +| `gunwip` | `git rev-list --max-count=1 --format="%s" HEAD \| grep -q "--wip--" && git reset HEAD~1` | +| `grev` | `git revert` | +| `grm` | `git rm` | +| `grmc` | `git rm --cached` | +| `gcount` | `git shortlog --summary -n` | +| `gsh` | `git show` | +| `gsps` | `git show --pretty=short --show-signature` | +| `gstall` | `git stash --all` | +| `gstu` | `git stash --include-untracked` | +| `gstaa` | `git stash apply` | +| `gstc` | `git stash clear` | +| `gstd` | `git stash drop` | +| `gstl` | `git stash list` | +| `gstp` | `git stash pop` | +| `gsta` | On Git >= 2.13: `git stash push` | +| `gsta` | On Git < 2.13: `git stash save` | +| `gsts` | `git stash show --patch` | +| `gst` | `git status` | +| `gss` | `git status --short` | +| `gsb` | `git status --short -b` | +| `gsi` | `git submodule init` | +| `gsu` | `git submodule update` | +| `gsd` | `git svn dcommit` | +| `git-svn-dcommit-push` | `git svn dcommit && git push github $(git_main_branch):svntrunk` | +| `gsr` | `git svn rebase` | +| `gsw` | `git switch` | +| `gswc` | `git switch -c` | +| `gswd` | `git switch $(git_develop_branch)` | +| `gswm` | `git switch $(git_main_branch)` | +| `gta` | `git tag --annotate` | +| `gts` | `git tag -s` | +| `gtv` | `git tag \| sort -V` | +| `gignore` | `git update-index --assume-unchanged` | +| `gunignore` | `git update-index --no-assume-unchanged` | +| `gwch` | `git whatchanged -p --abbrev-commit --pretty=medium` | +| `gwt` | `git worktree` | +| `gwtls` | `git worktree list` | +| `gwtmv` | `git worktree move` | +| `gwtrm` | `git worktree remove` | +| `gk` | `gitk --all --branches &!` | +| `gke` | `gitk --all $(git log --walk-reflogs --pretty=%h) &!` | +| `gtl` | `gtl(){ git tag --sort=-v:refname -n --list ${1}\* }; noglob gtl` | ### Main branch preference @@ -224,19 +222,25 @@ branch exists. We do this via the function `git_main_branch`. These are aliases that have been removed, renamed, or otherwise modified in a way that may, or may not, receive further support. -| Alias | Command | Modification | -| :------- | :----------------------------------------------------- | :-------------------------------------------------------- | -| `gap` | `git add --patch` | New alias: `gapa`. | -| `gcl` | `git config --list` | New alias: `gcf`. | -| `gdc` | `git diff --cached` | New alias: `gdca`. | -| `gdt` | `git difftool` | No replacement. | -| `ggpull` | `git pull origin $(current_branch)` | New alias: `ggl`. (`ggpull` still exists for now though.) | -| `ggpur` | `git pull --rebase origin $(current_branch)` | New alias: `ggu`. (`ggpur` still exists for now though.) | -| `ggpush` | `git push origin $(current_branch)` | New alias: `ggp`. (`ggpush` still exists for now though.) | -| `gk` | `gitk --all --branches` | Now aliased to `gitk --all --branches`. | -| `glg` | `git log --stat --max-count=10` | Now aliased to `git log --stat --color`. | -| `glgg` | `git log --graph --max-count=10` | Now aliased to `git log --graph --color`. | -| `gwc` | `git whatchanged -p --abbrev-commit --pretty = medium` | New alias: `gwch`. | +| Alias | Command | Modification | +| :------- | :-------------------------------------------------------- | :-------------------------------------------------------- | +| `gap` | `git add --patch` | New alias: `gapa`. | +| `gcl` | `git config --list` | New alias: `gcf`. | +| `gdc` | `git diff --cached` | New alias: `gdca`. | +| `gdt` | `git difftool` | No replacement. | +| `ggpull` | `git pull origin $(current_branch)` | New alias: `ggl`. (`ggpull` still exists for now though.) | +| `ggpur` | `git pull --rebase origin $(current_branch)` | New alias: `ggu`. (`ggpur` still exists for now though.) | +| `ggpush` | `git push origin $(current_branch)` | New alias: `ggp`. (`ggpush` still exists for now though.) | +| `gk` | `gitk --all --branches` | Now aliased to `gitk --all --branches`. | +| `glg` | `git log --stat --max-count=10` | Now aliased to `git log --stat --color`. | +| `glgg` | `git log --graph --max-count=10` | Now aliased to `git log --graph --color`. | +| `gwc` | `git whatchanged -p --abbrev-commit --pretty = medium` | New alias: `gwch`. | +| `gup` | `git pull --rebase` | now alias `gpr` | +| `gupv` | `git pull --rebase -v` | now alias `gprv` | +| `gupa` | `git pull --rebase --autostash` | now alias `gpra` | +| `gupav` | `git pull --rebase --autostash -v` | now alias `gprav` | +| `gupom` | `git pull --rebase origin $(git_main_branch)` | now alias `gprom` | +| `gupomi` | `git pull --rebase=interactive origin $(git_main_branch)` | now alias `gpromi` | ## Functions @@ -250,7 +254,7 @@ receive further support. | `git_develop_branch` | Returns the name of the “development” branch: `dev`, `devel`, `development` if they exist, `develop` otherwise. | | `git_main_branch` | Returns the name of the main branch: `main` if it exists, `master` otherwise. | | `grename ` | Renames branch `` to ``, including on the origin remote. | -| `gbda` | Deletes all merged branches | +| `gbda` | Deletes all merged branches | | `gbds` | Deletes all squash-merged branches (**Note: performance degrades with number of branches**) | ### Work in Progress (WIP) diff --git a/plugins/git/git.plugin.zsh b/plugins/git/git.plugin.zsh index 48937cb83..5ec2bbe2b 100644 --- a/plugins/git/git.plugin.zsh +++ b/plugins/git/git.plugin.zsh @@ -246,12 +246,12 @@ alias gmom='git merge origin/$(git_main_branch)' alias gmum='git merge upstream/$(git_main_branch)' alias gmtl='git mergetool --no-prompt' alias gmtlvim='git mergetool --no-prompt --tool=vimdiff' + alias gl='git pull' alias gpr='git pull --rebase' -alias gup='git pull --rebase' -alias gupa='git pull --rebase --autostash' -alias gupav='git pull --rebase --autostash --verbose' -alias gupv='git pull --rebase --verbose' +alias gprv='git pull --rebase -v' +alias gpra='git pull --rebase --autostash' +alias gprav='git pull --rebase --autostash -v' function ggu() { [[ "$#" != 1 ]] && local b="$(git_current_branch)" @@ -259,8 +259,8 @@ function ggu() { } compdef _git ggu=git-checkout -alias gupom='git pull --rebase origin $(git_main_branch)' -alias gupomi='git pull --rebase=interactive origin $(git_main_branch)' +alias gprom='git pull --rebase origin $(git_main_branch)' +alias gpromi='git pull --rebase=interactive origin $(git_main_branch)' alias ggpull='git pull origin "$(git_current_branch)"' function ggl() { @@ -388,3 +388,20 @@ alias gk='\gitk --all --branches &!' alias gke='\gitk --all $(git log --walk-reflogs --pretty=%h) &!' unset git_version + +# Logic for adding warnings on deprecated aliases +local old_alias new_alias +for old_alias new_alias ( + # TODO(2023-10-19): remove deprecated `git pull --rebase` aliases + gup gpr + gupv gprv + gupa gpra + gupav gprav + gupom gprom + gupomi gpromi +); do + aliases[$old_alias]=" + print -Pu2 \"%F{yellow}[oh-my-zsh] '%F{red}${old_alias}%F{yellow}' is a deprecated alias, using '%F{green}${new_alias}%F{yellow}' instead.%f\" + $new_alias" +done +unset old_alias new_alias From f79647dba5df47cd87917bcf527c5825be6511dc Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Thu, 19 Oct 2023 22:05:03 +0200 Subject: [PATCH 411/672] fix(git): fix check in `gbds` function --- plugins/git/git.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/git/git.plugin.zsh b/plugins/git/git.plugin.zsh index 5ec2bbe2b..eef538b75 100644 --- a/plugins/git/git.plugin.zsh +++ b/plugins/git/git.plugin.zsh @@ -141,7 +141,7 @@ function gbds() { git for-each-ref refs/heads/ "--format=%(refname:short)" | \ while read branch; do local merge_base=$(git merge-base $default_branch $branch) - if [[ '-*' == $(git cherry $default_branch $(git commit-tree $(git rev-parse $branch\^{tree}) -p $merge_base -m _)) ]]; then + if [[ $(git cherry $default_branch $(git commit-tree $(git rev-parse $branch\^{tree}) -p $merge_base -m _)) = -* ]]; then git branch -D $branch fi done From ff6dac56a256e376a10b19a4948ada7df4509c71 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Thu, 19 Oct 2023 23:04:08 +0200 Subject: [PATCH 412/672] fix(git): fix smart cd to cloned directory in `gccd` function --- plugins/git/git.plugin.zsh | 11 +++++++++-- 1 file changed, 9 insertions(+), 2 deletions(-) diff --git a/plugins/git/git.plugin.zsh b/plugins/git/git.plugin.zsh index eef538b75..6ea1d1177 100644 --- a/plugins/git/git.plugin.zsh +++ b/plugins/git/git.plugin.zsh @@ -166,8 +166,15 @@ alias gclean='git clean --interactive -d' alias gcl='git clone --recurse-submodules' function gccd() { - command git clone --recurse-submodules "$@" - [[ -d "$_" ]] && cd "$_" || cd "${${_:t}%.git}" + # get repo URI from args based on valid formats: https://git-scm.com/docs/git-clone#URLS + local repo="${${@[(r)(ssh://*|git://*|ftp(s)#://*|http(s)#://*|*@*)(.git/#)#]}:-$_}" + + # clone repository and exit if it fails + command git clone --recurse-submodules "$@" || return + + # if last arg passed was a directory, that's where the repo was cloned + # otherwise parse the repo URI and use the last part as the directory + [[ -d "$_" ]] && cd "$_" || cd "${${repo:t}%.git/#}" } compdef _git gccd=git-clone From 8428442ff0e0114fab32b90443911b11a4b7f5df Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Thu, 19 Oct 2023 23:24:55 +0200 Subject: [PATCH 413/672] fix(termsupport): add workaround for directory tracking issues in Konsole Fixes #11683 Related: 50c6786 --- lib/termsupport.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/termsupport.zsh b/lib/termsupport.zsh index a800e651f..d170ffcbf 100644 --- a/lib/termsupport.zsh +++ b/lib/termsupport.zsh @@ -151,7 +151,7 @@ function omz_termsupport_cwd { URL_PATH="$(omz_urlencode -P $PWD)" || return 1 # Konsole errors if the HOST is provided - [[ -z "$KONSOLE_VERSION" ]] || URL_HOST="" + [[ -z "$KONSOLE_PROFILE_NAME" && -z "$KONSOLE_DBUS_SESSION" ]] || URL_HOST="" # common control sequence (OSC 7) to set current host and path printf "\e]7;file://%s%s\e\\" "${URL_HOST}" "${URL_PATH}" From 465253396df1865d3c73b1b3cff243798960ca3f Mon Sep 17 00:00:00 2001 From: Amir Hosseini <19665344+itsamirhn@users.noreply.github.com> Date: Sun, 22 Oct 2023 12:00:25 +0330 Subject: [PATCH 414/672] fix(direnv): use `hook` instead of `export` (#12000) --- plugins/direnv/direnv.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/direnv/direnv.plugin.zsh b/plugins/direnv/direnv.plugin.zsh index 5e32c4c23..6f8debb62 100644 --- a/plugins/direnv/direnv.plugin.zsh +++ b/plugins/direnv/direnv.plugin.zsh @@ -3,7 +3,7 @@ command -v direnv &>/dev/null || return _direnv_hook() { trap -- '' SIGINT; - eval "$(direnv export zsh)"; + eval "$(direnv hook zsh)"; trap - SIGINT; } typeset -ag precmd_functions; From 1868c15ec6b13c2da20375780f1e8b8f61458be5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Mon, 23 Oct 2023 13:24:35 +0200 Subject: [PATCH 415/672] chore: remove mentions of huntr.dev huntr.dev has pivoted to ML/AI-only vulnerability reporting, and we are now already using GitHub's private vulnerability reports. --- README.md | 1 - SECURITY.md | 5 ++--- 2 files changed, 2 insertions(+), 4 deletions(-) diff --git a/README.md b/README.md index 308d117e1..499986879 100644 --- a/README.md +++ b/README.md @@ -17,7 +17,6 @@ To learn more, visit [ohmyz.sh](https://ohmyz.sh), follow [@ohmyzsh](https://twi [![Mastodon Follow](https://img.shields.io/mastodon/follow/111169632522566717?label=%40ohmyzsh&domain=https%3A%2F%2Fmstdn.social&logo=mastodon&style=flat)](https://mstdn.social/@ohmyzsh) [![Discord server](https://img.shields.io/discord/642496866407284746)](https://discord.gg/ohmyzsh) [![Gitpod ready](https://img.shields.io/badge/Gitpod-ready-blue?logo=gitpod)](https://gitpod.io/#https://github.com/ohmyzsh/ohmyzsh) -[![huntr.dev](https://cdn.huntr.dev/huntr_security_badge_mono.svg)](https://huntr.dev/bounties/disclose/?utm_campaign=ohmyzsh%2Fohmyzsh&utm_medium=social&utm_source=github&target=https%3A%2F%2Fgithub.com%2Fohmyzsh%2Fohmyzsh)
Table of Contents diff --git a/SECURITY.md b/SECURITY.md index 7e5c8eed0..ae7458ee2 100644 --- a/SECURITY.md +++ b/SECURITY.md @@ -17,8 +17,7 @@ In the near future we will introduce versioning, so expect this section to chang **Do not submit an issue or pull request**: this might reveal the vulnerability. -Instead, you should email the maintainers directly at: [**security@ohmyz.sh**](mailto:security@ohmyz.sh). +Instead, you should email the maintainers directly at: [**security@ohmyz.sh**](mailto:security@ohmyz.sh), +or using the link to [privately report a vulnerability with GitHub](https://github.com/ohmyzsh/ohmyzsh/security/advisories/new). We will deal with the vulnerability privately and submit a patch as soon as possible. - -You can also submit your vulnerability report to [huntr.dev](https://huntr.dev/bounties/disclose/?utm_campaign=ohmyzsh%2Fohmyzsh&utm_medium=social&utm_source=github&target=https%3A%2F%2Fgithub.com%2Fohmyzsh%2Fohmyzsh) and see if you can get a bounty reward. From b7904ae54867cd9e64dfd3c1f952d72b5cfe17be Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E5=AE=B6=E9=B3=96=E5=A4=A7=E5=B8=9D?= Date: Tue, 24 Oct 2023 19:33:04 +0800 Subject: [PATCH 416/672] fix(firewalld): remove ` (default)` from the end of zone string (#11998) --- plugins/firewalld/firewalld.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/firewalld/firewalld.plugin.zsh b/plugins/firewalld/firewalld.plugin.zsh index 5b1090636..b2c0f64be 100644 --- a/plugins/firewalld/firewalld.plugin.zsh +++ b/plugins/firewalld/firewalld.plugin.zsh @@ -9,7 +9,7 @@ function fwl () { zones=("${(@f)$(sudo firewall-cmd --get-active-zones | grep -v 'interfaces\|sources')}") for i in $zones; do - sudo firewall-cmd --zone $i --list-all + sudo firewall-cmd --zone ${i/ \(default\)} --list-all done echo 'Direct Rules:' From 5c22c5812ec8b980d223b8252edc7759dd354014 Mon Sep 17 00:00:00 2001 From: alps2006 Date: Tue, 24 Oct 2023 20:00:26 +0800 Subject: [PATCH 417/672] feat(vi-mode): allow replacing on visual mode (#12006) --- plugins/vi-mode/vi-mode.plugin.zsh | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/plugins/vi-mode/vi-mode.plugin.zsh b/plugins/vi-mode/vi-mode.plugin.zsh index d1493e02f..8fefaf86c 100644 --- a/plugins/vi-mode/vi-mode.plugin.zsh +++ b/plugins/vi-mode/vi-mode.plugin.zsh @@ -154,7 +154,8 @@ wrap_clipboard_widgets copy \ vi-delete vi-delete-char vi-backward-delete-char wrap_clipboard_widgets paste \ - vi-put-{before,after} + vi-put-{before,after} \ + put-replace-selection unfunction wrap_clipboard_widgets From 048455ccefdc67c4f137b8f7886769c55c2e5417 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Wed, 25 Oct 2023 19:47:10 +0200 Subject: [PATCH 418/672] fix(git-commit): fix revert alias conflict (#12007) Fixes #12007 --- plugins/git-commit/README.md | 14 ++++++++++---- plugins/git-commit/git-commit.plugin.zsh | 24 ++++++++++++++---------- 2 files changed, 24 insertions(+), 14 deletions(-) diff --git a/plugins/git-commit/README.md b/plugins/git-commit/README.md index dc10d8ad5..91cc73b44 100644 --- a/plugins/git-commit/README.md +++ b/plugins/git-commit/README.md @@ -10,7 +10,7 @@ plugins=(... git-commit) ## Syntax -```zshrc +```zsh git [(-s, --scope) ""] "" ``` @@ -26,11 +26,17 @@ Where `type` is one of the following: - `fix` - `perf` - `refactor` -- `revert` +- `rev` - `style` - `test` +> NOTE: the alias for `revert` type is `rev`, as otherwise it conflicts with the git command of the same name. +> It will still generate a commit message in the format `revert: ` + ## Examples -`git style "remove trailing whitespace"` -> `git commit -m "style: remove trailing whitespace"` -`git fix -s "router" "correct redirect link"` -> `git commit -m "fix(router): correct redirect link"` +| Git alias | Command | +| --------------------------------------------- | ---------------------------------------------------- | +| `git style "remove trailing whitespace"` | `git commit -m "style: remove trailing whitespace"` | +| `git fix -s "router" "correct redirect link"` | `git commit -m "fix(router): correct redirect link"` | +| `git rev -s "api" "rollback v2"` | `git commit -m "revert(api): rollback v2"` | diff --git a/plugins/git-commit/git-commit.plugin.zsh b/plugins/git-commit/git-commit.plugin.zsh index 4ad4c0177..72cecb1d6 100644 --- a/plugins/git-commit/git-commit.plugin.zsh +++ b/plugins/git-commit/git-commit.plugin.zsh @@ -1,9 +1,3 @@ -function _git_commit_register { - if ! git config --global --get-all alias.$1 >/dev/null 2>&1; then - git config --global alias.$1 '!a() { if [ "$1" = "-s" ] || [ "$1" = "--scope" ]; then local scope="$2"; shift 2; git commit -m "'$1'(${scope}): ${@}"; else git commit -m "'$1': ${@}"; fi }; a' - fi -} - local -a _git_commit_aliases _git_commit_aliases=( 'build' @@ -19,9 +13,19 @@ _git_commit_aliases=( 'test' ) -for _alias in "${_git_commit_aliases[@]}"; do - _git_commit_register $_alias +local alias type +for type in "${_git_commit_aliases[@]}"; do + # an alias can't be named "revert" because the git command takes precedence + # https://stackoverflow.com/a/3538791 + case "$type" in + revert) alias=rev ;; + *) alias=$type ;; + esac + + local func='!a() { if [ "$1" = "-s" ] || [ "$1" = "--scope" ]; then local scope="$2"; shift 2; git commit -m "'$type'(${scope}): ${@}"; else git commit -m "'$type': ${@}"; fi }; a' + if ! git config --global --get-all alias.${alias} >/dev/null 2>&1; then + git config --global alias.${alias} "$func" + fi done -unfunction _git_commit_register -unset _alias +unset _git_commit_aliases alias type func From 7348d12f8e5cd755037aa6f5d347eab0ac2efb0b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Sat, 28 Oct 2023 10:24:24 +0200 Subject: [PATCH 419/672] ci(vercel): add Content-Disposition header on installer This allows doing something like curl -O https://install.ohmyz.sh and have the `install.sh` file automatically saved to its right name. --- .github/workflows/installer/vercel.json | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/.github/workflows/installer/vercel.json b/.github/workflows/installer/vercel.json index 8c5aec5e0..524dc3c0f 100644 --- a/.github/workflows/installer/vercel.json +++ b/.github/workflows/installer/vercel.json @@ -2,7 +2,16 @@ "headers": [ { "source": "/((?!favicon.ico).*)", - "headers": [{ "key": "Content-Type", "value": "text/plain" }] + "headers": [ + { + "key": "Content-Type", + "value": "text/plain" + }, + { + "key": "Content-Disposition", + "value": "inline; filename=\"install.sh\"" + } + ] } ], "rewrites": [ From 7733e3ab57ee3f666cf6f3e699d03b69aca2d373 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Sat, 28 Oct 2023 10:29:54 +0200 Subject: [PATCH 420/672] ci: fix path filtering in installer workflow See https://docs.github.com/en/actions/using-workflows/workflow-syntax-for-github-actions#example-including-and-excluding-paths --- .github/workflows/installer.yml | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/.github/workflows/installer.yml b/.github/workflows/installer.yml index 4a25c8079..a70c483d1 100644 --- a/.github/workflows/installer.yml +++ b/.github/workflows/installer.yml @@ -3,9 +3,9 @@ on: workflow_dispatch: {} push: paths: - - tools/install.sh - - .github/workflows/installer - - .github/workflows/installer.yml + - 'tools/install.sh' + - '.github/workflows/installer/**' + - '.github/workflows/installer.yml' concurrency: group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }} From cb86d378f287f1731cc6ad907f6248e35b52dc25 Mon Sep 17 00:00:00 2001 From: Josh Hubbard Date: Sat, 28 Oct 2023 04:37:50 -0400 Subject: [PATCH 421/672] feat(git-auto-fetch): fetch also submodules (#12001) --- plugins/git-auto-fetch/git-auto-fetch.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/git-auto-fetch/git-auto-fetch.plugin.zsh b/plugins/git-auto-fetch/git-auto-fetch.plugin.zsh index 2df34bb7b..f8dfec759 100644 --- a/plugins/git-auto-fetch/git-auto-fetch.plugin.zsh +++ b/plugins/git-auto-fetch/git-auto-fetch.plugin.zsh @@ -29,7 +29,7 @@ function git-fetch-all { date -R &>! "$gitdir/FETCH_LOG" GIT_SSH_COMMAND="command ssh -o BatchMode=yes" \ GIT_TERMINAL_PROMPT=0 \ - command git fetch --all 2>/dev/null &>> "$gitdir/FETCH_LOG" + command git fetch --all --recurse-submodules=yes 2>/dev/null &>> "$gitdir/FETCH_LOG" ) &| } From 38c01a235fef0d990be5ece0d62f94fd06b10571 Mon Sep 17 00:00:00 2001 From: Sarah Noor <88581241+sarah-noor-12232@users.noreply.github.com> Date: Sat, 28 Oct 2023 20:48:45 +0500 Subject: [PATCH 422/672] feat(npm): add alias for `npm run build` (#12012) Closes #12010 --- plugins/npm/README.md | 1 + plugins/npm/npm.plugin.zsh | 3 +++ 2 files changed, 4 insertions(+) diff --git a/plugins/npm/README.md b/plugins/npm/README.md index 420dd710a..7848a1290 100644 --- a/plugins/npm/README.md +++ b/plugins/npm/README.md @@ -30,6 +30,7 @@ plugins=(... npm) | `npmi` | `npm info` | Run npm info | | `npmSe` | `npm search` | Run npm search | | `npmrd` | `npm run dev` | Run npm run dev | +| `npmrb` | `npm run build` | Run npm run build | ## `npm install` / `npm uninstall` toggle diff --git a/plugins/npm/npm.plugin.zsh b/plugins/npm/npm.plugin.zsh index 3cba18f6c..23377b085 100644 --- a/plugins/npm/npm.plugin.zsh +++ b/plugins/npm/npm.plugin.zsh @@ -73,6 +73,9 @@ alias npmSe="npm search" # Run npm run dev alias npmrd="npm run dev" +# Run npm run build +alias npmrb="npm run build" + npm_toggle_install_uninstall() { # Look up to the previous 2 history commands local line From 632ed413a9ce62747ded83d7736491b081be4b49 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Wed, 1 Nov 2023 21:24:28 +0100 Subject: [PATCH 423/672] fix(wd): use `(( ))` instead of `[[ ]]` zsh versions prior to 5.0.6 mark `[[ ]]` as invalid syntax Closes #12017 --- plugins/wd/wd.sh | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/plugins/wd/wd.sh b/plugins/wd/wd.sh index e51cf906a..840e92d61 100644 --- a/plugins/wd/wd.sh +++ b/plugins/wd/wd.sh @@ -396,7 +396,7 @@ fi # disable extendedglob for the complete wd execution time setopt | grep -q extendedglob wd_extglob_is_set=$? -[[ $wd_extglob_is_set ]] && setopt noextendedglob +(( ! $wd_extglob_is_set )) && setopt noextendedglob # load warp points typeset -A points @@ -484,7 +484,7 @@ fi # if not, next time warp will pick up variables from this run # remember, there's no sub shell -[[ $wd_extglob_is_set ]] && setopt extendedglob +(( ! $wd_extglob_is_set )) && setopt extendedglob unset wd_extglob_is_set unset wd_warp From b6bb133f230847ed0b3f9f4e25f2ceb874ca6c91 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Wed, 8 Nov 2023 08:42:34 +0100 Subject: [PATCH 424/672] fix(git): fix repository detection in `gccd` function (#12023) Fixes #12023 --- plugins/git/git.plugin.zsh | 2 ++ 1 file changed, 2 insertions(+) diff --git a/plugins/git/git.plugin.zsh b/plugins/git/git.plugin.zsh index 6ea1d1177..2a824444b 100644 --- a/plugins/git/git.plugin.zsh +++ b/plugins/git/git.plugin.zsh @@ -166,6 +166,8 @@ alias gclean='git clean --interactive -d' alias gcl='git clone --recurse-submodules' function gccd() { + setopt localoptions extendedglob + # get repo URI from args based on valid formats: https://git-scm.com/docs/git-clone#URLS local repo="${${@[(r)(ssh://*|git://*|ftp(s)#://*|http(s)#://*|*@*)(.git/#)#]}:-$_}" From c8e600f39779c6d2ef75b40304b5391a541c41df Mon Sep 17 00:00:00 2001 From: Thomas Luzat Date: Wed, 15 Nov 2023 12:53:39 +0100 Subject: [PATCH 425/672] fix(direnv): initialize properly direnv Closes #12038 Closes #12039 Co-authored-by: Carlo Sala --- plugins/direnv/direnv.plugin.zsh | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/plugins/direnv/direnv.plugin.zsh b/plugins/direnv/direnv.plugin.zsh index 6f8debb62..0a33194dd 100644 --- a/plugins/direnv/direnv.plugin.zsh +++ b/plugins/direnv/direnv.plugin.zsh @@ -3,14 +3,14 @@ command -v direnv &>/dev/null || return _direnv_hook() { trap -- '' SIGINT; - eval "$(direnv hook zsh)"; + eval "$(direnv export zsh)"; trap - SIGINT; } typeset -ag precmd_functions; -if [[ -z ${precmd_functions[(r)_direnv_hook]} ]]; then +if [[ -z "${precmd_functions[(r)_direnv_hook]+1}" ]]; then precmd_functions=( _direnv_hook ${precmd_functions[@]} ) fi typeset -ag chpwd_functions; -if [[ -z ${chpwd_functions[(r)_direnv_hook]} ]]; then +if [[ -z "${chpwd_functions[(r)_direnv_hook]+1}" ]]; then chpwd_functions=( _direnv_hook ${chpwd_functions[@]} ) fi From 6165c257ae56921bf44bfa7488fd5bf179ea0e61 Mon Sep 17 00:00:00 2001 From: nexpspace <380097+nexpspace@users.noreply.github.com> Date: Mon, 20 Nov 2023 12:25:22 +0100 Subject: [PATCH 426/672] fix(grc): source grc.zsh on gentoo (#12050) Co-authored-by: mphi Co-authored-by: Carlo Sala --- plugins/grc/grc.plugin.zsh | 1 + 1 file changed, 1 insertion(+) diff --git a/plugins/grc/grc.plugin.zsh b/plugins/grc/grc.plugin.zsh index e036b8d89..55ffc1a1e 100644 --- a/plugins/grc/grc.plugin.zsh +++ b/plugins/grc/grc.plugin.zsh @@ -5,6 +5,7 @@ files=( /etc/grc.zsh # default /usr/local/etc/grc.zsh # homebrew darwin-x64 /opt/homebrew/etc/grc.zsh # homebrew darwin-arm64 + /usr/share/grc/grc.zsh # Gentoo Linux (app-misc/grc) ) # verify the file is readable and source it From e0213342d12808e916dd02f8ac28509e71dc3283 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=C3=9E=C3=B3rhallur=20Sverrisson?= Date: Mon, 20 Nov 2023 11:27:54 +0000 Subject: [PATCH 427/672] feat(vi-mode): add option to disable clipboard (#12037) --- plugins/vi-mode/README.md | 2 ++ plugins/vi-mode/vi-mode.plugin.zsh | 20 +++++++++++--------- 2 files changed, 13 insertions(+), 9 deletions(-) diff --git a/plugins/vi-mode/README.md b/plugins/vi-mode/README.md index 821c12adb..84ba30105 100644 --- a/plugins/vi-mode/README.md +++ b/plugins/vi-mode/README.md @@ -37,6 +37,8 @@ plugins=(... vi-mode) - `INSERT_MODE_INDICATOR`: controls the string displayed when the shell is in insert mode. See [Mode indicators](#mode-indicators) for details. +- `VI_MODE_DISABLE_CLIPBOARD`: If set, disables clipboard integration on yank/paste + ## Mode indicators *Normal mode* is indicated with a red `<<<` mark at the right prompt, when it diff --git a/plugins/vi-mode/vi-mode.plugin.zsh b/plugins/vi-mode/vi-mode.plugin.zsh index 8fefaf86c..5c104f7bb 100644 --- a/plugins/vi-mode/vi-mode.plugin.zsh +++ b/plugins/vi-mode/vi-mode.plugin.zsh @@ -147,17 +147,19 @@ function wrap_clipboard_widgets() { done } -wrap_clipboard_widgets copy \ - vi-yank vi-yank-eol vi-yank-whole-line \ - vi-change vi-change-eol vi-change-whole-line \ - vi-kill-line vi-kill-eol vi-backward-kill-word \ - vi-delete vi-delete-char vi-backward-delete-char +if [[ -z "${VI_MODE_DISABLE_CLIPBOARD:-}" ]]; then + wrap_clipboard_widgets copy \ + vi-yank vi-yank-eol vi-yank-whole-line \ + vi-change vi-change-eol vi-change-whole-line \ + vi-kill-line vi-kill-eol vi-backward-kill-word \ + vi-delete vi-delete-char vi-backward-delete-char -wrap_clipboard_widgets paste \ - vi-put-{before,after} \ - put-replace-selection + wrap_clipboard_widgets paste \ + vi-put-{before,after} \ + put-replace-selection -unfunction wrap_clipboard_widgets + unfunction wrap_clipboard_widgets +fi # if mode indicator wasn't setup by theme, define default, we'll leave INSERT_MODE_INDICATOR empty by default if [[ -z "$MODE_INDICATOR" ]]; then From 22f9a8d3b8e3c229409579caff077ec90fbac9a3 Mon Sep 17 00:00:00 2001 From: "Babak K. Shandiz" Date: Mon, 20 Nov 2023 14:52:32 +0200 Subject: [PATCH 428/672] fix(juju): add `public-address` fallback to `jaddr` (#12046) --- plugins/juju/juju.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/juju/juju.plugin.zsh b/plugins/juju/juju.plugin.zsh index 0c60e35ce..a82ebaf84 100644 --- a/plugins/juju/juju.plugin.zsh +++ b/plugins/juju/juju.plugin.zsh @@ -98,7 +98,7 @@ jaddr() { elif [[ $# -eq 2 ]]; then # Get unit address juju status "$1/$2" --format=json \ - | jq -r ".applications.\"$1\".units.\"$1/$2\".address" + | jq -r ".applications.\"$1\".units.\"$1/$2\" | .address // .\"public-address\"" else echo "Invalid number of arguments." echo "Usage: jaddr []" From e6a1db213d66efdaec00469e58d4f9f3f2a78bd0 Mon Sep 17 00:00:00 2001 From: bretello Date: Mon, 20 Nov 2023 13:54:56 +0100 Subject: [PATCH 429/672] feat(bgnotify): add support to wayland (#12045) --- plugins/bgnotify/bgnotify.plugin.zsh | 28 ++++++++++++++++++---------- 1 file changed, 18 insertions(+), 10 deletions(-) diff --git a/plugins/bgnotify/bgnotify.plugin.zsh b/plugins/bgnotify/bgnotify.plugin.zsh index ed2653aa8..9ad989c0b 100644 --- a/plugins/bgnotify/bgnotify.plugin.zsh +++ b/plugins/bgnotify/bgnotify.plugin.zsh @@ -59,11 +59,14 @@ function bgnotify_formatted { fi } -# for macOS, output is "app ID, window ID" (com.googlecode.iterm2, 116) function bgnotify_appid { if (( ${+commands[osascript]} )); then + # output is "app ID, window ID" (com.googlecode.iterm2, 116) osascript -e 'tell application (path to frontmost application as text) to get the {id, id of front window}' 2>/dev/null - elif (( ${+commands[xprop]} )); then + elif [[ -n $WAYLAND_DISPLAY && ${+commands[swaymsg]} && ${+commands[jq]} ]]; then # wayland+sway + # output is "app_id, container id" (Alacritty, 1694) + swaymsg -t get_tree | jq '.. | select(.type?) | select(.focused==true) | {app_id, id} | join(", ")' + elif [[ -n $DISPLAY && ${+commands[xprop]} ]]; then xprop -root _NET_ACTIVE_WINDOW 2>/dev/null | cut -d' ' -f5 else echo $EPOCHSECONDS @@ -71,7 +74,8 @@ function bgnotify_appid { } function bgnotify { - # $1: title, $2: message + local title="$1" + local message="$2" if (( ${+commands[terminal-notifier]} )); then # macOS local term_id="${bgnotify_termid%%,*}" # remove window id if [[ -z "$term_id" ]]; then @@ -82,18 +86,22 @@ function bgnotify { fi if [[ -z "$term_id" ]]; then - terminal-notifier -message "$2" -title "$1" &>/dev/null + terminal-notifier -message "$message" -title "$title" &>/dev/null else - terminal-notifier -message "$2" -title "$1" -activate "$term_id" -sender "$term_id" &>/dev/null + terminal-notifier -message "$message" -title "$title" -activate "$term_id" -sender "$term_id" &>/dev/null fi elif (( ${+commands[growlnotify]} )); then # macOS growl - growlnotify -m "$1" "$2" - elif (( ${+commands[notify-send]} )); then # GNOME - notify-send "$1" "$2" + growlnotify -m "$title" "$message" + elif (( ${+commands[notify-send]} )); then + if [[ -n $ALACRITTY_WINDOW_ID ]]; then + notify-send -i Alacritty "$title" "$message" + else + notify-send "$title" "$message" + fi elif (( ${+commands[kdialog]} )); then # KDE - kdialog --title "$1" --passivepopup "$2" 5 + kdialog --title "$title" --passivepopup "$message" 5 elif (( ${+commands[notifu]} )); then # cygwin - notifu /m "$2" /p "$1" + notifu /m "$message" /p "$title" fi } From 18073af622703a8aca28c630614d13d2f50d30fe Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Wed, 22 Nov 2023 15:22:36 +0100 Subject: [PATCH 430/672] fix(bgnotify): detect properly if `swaymsg` is installed Closes #12053 --- plugins/bgnotify/bgnotify.plugin.zsh | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/plugins/bgnotify/bgnotify.plugin.zsh b/plugins/bgnotify/bgnotify.plugin.zsh index 9ad989c0b..493a20815 100644 --- a/plugins/bgnotify/bgnotify.plugin.zsh +++ b/plugins/bgnotify/bgnotify.plugin.zsh @@ -63,10 +63,10 @@ function bgnotify_appid { if (( ${+commands[osascript]} )); then # output is "app ID, window ID" (com.googlecode.iterm2, 116) osascript -e 'tell application (path to frontmost application as text) to get the {id, id of front window}' 2>/dev/null - elif [[ -n $WAYLAND_DISPLAY && ${+commands[swaymsg]} && ${+commands[jq]} ]]; then # wayland+sway + elif [[ -n $WAYLAND_DISPLAY ]] && (( ${+commands[swaymsg]} )) && (( ${+commands[jq]} )); then # wayland+sway # output is "app_id, container id" (Alacritty, 1694) swaymsg -t get_tree | jq '.. | select(.type?) | select(.focused==true) | {app_id, id} | join(", ")' - elif [[ -n $DISPLAY && ${+commands[xprop]} ]]; then + elif [[ -n $DISPLAY ]] && (( ${+commands[xprop]} )); then xprop -root _NET_ACTIVE_WINDOW 2>/dev/null | cut -d' ' -f5 else echo $EPOCHSECONDS From 44a5513fcb3f528afb056490908d216f926497e6 Mon Sep 17 00:00:00 2001 From: Saduff <11700507+Saduff@users.noreply.github.com> Date: Wed, 22 Nov 2023 10:44:21 -0700 Subject: [PATCH 431/672] fix(per-directory-history): print toggle message properly (#10872) --- plugins/per-directory-history/per-directory-history.zsh | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/plugins/per-directory-history/per-directory-history.zsh b/plugins/per-directory-history/per-directory-history.zsh index acbd64757..cfc4535d3 100644 --- a/plugins/per-directory-history/per-directory-history.zsh +++ b/plugins/per-directory-history/per-directory-history.zsh @@ -68,14 +68,14 @@ function per-directory-history-toggle-history() { if [[ $_per_directory_history_is_global == true ]]; then _per-directory-history-set-directory-history _per_directory_history_is_global=false - print -n "\nusing local history" + zle -I + echo "using local history" else _per-directory-history-set-global-history _per_directory_history_is_global=true - print -n "\nusing global history" + zle -I + echo "using global history" fi - zle .push-line - zle .accept-line } autoload per-directory-history-toggle-history From 38e80e9f21ee981b5f616003c788dcbb9267466c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Johan=20Sj=C3=B6blom?= Date: Thu, 23 Nov 2023 10:11:08 +0000 Subject: [PATCH 432/672] feat(bgnotify): add icon parameter (#12055) --- plugins/bgnotify/bgnotify.plugin.zsh | 23 ++++++++--------------- 1 file changed, 8 insertions(+), 15 deletions(-) diff --git a/plugins/bgnotify/bgnotify.plugin.zsh b/plugins/bgnotify/bgnotify.plugin.zsh index 493a20815..a4a7b621b 100644 --- a/plugins/bgnotify/bgnotify.plugin.zsh +++ b/plugins/bgnotify/bgnotify.plugin.zsh @@ -52,10 +52,10 @@ function bgnotify_formatted { (( $3 < 60 )) || elapsed="$((( $3 % 3600) / 60 ))m $elapsed" (( $3 < 3600 )) || elapsed="$(( $3 / 3600 ))h $elapsed" - if [[ $1 -eq 0 ]]; then - bgnotify "#win (took $elapsed)" "$2" + if [[ $exit_status -eq 0 ]]; then + bgnotify "#win (took $elapsed)" "$cmd" else - bgnotify "#fail (took $elapsed)" "$2" + bgnotify "#fail (took $elapsed)" "$cmd" fi } @@ -66,7 +66,7 @@ function bgnotify_appid { elif [[ -n $WAYLAND_DISPLAY ]] && (( ${+commands[swaymsg]} )) && (( ${+commands[jq]} )); then # wayland+sway # output is "app_id, container id" (Alacritty, 1694) swaymsg -t get_tree | jq '.. | select(.type?) | select(.focused==true) | {app_id, id} | join(", ")' - elif [[ -n $DISPLAY ]] && (( ${+commands[xprop]} )); then + elif [[ -z $WAYLAND_DISPLAY ]] && [[ -n $DISPLAY ]] && (( ${+commands[xprop]} )); then xprop -root _NET_ACTIVE_WINDOW 2>/dev/null | cut -d' ' -f5 else echo $EPOCHSECONDS @@ -76,6 +76,7 @@ function bgnotify_appid { function bgnotify { local title="$1" local message="$2" + local icon="$3" if (( ${+commands[terminal-notifier]} )); then # macOS local term_id="${bgnotify_termid%%,*}" # remove window id if [[ -z "$term_id" ]]; then @@ -85,23 +86,15 @@ function bgnotify { esac fi - if [[ -z "$term_id" ]]; then - terminal-notifier -message "$message" -title "$title" &>/dev/null - else - terminal-notifier -message "$message" -title "$title" -activate "$term_id" -sender "$term_id" &>/dev/null - fi + terminal-notifier -message "$message" -title "$title" ${=icon:+-appIcon "$icon"} ${=term_id:+-activate "$term_id" -sender "$term_id"} &>/dev/null elif (( ${+commands[growlnotify]} )); then # macOS growl growlnotify -m "$title" "$message" elif (( ${+commands[notify-send]} )); then - if [[ -n $ALACRITTY_WINDOW_ID ]]; then - notify-send -i Alacritty "$title" "$message" - else - notify-send "$title" "$message" - fi + notify-send "$title" "$message" ${=icon:+--icon "$icon"} elif (( ${+commands[kdialog]} )); then # KDE kdialog --title "$title" --passivepopup "$message" 5 elif (( ${+commands[notifu]} )); then # cygwin - notifu /m "$message" /p "$title" + notifu /m "$message" /p "$title" ${=icon:+/i "$icon"} fi } From 6c5586cb085d5cc6fb42b7304428654cc6bf5f31 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Johan=20Sj=C3=B6blom?= Date: Thu, 23 Nov 2023 19:00:34 +0000 Subject: [PATCH 433/672] docs(bgnotify): match README with current features (#12057) --- plugins/bgnotify/README.md | 27 +++++++++++++++++---------- 1 file changed, 17 insertions(+), 10 deletions(-) diff --git a/plugins/bgnotify/README.md b/plugins/bgnotify/README.md index 1d8fac54d..6bbe3b302 100644 --- a/plugins/bgnotify/README.md +++ b/plugins/bgnotify/README.md @@ -1,19 +1,19 @@ # bgnotify zsh plugin -cross-platform background notifications for long running commands! Supports OSX and Ubuntu linux. +cross-platform background notifications for long running commands! Supports OSX and Linux. Standalone homepage: [t413/zsh-background-notify](https://github.com/t413/zsh-background-notify) ----------------------------------- +--- -## How to use! +## How to use Just add bgnotify to your plugins list in your `.zshrc` - On OS X you'll need [terminal-notifier](https://github.com/alloy/terminal-notifier) * `brew install terminal-notifier` (or `gem install terminal-notifier`) -- On ubuntu you're already all set! -- On windows you can use [notifu](https://www.paralint.com/projects/notifu/) or the Cygwin Ports libnotify package +- On Linux, make sure you have `notify-send` or `kdialog` installed. If you're using Ubuntu you should already be all set! +- On Windows you can use [notifu](https://www.paralint.com/projects/notifu/) or the Cygwin Ports libnotify package ## Screenshots @@ -36,19 +36,26 @@ Just add bgnotify to your plugins list in your `.zshrc` One can configure a few things: - `bgnotify_threshold` sets the notification threshold time (default 6 seconds) -- `function bgnotify_formatted` lets you change the notification +- `function bgnotify_formatted` lets you change the notification. You can for instance customize the message and pass in an icon. Use these by adding a function definition before the your call to source. Example: -~~~ sh +```sh bgnotify_threshold=4 ## set your own notification threshold function bgnotify_formatted { ## $1=exit_status, $2=command, $3=elapsed_time - [ $1 -eq 0 ] && title="Holy Smokes Batman!" || title="Holy Graf Zeppelin!" - bgnotify "$title -- after $3 s" "$2"; + + # Humanly readable elapsed time + local elapsed="$(( $3 % 60 ))s" + (( $3 < 60 )) || elapsed="$((( $3 % 3600) / 60 ))m $elapsed" + (( $3 < 3600 )) || elapsed="$(( $3 / 3600 ))h $elapsed" + + [ $1 -eq 0 ] && title="Holy Smokes Batman" || title="Holy Graf Zeppelin" + [ $1 -eq 0 ] && icon="$HOME/icons/success.png" || icon="$HOME/icons/fail.png" + bgnotify "$title - took ${elapsed}" "$2" "$icon" } plugins=(git bgnotify) ## add to plugins list source $ZSH/oh-my-zsh.sh ## existing source call -~~~ +``` From 76a1dfcf2b5365e966bbc75749d9ced985c2d674 Mon Sep 17 00:00:00 2001 From: Mamad Kajbaf Date: Thu, 23 Nov 2023 11:03:59 -0800 Subject: [PATCH 434/672] feat(docker-compose): add `dclF` alias (#10603) --- plugins/docker-compose/README.md | 41 ++++++++++--------- .../docker-compose/docker-compose.plugin.zsh | 1 + 2 files changed, 22 insertions(+), 20 deletions(-) diff --git a/plugins/docker-compose/README.md b/plugins/docker-compose/README.md index bbcff2e0c..66d4e0521 100644 --- a/plugins/docker-compose/README.md +++ b/plugins/docker-compose/README.md @@ -11,23 +11,24 @@ plugins=(... docker-compose) ## Aliases -| Alias | Command | Description | -|-----------|--------------------------------|----------------------------------------------------------------------------------| -| dco | `docker-compose` | Docker-compose main command | -| dcb | `docker-compose build` | Build containers | -| dce | `docker-compose exec` | Execute command inside a container | -| dcps | `docker-compose ps` | List containers | -| dcrestart | `docker-compose restart` | Restart container | -| dcrm | `docker-compose rm` | Remove container | -| dcr | `docker-compose run` | Run a command in container | -| dcstop | `docker-compose stop` | Stop a container | -| dcup | `docker-compose up` | Build, (re)create, start, and attach to containers for a service | -| dcupb | `docker-compose up --build` | Same as `dcup`, but build images before starting containers | -| dcupd | `docker-compose up -d` | Same as `dcup`, but starts as daemon | -| dcupdb | `docker-compose up -d --build` | Same as `dcup`, but build images before starting containers and starts as daemon | -| dcdn | `docker-compose down` | Stop and remove containers | -| dcl | `docker-compose logs` | Show logs of container | -| dclf | `docker-compose logs -f` | Show logs and follow output | -| dcpull | `docker-compose pull` | Pull image of a service | -| dcstart | `docker-compose start` | Start a container | -| dck | `docker-compose kill` | Kills containers | +| Alias | Command | Description | +|-----------|----------------------------------|----------------------------------------------------------------------------------| +| dco | `docker-compose` | Docker-compose main command | +| dcb | `docker-compose build` | Build containers | +| dce | `docker-compose exec` | Execute command inside a container | +| dcps | `docker-compose ps` | List containers | +| dcrestart | `docker-compose restart` | Restart container | +| dcrm | `docker-compose rm` | Remove container | +| dcr | `docker-compose run` | Run a command in container | +| dcstop | `docker-compose stop` | Stop a container | +| dcup | `docker-compose up` | Build, (re)create, start, and attach to containers for a service | +| dcupb | `docker-compose up --build` | Same as `dcup`, but build images before starting containers | +| dcupd | `docker-compose up -d` | Same as `dcup`, but starts as daemon | +| dcupdb | `docker-compose up -d --build` | Same as `dcup`, but build images before starting containers and starts as daemon | +| dcdn | `docker-compose down` | Stop and remove containers | +| dcl | `docker-compose logs` | Show logs of container | +| dclf | `docker-compose logs -f` | Show logs and follow output | +| dclF | `docker-compose logs -f --tail0` | Just follow recent logs | +| dcpull | `docker-compose pull` | Pull image of a service | +| dcstart | `docker-compose start` | Start a container | +| dck | `docker-compose kill` | Kills containers | diff --git a/plugins/docker-compose/docker-compose.plugin.zsh b/plugins/docker-compose/docker-compose.plugin.zsh index 7a8bf4a03..d1823f535 100644 --- a/plugins/docker-compose/docker-compose.plugin.zsh +++ b/plugins/docker-compose/docker-compose.plugin.zsh @@ -16,6 +16,7 @@ alias dcupdb="$dccmd up -d --build" alias dcdn="$dccmd down" alias dcl="$dccmd logs" alias dclf="$dccmd logs -f" +alias dclF="$dccmd logs -f --tail 0" alias dcpull="$dccmd pull" alias dcstart="$dccmd start" alias dck="$dccmd kill" From ddf673b36dd43e5ca60189a117c25ad6f55457e7 Mon Sep 17 00:00:00 2001 From: MikuHatsune39 <32179075+MikuHatsune39@users.noreply.github.com> Date: Fri, 24 Nov 2023 00:35:46 -0800 Subject: [PATCH 435/672] fix(python): set `py` alias if `py` is not installed (#12059) Co-authored-by: Carlo Sala --- plugins/python/README.md | 2 +- plugins/python/python.plugin.zsh | 4 ++-- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/plugins/python/README.md b/plugins/python/README.md index 97c1a34ee..7bf1b34ac 100644 --- a/plugins/python/README.md +++ b/plugins/python/README.md @@ -12,7 +12,7 @@ plugins=(... python) | Command | Description | | ---------------- | -------------------------------------------------------------------------------------- | -| `py` | Runs `python3` | +| `py` | Runs `python3`. Only set if `py` is not installed. | | `ipython` | Runs the appropriate `ipython` version according to the activated virtualenv | | `pyfind` | Finds .py files recursively in the current directory | | `pyclean [dirs]` | Deletes byte-code and cache files from a list of directories or the current one | diff --git a/plugins/python/python.plugin.zsh b/plugins/python/python.plugin.zsh index 2fbb59577..3d7ca55c9 100644 --- a/plugins/python/python.plugin.zsh +++ b/plugins/python/python.plugin.zsh @@ -1,5 +1,5 @@ -# python command -alias py='python3' +# set python command if 'py' not installed +builtin which py > /dev/null || alias py='python3' # Find python file alias pyfind='find . -name "*.py"' From e11d81303753b0fefbc50ce10ec4612c7ff33e84 Mon Sep 17 00:00:00 2001 From: Yuxuan Lu Date: Fri, 24 Nov 2023 03:45:32 -0500 Subject: [PATCH 436/672] fix(robbyrussell): line wrapping for some systems (#12058) --- themes/robbyrussell.zsh-theme | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/themes/robbyrussell.zsh-theme b/themes/robbyrussell.zsh-theme index 173e6d579..cfecfc892 100644 --- a/themes/robbyrussell.zsh-theme +++ b/themes/robbyrussell.zsh-theme @@ -1,7 +1,7 @@ -PROMPT="%(?:%{$fg_bold[green]%}➜ :%{$fg_bold[red]%}➜ ) %{$fg[cyan]%}%c%{$reset_color%}" +PROMPT="%(?:%{$fg_bold[green]%}%1{➜%} :%{$fg_bold[red]%}%1{➜%} ) %{$fg[cyan]%}%c%{$reset_color%}" PROMPT+=' $(git_prompt_info)' ZSH_THEME_GIT_PROMPT_PREFIX="%{$fg_bold[blue]%}git:(%{$fg[red]%}" ZSH_THEME_GIT_PROMPT_SUFFIX="%{$reset_color%} " -ZSH_THEME_GIT_PROMPT_DIRTY="%{$fg[blue]%}) %{$fg[yellow]%}✗" +ZSH_THEME_GIT_PROMPT_DIRTY="%{$fg[blue]%}) %{$fg[yellow]%}%1{✗%}" ZSH_THEME_GIT_PROMPT_CLEAN="%{$fg[blue]%})" From 7e3fdf33ec53821e574b8d6df43bec7264c507ee Mon Sep 17 00:00:00 2001 From: Bernard Grymonpon Date: Mon, 27 Nov 2023 11:07:51 +0100 Subject: [PATCH 437/672] fix(misc): only set PAGER if `less` or `more` are available (#12060) --- lib/misc.zsh | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/lib/misc.zsh b/lib/misc.zsh index 132f33551..ff2017713 100644 --- a/lib/misc.zsh +++ b/lib/misc.zsh @@ -19,8 +19,13 @@ setopt multios # enable redirect to multiple streams: echo >file1 > setopt long_list_jobs # show long list format job notifications setopt interactivecomments # recognize comments -env_default 'PAGER' 'less' -env_default 'LESS' '-R' +# define pager dependant on what is available (less or more) +if (( ${+commands[less]} )); then + env_default 'PAGER' 'less' + env_default 'LESS' '-R' +elif (( ${+commands[more]} )); then + env_default 'PAGER' 'more' +fi ## super user alias alias _='sudo ' From 418046e9583f635b0303e4b8cf31c356b175cec3 Mon Sep 17 00:00:00 2001 From: cohml <62400541+cohml@users.noreply.github.com> Date: Wed, 29 Nov 2023 04:15:32 -0500 Subject: [PATCH 438/672] feat(per-directory-history): add option to reduce verbosity (#12069) Co-authored-by: Chris Hamill --- plugins/per-directory-history/README.md | 2 ++ .../per-directory-history/per-directory-history.zsh | 11 +++++++---- 2 files changed, 9 insertions(+), 4 deletions(-) diff --git a/plugins/per-directory-history/README.md b/plugins/per-directory-history/README.md index 69854aa38..11150b059 100644 --- a/plugins/per-directory-history/README.md +++ b/plugins/per-directory-history/README.md @@ -34,6 +34,8 @@ toggle set the `PER_DIRECTORY_HISTORY_TOGGLE` environment variable. and global histories. * `PER_DIRECTORY_HISTORY_TOGGLE` is the key binding used to run the toggle-history function above (default `^G`) +* `PER_DIRECTORY_HISTORY_PRINT_MODE_CHANGE` is a variable which toggles whether + the current mode is printed to the screen following a mode change (default `true`) ## History diff --git a/plugins/per-directory-history/per-directory-history.zsh b/plugins/per-directory-history/per-directory-history.zsh index cfc4535d3..b33e0b5dd 100644 --- a/plugins/per-directory-history/per-directory-history.zsh +++ b/plugins/per-directory-history/per-directory-history.zsh @@ -59,6 +59,7 @@ [[ -z $HISTORY_BASE ]] && HISTORY_BASE="$HOME/.directory_history" [[ -z $HISTORY_START_WITH_GLOBAL ]] && HISTORY_START_WITH_GLOBAL=false [[ -z $PER_DIRECTORY_HISTORY_TOGGLE ]] && PER_DIRECTORY_HISTORY_TOGGLE='^G' +[[ -z $PER_DIRECTORY_HISTORY_PRINT_MODE_CHANGE ]] && PER_DIRECTORY_HISTORY_PRINT_MODE_CHANGE=true #------------------------------------------------------------------------------- # toggle global/directory history used for searching - ctrl-G by default @@ -68,13 +69,15 @@ function per-directory-history-toggle-history() { if [[ $_per_directory_history_is_global == true ]]; then _per-directory-history-set-directory-history _per_directory_history_is_global=false - zle -I - echo "using local history" + if [[ $PER_DIRECTORY_HISTORY_PRINT_MODE_CHANGE == true ]]; then + zle -M "using local history" + fi else _per-directory-history-set-global-history _per_directory_history_is_global=true - zle -I - echo "using global history" + if [[ $PER_DIRECTORY_HISTORY_PRINT_MODE_CHANGE == true ]]; then + zle -M "using global history" + fi fi } From 7a30bcae40dfd19153ad6fc4abd52dfa805dbd03 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Thu, 30 Nov 2023 14:15:21 +0100 Subject: [PATCH 439/672] ci(installer): fix token passing and only run on main repo --- .github/workflows/installer.yml | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/.github/workflows/installer.yml b/.github/workflows/installer.yml index a70c483d1..cad5d445b 100644 --- a/.github/workflows/installer.yml +++ b/.github/workflows/installer.yml @@ -17,6 +17,7 @@ permissions: jobs: test: name: Test installer + if: github.repository == 'ohmyzsh/ohmyzsh' runs-on: ${{ matrix.os }} strategy: matrix: @@ -48,7 +49,8 @@ jobs: env: VERCEL_ORG_ID: ${{ secrets.VERCEL_ORG_ID }} VERCEL_PROJECT_ID: ${{ secrets.VERCEL_PROJECT_ID }} + VERCEL_TOKEN: ${{ secrets.VERCEL_TOKEN }} run: | cp tools/install.sh .github/workflows/installer/install.sh cd .github/workflows/installer - vc deploy --prod -t ${{ secrets.VERCEL_TOKEN }} + vc deploy --prod -t "$VERCEL_TOKEN" From f9993d0c687c0fb50490aa530adee57ea4c70c12 Mon Sep 17 00:00:00 2001 From: "Olivia (Zoe)" Date: Fri, 1 Dec 2023 16:06:50 +0100 Subject: [PATCH 440/672] docs: document the off-GitHub installation URL (#12079) --- README.md | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/README.md b/README.md index 499986879..98743432d 100644 --- a/README.md +++ b/README.md @@ -88,6 +88,14 @@ Oh My Zsh is installed by running one of the following commands in your terminal | **wget** | `sh -c "$(wget -O- https://raw.githubusercontent.com/ohmyzsh/ohmyzsh/master/tools/install.sh)"` | | **fetch** | `sh -c "$(fetch -o - https://raw.githubusercontent.com/ohmyzsh/ohmyzsh/master/tools/install.sh)"` | +Alternatively, the installer is also mirrored outside GitHub. Using this URL instead may be required if you're in a country like India or China, that blocks `raw.githubusercontent.com`: + +| Method | Command | +| :-------- | :------------------------------------------------------------------------------------------------ | +| **curl** | `sh -c "$(curl -fsSL https://install.ohmyz.sh/)"` | +| **wget** | `sh -c "$(wget -O- https://install.ohmyz.sh/)"` | +| **fetch** | `sh -c "$(fetch -o - https://install.ohmyz.sh/)"` | + _Note that any previous `.zshrc` will be renamed to `.zshrc.pre-oh-my-zsh`. After installation, you can move the configuration you want to preserve into the new `.zshrc`._ #### Manual Inspection @@ -101,6 +109,8 @@ wget https://raw.githubusercontent.com/ohmyzsh/ohmyzsh/master/tools/install.sh sh install.sh ``` +If the above URL times out or otherwise fails, you may have to substitute the URL for `https://install.ohmyz.sh` to be able to get the script. + ## Using Oh My Zsh ### Plugins @@ -220,6 +230,8 @@ the default shell, and it also won't run `zsh` when the installation has finishe sh -c "$(curl -fsSL https://raw.githubusercontent.com/ohmyzsh/ohmyzsh/master/tools/install.sh)" "" --unattended ``` +If you're in China, India, or another country that blocks `raw.githubusercontent.com`, you may have to substitute the URL for `https://install.ohmyz.sh` for it to install. + #### Installing From A Forked Repository The install script also accepts these variables to allow installation of a different repository: From 9b5b389c22396552086480474c108380817a44a7 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Johan=20Sj=C3=B6blom?= Date: Sat, 25 Nov 2023 11:27:59 +0100 Subject: [PATCH 441/672] refactor(bgnotify): get Sway AppId with `awk` as fallback (#12062) Closes #12062 --- plugins/bgnotify/bgnotify.plugin.zsh | 58 ++++++++++++++++++++++------ 1 file changed, 47 insertions(+), 11 deletions(-) diff --git a/plugins/bgnotify/bgnotify.plugin.zsh b/plugins/bgnotify/bgnotify.plugin.zsh index a4a7b621b..4499d816c 100644 --- a/plugins/bgnotify/bgnotify.plugin.zsh +++ b/plugins/bgnotify/bgnotify.plugin.zsh @@ -63,9 +63,9 @@ function bgnotify_appid { if (( ${+commands[osascript]} )); then # output is "app ID, window ID" (com.googlecode.iterm2, 116) osascript -e 'tell application (path to frontmost application as text) to get the {id, id of front window}' 2>/dev/null - elif [[ -n $WAYLAND_DISPLAY ]] && (( ${+commands[swaymsg]} )) && (( ${+commands[jq]} )); then # wayland+sway - # output is "app_id, container id" (Alacritty, 1694) - swaymsg -t get_tree | jq '.. | select(.type?) | select(.focused==true) | {app_id, id} | join(", ")' + elif [[ -n $WAYLAND_DISPLAY ]] && (( ${+commands[swaymsg]} )); then # wayland+sway + local app_id=$(find_sway_appid) + [[ -n "$app_id" ]] && echo "$app_id" || echo $EPOCHSECONDS elif [[ -z $WAYLAND_DISPLAY ]] && [[ -n $DISPLAY ]] && (( ${+commands[xprop]} )); then xprop -root _NET_ACTIVE_WINDOW 2>/dev/null | cut -d' ' -f5 else @@ -73,19 +73,55 @@ function bgnotify_appid { fi } + +function find_sway_appid { + # output is "app_id,container_id", for example "Alacritty,1694" + # see example swaymsg output: https://github.com/ohmyzsh/ohmyzsh/files/13463939/output.json + if (( ${+commands[jq]} )); then + swaymsg -t get_tree | jq '.. | select(.type?) | select(.focused==true) | {app_id, id} | join(",")' + else + swaymsg -t get_tree | awk ' + BEGIN { Id = ""; Appid = ""; FocusNesting = -1; Nesting = 0 } + { + # Enter a block + if ($0 ~ /.*{$/) Nesting++ + + # Exit a block. If Nesting is now less than FocusNesting, we have the data we are looking for + if ($0 ~ /^[[:blank:]]*}.*/) { Nesting--; if (FocusNesting > 0 && Nesting < FocusNesting) exit 0 } + + # Save the Id, it is potentially what we are looking for + if ($0 ~ /^[[:blank:]]*"id": [0-9]*,?$/) { sub(/^[[:blank:]]*"id": /, ""); sub(/,$/, ""); Id = $0 } + + # Save the Appid, it is potentially what we are looking for + if ($0 ~ /^[[:blank:]]*"app_id": ".*",?$/) { sub(/^[[:blank:]]*"app_id": "/, ""); sub(/",$/, ""); Appid = $0 } + + # Window is focused, this nesting block contains the Id and Appid we want! + if ($0 ~ /^[[:blank:]]*"focused": true,?$/) { FocusNesting = Nesting } + } + END { + if (Appid != "" && Id != "" && FocusNesting != -1) print Appid "," Id + else print "" + }' + fi +} + +function find_term_id { + local term_id="${bgnotify_termid%%,*}" # remove window id + if [[ -z "$term_id" ]]; then + case "$TERM_PROGRAM" in + iTerm.app) term_id='com.googlecode.iterm2' ;; + Apple_Terminal) term_id='com.apple.terminal' ;; + esac + fi + echo "$term_id" +} + function bgnotify { local title="$1" local message="$2" local icon="$3" if (( ${+commands[terminal-notifier]} )); then # macOS - local term_id="${bgnotify_termid%%,*}" # remove window id - if [[ -z "$term_id" ]]; then - case "$TERM_PROGRAM" in - iTerm.app) term_id='com.googlecode.iterm2' ;; - Apple_Terminal) term_id='com.apple.terminal' ;; - esac - fi - + local term_id=$(find_term_id) terminal-notifier -message "$message" -title "$title" ${=icon:+-appIcon "$icon"} ${=term_id:+-activate "$term_id" -sender "$term_id"} &>/dev/null elif (( ${+commands[growlnotify]} )); then # macOS growl growlnotify -m "$title" "$message" From b6afbbea3a6f41e4016e967da57b33872aff9944 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Fri, 1 Dec 2023 17:03:15 +0100 Subject: [PATCH 442/672] fix(installer): fix path logic and improve clarity on ZDOTDIR use --- tools/install.sh | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/tools/install.sh b/tools/install.sh index fcfbcf778..508fc2f77 100755 --- a/tools/install.sh +++ b/tools/install.sh @@ -63,7 +63,9 @@ zdot="${ZDOTDIR:-$HOME}" # Default value for $ZSH # a) if $ZDOTDIR is supplied and not $HOME: $ZDOTDIR/ohmyzsh # b) otherwise, $HOME/.oh-my-zsh -[ "$ZDOTDIR" = "$HOME" ] || ZSH="${ZSH:-${ZDOTDIR:+$ZDOTDIR/ohmyzsh}}" +if [ -n "$ZDOTDIR" ] && [ "$ZDOTDIR" != "$HOME" ]; then + ZSH="${ZSH:-$ZDOTDIR/ohmyzsh}" +fi ZSH="${ZSH:-$HOME/.oh-my-zsh}" # Default settings From 0a9d82780e20e24b6fafc5b2aaefedb0957986c9 Mon Sep 17 00:00:00 2001 From: Benjamin Neff Date: Fri, 1 Dec 2023 17:09:48 +0100 Subject: [PATCH 443/672] feat(bgnotify): add option to disable terminal bell (#12077) --- plugins/bgnotify/README.md | 2 ++ plugins/bgnotify/bgnotify.plugin.zsh | 5 ++++- 2 files changed, 6 insertions(+), 1 deletion(-) diff --git a/plugins/bgnotify/README.md b/plugins/bgnotify/README.md index 6bbe3b302..33d529f15 100644 --- a/plugins/bgnotify/README.md +++ b/plugins/bgnotify/README.md @@ -35,12 +35,14 @@ Just add bgnotify to your plugins list in your `.zshrc` One can configure a few things: +- `bgnotify_bell` enabled or disables the terminal bell (default true) - `bgnotify_threshold` sets the notification threshold time (default 6 seconds) - `function bgnotify_formatted` lets you change the notification. You can for instance customize the message and pass in an icon. Use these by adding a function definition before the your call to source. Example: ```sh +bgnotify_bell=false ## disable terminal bell bgnotify_threshold=4 ## set your own notification threshold function bgnotify_formatted { diff --git a/plugins/bgnotify/bgnotify.plugin.zsh b/plugins/bgnotify/bgnotify.plugin.zsh index 4499d816c..3c0766191 100644 --- a/plugins/bgnotify/bgnotify.plugin.zsh +++ b/plugins/bgnotify/bgnotify.plugin.zsh @@ -27,7 +27,7 @@ function bgnotify_end { # check if Terminal app is not active [[ $(bgnotify_appid) != "$bgnotify_termid" ]] || return - printf '\a' # beep sound + [[ $bgnotify_bell = true ]] && printf '\a' # beep sound bgnotify_formatted "$exit_status" "$bgnotify_lastcmd" "$elapsed" } always { bgnotify_timestamp=0 @@ -136,6 +136,9 @@ function bgnotify { ## Defaults +# enable terminal bell on notify by default +bgnotify_bell=${bgnotify_bell:-true} + # notify if command took longer than 5s by default bgnotify_threshold=${bgnotify_threshold:-5} From 1ae0515a80686d33406c9a2c58c0c9666ca47c77 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Wed, 6 Dec 2023 08:09:45 +0100 Subject: [PATCH 444/672] fix(lib): patch `omz_urlencode` to not encode UTF-8 chars in Termux (#12076) Fixes #12061 --- lib/functions.zsh | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/lib/functions.zsh b/lib/functions.zsh index a252d0a33..f5c671f9c 100644 --- a/lib/functions.zsh +++ b/lib/functions.zsh @@ -182,6 +182,8 @@ function omz_urlencode() { fi # Use LC_CTYPE=C to process text byte-by-byte + # Note that this doesn't work in Termux, as it only has UTF-8 locale. + # Characters will be processed as UTF-8, which is fine for URLs. local i byte ord LC_ALL=C export LC_ALL local reserved=';/?:@&=+$,' @@ -206,6 +208,9 @@ function omz_urlencode() { else if [[ "$byte" == " " && -n $spaces_as_plus ]]; then url_str+="+" + elif [[ "$PREFIX" = *com.termux* ]]; then + # Termux does not have non-UTF8 locales, so just send the UTF-8 character directly + url_str+="$byte" else ord=$(( [##16] #byte )) url_str+="%$ord" From c37df3ebd48df98b0987d891acc7ea30044bb113 Mon Sep 17 00:00:00 2001 From: Josh Hubbard Date: Wed, 6 Dec 2023 09:13:19 +0100 Subject: [PATCH 445/672] feat(frontend-search): add nextjs --- plugins/frontend-search/README.md | 1 + plugins/frontend-search/frontend-search.plugin.zsh | 6 ++++-- 2 files changed, 5 insertions(+), 2 deletions(-) diff --git a/plugins/frontend-search/README.md b/plugins/frontend-search/README.md index 050058931..619d31e7f 100644 --- a/plugins/frontend-search/README.md +++ b/plugins/frontend-search/README.md @@ -60,6 +60,7 @@ Available search contexts are: | typescript | `https://google.com/search?as_sitesearch=www.typescriptlang.org/docs&as_q=` | | unheap | `http://www.unheap.com/?s=` | | vuejs | `https://www.google.com/search?as_sitesearch=vuejs.org&as_q=` | +| nextjs | `https://www.google.com/search?as_sitesearch=nextjs.org&as_q=` | If you want to have another context, open an Issue and tell us! diff --git a/plugins/frontend-search/frontend-search.plugin.zsh b/plugins/frontend-search/frontend-search.plugin.zsh index b9e2fe95d..541b23701 100644 --- a/plugins/frontend-search/frontend-search.plugin.zsh +++ b/plugins/frontend-search/frontend-search.plugin.zsh @@ -27,6 +27,7 @@ alias stackoverflow='frontend stackoverflow' alias typescript='frontend typescript' alias unheap='frontend unheap' alias vuejs='frontend vuejs' +alias nextjs='frontend nextjs' function _frontend_fallback() { case "$FRONTEND_SEARCH_FALLBACK" in @@ -70,6 +71,7 @@ function frontend() { typescript $(_frontend_fallback 'www.typescriptlang.org/docs') unheap 'http://www.unheap.com/?s=' vuejs $(_frontend_fallback 'vuejs.org') + nextjs $(_frontend_fallback 'nextjs.org') ) # show help for command list @@ -81,7 +83,7 @@ function frontend() { print -P "" print -P " angular, angularjs, bem, bootsnipp, caniuse, codepen, compassdoc, cssflow, packagephobia" print -P " dartlang, emberjs, fontello, flowtype, github, html5please, jestjs, jquery, lodash," - print -P " mdn, npmjs, nodejs, qunit, reactjs, smacss, stackoverflow, unheap, vuejs, bundlephobia" + print -P " mdn, npmjs, nodejs, qunit, reactjs, smacss, stackoverflow, unheap, vuejs, bundlephobia, nextjs" print -P "" print -P "For example: frontend npmjs mocha (or just: npmjs mocha)." print -P "" @@ -96,7 +98,7 @@ function frontend() { echo "" echo " angular, angularjs, bem, bootsnipp, caniuse, codepen, compassdoc, cssflow, packagephobia" echo " dartlang, emberjs, fontello, github, html5please, jest, jquery, lodash," - echo " mdn, npmjs, nodejs, qunit, reactjs, smacss, stackoverflow, unheap, vuejs, bundlephobia" + echo " mdn, npmjs, nodejs, qunit, reactjs, smacss, stackoverflow, unheap, vuejs, bundlephobia, nextjs" echo "" return 1 fi From 346bd1cd53e1bd3bd881f94552efadeebab430e4 Mon Sep 17 00:00:00 2001 From: Josh Hubbard Date: Wed, 6 Dec 2023 09:15:53 +0100 Subject: [PATCH 446/672] feat(frontend-search): add `I am lucky` option --- plugins/frontend-search/README.md | 11 ++++++++++- plugins/frontend-search/frontend-search.plugin.zsh | 14 ++++++++++---- 2 files changed, 20 insertions(+), 5 deletions(-) diff --git a/plugins/frontend-search/README.md b/plugins/frontend-search/README.md index 619d31e7f..920795060 100644 --- a/plugins/frontend-search/README.md +++ b/plugins/frontend-search/README.md @@ -66,7 +66,16 @@ If you want to have another context, open an Issue and tell us! ## Fallback search behaviour -The plugin will use Google as a fallback if the docs site for a search context does not have a search function. You can set the fallback search engine to DuckDuckGo by setting `FRONTEND_SEARCH_FALLBACK='duckduckgo'` in your `~/.zshrc` file before Oh My Zsh is sourced. +The plugin will use Google as a fallback if the docs site for a search context does not have a search +function. You can set the fallback search engine to DuckDuckGo by setting +`FRONTEND_SEARCH_FALLBACK='duckduckgo'` in your `~/.zshrc` file before Oh My Zsh is sourced. + +## DuckDuckGo Lucky Search + +Enable DuckDuckGo's "ducky" (lucky) search feature to automatically access the top search result. This feature +is optimized for DuckDuckGo, as Google redirects to an intermediate page. The FRONTEND_SEARCH_FALLBACK_LUCKY +environment variable triggers the use of DuckDuckGo's lucky search, rendering the FRONTEND_SEARCH_FALLBACK +setting unnecessary in this context. ## Author diff --git a/plugins/frontend-search/frontend-search.plugin.zsh b/plugins/frontend-search/frontend-search.plugin.zsh index 541b23701..c96596eb9 100644 --- a/plugins/frontend-search/frontend-search.plugin.zsh +++ b/plugins/frontend-search/frontend-search.plugin.zsh @@ -30,10 +30,16 @@ alias vuejs='frontend vuejs' alias nextjs='frontend nextjs' function _frontend_fallback() { - case "$FRONTEND_SEARCH_FALLBACK" in - duckduckgo) echo "https://duckduckgo.com/?sites=$1&q=" ;; - *) echo "https://google.com/search?as_sitesearch=$1&as_q=" ;; - esac + if [[ "$FRONTEND_SEARCH_FALLBACK_LUCKY" == "true" ]]; then + case true in + *) echo "https://duckduckgo.com/?q=!ducky+site%3A$1+" ;; + esac + else + case "$FRONTEND_SEARCH_FALLBACK" in + duckduckgo) echo "https://duckduckgo.com/?sites=$1&q=" ;; + *) echo "https://google.com/search?as_sitesearch=$1&as_q=" ;; + esac + fi } function frontend() { From 48ccc7b36de8efb2bd7beb9bd6e0a6f6fe03b95d Mon Sep 17 00:00:00 2001 From: Jasmin Date: Wed, 6 Dec 2023 08:22:06 +0000 Subject: [PATCH 447/672] feat(dotnet): update completion script (#12028) --- plugins/dotnet/dotnet.plugin.zsh | 22 +++++++--------------- 1 file changed, 7 insertions(+), 15 deletions(-) diff --git a/plugins/dotnet/dotnet.plugin.zsh b/plugins/dotnet/dotnet.plugin.zsh index 89d464670..40ee7efae 100644 --- a/plugins/dotnet/dotnet.plugin.zsh +++ b/plugins/dotnet/dotnet.plugin.zsh @@ -1,22 +1,14 @@ # This scripts is copied from (MIT License): -# https://github.com/dotnet/toolset/blob/master/scripts/register-completions.zsh +# https://raw.githubusercontent.com/dotnet/sdk/main/scripts/register-completions.zsh -_dotnet_zsh_complete() -{ - local completions=("$(dotnet complete "$words")") - - # If the completion list is empty, just continue with filename selection - if [ -z "$completions" ] - then - _arguments '*::arguments: _normal' - return - fi - - # This is not a variable assignment, don't remove spaces! - _values = "${(ps:\n:)completions}" +#compdef dotnet +_dotnet_completion() { + local -a completions=("${(@f)$(dotnet complete "${words}")}") + compadd -a completions + _files } -compdef _dotnet_zsh_complete dotnet +compdef _dotnet_completion dotnet # Aliases bellow are here for backwards compatibility # added by Shaun Tabone (https://github.com/xontab) From dd3be612e3df1450de40a74fadc6df3c2885e9b1 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Wed, 20 Dec 2023 10:21:31 +0100 Subject: [PATCH 448/672] ci(dependencies): add automation for updating external dependencies (#12109) --- .github/dependencies.yml | 20 + .github/workflows/dependencies.yml | 26 ++ .github/workflows/dependencies/updater.py | 450 ++++++++++++++++++++++ 3 files changed, 496 insertions(+) create mode 100644 .github/dependencies.yml create mode 100644 .github/workflows/dependencies.yml create mode 100644 .github/workflows/dependencies/updater.py diff --git a/.github/dependencies.yml b/.github/dependencies.yml new file mode 100644 index 000000000..8c46395d7 --- /dev/null +++ b/.github/dependencies.yml @@ -0,0 +1,20 @@ +dependencies: + plugins/gitfast: + repo: felipec/git-completion + branch: master + version: tag:v1.3.7 + postcopy: | + set -e + rm -rf git-completion.plugin.zsh Makefile README.adoc t tools + test -e git-completion.zsh && mv -f git-completion.zsh _git + plugins/z: + branch: master + repo: agkozak/zsh-z + version: 6bfe418332866d15373392164df11b4fbec2083f + precopy: | + set -e + test -e README.md && mv -f README.md MANUAL.md + postcopy: | + set -e + test -e _zshz && mv -f _zshz _z + test -e zsh-z.plugin.zsh && mv -f zsh-z.plugin.zsh z.plugin.zsh diff --git a/.github/workflows/dependencies.yml b/.github/workflows/dependencies.yml new file mode 100644 index 000000000..c27ad7998 --- /dev/null +++ b/.github/workflows/dependencies.yml @@ -0,0 +1,26 @@ +name: Update dependencies +on: + workflow_dispatch: {} + # schedule: + # - cron: '34 3 * * */8' + +jobs: + check: + name: Check for updates + runs-on: ubuntu-latest + steps: + - name: Checkout + if: github.repository == 'ohmyzsh/ohmyzsh' + uses: actions/checkout@v4 + - name: Authenticate as @ohmyzsh + uses: ohmyzsh/github-app-token@v2 + with: + app-id: ${{ secrets.OHMYZSH_APP_ID }} + private-key: ${{ secrets.OHMYZSH_APP_PRIVATE_KEY }} + - name: Process dependencies + env: + GITHUB_TOKEN: ${{ steps.generate_token.outputs.token }} + TMP_DIR: ${{ env.RUNNER_TEMP }} + run: | + gh auth login --with-token <<< "${GITHUB_TOKEN}" + python3 .github/workflows/dependencies/updater.py diff --git a/.github/workflows/dependencies/updater.py b/.github/workflows/dependencies/updater.py new file mode 100644 index 000000000..5af19d14c --- /dev/null +++ b/.github/workflows/dependencies/updater.py @@ -0,0 +1,450 @@ +import os +import subprocess +import sys +import requests +import shutil +import yaml +from copy import deepcopy +from typing import Optional, TypedDict + +# Get TMP_DIR variable from environment +TMP_DIR = os.path.join(os.environ.get("TMP_DIR", "/tmp"), "ohmyzsh") +# Relative path to dependencies.yml file +DEPS_YAML_FILE = ".github/dependencies.yml" +# Dry run flag +DRY_RUN = os.environ.get("DRY_RUN", "0") == "1" + +import timeit +class CodeTimer: + def __init__(self, name=None): + self.name = " '" + name + "'" if name else '' + + def __enter__(self): + self.start = timeit.default_timer() + + def __exit__(self, exc_type, exc_value, traceback): + self.took = (timeit.default_timer() - self.start) * 1000.0 + print('Code block' + self.name + ' took: ' + str(self.took) + ' ms') + + +### YAML representation +def str_presenter(dumper, data): + """ + Configures yaml for dumping multiline strings + Ref: https://stackoverflow.com/a/33300001 + """ + if len(data.splitlines()) > 1: # check for multiline string + return dumper.represent_scalar('tag:yaml.org,2002:str', data, style='|') + return dumper.represent_scalar('tag:yaml.org,2002:str', data) + +yaml.add_representer(str, str_presenter) +yaml.representer.SafeRepresenter.add_representer(str, str_presenter) + + +# Types +class DependencyDict(TypedDict): + repo: str + branch: str + version: str + precopy: Optional[str] + postcopy: Optional[str] + +class DependencyYAML(TypedDict): + dependencies: dict[str, DependencyDict] + +class UpdateStatus(TypedDict): + has_updates: bool + version: Optional[str] + compare_url: Optional[str] + head_ref: Optional[str] + head_url: Optional[str] + + +class CommandRunner: + class Exception(Exception): + def __init__(self, message, returncode, stage, stdout, stderr): + super().__init__(message) + self.returncode = returncode + self.stage = stage + self.stdout = stdout + self.stderr = stderr + + @staticmethod + def run_or_fail(command: list[str], stage: str, *args, **kwargs): + if DRY_RUN and command[0] == "gh": + command.insert(0, "echo") + + result = subprocess.run(command, *args, capture_output=True, **kwargs) + + if result.returncode != 0: + raise CommandRunner.Exception( + f"{stage} command failed with exit code {result.returncode}", returncode=result.returncode, + stage=stage, + stdout=result.stdout.decode("utf-8"), + stderr=result.stderr.decode("utf-8") + ) + + return result + + +class DependencyStore: + store: DependencyYAML = { + "dependencies": {} + } + + @staticmethod + def set(data: DependencyYAML): + DependencyStore.store = data + + @staticmethod + def update_dependency_version(path: str, version: str) -> DependencyYAML: + with CodeTimer(f"store deepcopy: {path}"): + store_copy = deepcopy(DependencyStore.store) + + dependency = store_copy["dependencies"].get(path, {}) + dependency["version"] = version + store_copy["dependencies"][path] = dependency + + return store_copy + + @staticmethod + def write_store(file: str, data: DependencyYAML): + with open(file, "w") as yaml_file: + yaml.safe_dump(data, yaml_file, sort_keys=False) + + +class Dependency: + def __init__(self, path: str, values: DependencyDict): + self.path = path + self.values = values + + self.name: str = "" + self.desc: str = "" + self.kind: str = "" + + match path.split("/"): + case ["plugins", name]: + self.name = name + self.kind = "plugin" + self.desc = f"{name} plugin" + case ["themes", name]: + self.name = name.replace(".zsh-theme", "") + self.kind = "theme" + self.desc = f"{self.name} theme" + case _: + self.name = self.desc = path + + def __str__(self): + output: str = "" + for key in DependencyDict.__dict__['__annotations__'].keys(): + if key not in self.values: + output += f"{key}: None\n" + continue + + value = self.values[key] + if "\n" not in value: + output += f"{key}: {value}\n" + else: + output += f"{key}:\n " + output += value.replace("\n", "\n ", value.count("\n") - 1) + return output + + def update_or_notify(self): + # Print dependency settings + print(f"Processing {self.desc}...", file=sys.stderr) + print(self, file=sys.stderr) + + # Check for updates + repo = self.values["repo"] + remote_branch = self.values["branch"] + version = self.values["version"] + is_tag = version.startswith("tag:") + + try: + with CodeTimer(f"update check: {repo}"): + if is_tag: + status = GitHub.check_newer_tag(repo, version.replace("tag:", "")) + else: + status = GitHub.check_updates(repo, remote_branch, version) + + if status["has_updates"]: + short_sha = status["head_ref"][:8] + new_version = status["version"] if is_tag else short_sha + + try: + # Create new branch + branch = Git.create_branch(self.path, new_version) + + # Update dependencies.yml file + self.__update_yaml(f"tag:{new_version}" if is_tag else status["version"]) + + # Update dependency files + self.__apply_upstream_changes() + + # Add all changes and commit + Git.add_and_commit(self.name, short_sha) + + # Push changes to remote + Git.push(branch) + + # Create GitHub PR + GitHub.create_pr( + branch, + f"feat({self.name}): update to version {new_version}", + f"""## Description + +Update for **{self.desc}**: update to version [{new_version}]({status['head_url']}). +Check out the [list of changes]({status['compare_url']}). +""" + ) + + # Clean up repository + Git.clean_repo() + except (CommandRunner.Exception, shutil.Error) as e: + # Handle exception on automatic update + match type(e): + case CommandRunner.Exception: + # Print error message + print(f"Error running {e.stage} command: {e.returncode}", file=sys.stderr) + print(e.stderr, file=sys.stderr) + case shutil.Error: + print(f"Error copying files: {e}", file=sys.stderr) + + try: + Git.clean_repo() + except CommandRunner.Exception as e: + print(f"Error reverting repository to clean state: {e}", file=sys.stderr) + sys.exit(1) + + # Create a GitHub issue to notify maintainer + title = f"{self.path}: update to {new_version}" + body = ( + f"""## Description + +There is a new version of `{self.name}` {self.kind} available. + +New version: [{new_version}]({status['head_url']}) +Check out the [list of changes]({status['compare_url']}). +""" + ) + + print(f"Creating GitHub issue", file=sys.stderr) + print(f"{title}\n\n{body}", file=sys.stderr) + GitHub.create_issue(title, body) + except Exception as e: + print(e, file=sys.stderr) + + def __update_yaml(self, new_version: str) -> None: + dep_yaml = DependencyStore.update_dependency_version(self.path, new_version) + DependencyStore.write_store(DEPS_YAML_FILE, dep_yaml) + + def __apply_upstream_changes(self) -> None: + # Patterns to ignore in copying files from upstream repo + GLOBAL_IGNORE = [ + ".git", + ".github", + ".gitignore" + ] + + path = os.path.abspath(self.path) + precopy = self.values.get("precopy") + postcopy = self.values.get("postcopy") + + repo = self.values["repo"] + branch = self.values["branch"] + remote_url = f"https://github.com/{repo}.git" + repo_dir = os.path.join(TMP_DIR, repo) + + # Clone repository + Git.clone(remote_url, branch, repo_dir, reclone=True) + + # Run precopy on tmp repo + if precopy is not None: + print("Running precopy script:", end="\n ", file=sys.stderr) + print(precopy.replace("\n", "\n ", precopy.count("\n") - 1), file=sys.stderr) + CommandRunner.run_or_fail(["bash", "-c", precopy], cwd=repo_dir, stage="Precopy") + + # Copy files from upstream repo + print(f"Copying files from {repo_dir} to {path}", file=sys.stderr) + shutil.copytree(repo_dir, path, dirs_exist_ok=True, ignore=shutil.ignore_patterns(*GLOBAL_IGNORE)) + + # Run postcopy on our repository + if postcopy is not None: + print("Running postcopy script:", end="\n ", file=sys.stderr) + print(postcopy.replace("\n", "\n ", postcopy.count("\n") - 1), file=sys.stderr) + CommandRunner.run_or_fail(["bash", "-c", postcopy], cwd=path, stage="Postcopy") + + +class Git: + default_branch = "master" + + @staticmethod + def clone(remote_url: str, branch: str, repo_dir: str, reclone=False): + # If repo needs to be fresh + if reclone and os.path.exists(repo_dir): + shutil.rmtree(repo_dir) + + # Clone repo in tmp directory and checkout branch + if not os.path.exists(repo_dir): + print(f"Cloning {remote_url} to {repo_dir} and checking out {branch}", file=sys.stderr) + CommandRunner.run_or_fail(["git", "clone", "--depth=1", "-b", branch, remote_url, repo_dir], stage="Clone") + + @staticmethod + def create_branch(path: str, version: str): + # Get current branch name + result = CommandRunner.run_or_fail(["git", "rev-parse", "--abbrev-ref", "HEAD"], stage="GetDefaultBranch") + Git.default_branch = result.stdout.decode("utf-8").strip() + + # Create new branch and return created branch name + branch_name = f"update/{path}/{version}" + CommandRunner.run_or_fail(["git", "checkout", "-b", branch_name], stage="CreateBranch") + return branch_name + + @staticmethod + def add_and_commit(scope: str, version: str): + user_name = "ohmyzsh" + user_email = "bot@ohmyz.sh" + + # Add all files to git staging + CommandRunner.run_or_fail(["git", "add", "-A", "-v"], stage="AddFiles") + + # Reset environment and git config + clean_env = os.environ.copy() + clean_env["LANG"]="C.UTF-8" + clean_env["GIT_CONFIG_GLOBAL"]="/dev/null" + clean_env["GIT_CONFIG_NOSYSTEM"]="1" + + # Commit with settings above + CommandRunner.run_or_fail([ + "git", + "-c", f"user.name={user_name}", + "-c", f"user.email={user_email}", + "commit", + "-m", f"feat({scope}): update to {version}" + ], stage="CreateCommit", env=clean_env) + + @staticmethod + def push(branch: str): + CommandRunner.run_or_fail(["git", "push", "-u", "origin", branch], stage="PushBranch") + + @staticmethod + def clean_repo(): + CommandRunner.run_or_fail(["git", "reset", "--hard", "HEAD"], stage="ResetRepository") + CommandRunner.run_or_fail(["git", "checkout", Git.default_branch], stage="CheckoutDefaultBranch") + + +class GitHub: + @staticmethod + def check_newer_tag(repo, current_tag) -> UpdateStatus: + # GET /repos/:owner/:repo/git/refs/tags + url = f"https://api.github.com/repos/{repo}/git/refs/tags" + + # Send a GET request to the GitHub API + response = requests.get(url) + + # If the request was successful + if response.status_code == 200: + # Parse the JSON response + data = response.json() + + if len(data) == 0: + return { + "has_updates": False, + } + + latest_ref = data[-1] + latest_tag = latest_ref["ref"].replace("refs/tags/", "") + + if latest_tag == current_tag: + return { + "has_updates": False, + } + + return { + "has_updates": True, + "version": latest_tag, + "compare_url": f"https://github.com/{repo}/compare/{current_tag}...{latest_tag}", + "head_ref": latest_ref["object"]["sha"], + "head_url": f"https://github.com/{repo}/releases/tag/{latest_tag}", + } + else: + # If the request was not successful, raise an exception + raise Exception(f"GitHub API request failed with status code {response.status_code}: {response.json()}") + + @staticmethod + def check_updates(repo, branch, version) -> UpdateStatus: + # TODO: add support for semver updating (based on tags) + # Check if upstream github repo has a new version + # GitHub API URL for comparing two commits + url = f"https://api.github.com/repos/{repo}/compare/{version}...{branch}" + + # Send a GET request to the GitHub API + response = requests.get(url) + + # If the request was successful + if response.status_code == 200: + # Parse the JSON response + data = response.json() + + # If the base is behind the head, there is a newer version + has_updates = data["status"] != "identical" + + if not has_updates: + return { + "has_updates": False, + } + + return { + "has_updates": data["status"] != "identical", + "version": data["commits"][-1]["sha"], + "compare_url": data["permalink_url"], + "head_ref": data["commits"][-1]["sha"], + "head_url": data["commits"][-1]["html_url"] + } + else: + # If the request was not successful, raise an exception + raise Exception(f"GitHub API request failed with status code {response.status_code}: {response.json()}") + + @staticmethod + def create_issue(title: str, body: str) -> None: + cmd = [ + "gh", + "issue", + "create", + "-t", title, + "-b", body + ] + CommandRunner.run_or_fail(cmd, stage="CreateIssue") + + @staticmethod + def create_pr(branch: str, title: str, body: str) -> None: + cmd = [ + "gh", + "pr", + "create", + "-B", Git.default_branch, + "-H", branch, + "-t", title, + "-b", body + ] + CommandRunner.run_or_fail(cmd, stage="CreatePullRequest") + + +def main(): + # Load the YAML file + with open(DEPS_YAML_FILE, "r") as yaml_file: + data: DependencyYAML = yaml.safe_load(yaml_file) + + if "dependencies" not in data: + raise Exception(f"dependencies.yml not properly formatted") + + # Cache YAML version + DependencyStore.set(data) + + dependencies = data["dependencies"] + for path in dependencies: + dependency = Dependency(path, dependencies[path]) + dependency.update_or_notify() + +if __name__ == "__main__": + main() From 0bb00eddbbc25564b5329899fcdfcd28153da720 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Wed, 20 Dec 2023 19:38:25 +0100 Subject: [PATCH 449/672] ci(dependencies): fix typo --- .github/workflows/dependencies.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/dependencies.yml b/.github/workflows/dependencies.yml index c27ad7998..aab740126 100644 --- a/.github/workflows/dependencies.yml +++ b/.github/workflows/dependencies.yml @@ -15,8 +15,8 @@ jobs: - name: Authenticate as @ohmyzsh uses: ohmyzsh/github-app-token@v2 with: - app-id: ${{ secrets.OHMYZSH_APP_ID }} - private-key: ${{ secrets.OHMYZSH_APP_PRIVATE_KEY }} + app_id: ${{ secrets.OHMYZSH_APP_ID }} + private_key: ${{ secrets.OHMYZSH_APP_PRIVATE_KEY }} - name: Process dependencies env: GITHUB_TOKEN: ${{ steps.generate_token.outputs.token }} From 2a1574165691495d21b3f243f50e1b655b361d9b Mon Sep 17 00:00:00 2001 From: Oleg Grigoriev Date: Wed, 20 Dec 2023 22:52:27 +0300 Subject: [PATCH 450/672] fix(rake-fast): make `.rake_tasks` write atomic (#12108) --- plugins/rake-fast/rake-fast.plugin.zsh | 13 ++++++++----- 1 file changed, 8 insertions(+), 5 deletions(-) diff --git a/plugins/rake-fast/rake-fast.plugin.zsh b/plugins/rake-fast/rake-fast.plugin.zsh index 86e5ed586..082f02f29 100644 --- a/plugins/rake-fast/rake-fast.plugin.zsh +++ b/plugins/rake-fast/rake-fast.plugin.zsh @@ -43,14 +43,17 @@ _tasks_changed () { } _rake_generate () { - echo "version:$_rake_tasks_version" > .rake_tasks - - rake --silent --tasks --all \ + local rake_tasks_content="version:$_rake_tasks_version\n" + rake_tasks_content+=$(rake --silent --tasks --all \ | sed "s/^rake //" | sed "s/\:/\\\:/g" \ | sed "s/\[[^]]*\]//g" \ | sed "s/ *# /\:/" \ - | sed "s/\:$//" \ - >> .rake_tasks + | sed "s/\:$//") + + local rake_tasks_file="$(mktemp -t .rake_tasks.XXXXXX)" + echo $rake_tasks_content > $rake_tasks_file + + mv $rake_tasks_file .rake_tasks } _rake () { From 17e96bf91ee0bc3dc27fa65b0ea7b10d3b971f9d Mon Sep 17 00:00:00 2001 From: Gautam krishna R Date: Thu, 21 Dec 2023 01:40:32 +0530 Subject: [PATCH 451/672] fix(changelog): use longer hashes for commits (#12096) --- tools/changelog.sh | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) diff --git a/tools/changelog.sh b/tools/changelog.sh index 6d768963e..3ad8fe786 100755 --- a/tools/changelog.sh +++ b/tools/changelog.sh @@ -292,16 +292,17 @@ function display-release { function fmt:hash { #* Uses $hash from outer scope local hash="${1:-$hash}" + local short_hash="${hash:0:7}" # 7 characters sha, top level sha is 12 characters case "$output" in - raw) printf '%s' "$hash" ;; + raw) printf '%s' "$short_hash" ;; text) - local text="\e[33m$hash\e[0m"; # red + local text="\e[33m$short_hash\e[0m"; # red if supports_hyperlinks; then printf "\e]8;;%s\a%s\e]8;;\a" "https://github.com/ohmyzsh/ohmyzsh/commit/$hash" $text; else echo $text; fi ;; - md) printf '[`%s`](https://github.com/ohmyzsh/ohmyzsh/commit/%s)' "$hash" "$hash" ;; + md) printf '[`%s`](https://github.com/ohmyzsh/ohmyzsh/commit/%s)' "$short_hash" "$hash" ;; esac } @@ -512,13 +513,13 @@ function main { # Git log options # -z: commits are delimited by null bytes # --format: [7-char hash][ref names][subject][body] - # --abbrev=7: force commit hashes to be 7 characters long + # --abbrev=7: force commit hashes to be 12 characters long # --no-merges: merge commits are omitted # --first-parent: commits from merged branches are omitted local SEP="0mZmAgIcSeP" local -a raw_commits raw_commits=(${(0)"$(command git -c log.showSignature=false log -z \ - --format="%h${SEP}%D${SEP}%s${SEP}%b" --abbrev=7 \ + --format="%h${SEP}%D${SEP}%s${SEP}%b" --abbrev=12 \ --no-merges --first-parent $range)"}) local raw_commit From 9004c177bac951f46ab1ec5b74a8bcfb8e3c686b Mon Sep 17 00:00:00 2001 From: Gautam krishna R Date: Fri, 22 Dec 2023 14:27:23 +0530 Subject: [PATCH 452/672] fix(bgnotify): make it work with `set -e` (#12111) Co-authored-by: ipChrisLee --- plugins/bgnotify/bgnotify.plugin.zsh | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/plugins/bgnotify/bgnotify.plugin.zsh b/plugins/bgnotify/bgnotify.plugin.zsh index 3c0766191..c28a29e19 100644 --- a/plugins/bgnotify/bgnotify.plugin.zsh +++ b/plugins/bgnotify/bgnotify.plugin.zsh @@ -21,11 +21,11 @@ function bgnotify_end { local elapsed=$(( EPOCHSECONDS - bgnotify_timestamp )) # check time elapsed - [[ $bgnotify_timestamp -gt 0 ]] || return - [[ $elapsed -ge $bgnotify_threshold ]] || return + [[ $bgnotify_timestamp -gt 0 ]] || return 0 + [[ $elapsed -ge $bgnotify_threshold ]] || return 0 # check if Terminal app is not active - [[ $(bgnotify_appid) != "$bgnotify_termid" ]] || return + [[ $(bgnotify_appid) != "$bgnotify_termid" ]] || return 0 [[ $bgnotify_bell = true ]] && printf '\a' # beep sound bgnotify_formatted "$exit_status" "$bgnotify_lastcmd" "$elapsed" From f74add6cb215b55722f9e64273be82d7bae5014e Mon Sep 17 00:00:00 2001 From: Nidelson Gimenez Date: Sun, 24 Dec 2023 05:40:51 -0300 Subject: [PATCH 453/672] feat(react-native): add aliases for iPhone 15 (#12114) --- plugins/react-native/README.md | 4 ++++ plugins/react-native/react-native.plugin.zsh | 4 ++++ 2 files changed, 8 insertions(+) diff --git a/plugins/react-native/README.md b/plugins/react-native/README.md index 807c063a5..39eed6c68 100644 --- a/plugins/react-native/README.md +++ b/plugins/react-native/README.md @@ -54,6 +54,10 @@ plugins=(... react-native) | **rnios14pl** | `react-native run-ios --simulator "iPhone 14 Plus"` | | **rnios14p** | `react-native run-ios --simulator "iPhone 14 Pro"` | | **rnios14pm** | `react-native run-ios --simulator "iPhone 14 Pro Max"` | +| **rnios15** | `react-native run-ios --simulator "iPhone 15"` | +| **rnios15pl** | `react-native run-ios --simulator "iPhone 15 Plus"` | +| **rnios15p** | `react-native run-ios --simulator "iPhone 15 Pro"` | +| **rnios15pm** | `react-native run-ios --simulator "iPhone 15 Pro Max"` | | _iPad_ | | | **rnipad2** | `react-native run-ios --simulator "iPad 2"` | | **rnipad5** | `react-native run-ios --simulator "iPad (5th generation)"` | diff --git a/plugins/react-native/react-native.plugin.zsh b/plugins/react-native/react-native.plugin.zsh index afeaab4fd..9ee081248 100644 --- a/plugins/react-native/react-native.plugin.zsh +++ b/plugins/react-native/react-native.plugin.zsh @@ -39,6 +39,10 @@ alias rnios14='react-native run-ios --simulator "iPhone 14"' alias rnios14pl='react-native run-ios --simulator "iPhone 14 Plus"' alias rnios14p='react-native run-ios --simulator "iPhone 14 Pro"' alias rnios14pm='react-native run-ios --simulator "iPhone 14 Pro Max"' +alias rnios15='react-native run-ios --simulator "iPhone 15"' +alias rnios15pl='react-native run-ios --simulator "iPhone 15 Plus"' +alias rnios15p='react-native run-ios --simulator "iPhone 15 Pro"' +alias rnios15pm='react-native run-ios --simulator "iPhone 15 Pro Max"' # iPad alias rnipad2='react-native run-ios --simulator "iPad 2"' From 8a8a04f43a23f9d3f25b941293d0e9be1d3e301c Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Wed, 27 Dec 2023 10:52:23 +0100 Subject: [PATCH 454/672] fix(nvm): prevent duplicates in lazy_cmd Closes #11344 --- plugins/nvm/nvm.plugin.zsh | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/plugins/nvm/nvm.plugin.zsh b/plugins/nvm/nvm.plugin.zsh index 1badbeab5..94b666175 100644 --- a/plugins/nvm/nvm.plugin.zsh +++ b/plugins/nvm/nvm.plugin.zsh @@ -24,9 +24,14 @@ if zstyle -t ':omz:plugins:nvm' lazy && \ ! zstyle -t ':omz:plugins:nvm' autoload; then # Call nvm when first using nvm, node, npm, pnpm, yarn or other commands in lazy-cmd zstyle -a ':omz:plugins:nvm' lazy-cmd nvm_lazy_cmd + nvm_lazy_cmd=(nvm node npm npx pnpm yarn $nvm_lazy_cmd) # default values eval " - function nvm node npm npx pnpm yarn $nvm_lazy_cmd { - unfunction nvm node npm npx pnpm yarn $nvm_lazy_cmd + function $nvm_lazy_cmd { + for func in $nvm_lazy_cmd; do + if (( \$+functions[\$func] )); then + unfunction \$func + fi + done # Load nvm if it exists in \$NVM_DIR [[ -f \"\$NVM_DIR/nvm.sh\" ]] && source \"\$NVM_DIR/nvm.sh\" \"\$0\" \"\$@\" From 64d881b479cec5e62384176773f1b4d0a057ba47 Mon Sep 17 00:00:00 2001 From: Brian Hartvigsen Date: Wed, 27 Dec 2023 02:57:53 -0700 Subject: [PATCH 455/672] fix(bgnotify): don't require accessibility perms in macos (#11433) --- plugins/bgnotify/bgnotify.plugin.zsh | 25 ++++++++++--------------- 1 file changed, 10 insertions(+), 15 deletions(-) diff --git a/plugins/bgnotify/bgnotify.plugin.zsh b/plugins/bgnotify/bgnotify.plugin.zsh index c28a29e19..0e3f2c640 100644 --- a/plugins/bgnotify/bgnotify.plugin.zsh +++ b/plugins/bgnotify/bgnotify.plugin.zsh @@ -27,7 +27,6 @@ function bgnotify_end { # check if Terminal app is not active [[ $(bgnotify_appid) != "$bgnotify_termid" ]] || return 0 - [[ $bgnotify_bell = true ]] && printf '\a' # beep sound bgnotify_formatted "$exit_status" "$bgnotify_lastcmd" "$elapsed" } always { bgnotify_timestamp=0 @@ -52,6 +51,7 @@ function bgnotify_formatted { (( $3 < 60 )) || elapsed="$((( $3 % 3600) / 60 ))m $elapsed" (( $3 < 3600 )) || elapsed="$(( $3 / 3600 ))h $elapsed" + [[ $bgnotify_bell = true ]] && printf '\a' # beep sound if [[ $exit_status -eq 0 ]]; then bgnotify "#win (took $elapsed)" "$cmd" else @@ -61,10 +61,9 @@ function bgnotify_formatted { function bgnotify_appid { if (( ${+commands[osascript]} )); then - # output is "app ID, window ID" (com.googlecode.iterm2, 116) - osascript -e 'tell application (path to frontmost application as text) to get the {id, id of front window}' 2>/dev/null + osascript -e "tell application id \"$(bgnotify_programid)\" to get the {id, frontmost, id of front window, visible of front window}" 2>/dev/null elif [[ -n $WAYLAND_DISPLAY ]] && (( ${+commands[swaymsg]} )); then # wayland+sway - local app_id=$(find_sway_appid) + local app_id=$(bgnotify_find_sway_appid) [[ -n "$app_id" ]] && echo "$app_id" || echo $EPOCHSECONDS elif [[ -z $WAYLAND_DISPLAY ]] && [[ -n $DISPLAY ]] && (( ${+commands[xprop]} )); then xprop -root _NET_ACTIVE_WINDOW 2>/dev/null | cut -d' ' -f5 @@ -74,7 +73,7 @@ function bgnotify_appid { } -function find_sway_appid { +function bgnotify_find_sway_appid { # output is "app_id,container_id", for example "Alacritty,1694" # see example swaymsg output: https://github.com/ohmyzsh/ohmyzsh/files/13463939/output.json if (( ${+commands[jq]} )); then @@ -105,15 +104,11 @@ function find_sway_appid { fi } -function find_term_id { - local term_id="${bgnotify_termid%%,*}" # remove window id - if [[ -z "$term_id" ]]; then - case "$TERM_PROGRAM" in - iTerm.app) term_id='com.googlecode.iterm2' ;; - Apple_Terminal) term_id='com.apple.terminal' ;; - esac - fi - echo "$term_id" +function bgnotify_programid { + case "$TERM_PROGRAM" in + iTerm.app) echo 'com.googlecode.iterm2' ;; + Apple_Terminal) echo 'com.apple.terminal' ;; + esac } function bgnotify { @@ -121,7 +116,7 @@ function bgnotify { local message="$2" local icon="$3" if (( ${+commands[terminal-notifier]} )); then # macOS - local term_id=$(find_term_id) + local term_id=$(bgnotify_programid) terminal-notifier -message "$message" -title "$title" ${=icon:+-appIcon "$icon"} ${=term_id:+-activate "$term_id" -sender "$term_id"} &>/dev/null elif (( ${+commands[growlnotify]} )); then # macOS growl growlnotify -m "$title" "$message" From 94a0481f182b4a2cc87e76af8761e00c07de79dc Mon Sep 17 00:00:00 2001 From: Basti <107778224+krakenbite@users.noreply.github.com> Date: Wed, 27 Dec 2023 10:59:05 +0100 Subject: [PATCH 456/672] feat(aws): add sso logout capabilities (#12113) --- plugins/aws/README.md | 1 + plugins/aws/aws.plugin.zsh | 2 ++ 2 files changed, 3 insertions(+) diff --git a/plugins/aws/README.md b/plugins/aws/README.md index 9e1e055b8..4850e223e 100644 --- a/plugins/aws/README.md +++ b/plugins/aws/README.md @@ -16,6 +16,7 @@ plugins=(... aws) It also sets `$AWS_EB_PROFILE` to `` for the Elastic Beanstalk CLI. It sets `$AWS_PROFILE_REGION` for display in `aws_prompt_info`. Run `asp` without arguments to clear the profile. * `asp [] login`: If AWS SSO has been configured in your aws profile, it will run the `aws sso login` command following profile selection. +* `asp [] logout`: If AWS SSO has been configured in your aws profile, it will run the `aws sso logout` command following profile selection. * `asr []`: sets `$AWS_REGION` and `$AWS_DEFAULT_REGION` (legacy) to ``. Run `asr` without arguments to clear the profile. diff --git a/plugins/aws/aws.plugin.zsh b/plugins/aws/aws.plugin.zsh index c946515be..0d7040f92 100644 --- a/plugins/aws/aws.plugin.zsh +++ b/plugins/aws/aws.plugin.zsh @@ -30,6 +30,8 @@ function asp() { if [[ "$2" == "login" ]]; then aws sso login + elif [[ "$2" == "logout" ]]; then + aws sso logout fi } From 3e92d251ba7a950d050234d8780ce75085b1b1d4 Mon Sep 17 00:00:00 2001 From: "B. Hamonangan" <70834922+hamonangann@users.noreply.github.com> Date: Wed, 27 Dec 2023 17:09:23 +0700 Subject: [PATCH 457/672] feat(aws): add support for sso sessions login (#12090) Co-authored-by: Carlo Sala --- plugins/aws/README.md | 1 + plugins/aws/aws.plugin.zsh | 6 +++++- 2 files changed, 6 insertions(+), 1 deletion(-) diff --git a/plugins/aws/README.md b/plugins/aws/README.md index 4850e223e..dbf8dcfeb 100644 --- a/plugins/aws/README.md +++ b/plugins/aws/README.md @@ -16,6 +16,7 @@ plugins=(... aws) It also sets `$AWS_EB_PROFILE` to `` for the Elastic Beanstalk CLI. It sets `$AWS_PROFILE_REGION` for display in `aws_prompt_info`. Run `asp` without arguments to clear the profile. * `asp [] login`: If AWS SSO has been configured in your aws profile, it will run the `aws sso login` command following profile selection. +* `asp [] login []`: In addition to `asp [] login`, if SSO session has been configured in your aws profile, it will run the `aws sso login --sso-session ` command following profile selection. * `asp [] logout`: If AWS SSO has been configured in your aws profile, it will run the `aws sso logout` command following profile selection. * `asr []`: sets `$AWS_REGION` and `$AWS_DEFAULT_REGION` (legacy) to ``. diff --git a/plugins/aws/aws.plugin.zsh b/plugins/aws/aws.plugin.zsh index 0d7040f92..fd00714e7 100644 --- a/plugins/aws/aws.plugin.zsh +++ b/plugins/aws/aws.plugin.zsh @@ -29,7 +29,11 @@ function asp() { export AWS_PROFILE_REGION=$(aws configure get region) if [[ "$2" == "login" ]]; then - aws sso login + if [[ -n "$3" ]]; then + aws sso login --sso-session $3 + else + aws sso login + fi elif [[ "$2" == "logout" ]]; then aws sso logout fi From ec74eb91bda8ee0cb42f4b9697d13154e31a93d6 Mon Sep 17 00:00:00 2001 From: "B. Hamonangan" <70834922+hamonangann@users.noreply.github.com> Date: Wed, 27 Dec 2023 19:47:58 +0700 Subject: [PATCH 458/672] feat(git): add `gcB` alias (#12116) --- plugins/git/README.md | 1 + plugins/git/git.plugin.zsh | 1 + 2 files changed, 2 insertions(+) diff --git a/plugins/git/README.md b/plugins/git/README.md index 93dc8ccea..b7b9a6635 100644 --- a/plugins/git/README.md +++ b/plugins/git/README.md @@ -51,6 +51,7 @@ plugins=(... git) | `gco` | `git checkout` | | `gcor` | `git checkout --recurse-submodules` | | `gcb` | `git checkout -b` | +| `gcB` | `git checkout -B` | | `gcd` | `git checkout $(git_develop_branch)` | | `gcm` | `git checkout $(git_main_branch)` | | `gcp` | `git cherry-pick` | diff --git a/plugins/git/git.plugin.zsh b/plugins/git/git.plugin.zsh index 2a824444b..bee9eb67d 100644 --- a/plugins/git/git.plugin.zsh +++ b/plugins/git/git.plugin.zsh @@ -157,6 +157,7 @@ alias gbg='LANG=C git branch -vv | grep ": gone\]"' alias gco='git checkout' alias gcor='git checkout --recurse-submodules' alias gcb='git checkout -b' +alias gcB='git checkout -B' alias gcd='git checkout $(git_develop_branch)' alias gcm='git checkout $(git_main_branch)' alias gcp='git cherry-pick' From 46b24d409909cdc00ac441448c0aa31cc35d12c9 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Thu, 28 Dec 2023 21:20:28 +0100 Subject: [PATCH 459/672] ci(dependencies): fix some envs and add requirements --- .github/workflows/dependencies.yml | 11 +++++++---- .github/workflows/dependencies/requirements.txt | 2 ++ .github/workflows/dependencies/updater.py | 4 ++-- 3 files changed, 11 insertions(+), 6 deletions(-) create mode 100644 .github/workflows/dependencies/requirements.txt diff --git a/.github/workflows/dependencies.yml b/.github/workflows/dependencies.yml index aab740126..2e2217e1c 100644 --- a/.github/workflows/dependencies.yml +++ b/.github/workflows/dependencies.yml @@ -8,19 +8,22 @@ jobs: check: name: Check for updates runs-on: ubuntu-latest + if: github.repository == 'ohmyzsh/ohmyzsh' steps: - name: Checkout - if: github.repository == 'ohmyzsh/ohmyzsh' uses: actions/checkout@v4 - name: Authenticate as @ohmyzsh + id: generate_token uses: ohmyzsh/github-app-token@v2 with: app_id: ${{ secrets.OHMYZSH_APP_ID }} private_key: ${{ secrets.OHMYZSH_APP_PRIVATE_KEY }} - name: Process dependencies env: - GITHUB_TOKEN: ${{ steps.generate_token.outputs.token }} - TMP_DIR: ${{ env.RUNNER_TEMP }} + GH_TOKEN: ${{ steps.generate_token.outputs.token }} + GIT_APP_NAME: ohmyzsh[bot] + GIT_APP_EMAIL: 54982679+ohmyzsh[bot]@users.noreply.github.com + TMP_DIR: ${{ runner.temp }} run: | - gh auth login --with-token <<< "${GITHUB_TOKEN}" + pip install -r .github/workflows/dependencies/requirements.txt python3 .github/workflows/dependencies/updater.py diff --git a/.github/workflows/dependencies/requirements.txt b/.github/workflows/dependencies/requirements.txt new file mode 100644 index 000000000..3c4c149ea --- /dev/null +++ b/.github/workflows/dependencies/requirements.txt @@ -0,0 +1,2 @@ +PyYAML~=6.0.1 +requests~=2.31.0 diff --git a/.github/workflows/dependencies/updater.py b/.github/workflows/dependencies/updater.py index 5af19d14c..f54d316f9 100644 --- a/.github/workflows/dependencies/updater.py +++ b/.github/workflows/dependencies/updater.py @@ -302,8 +302,8 @@ class Git: @staticmethod def add_and_commit(scope: str, version: str): - user_name = "ohmyzsh" - user_email = "bot@ohmyz.sh" + user_name = os.environ.get("GIT_APP_NAME") + user_email = os.environ.get("GIT_APP_EMAIL") # Add all files to git staging CommandRunner.run_or_fail(["git", "add", "-A", "-v"], stage="AddFiles") From 544eb17e33454dbfb758683cc37bc3ab50661f98 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Thu, 28 Dec 2023 21:21:09 +0100 Subject: [PATCH 460/672] ci(project): use ohmyzsh's bot credentials --- .github/workflows/project.yml | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/.github/workflows/project.yml b/.github/workflows/project.yml index 1d961d8c0..2c2a1cdaa 100644 --- a/.github/workflows/project.yml +++ b/.github/workflows/project.yml @@ -15,9 +15,15 @@ jobs: name: Add to project runs-on: ubuntu-latest if: github.repository == 'ohmyzsh/ohmyzsh' - env: - GITHUB_TOKEN: ${{ secrets.PROJECT_TOKEN }} steps: + - name: Authenticate as @ohmyzsh + id: generate_token + uses: ohmyzsh/github-app-token@v2 + with: + app_id: ${{ secrets.OHMYZSH_APP_ID }} + private_key: ${{ secrets.OHMYZSH_APP_PRIVATE_KEY }} + - name: Store app token + run: echo "GH_TOKEN=${{ steps.generate_token.outputs.token }}" >> "$GITHUB_ENV" - name: Read project data env: ORGANIZATION: ohmyzsh From f43ee85d8f154fbc95229772cac93dec83b09188 Mon Sep 17 00:00:00 2001 From: "ohmyzsh[bot]" <54982679+ohmyzsh[bot]@users.noreply.github.com> Date: Thu, 28 Dec 2023 22:05:07 +0100 Subject: [PATCH 461/672] feat(gitfast): update to version v2.0 (#12135) Co-authored-by: ohmyzsh[bot] <54982679+ohmyzsh[bot]@users.noreply.github.com> --- .github/dependencies.yml | 2 +- plugins/gitfast/git-completion.bash | 221 +++++++--------------------- plugins/gitfast/git-prompt.sh | 31 ++-- 3 files changed, 71 insertions(+), 183 deletions(-) diff --git a/.github/dependencies.yml b/.github/dependencies.yml index 8c46395d7..4d5a8fa80 100644 --- a/.github/dependencies.yml +++ b/.github/dependencies.yml @@ -2,7 +2,7 @@ dependencies: plugins/gitfast: repo: felipec/git-completion branch: master - version: tag:v1.3.7 + version: tag:v2.0 postcopy: | set -e rm -rf git-completion.plugin.zsh Makefile README.adoc t tools diff --git a/plugins/gitfast/git-completion.bash b/plugins/gitfast/git-completion.bash index dd06b5048..9a2045f26 100644 --- a/plugins/gitfast/git-completion.bash +++ b/plugins/gitfast/git-completion.bash @@ -58,6 +58,12 @@ # # When set to "1" suggest all options, including options which are # typically hidden (e.g. '--allow-empty' for 'git commit'). +# +# GIT_COMPLETION_IGNORE_CASE +# +# When set, uses for-each-ref '--ignore-case' to find refs that match +# case insensitively, even on systems with case sensitive file systems +# (e.g., completing tag name "FOO" on "git checkout f"). # The following functions are meant to modify COMPREPLY, which should not be # modified directly. The purpose is to localize the modifications so it's @@ -320,116 +326,6 @@ else unset $(compgen -v __gitcomp_builtin_) fi -__gitcomp_builtin_add_default=" --dry-run --verbose --interactive --patch --edit --force --update --renormalize --intent-to-add --all --ignore-removal --refresh --ignore-errors --ignore-missing --sparse --chmod= --pathspec-from-file= --pathspec-file-nul --no-dry-run -- --no-verbose --no-interactive --no-patch --no-edit --no-force --no-update --no-renormalize --no-intent-to-add --no-all --no-ignore-removal --no-refresh --no-ignore-errors --no-ignore-missing --no-sparse --no-chmod --no-pathspec-from-file --no-pathspec-file-nul" -__gitcomp_builtin_am_default=" --interactive --3way --quiet --signoff --utf8 --keep --keep-non-patch --message-id --keep-cr --no-keep-cr --scissors --quoted-cr= --whitespace= --ignore-space-change --ignore-whitespace --directory= --exclude= --include= --patch-format= --reject --resolvemsg= --continue --resolved --skip --abort --quit --show-current-patch --allow-empty --committer-date-is-author-date --ignore-date --rerere-autoupdate --gpg-sign --empty= -- --no-interactive --no-3way --no-quiet --no-signoff --no-utf8 --no-keep --no-keep-non-patch --no-message-id --no-scissors --no-whitespace --no-ignore-space-change --no-ignore-whitespace --no-directory --no-exclude --no-include --no-patch-format --no-reject --no-resolvemsg --no-committer-date-is-author-date --no-ignore-date --no-rerere-autoupdate --no-gpg-sign" -__gitcomp_builtin_apply_default=" --exclude= --include= --no-add --stat --numstat --summary --check --index --intent-to-add --cached --apply --3way --build-fake-ancestor= --whitespace= --ignore-space-change --ignore-whitespace --reverse --unidiff-zero --reject --allow-overlap --verbose --quiet --inaccurate-eof --recount --directory= --allow-empty --add -- --no-stat --no-numstat --no-summary --no-check --no-index --no-intent-to-add --no-cached --no-apply --no-3way --no-build-fake-ancestor --no-whitespace --no-ignore-space-change --no-ignore-whitespace --no-reverse --no-unidiff-zero --no-reject --no-allow-overlap --no-verbose --no-quiet --no-inaccurate-eof --no-recount --no-directory --no-allow-empty" -__gitcomp_builtin_archive_default=" --output= --remote= --exec= --no-output -- --no-remote --no-exec" -__gitcomp_builtin_bisect__helper_default=" --bisect-reset --bisect-next-check --bisect-terms --bisect-start --bisect-next --bisect-state --bisect-log --bisect-replay --bisect-skip --bisect-visualize --bisect-run --no-log --log" -__gitcomp_builtin_blame_default=" --incremental --root --show-stats --progress --score-debug --show-name --show-number --porcelain --line-porcelain --show-email --ignore-rev= --ignore-revs-file= --color-lines --color-by-age --minimal --contents= --abbrev --no-incremental -- --no-root --no-show-stats --no-progress --no-score-debug --no-show-name --no-show-number --no-porcelain --no-line-porcelain --no-show-email --no-ignore-rev --no-ignore-revs-file --no-color-lines --no-color-by-age --no-minimal --no-contents --no-abbrev" -__gitcomp_builtin_branch_default=" --verbose --quiet --track --set-upstream-to= --unset-upstream --color --remotes --contains --no-contains --abbrev --all --delete --move --copy --list --show-current --create-reflog --edit-description --merged --no-merged --column --sort= --points-at= --ignore-case --recurse-submodules --format= -- --no-verbose --no-quiet --no-track --no-set-upstream-to --no-unset-upstream --no-color --no-remotes --no-abbrev --no-all --no-delete --no-move --no-copy --no-list --no-show-current --no-create-reflog --no-edit-description --no-column --no-sort --no-points-at --no-ignore-case --no-recurse-submodules --no-format" -__gitcomp_builtin_bugreport_default=" --output-directory= --suffix= --no-output-directory -- --no-suffix" -__gitcomp_builtin_cat_file_default=" --allow-unknown-type --batch --batch-check --batch-command --batch-all-objects --buffer --follow-symlinks --unordered --textconv --filters --path= --no-allow-unknown-type -- --no-buffer --no-follow-symlinks --no-unordered --no-path" -__gitcomp_builtin_check_attr_default=" --all --cached --stdin --no-all -- --no-cached --no-stdin" -__gitcomp_builtin_check_ignore_default=" --quiet --verbose --stdin --non-matching --no-index --index -- --no-quiet --no-verbose --no-stdin --no-non-matching" -__gitcomp_builtin_check_mailmap_default=" --stdin --no-stdin" -__gitcomp_builtin_checkout_default=" --guess --overlay --quiet --recurse-submodules --progress --merge --conflict= --detach --track --orphan= --ignore-other-worktrees --ours --theirs --patch --ignore-skip-worktree-bits --pathspec-from-file= --pathspec-file-nul --no-guess -- --no-overlay --no-quiet --no-recurse-submodules --no-progress --no-merge --no-conflict --no-detach --no-track --no-orphan --no-ignore-other-worktrees --no-patch --no-ignore-skip-worktree-bits --no-pathspec-from-file --no-pathspec-file-nul" -__gitcomp_builtin_checkout__worker_default=" --prefix= --no-prefix" -__gitcomp_builtin_checkout_index_default=" --all --ignore-skip-worktree-bits --force --quiet --no-create --index --stdin --temp --prefix= --stage= --create -- --no-all --no-ignore-skip-worktree-bits --no-force --no-quiet --no-index --no-stdin --no-temp --no-prefix" -__gitcomp_builtin_cherry_default=" --abbrev --verbose --no-abbrev -- --no-verbose" -__gitcomp_builtin_cherry_pick_default=" --quit --continue --abort --skip --cleanup= --no-commit --edit --signoff --mainline= --rerere-autoupdate --strategy= --strategy-option= --gpg-sign --ff --allow-empty --allow-empty-message --keep-redundant-commits --commit -- --no-cleanup --no-edit --no-signoff --no-mainline --no-rerere-autoupdate --no-strategy --no-strategy-option --no-gpg-sign --no-ff --no-allow-empty --no-allow-empty-message --no-keep-redundant-commits" -__gitcomp_builtin_clean_default=" --quiet --dry-run --interactive --exclude= --no-quiet -- --no-dry-run --no-interactive" -__gitcomp_builtin_clone_default=" --verbose --quiet --progress --reject-shallow --no-checkout --bare --mirror --local --no-hardlinks --shared --recurse-submodules --jobs= --template= --reference= --reference-if-able= --dissociate --origin= --branch= --upload-pack= --depth= --shallow-since= --shallow-exclude= --single-branch --no-tags --shallow-submodules --separate-git-dir= --config= --server-option= --ipv4 --ipv6 --filter= --also-filter-submodules --remote-submodules --sparse --checkout --hardlinks --tags -- --no-verbose --no-quiet --no-progress --no-reject-shallow --no-bare --no-mirror --no-local --no-shared --no-recurse-submodules --no-recursive --no-jobs --no-template --no-reference --no-reference-if-able --no-dissociate --no-origin --no-branch --no-upload-pack --no-depth --no-shallow-since --no-shallow-exclude --no-single-branch --no-shallow-submodules --no-separate-git-dir --no-config --no-server-option --no-ipv4 --no-ipv6 --no-filter --no-also-filter-submodules --no-remote-submodules --no-sparse" -__gitcomp_builtin_column_default=" --command= --mode --raw-mode= --width= --indent= --nl= --padding= --no-command -- --no-mode --no-raw-mode --no-width --no-indent --no-nl --no-padding" -__gitcomp_builtin_commit_default=" --quiet --verbose --file= --author= --date= --message= --reedit-message= --reuse-message= --fixup= --squash= --reset-author --trailer= --signoff --template= --edit --cleanup= --status --gpg-sign --all --include --interactive --patch --only --no-verify --dry-run --short --branch --ahead-behind --porcelain --long --null --amend --no-post-rewrite --untracked-files --pathspec-from-file= --pathspec-file-nul --verify --post-rewrite -- --no-quiet --no-verbose --no-file --no-author --no-date --no-message --no-reedit-message --no-reuse-message --no-fixup --no-squash --no-reset-author --no-signoff --no-template --no-edit --no-cleanup --no-status --no-gpg-sign --no-all --no-include --no-interactive --no-patch --no-only --no-dry-run --no-short --no-branch --no-ahead-behind --no-porcelain --no-long --no-null --no-amend --no-untracked-files --no-pathspec-from-file --no-pathspec-file-nul" -__gitcomp_builtin_commit_graph_default=" --object-dir= --no-object-dir" -__gitcomp_builtin_config_default=" --global --system --local --worktree --file= --blob= --get --get-all --get-regexp --get-urlmatch --replace-all --add --unset --unset-all --rename-section --remove-section --list --fixed-value --edit --get-color --get-colorbool --type= --bool --int --bool-or-int --bool-or-str --path --expiry-date --null --name-only --includes --show-origin --show-scope --default= --no-global -- --no-system --no-local --no-worktree --no-file --no-blob --no-get --no-get-all --no-get-regexp --no-get-urlmatch --no-replace-all --no-add --no-unset --no-unset-all --no-rename-section --no-remove-section --no-list --no-fixed-value --no-edit --no-get-color --no-get-colorbool --no-type --no-null --no-name-only --no-includes --no-show-origin --no-show-scope --no-default" -__gitcomp_builtin_count_objects_default=" --verbose --human-readable --no-verbose -- --no-human-readable" -__gitcomp_builtin_credential_cache_default=" --timeout= --socket= --no-timeout -- --no-socket" -__gitcomp_builtin_credential_cache__daemon_default=" --debug --no-debug" -__gitcomp_builtin_credential_store_default=" --file= --no-file" -__gitcomp_builtin_describe_default=" --contains --debug --all --tags --long --first-parent --abbrev --exact-match --candidates= --match= --exclude= --always --dirty --broken --no-contains -- --no-debug --no-all --no-tags --no-long --no-first-parent --no-abbrev --no-exact-match --no-candidates --no-match --no-exclude --no-always --no-dirty --no-broken" -__gitcomp_builtin_difftool_default=" --gui --dir-diff --no-prompt --symlinks --tool= --tool-help --trust-exit-code --extcmd= --no-index --index -- --no-gui --no-dir-diff --no-symlinks --no-tool --no-tool-help --no-trust-exit-code --no-extcmd" -__gitcomp_builtin_env__helper_default=" --type= --default= --exit-code --no-default -- --no-exit-code" -__gitcomp_builtin_fast_export_default=" --progress= --signed-tags= --tag-of-filtered-object= --reencode= --export-marks= --import-marks= --import-marks-if-exists= --fake-missing-tagger --full-tree --use-done-feature --no-data --refspec= --anonymize --anonymize-map= --reference-excluded-parents --show-original-ids --mark-tags --data -- --no-progress --no-signed-tags --no-tag-of-filtered-object --no-reencode --no-export-marks --no-import-marks --no-import-marks-if-exists --no-fake-missing-tagger --no-full-tree --no-use-done-feature --no-refspec --no-anonymize --no-reference-excluded-parents --no-show-original-ids --no-mark-tags" -__gitcomp_builtin_fetch_default=" --verbose --quiet --all --set-upstream --append --atomic --upload-pack= --force --multiple --tags --jobs= --prefetch --prune --prune-tags --recurse-submodules --dry-run --write-fetch-head --keep --update-head-ok --progress --depth= --shallow-since= --shallow-exclude= --deepen= --unshallow --refetch --update-shallow --refmap= --server-option= --ipv4 --ipv6 --negotiation-tip= --negotiate-only --filter= --auto-maintenance --auto-gc --show-forced-updates --write-commit-graph --stdin --no-verbose -- --no-quiet --no-all --no-set-upstream --no-append --no-atomic --no-upload-pack --no-force --no-multiple --no-tags --no-jobs --no-prefetch --no-prune --no-prune-tags --no-recurse-submodules --no-dry-run --no-write-fetch-head --no-keep --no-update-head-ok --no-progress --no-depth --no-shallow-since --no-shallow-exclude --no-deepen --no-update-shallow --no-server-option --no-ipv4 --no-ipv6 --no-negotiation-tip --no-negotiate-only --no-filter --no-auto-maintenance --no-auto-gc --no-show-forced-updates --no-write-commit-graph --no-stdin" -__gitcomp_builtin_fmt_merge_msg_default=" --log --message= --into-name= --file= --no-log -- --no-message --no-into-name --no-file" -__gitcomp_builtin_for_each_ref_default=" --shell --perl --python --tcl --count= --format= --color --sort= --points-at= --merged --no-merged --contains --no-contains --ignore-case -- --no-shell --no-perl --no-python --no-tcl --no-count --no-format --no-color --no-sort --no-points-at --no-ignore-case" -__gitcomp_builtin_for_each_repo_default=" --config= --no-config" -__gitcomp_builtin_format_patch_default=" --numbered --no-numbered --signoff --stdout --cover-letter --numbered-files --suffix= --start-number= --reroll-count= --filename-max-length= --rfc --cover-from-description= --subject-prefix= --output-directory= --keep-subject --no-binary --zero-commit --ignore-if-in-upstream --no-stat --add-header= --to= --cc= --from --in-reply-to= --attach --inline --thread --signature= --base= --signature-file= --quiet --progress --interdiff= --range-diff= --creation-factor= --binary -- --no-numbered --no-signoff --no-stdout --no-cover-letter --no-numbered-files --no-suffix --no-start-number --no-reroll-count --no-filename-max-length --no-cover-from-description --no-zero-commit --no-ignore-if-in-upstream --no-add-header --no-to --no-cc --no-from --no-in-reply-to --no-attach --no-thread --no-signature --no-base --no-signature-file --no-quiet --no-progress --no-interdiff --no-range-diff --no-creation-factor" -__gitcomp_builtin_fsck_default=" --verbose --unreachable --dangling --tags --root --cache --reflogs --full --connectivity-only --strict --lost-found --progress --name-objects --no-verbose -- --no-unreachable --no-dangling --no-tags --no-root --no-cache --no-reflogs --no-full --no-connectivity-only --no-strict --no-lost-found --no-progress --no-name-objects" -__gitcomp_builtin_fsck_objects_default=" --verbose --unreachable --dangling --tags --root --cache --reflogs --full --connectivity-only --strict --lost-found --progress --name-objects --no-verbose -- --no-unreachable --no-dangling --no-tags --no-root --no-cache --no-reflogs --no-full --no-connectivity-only --no-strict --no-lost-found --no-progress --no-name-objects" -__gitcomp_builtin_fsmonitor__daemon_default="" -__gitcomp_builtin_gc_default=" --quiet --prune --aggressive --keep-largest-pack --no-quiet -- --no-prune --no-aggressive --no-keep-largest-pack" -__gitcomp_builtin_grep_default=" --cached --no-index --untracked --exclude-standard --recurse-submodules --invert-match --ignore-case --word-regexp --text --textconv --recursive --max-depth= --extended-regexp --basic-regexp --fixed-strings --perl-regexp --line-number --column --full-name --files-with-matches --name-only --files-without-match --only-matching --count --color --break --heading --context= --before-context= --after-context= --threads= --show-function --function-context --and --or --not --quiet --all-match --index -- --no-cached --no-untracked --no-exclude-standard --no-recurse-submodules --no-invert-match --no-ignore-case --no-word-regexp --no-text --no-textconv --no-recursive --no-extended-regexp --no-basic-regexp --no-fixed-strings --no-perl-regexp --no-line-number --no-column --no-full-name --no-files-with-matches --no-name-only --no-files-without-match --no-only-matching --no-count --no-color --no-break --no-heading --no-context --no-before-context --no-after-context --no-threads --no-show-function --no-function-context --no-or --no-quiet --no-all-match" -__gitcomp_builtin_hash_object_default=" --stdin --stdin-paths --no-filters --literally --path= --filters -- --no-stdin --no-stdin-paths --no-literally --no-path" -__gitcomp_builtin_help_default=" --all --external-commands --aliases --man --web --info --verbose --guides --config --no-external-commands -- --no-aliases --no-man --no-web --no-info --no-verbose" -__gitcomp_builtin_hook_default="" -__gitcomp_builtin_init_default=" --template= --bare --shared --quiet --separate-git-dir= --initial-branch= --object-format= --no-template -- --no-bare --no-quiet --no-separate-git-dir --no-initial-branch --no-object-format" -__gitcomp_builtin_init_db_default=" --template= --bare --shared --quiet --separate-git-dir= --initial-branch= --object-format= --no-template -- --no-bare --no-quiet --no-separate-git-dir --no-initial-branch --no-object-format" -__gitcomp_builtin_interpret_trailers_default=" --in-place --trim-empty --where= --if-exists= --if-missing= --only-trailers --only-input --unfold --parse --no-divider --trailer= --divider -- --no-in-place --no-trim-empty --no-where --no-if-exists --no-if-missing --no-only-trailers --no-only-input --no-unfold --no-trailer" -__gitcomp_builtin_log_default=" --quiet --source --use-mailmap --decorate-refs= --decorate-refs-exclude= --decorate --no-quiet -- --no-source --no-use-mailmap --no-mailmap --no-decorate-refs --no-decorate-refs-exclude --no-decorate" -__gitcomp_builtin_ls_files_default=" --cached --deleted --modified --others --ignored --stage --killed --directory --eol --empty-directory --unmerged --resolve-undo --exclude= --exclude-from= --exclude-per-directory= --exclude-standard --full-name --recurse-submodules --error-unmatch --with-tree= --abbrev --debug --deduplicate --sparse --no-cached -- --no-deleted --no-modified --no-others --no-ignored --no-stage --no-killed --no-directory --no-eol --no-empty-directory --no-unmerged --no-resolve-undo --no-exclude-per-directory --no-recurse-submodules --no-error-unmatch --no-with-tree --no-abbrev --no-debug --no-deduplicate --no-sparse" -__gitcomp_builtin_ls_remote_default=" --quiet --upload-pack= --tags --heads --refs --get-url --sort= --symref --server-option= --no-quiet -- --no-upload-pack --no-tags --no-heads --no-refs --no-get-url --no-sort --no-symref --no-server-option" -__gitcomp_builtin_ls_tree_default=" --long --name-only --name-status --object-only --full-name --full-tree --format= --abbrev --no-full-name -- --no-full-tree --no-abbrev" -__gitcomp_builtin_merge_default=" --stat --summary --log --squash --commit --edit --cleanup= --ff --ff-only --rerere-autoupdate --verify-signatures --strategy= --strategy-option= --message= --file --into-name= --verbose --quiet --abort --quit --continue --allow-unrelated-histories --progress --gpg-sign --autostash --overwrite-ignore --signoff --no-verify --verify -- --no-stat --no-summary --no-log --no-squash --no-commit --no-edit --no-cleanup --no-ff --no-rerere-autoupdate --no-verify-signatures --no-strategy --no-strategy-option --no-message --no-into-name --no-verbose --no-quiet --no-abort --no-quit --no-continue --no-allow-unrelated-histories --no-progress --no-gpg-sign --no-autostash --no-overwrite-ignore --no-signoff" -__gitcomp_builtin_merge_base_default=" --all --octopus --independent --is-ancestor --fork-point --no-all" -__gitcomp_builtin_merge_file_default=" --stdout --diff3 --zdiff3 --ours --theirs --union --marker-size= --quiet --no-stdout -- --no-diff3 --no-zdiff3 --no-ours --no-theirs --no-union --no-marker-size --no-quiet" -__gitcomp_builtin_mktree_default=" --missing --batch --no-missing -- --no-batch" -__gitcomp_builtin_multi_pack_index_default=" --object-dir= --no-object-dir" -__gitcomp_builtin_mv_default=" --verbose --dry-run --sparse --no-verbose -- --no-dry-run --no-sparse" -__gitcomp_builtin_name_rev_default=" --name-only --tags --refs= --exclude= --all --stdin --annotate-stdin --undefined --always --no-name-only -- --no-tags --no-refs --no-exclude --no-all --no-stdin --no-annotate-stdin --no-undefined --no-always" -__gitcomp_builtin_notes_default=" --ref= --no-ref" -__gitcomp_builtin_pack_objects_default=" --quiet --progress --all-progress --all-progress-implied --index-version= --max-pack-size= --local --incremental --window= --window-memory= --depth= --reuse-delta --reuse-object --delta-base-offset --threads= --non-empty --revs --unpacked --all --reflog --indexed-objects --stdin-packs --stdout --include-tag --keep-unreachable --pack-loose-unreachable --unpack-unreachable --sparse --thin --shallow --honor-pack-keep --keep-pack= --compression= --keep-true-parents --use-bitmap-index --write-bitmap-index --filter= --missing= --exclude-promisor-objects --delta-islands --uri-protocol= --no-quiet -- --no-progress --no-all-progress --no-all-progress-implied --no-local --no-incremental --no-window --no-depth --no-reuse-delta --no-reuse-object --no-delta-base-offset --no-threads --no-non-empty --no-revs --no-stdin-packs --no-stdout --no-include-tag --no-keep-unreachable --no-pack-loose-unreachable --no-unpack-unreachable --no-sparse --no-thin --no-shallow --no-honor-pack-keep --no-keep-pack --no-compression --no-keep-true-parents --no-use-bitmap-index --no-write-bitmap-index --no-filter --no-exclude-promisor-objects --no-delta-islands --no-uri-protocol" -__gitcomp_builtin_pack_refs_default=" --all --prune --no-all -- --no-prune" -__gitcomp_builtin_pickaxe_default=" --incremental --root --show-stats --progress --score-debug --show-name --show-number --porcelain --line-porcelain --show-email --ignore-rev= --ignore-revs-file= --color-lines --color-by-age --minimal --contents= --abbrev --no-incremental -- --no-root --no-show-stats --no-progress --no-score-debug --no-show-name --no-show-number --no-porcelain --no-line-porcelain --no-show-email --no-ignore-rev --no-ignore-revs-file --no-color-lines --no-color-by-age --no-minimal --no-contents --no-abbrev" -__gitcomp_builtin_prune_default=" --dry-run --verbose --progress --expire= --exclude-promisor-objects --no-dry-run -- --no-verbose --no-progress --no-expire --no-exclude-promisor-objects" -__gitcomp_builtin_prune_packed_default=" --dry-run --quiet --no-dry-run -- --no-quiet" -__gitcomp_builtin_pull_default=" --verbose --quiet --progress --recurse-submodules --rebase --stat --log --signoff --squash --commit --edit --cleanup= --ff --ff-only --verify --verify-signatures --autostash --strategy= --strategy-option= --gpg-sign --allow-unrelated-histories --all --append --upload-pack= --force --tags --prune --jobs --dry-run --keep --depth= --shallow-since= --shallow-exclude= --deepen= --unshallow --update-shallow --refmap= --server-option= --ipv4 --ipv6 --negotiation-tip= --show-forced-updates --set-upstream --no-verbose -- --no-quiet --no-progress --no-recurse-submodules --no-rebase --no-stat --no-log --no-signoff --no-squash --no-commit --no-edit --no-cleanup --no-ff --no-verify --no-verify-signatures --no-autostash --no-strategy --no-strategy-option --no-gpg-sign --no-allow-unrelated-histories --no-all --no-append --no-upload-pack --no-force --no-tags --no-prune --no-jobs --no-dry-run --no-keep --no-depth --no-shallow-since --no-shallow-exclude --no-deepen --no-update-shallow --no-server-option --no-ipv4 --no-ipv6 --no-negotiation-tip --no-show-forced-updates --no-set-upstream" -__gitcomp_builtin_push_default=" --verbose --quiet --repo= --all --mirror --delete --tags --dry-run --porcelain --force --force-with-lease --force-if-includes --recurse-submodules= --receive-pack= --exec= --set-upstream --progress --prune --no-verify --follow-tags --signed --atomic --push-option= --ipv4 --ipv6 --verify -- --no-verbose --no-quiet --no-repo --no-all --no-mirror --no-delete --no-tags --no-dry-run --no-porcelain --no-force --no-force-with-lease --no-force-if-includes --no-recurse-submodules --no-receive-pack --no-exec --no-set-upstream --no-progress --no-prune --no-follow-tags --no-signed --no-atomic --no-push-option --no-ipv4 --no-ipv6" -__gitcomp_builtin_range_diff_default=" --creation-factor= --no-dual-color --notes --left-only --right-only --patch --no-patch --unified --function-context --raw --patch-with-raw --patch-with-stat --numstat --shortstat --dirstat --cumulative --dirstat-by-file --check --summary --name-only --name-status --stat --stat-width= --stat-name-width= --stat-graph-width= --stat-count= --compact-summary --binary --full-index --color --ws-error-highlight= --abbrev --src-prefix= --dst-prefix= --line-prefix= --no-prefix --inter-hunk-context= --output-indicator-new= --output-indicator-old= --output-indicator-context= --break-rewrites --find-renames --irreversible-delete --find-copies --find-copies-harder --no-renames --rename-empty --follow --minimal --ignore-all-space --ignore-space-change --ignore-space-at-eol --ignore-cr-at-eol --ignore-blank-lines --ignore-matching-lines= --indent-heuristic --patience --histogram --diff-algorithm= --anchored= --word-diff --word-diff-regex= --color-words --color-moved --color-moved-ws= --relative --text --exit-code --quiet --ext-diff --textconv --ignore-submodules --submodule --ita-invisible-in-index --ita-visible-in-index --pickaxe-all --pickaxe-regex --rotate-to= --skip-to= --find-object= --diff-filter= --output= --dual-color -- --no-creation-factor --no-notes --no-left-only --no-right-only --no-function-context --no-compact-summary --no-full-index --no-color --no-abbrev --no-find-copies-harder --no-rename-empty --no-follow --no-minimal --no-ignore-matching-lines --no-indent-heuristic --no-color-moved --no-color-moved-ws --no-relative --no-text --no-exit-code --no-quiet --no-ext-diff --no-textconv" -__gitcomp_builtin_read_tree_default=" --index-output= --empty --verbose --trivial --aggressive --reset --prefix= --exclude-per-directory= --dry-run --no-sparse-checkout --debug-unpack --recurse-submodules --quiet --sparse-checkout -- --no-empty --no-verbose --no-trivial --no-aggressive --no-reset --no-dry-run --no-debug-unpack --no-recurse-submodules --no-quiet" -__gitcomp_builtin_rebase_default=" --onto= --keep-base --no-verify --quiet --verbose --no-stat --signoff --committer-date-is-author-date --reset-author-date --ignore-whitespace --whitespace= --force-rebase --no-ff --continue --skip --abort --quit --edit-todo --show-current-patch --apply --merge --interactive --rerere-autoupdate --empty= --autosquash --gpg-sign --autostash --exec= --rebase-merges --fork-point --strategy= --strategy-option= --root --reschedule-failed-exec --reapply-cherry-picks --verify --stat --ff -- --no-onto --no-keep-base --no-quiet --no-verbose --no-signoff --no-committer-date-is-author-date --no-reset-author-date --no-ignore-whitespace --no-whitespace --no-force-rebase --no-rerere-autoupdate --no-autosquash --no-gpg-sign --no-autostash --no-exec --no-rebase-merges --no-fork-point --no-strategy --no-strategy-option --no-root --no-reschedule-failed-exec --no-reapply-cherry-picks" -__gitcomp_builtin_receive_pack_default=" --quiet --no-quiet" -__gitcomp_builtin_reflog_default="" -__gitcomp_builtin_remote_default=" --verbose --no-verbose" -__gitcomp_builtin_repack_default=" --quiet --local --write-bitmap-index --delta-islands --unpack-unreachable= --keep-unreachable --window= --window-memory= --depth= --threads= --max-pack-size= --pack-kept-objects --keep-pack= --geometric= --write-midx --no-quiet -- --no-local --no-write-bitmap-index --no-delta-islands --no-unpack-unreachable --no-keep-unreachable --no-window --no-window-memory --no-depth --no-threads --no-max-pack-size --no-pack-kept-objects --no-keep-pack --no-geometric --no-write-midx" -__gitcomp_builtin_replace_default=" --list --delete --edit --graft --convert-graft-file --raw --format= --no-raw -- --no-format" -__gitcomp_builtin_rerere_default=" --rerere-autoupdate --no-rerere-autoupdate" -__gitcomp_builtin_reset_default=" --quiet --no-refresh --mixed --soft --hard --merge --keep --recurse-submodules --patch --intent-to-add --pathspec-from-file= --pathspec-file-nul --refresh -- --no-quiet --no-mixed --no-soft --no-hard --no-merge --no-keep --no-recurse-submodules --no-patch --no-intent-to-add --no-pathspec-from-file --no-pathspec-file-nul" -__gitcomp_builtin_restore_default=" --source= --staged --worktree --ignore-unmerged --overlay --quiet --recurse-submodules --progress --merge --conflict= --ours --theirs --patch --ignore-skip-worktree-bits --pathspec-from-file= --pathspec-file-nul --no-source -- --no-staged --no-worktree --no-ignore-unmerged --no-overlay --no-quiet --no-recurse-submodules --no-progress --no-merge --no-conflict --no-patch --no-ignore-skip-worktree-bits --no-pathspec-from-file --no-pathspec-file-nul" -__gitcomp_builtin_revert_default=" --quit --continue --abort --skip --cleanup= --no-commit --edit --signoff --mainline= --rerere-autoupdate --strategy= --strategy-option= --gpg-sign --commit -- --no-cleanup --no-edit --no-signoff --no-mainline --no-rerere-autoupdate --no-strategy --no-strategy-option --no-gpg-sign" -__gitcomp_builtin_rm_default=" --dry-run --quiet --cached --ignore-unmatch --sparse --pathspec-from-file= --pathspec-file-nul --no-dry-run -- --no-quiet --no-cached --no-ignore-unmatch --no-sparse --no-pathspec-from-file --no-pathspec-file-nul" -__gitcomp_builtin_send_pack_default=" --verbose --quiet --receive-pack= --exec= --remote= --all --dry-run --mirror --force --signed --push-option= --progress --thin --atomic --stateless-rpc --stdin --helper-status --force-with-lease --force-if-includes --no-verbose -- --no-quiet --no-receive-pack --no-exec --no-remote --no-all --no-dry-run --no-mirror --no-force --no-signed --no-push-option --no-progress --no-thin --no-atomic --no-stateless-rpc --no-stdin --no-helper-status --no-force-with-lease --no-force-if-includes" -__gitcomp_builtin_shortlog_default=" --committer --numbered --summary --email --group= --no-committer -- --no-numbered --no-summary --no-email --no-group" -__gitcomp_builtin_show_default=" --quiet --source --use-mailmap --decorate-refs= --decorate-refs-exclude= --decorate --no-quiet -- --no-source --no-use-mailmap --no-mailmap --no-decorate-refs --no-decorate-refs-exclude --no-decorate" -__gitcomp_builtin_show_branch_default=" --all --remotes --color --more --list --no-name --current --sha1-name --merge-base --independent --topo-order --topics --sparse --date-order --reflog --name -- --no-all --no-remotes --no-color --no-more --no-list --no-current --no-sha1-name --no-merge-base --no-independent --no-topo-order --no-topics --no-sparse --no-date-order" -__gitcomp_builtin_show_index_default=" --object-format= --no-object-format" -__gitcomp_builtin_show_ref_default=" --tags --heads --verify --head --dereference --hash --abbrev --quiet --exclude-existing --no-tags -- --no-heads --no-verify --no-head --no-dereference --no-hash --no-abbrev --no-quiet" -__gitcomp_builtin_sparse_checkout_default="" -__gitcomp_builtin_stage_default=" --dry-run --verbose --interactive --patch --edit --force --update --renormalize --intent-to-add --all --ignore-removal --refresh --ignore-errors --ignore-missing --sparse --chmod= --pathspec-from-file= --pathspec-file-nul --no-dry-run -- --no-verbose --no-interactive --no-patch --no-edit --no-force --no-update --no-renormalize --no-intent-to-add --no-all --no-ignore-removal --no-refresh --no-ignore-errors --no-ignore-missing --no-sparse --no-chmod --no-pathspec-from-file --no-pathspec-file-nul" -__gitcomp_builtin_stash_default="" -__gitcomp_builtin_status_default=" --verbose --short --branch --show-stash --ahead-behind --porcelain --long --null --untracked-files --ignored --ignore-submodules --column --no-renames --find-renames --renames -- --no-verbose --no-short --no-branch --no-show-stash --no-ahead-behind --no-porcelain --no-long --no-null --no-untracked-files --no-ignored --no-ignore-submodules --no-column" -__gitcomp_builtin_stripspace_default=" --strip-comments --comment-lines" -__gitcomp_builtin_switch_default=" --create= --force-create= --guess --discard-changes --quiet --recurse-submodules --progress --merge --conflict= --detach --track --orphan= --ignore-other-worktrees --no-create -- --no-force-create --no-guess --no-discard-changes --no-quiet --no-recurse-submodules --no-progress --no-merge --no-conflict --no-detach --no-track --no-orphan --no-ignore-other-worktrees" -__gitcomp_builtin_symbolic_ref_default=" --quiet --delete --short --no-quiet -- --no-delete --no-short" -__gitcomp_builtin_tag_default=" --list --delete --verify --annotate --message= --file= --edit --sign --cleanup= --local-user= --force --create-reflog --column --contains --no-contains --merged --no-merged --sort= --points-at --format= --color --ignore-case -- --no-annotate --no-file --no-edit --no-sign --no-cleanup --no-local-user --no-force --no-create-reflog --no-column --no-sort --no-points-at --no-format --no-color --no-ignore-case" -__gitcomp_builtin_update_index_default=" --ignore-submodules --add --replace --remove --unmerged --refresh --really-refresh --cacheinfo --chmod= --assume-unchanged --no-assume-unchanged --skip-worktree --no-skip-worktree --ignore-skip-worktree-entries --info-only --force-remove --stdin --index-info --unresolve --again --ignore-missing --verbose --clear-resolve-undo --index-version= --split-index --untracked-cache --test-untracked-cache --force-untracked-cache --force-write-index --fsmonitor --fsmonitor-valid --no-fsmonitor-valid -- --no-ignore-submodules --no-add --no-replace --no-remove --no-unmerged --no-ignore-skip-worktree-entries --no-info-only --no-force-remove --no-ignore-missing --no-verbose --no-index-version --no-split-index --no-untracked-cache --no-test-untracked-cache --no-force-untracked-cache --no-force-write-index --no-fsmonitor" -__gitcomp_builtin_update_ref_default=" --no-deref --stdin --create-reflog --deref -- --no-stdin --no-create-reflog" -__gitcomp_builtin_update_server_info_default=" --force --no-force" -__gitcomp_builtin_upload_pack_default=" --stateless-rpc --strict --timeout= --no-stateless-rpc -- --no-strict --no-timeout" -__gitcomp_builtin_verify_commit_default=" --verbose --raw --no-verbose -- --no-raw" -__gitcomp_builtin_verify_pack_default=" --verbose --stat-only --object-format= --no-verbose -- --no-stat-only --no-object-format" -__gitcomp_builtin_verify_tag_default=" --verbose --raw --format= --no-verbose -- --no-raw --no-format" -__gitcomp_builtin_version_default=" --build-options --no-build-options" -__gitcomp_builtin_whatchanged_default=" --quiet --source --use-mailmap --decorate-refs= --decorate-refs-exclude= --decorate --no-quiet -- --no-source --no-use-mailmap --no-mailmap --no-decorate-refs --no-decorate-refs-exclude --no-decorate" -__gitcomp_builtin_write_tree_default=" --missing-ok --prefix= --no-missing-ok -- --no-prefix" -__gitcomp_builtin_send_email_default="--sender= --from= --smtp-auth= --8bit-encoding= --no-format-patch --no-bcc --no-suppress-from --no-annotate --relogin-delay= --no-cc --no-signed-off-cc --no-signed-off-by-cc --no-chain-reply-to --smtp-debug= --smtp-domain= --chain-reply-to --dry-run --compose --bcc= --smtp-user= --thread --cc-cover --identity= --to= --reply-to= --no-cc-cover --suppress-cc= --to-cmd= --smtp-server= --smtp-ssl-cert-path= --no-thread --smtp-server-option= --quiet --batch-size= --envelope-sender= --smtp-ssl --no-to --validate --format-patch --suppress-from --cc= --compose-encoding= --to-cover --in-reply-to= --annotate --smtp-encryption= --cc-cmd= --smtp-server-port= --smtp-pass= --signed-off-cc --signed-off-by-cc --no-xmailer --subject= --no-to-cover --confirm= --transfer-encoding= --no-smtp-auth --sendmail-cmd= --no-validate --no-identity --dump-aliases --xmailer --force --numbered --no-numbered --signoff --stdout --cover-letter --numbered-files --suffix= --start-number= --reroll-count= --filename-max-length= --rfc --cover-from-description= --subject-prefix= --output-directory= --keep-subject --no-binary --zero-commit --ignore-if-in-upstream --no-stat --add-header= --from --attach --inline --signature= --base= --signature-file= --progress --interdiff= --range-diff= --creation-factor= --binary -- --no-signoff --no-stdout --no-cover-letter --no-numbered-files --no-suffix --no-start-number --no-reroll-count --no-filename-max-length --no-cover-from-description --no-zero-commit --no-ignore-if-in-upstream --no-add-header --no-from --no-in-reply-to --no-attach --no-signature --no-base --no-signature-file --no-quiet --no-progress --no-interdiff --no-range-diff --no-creation-factor" - -__gitcomp_builtin_get_default () -{ - eval "test -n \"\$${1}_default\" && echo \"\$${1}_default\"" -} - # This function is equivalent to # # __gitcomp_opts "$(git xxx --git-completion-helper) ..." @@ -457,11 +353,9 @@ __gitcomp_builtin () else completion_helper="--git-completion-helper" fi - completion="$(__git ${cmd/_/ } $completion_helper || - __gitcomp_builtin_get_default $var)" || return # leading and trailing spaces are significant to make # option removal work correctly. - options=" $incl $completion " + options=" $incl $(__git ${cmd/_/ } $completion_helper) " || return for i in $excl; do options="${options/ $i / }" @@ -604,6 +498,7 @@ __git_heads () local pfx="${1-}" cur_="${2-}" sfx="${3-}" __git for-each-ref --format="${pfx//\%/%%}%(refname:strip=2)$sfx" \ + ${GIT_COMPLETION_IGNORE_CASE+--ignore-case} \ "refs/heads/$cur_*" "refs/heads/$cur_*/**" } @@ -617,6 +512,7 @@ __git_remote_heads () local pfx="${1-}" cur_="${2-}" sfx="${3-}" __git for-each-ref --format="${pfx//\%/%%}%(refname:strip=2)$sfx" \ + ${GIT_COMPLETION_IGNORE_CASE+--ignore-case} \ "refs/remotes/$cur_*" "refs/remotes/$cur_*/**" } @@ -627,6 +523,7 @@ __git_tags () local pfx="${1-}" cur_="${2-}" sfx="${3-}" __git for-each-ref --format="${pfx//\%/%%}%(refname:strip=2)$sfx" \ + ${GIT_COMPLETION_IGNORE_CASE+--ignore-case} \ "refs/tags/$cur_*" "refs/tags/$cur_*/**" } @@ -646,6 +543,7 @@ __git_dwim_remote_heads () # but only output if the branch name is unique __git for-each-ref --format="$fer_pfx%(refname:strip=3)$sfx" \ --sort="refname:strip=3" \ + ${GIT_COMPLETION_IGNORE_CASE+--ignore-case} \ "refs/remotes/*/$cur_*" "refs/remotes/*/$cur_*/**" | \ uniq -u } @@ -670,6 +568,7 @@ __git_refs () local format refs local pfx="${3-}" cur_="${4-$cur}" sfx="${5-}" local match="${4-}" + local umatch="${4-}" local fer_pfx="${pfx//\%/%%}" # "escape" for-each-ref format specifiers __git_find_repo_path @@ -693,12 +592,19 @@ __git_refs () fi fi + if test "${GIT_COMPLETION_IGNORE_CASE:+1}" = "1" + then + # uppercase with tr instead of ${match,^^} for bash 3.2 compatibility + umatch=$(echo "$match" | tr a-z A-Z 2>/dev/null || echo "$match") + fi + if [ "$list_refs_from" = path ]; then if [[ "$cur_" == ^* ]]; then pfx="$pfx^" fer_pfx="$fer_pfx^" cur_=${cur_#^} match=${match#^} + umatch=${umatch#^} fi case "$cur_" in refs|refs/*) @@ -709,7 +615,7 @@ __git_refs () *) for i in HEAD FETCH_HEAD ORIG_HEAD MERGE_HEAD REBASE_HEAD CHERRY_PICK_HEAD; do case "$i" in - $match*) + $match*|$umatch*) if [ -e "$dir/$i" ]; then echo "$pfx$i$sfx" fi @@ -723,6 +629,7 @@ __git_refs () ;; esac __git_dir="$dir" __git for-each-ref --format="$fer_pfx%($format)$sfx" \ + ${GIT_COMPLETION_IGNORE_CASE+--ignore-case} \ "${refs[@]}" if [ -n "$track" ]; then __git_dwim_remote_heads "$pfx" "$match" "$sfx" @@ -742,15 +649,16 @@ __git_refs () *) if [ "$list_refs_from" = remote ]; then case "HEAD" in - $match*) echo "${pfx}HEAD$sfx" ;; + $match*|$umatch*) echo "${pfx}HEAD$sfx" ;; esac __git for-each-ref --format="$fer_pfx%(refname:strip=3)$sfx" \ + ${GIT_COMPLETION_IGNORE_CASE+--ignore-case} \ "refs/remotes/$remote/$match*" \ "refs/remotes/$remote/$match*/**" else local query_symref case "HEAD" in - $match*) query_symref="HEAD" ;; + $match*|$umatch*) query_symref="HEAD" ;; esac __git ls-remote "$remote" $query_symref \ "refs/tags/$match*" "refs/heads/$match*" \ @@ -888,7 +796,6 @@ __git_list_merge_strategies () }' } -__git_merge_strategies_default='octopus ours recursive resolve subtree' __git_merge_strategies= # 'git merge -s help' (and thus detection of the merge strategy # list) fails, unfortunately, if run outside of any git working @@ -898,8 +805,7 @@ __git_merge_strategies= __git_compute_merge_strategies () { test -n "$__git_merge_strategies" || - { __git_merge_strategies=$(__git_list_merge_strategies); - __git_merge_strategies="${__git_merge_strategies:-__git_merge_strategies_default}"; } + __git_merge_strategies=$(__git_list_merge_strategies) } __git_merge_strategy_options="ours theirs subtree subtree= patience @@ -2281,7 +2187,7 @@ _git_reflog () fi } -__git_send_email_options="--no-cc-cover --cc= --no-bcc --force --relogin-delay= --to= --suppress-cc= --no-annotate --no-chain-reply-to --sendmail-cmd= --no-identity --transfer-encoding= --validate --no-smtp-auth --confirm= --no-format-patch --reply-to= --smtp-pass= --smtp-server= --annotate --envelope-sender= --no-validate --dry-run --no-thread --smtp-debug= --no-to --thread --no-xmailer --identity= --no-signed-off-cc --no-signed-off-by-cc --smtp-domain= --to-cover --8bit-encoding= --bcc= --smtp-ssl-cert-path= --smtp-user= --cc-cmd= --to-cmd= --no-cc --smtp-server-option= --in-reply-to= --subject= --batch-size= --smtp-auth= --compose --smtp-server-port= --xmailer --no-to-cover --chain-reply-to --smtp-encryption= --dump-aliases --quiet --smtp-ssl --signed-off-cc --signed-off-by-cc --suppress-from --compose-encoding= --no-suppress-from --sender= --from= --format-patch --cc-cover --numbered --no-numbered --signoff --stdout --cover-letter --numbered-files --suffix= --start-number= --reroll-count= --filename-max-length= --rfc --cover-from-description= --subject-prefix= --output-directory= --keep-subject --no-binary --zero-commit --ignore-if-in-upstream --no-stat --add-header= --from --attach --inline --signature= --base= --signature-file= --progress --interdiff= --range-diff= --creation-factor= --binary -- --no-signoff --no-stdout --no-cover-letter --no-numbered-files --no-suffix --no-start-number --no-reroll-count --no-filename-max-length --no-cover-from-description --no-zero-commit --no-ignore-if-in-upstream --no-add-header --no-from --no-in-reply-to --no-attach --no-signature --no-base --no-signature-file --no-quiet --no-progress --no-interdiff --no-range-diff --no-creation-factor" +__gitcomp_builtin_send_email_default="--8bit-encoding= --add-header= --annotate --attach --base= --batch-size= --bcc= --binary --cc-cmd= --cc-cover --cc= --chain-reply-to --compose --compose-encoding= --confirm= --cover-from-description= --cover-letter --creation-factor= --dry-run --dump-aliases --envelope-sender= --filename-max-length= --force --force-in-body-from --format-patch --from --from= --identity= --ignore-if-in-upstream --in-reply-to= --inline --interdiff= --keep-subject --numbered --numbered-files --output-directory= --progress --quiet --range-diff= --relogin-delay= --reply-to= --reroll-count= --rfc --sender= --sendmail-cmd= --signature-file= --signature= --signed-off-by-cc --signed-off-cc --signoff --smtp-auth= --smtp-debug= --smtp-domain= --smtp-encryption= --smtp-pass= --smtp-server-option= --smtp-server-port= --smtp-server= --smtp-ssl --smtp-ssl-cert-path= --smtp-user= --start-number= --stdout --subject-prefix= --subject= --suffix= --suppress-cc= --suppress-from --thread --to-cmd= --to-cover --to= --transfer-encoding= --v= --validate --xmailer --zero-commit -- --no-add-header --no-annotate --no-attach --no-base --no-bcc --no-binary --no-cc --no-cc-cover --no-chain-reply-to --no-cover-from-description --no-cover-letter --no-creation-factor --no-filename-max-length --no-force-in-body-from --no-format-patch --no-from --no-identity --no-ignore-if-in-upstream --no-in-reply-to --no-interdiff --no-numbered --no-numbered-files --no-progress --no-quiet --no-range-diff --no-reroll-count --no-signature --no-signature-file --no-signed-off-by-cc --no-signed-off-cc --no-signoff --no-smtp-auth --no-start-number --no-stat --no-stdout --no-suffix --no-suppress-from --no-thread --no-to --no-to-cover --no-validate --no-xmailer --no-zero-commit" __git_send_email_confirm_options="always never auto cc compose" __git_send_email_suppresscc_options="author self cc bodycc sob cccmd body all" @@ -2321,7 +2227,11 @@ _git_send_email () return ;; --*) - __gitcomp_builtin send-email "$__git_send_email_options $__git_format_patch_extra_options" + # Older versions of git send-email don't have all the options + git send-email --git-completion-helper | grep -q annotate || + __gitcomp_builtin_send_email=$__gitcomp_builtin_send_email_default + + __gitcomp_builtin send-email "$__git_format_patch_extra_options" return ;; esac @@ -2456,7 +2366,25 @@ __git_config_vars= __git_compute_config_vars () { test -n "$__git_config_vars" || - __git_config_vars="$(git help --config-for-completion | sort -u)" + __git_config_vars="$(git help --config-for-completion)" +} + +__git_compute_config_sections_old () +{ + __git_compute_config_vars + echo "$__git_config_vars" | + awk -F . '{ dict[$1] = 1 } END { for (e in dict) print e }' +} + +__git_config_sections= +__git_compute_config_sections () +{ + test -n "$__git_config_sections" || + __git_config_sections="$( + git help --config-sections-for-completion > /dev/null 2>&1 && + git help --config-sections-for-completion || + __git_compute_config_sections_old + )" } # Completes possible values of various configuration variables. @@ -2670,16 +2598,8 @@ __git_complete_config_variable_name () __gitcomp "$__git_config_vars" "" "$cur_" "$sfx" ;; *) - __git_compute_config_vars - __gitcomp_nl "$(echo "$__git_config_vars" | - awk -F . '{ - sections[$1] = 1 - } - END { - for (s in sections) - print s "." - } - ')" "" "$cur_" "" + __git_compute_config_sections + __gitcomp_nl "$__git_config_sections" "" "$cur_" "." ;; esac } @@ -3628,43 +3548,6 @@ __git_complete () ___git_complete $1 $func } -if ! git --list-cmds=main >/dev/null 2>&1; then - - declare -A __git_cmds - __git_cmds[list-complete]="apply blame cherry config difftool fsck help instaweb mergetool prune reflog remote repack replace request-pull send-email show-branch stage whatchanged" - __git_cmds[list-guide]="attributes cli core-tutorial credentials cvs-migration diffcore everyday faq glossary hooks ignore mailmap modules namespaces remote-helpers repository-layout revisions submodules tutorial tutorial-2 workflows" - __git_cmds[list-mainporcelain]="add am archive bisect branch bundle checkout cherry-pick citool clean clone commit describe diff fetch format-patch gc grep gui init log maintenance merge mv notes pull push range-diff rebase reset restore revert rm shortlog show sparse-checkout stash status submodule switch tag worktree gitk" - __git_cmds[main]="add add--interactive am annotate apply archimport archive bisect bisect--helper blame branch bugreport bundle cat-file check-attr check-ignore check-mailmap check-ref-format checkout checkout--worker checkout-index cherry cherry-pick citool clean clone column commit commit-graph commit-tree config count-objects credential credential-cache credential-cache--daemon credential-store cvsexportcommit cvsimport cvsserver daemon describe diff diff-files diff-index diff-tree difftool difftool--helper env--helper fast-export fast-import fetch fetch-pack filter-branch fmt-merge-msg for-each-ref for-each-repo format-patch fsck fsck-objects fsmonitor--daemon gc get-tar-commit-id grep gui gui--askpass hash-object help hook http-backend http-fetch http-push imap-send index-pack init init-db instaweb interpret-trailers legacy-rebase legacy-stash log ls-files ls-remote ls-tree mailinfo mailsplit maintenance merge merge-base merge-file merge-index merge-octopus merge-one-file merge-ours merge-recursive merge-recursive-ours merge-recursive-theirs merge-resolve merge-subtree merge-tree mergetool mktag mktree multi-pack-index mv name-rev notes p4 pack-objects pack-redundant pack-refs patch-id pickaxe prune prune-packed pull push quiltimport range-diff read-tree rebase rebase--helper receive-pack reflog relink remote remote-ext remote-fd remote-ftp remote-ftps remote-http remote-https remote-testsvn repack replace request-pull rerere reset restore rev-list rev-parse revert rm send-email send-pack serve sh-i18n--envsubst shell shortlog show show-branch show-index show-ref sparse-checkout stage stash status stripspace submodule submodule--helper svn switch symbolic-ref tag unpack-file unpack-objects update-index update-ref update-server-info upload-archive upload-archive--writer upload-pack var verify-commit verify-pack verify-tag version web--browse whatchanged worktree write-tree" - __git_cmds[others]="" - __git_cmds[parseopt]="add am apply archive bisect--helper blame branch bugreport cat-file check-attr check-ignore check-mailmap checkout checkout--worker checkout-index cherry cherry-pick clean clone column commit commit-graph config count-objects credential-cache credential-cache--daemon credential-store describe difftool env--helper fast-export fetch fmt-merge-msg for-each-ref for-each-repo format-patch fsck fsck-objects fsmonitor--daemon gc grep hash-object help hook init init-db interpret-trailers log ls-files ls-remote ls-tree merge merge-base merge-file mktree multi-pack-index mv name-rev notes pack-objects pack-refs pickaxe prune prune-packed pull push range-diff read-tree rebase receive-pack reflog remote repack replace rerere reset restore revert rm send-pack shortlog show show-branch show-index show-ref sparse-checkout stage stash status stripspace switch symbolic-ref tag update-index update-ref update-server-info upload-pack verify-commit verify-pack verify-tag version whatchanged write-tree " - - # Override __git - __git () - { - case "$1" in - --list-cmds=*) - while read -r -d ',' x; do - case "$x" in - nohelpers) - ;; - alias) - ;; - config) - ;; - *) - echo ${__git_cmds[$x]} - ;; - esac - done <<< "${1##--list-cmds=}," - return - ;; - esac - git ${__git_C_args:+"${__git_C_args[@]}"} \ - ${__git_dir:+--git-dir="$__git_dir"} "$@" 2>/dev/null - } - -fi - ___git_complete git __git_main ___git_complete gitk __gitk_main diff --git a/plugins/gitfast/git-prompt.sh b/plugins/gitfast/git-prompt.sh index 1435548e0..76ee4ab1e 100644 --- a/plugins/gitfast/git-prompt.sh +++ b/plugins/gitfast/git-prompt.sh @@ -84,6 +84,10 @@ # single '?' character by setting GIT_PS1_COMPRESSSPARSESTATE, or omitted # by setting GIT_PS1_OMITSPARSESTATE. # +# If you would like to see a notification on the prompt when there are +# unresolved conflicts, set GIT_PS1_SHOWCONFLICTSTATE to "yes". The +# prompt will include "|CONFLICT". +# # If you would like to see more information about the identity of # commits checked out as a detached HEAD, set GIT_PS1_DESCRIBE_STYLE # to one of these values: @@ -96,9 +100,7 @@ # # If you would like a colored hint about the current dirty state, set # GIT_PS1_SHOWCOLORHINTS to a nonempty value. The colors are based on -# the colored output of "git status -sb" and are available only when -# using __git_ps1 for PROMPT_COMMAND or precmd in Bash, -# but always available in Zsh. +# the colored output of "git status -sb". # # If you would like __git_ps1 to do nothing in the case when the current # directory is set up to be ignored by git, then set @@ -255,12 +257,12 @@ __git_ps1_colorize_gitstring () local c_lblue='%F{blue}' local c_clear='%f' else - # Using \[ and \] around colors is necessary to prevent + # Using \001 and \002 around colors is necessary to prevent # issues with command line editing/browsing/completion! - local c_red='\[\e[31m\]' - local c_green='\[\e[32m\]' - local c_lblue='\[\e[1;34m\]' - local c_clear='\[\e[0m\]' + local c_red=$'\001\e[31m\002' + local c_green=$'\001\e[32m\002' + local c_lblue=$'\001\e[1;34m\002' + local c_clear=$'\001\e[0m\002' fi local bad_color=$c_red local ok_color=$c_green @@ -508,6 +510,12 @@ __git_ps1 () r="$r $step/$total" fi + local conflict="" # state indicator for unresolved conflicts + if [[ "${GIT_PS1_SHOWCONFLICTSTATE}" == "yes" ]] && + [[ $(git ls-files --unmerged 2>/dev/null) ]]; then + conflict="|CONFLICT" + fi + local w="" local i="" local s="" @@ -564,15 +572,12 @@ __git_ps1 () b="\${__git_ps1_branch_name}" fi - # NO color option unless in PROMPT_COMMAND mode or it's Zsh if [ -n "${GIT_PS1_SHOWCOLORHINTS-}" ]; then - if [ $pcmode = yes ] || [ -n "${ZSH_VERSION-}" ]; then - __git_ps1_colorize_gitstring - fi + __git_ps1_colorize_gitstring fi local f="$h$w$i$s$u$p" - local gitstring="$c$b${f:+$z$f}${sparse}$r${upstream}" + local gitstring="$c$b${f:+$z$f}${sparse}$r${upstream}${conflict}" if [ $pcmode = yes ]; then if [ "${__git_printf_supports_v-}" != yes ]; then From 667fdbf7746acc90aa29b316ef711180e7917aa2 Mon Sep 17 00:00:00 2001 From: "ohmyzsh[bot]" <54982679+ohmyzsh[bot]@users.noreply.github.com> Date: Thu, 28 Dec 2023 22:05:37 +0100 Subject: [PATCH 462/672] feat(z): update to version afaf2965 (#12136) Co-authored-by: ohmyzsh[bot] <54982679+ohmyzsh[bot]@users.noreply.github.com> --- .github/dependencies.yml | 2 +- plugins/z/MANUAL.md | 18 ++++++++++---- plugins/z/img/demo.gif | Bin 0 -> 1271520 bytes plugins/z/z.plugin.zsh | 52 +++++++++++++++++++++++++-------------- 4 files changed, 47 insertions(+), 25 deletions(-) create mode 100644 plugins/z/img/demo.gif diff --git a/.github/dependencies.yml b/.github/dependencies.yml index 4d5a8fa80..6d138736c 100644 --- a/.github/dependencies.yml +++ b/.github/dependencies.yml @@ -10,7 +10,7 @@ dependencies: plugins/z: branch: master repo: agkozak/zsh-z - version: 6bfe418332866d15373392164df11b4fbec2083f + version: afaf2965b41fdc6ca66066e09382726aa0b6aa04 precopy: | set -e test -e README.md && mv -f README.md MANUAL.md diff --git a/plugins/z/MANUAL.md b/plugins/z/MANUAL.md index d367c3026..67a207dbb 100644 --- a/plugins/z/MANUAL.md +++ b/plugins/z/MANUAL.md @@ -4,6 +4,8 @@ ![Zsh version 4.3.11 and higher](img/zsh_4.3.11_plus.svg) [![GitHub stars](https://img.shields.io/github/stars/agkozak/zsh-z.svg)](https://github.com/agkozak/zsh-z/stargazers) +![Zsh-z demo](img/demo.gif) + Zsh-z is a command line tool that allows you to jump quickly to directories that you have visited frequently in the past, or recently -- but most often a combination of the two (a concept known as ["frecency"](https://en.wikipedia.org/wiki/Frecency)). It works by keeping track of when you go to directories and how much time you spend in them. It is then in the position to guess where you want to go when you type a partial string, e.g., `z src` might take you to `~/src/zsh`. `z zsh` might also get you there, and `z c/z` might prove to be even more specific -- it all depends on your habits and how much time you have been using Zsh-z to build up a database. After using Zsh-z for a little while, you will get to where you want to be by typing considerably less than you would need if you were using `cd`. Zsh-z is a native Zsh port of [rupa/z](https://github.com/rupa/z), a tool written for `bash` and Zsh that uses embedded `awk` scripts to do the heavy lifting. It was quite possibly my most used command line tool for a couple of years. I decided to translate it, `awk` parts and all, into pure Zsh script, to see if by eliminating calls to external tools (`awk`, `sort`, `date`, `sed`, `mv`, `rm`, and `chown`) and reducing forking through subshells I could make it faster. The performance increase is impressive, particularly on systems where forking is slow, such as Cygwin, MSYS2, and WSL. I have found that, in those environments, switching directories using Zsh-z can be over 100% faster than it is using `rupa/z`. @@ -32,6 +34,12 @@ Zsh-z is a drop-in replacement for `rupa/z` and will, by default, use the same d
Here are the latest features and updates. +- August 24, 2023 + + Zsh-z will now run when `setopt NO_UNSET` has been enabled (props @ntninja). +- August 23, 2023 + + Better logic for loading `zsh/files` (props @z0rc) +- August 2, 2023 + + Zsh-z still uses the `zsh/files` module when possible, but will fall back on the standard `chown`, `mv`, and `rm` commands in its absence. - April 27, 2023 + Zsh-z now allows the user to specify the directory-changing command using the `ZSHZ_CD` environment variable (default: `builtin cd`; props @basnijholt). - January 27, 2023 @@ -64,7 +72,7 @@ Zsh-z is a drop-in replacement for `rupa/z` and will, by default, use the same d + Temporarily disabling use of `print -v`, which seems to be mangling CJK multibyte strings. - July 27, 2021 + Internal escaping of path names now works with older versions of ZSH. - + Zsh-z now detects and discards any incomplete or incorrectly formattted database entries. + + Zsh-z now detects and discards any incomplete or incorrectly formatted database entries. - July 10, 2021 + Setting `ZSHZ_TRAILING_SLASH=1` makes it so that a search pattern ending in `/` can match the end of a path; e.g. `z foo/` can match `/path/to/foo`. - June 25, 2021 @@ -85,7 +93,7 @@ Zsh-z is a drop-in replacement for `rupa/z` and will, by default, use the same d - January 11, 2021 + Major refactoring of the code. + `z -lr` and `z -lt` work as expected. - + `EXTENDED_GLOB` has been disabled within the plugin to accomodate old-fashioned Windows directories with names such as `Progra~1`. + + `EXTENDED_GLOB` has been disabled within the plugin to accommodate old-fashioned Windows directories with names such as `Progra~1`. + Removed `zshelldoc` documentation. - January 6, 2021 + I have corrected the frecency routine so that it matches `rupa/z`'s math, but for the present, Zsh-z will continue to display ranks as 1/10000th of what they are in `rupa/z` -- [they had to multiply theirs by 10000](https://github.com/rupa/z/commit/f1f113d9bae9effaef6b1e15853b5eeb445e0712) to work around `bash`'s inadequacies at dealing with decimal fractions. @@ -102,13 +110,13 @@ Zsh-z is a drop-in replacement for `rupa/z` and will, by default, use the same d ### General observations -This script can be installed simply by downloading it and sourcing it from your `.zshrc`: +This plugin can be installed simply by putting the various files in a directory together and by sourcing `zsh-z.plugin.zsh` in your `.zshrc`: source /path/to/zsh-z.plugin.zsh -For tab completion to work, you will want to have loaded `compinit`. The frameworks handle this themselves. If you are not using a framework, put +For tab completion to work, `_zshz` *must* be in the same directory as `zsh-z.plugin.zsh`, and you will want to have loaded `compinit`. The frameworks handle this themselves. If you are not using a framework, put - autoload -U compinit && compinit + autoload -U compinit; compinit in your .zshrc somewhere below where you source `zsh-z.plugin.zsh`. diff --git a/plugins/z/img/demo.gif b/plugins/z/img/demo.gif new file mode 100644 index 0000000000000000000000000000000000000000..247f52f4d2667211f897fdbe2fb10d7b696b3e0a GIT binary patch literal 1271520 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�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

`cEWYO^B-3) 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%0Dn()#e`j4r-$47`ltx@vyuKI{IyLSaKNE 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

2R>s=diTSbm~6TTwX={ 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

o1jU)UOt6GmRvs8eZ?Vpaz+M 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

    w?DXxyJA9 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

    oDp z)l~8^nu9y!p@a3j>@0NaqE;WlnAgnFM}n#0xiq{;1qMa^@GMgePj zM!yi^zB=;0y2)!#(PL)mO!6F<+a?4x4>8jMG3|Z+jDQQ&oxjkILzHFrYUe1bopn7d z4^^&CUeGx9mYVzxskWRmTxZ|+No>t?yrl&q%VN>jFB+gDi0PKD$Lo;Smyem?SGC>I zis70S!RR-MqE`52VxCBJNtJnWNzY$6k+r9v6V)qPi|L%VSR5-ZVoKbHQh0YoRa2!} z5I=Kjb3?^-_BVz{{b~!UM-}~R#F>%oSz{&=H3*4u=eioDS_(e#iO{;qD2b`~x~Wu& zui159pGkZxulrUn@x8h3`#Xv0UjNdd=hG9L(=*K3ECjpTh76Gff4@r1U8b-uHf+CT zo!O(~K)&^@+xi{6{^ub%>6V_CG=2aw|5L?(vG+o^QlGGFPKa>Y`r;X2*7V&(UIF zy1U-2fpcnAdrvg*o4vz#BSQ0x_P)XP*R?A@AdufBj>wSu!_2y#am<_o`6@efBt_~Z zm~g6s8EHfRYLq&Uc=-d9T6LfNDh+gS{N-fSw%M0wwy-X{lkF+epa(n8Nm{nefH_i) zh8@iYsHrr$Z3FpDX$r3fia=?~um;LU(m+B3kS0x)6EuLXrpjle>Gg27+p=m6@|U;C zE|;Dnt+JYurk$)~Q6ytsXt3A_qSL~(EMEj=obFh%%P>4=x4v4@%}Gd(La;wyKFsML?-yRA|#> zHqlt`3PxYEBq#;e%C~%ut!LC#yMXJU;HVG_3@ZUM;Vor|VtXLt;ZtgghC`;-bk=x{ z3*?Lk{ZvdpXBeR3@}Mv=ZNAStrUH%nO(LZh7!(;^sphsR`##e0a{*txt8}~=5A?Y@ zM*1We$!=-k7=kPcGH;N#4hqrLNRzpXmNtZyl2KovOp8a&5P5b$4;AChMG6$QCD z6Q=Rqs?m$IR%-ILt%Nq8T79%Q66)6_O5W*;vbjR&{Baj~P2pTx+`?PJ0wI2rT^vIH zhFgk2I7QpvJwP%!Y(^K8aAdpq;!yg=tt3eEa*SInrorZEmD{pfj_y3*^Wj2-6YR@_$bI(?r{6mfVF(=Wa#cU7n*g zm~@U`eda40!%ioQVT5lRl-~ZDb)-#z{heB9ZH01}Vs9Xg=1|kdtGnnuebgo+IFCpz?0dm6$$=udtHv2q=OBb%3DrHhaiw?ceesMrv$wElKfJUim z-yTB;>b6aXADbvi4J-7_+(Jj2684{>x6AHZ)+$eNJV)a12PU0Nn{A^VUbY;d-9)3`nFxR4Pe*79bBt3B2e-RuwP#51 z6Xd5j57gIl|9YuoP3De5DMI7#_N-Z{*(E8f=yubP69h~Z((r7Z1KoV-bc+NZ>~@R_ zdZ3eh@ketbFwIhRBK^K8uw&)kZXW&z0p-zcP(=>1G+*jzyMlhpB;DDU(s_ivD7$GY zkV=}5uKkVbzNY>Gv_uH#*kAfO`zeRE$YE{Wz zxS*Ame(6a;#V_@IDqo$I6`KA$>OuyQ=|dUwYbytfnKEe0Up%B_c__ev4z++PzJINF zbV1->jj_H9Me@LZZjY#3A!wSSRUZf=^(xKm(1EaWuMOoxoE$@RChx5~ zjOd!83!97 z7f0_eE;JAjdZlz1WE>@fkX38?Ev*DPUY#tZ3|H+WHW|+^tr>2*X*|eyX5~zG{l~)Q zwmw|cXbAA1`A4>aKul_wWI)-|@TJjdIg_}ad_*%i;Cn(cSvwbw|wbw{?p zLrY+i3cXz^7D-EP%!Sfq)7GH~`Y)PrNs>!&Cl?Qb^YopexxpSEb7Z_GBIRVdS;W=@ zSg+@W+#ait2~+%oaH06}@>XB=_54HaaUXtIvgJQC;rq8UvM8N<6b^R#ydRRgd*z^- zRO*Eh_tqyycjCH#F-a=O|6p$nL~mjux@c41k?*{+lMO-RO!fy7cRHT<_{IfyvxR zrj?E)S5T1chSi06FURd#nFhMF@T%-w;_HzHZINqiaBVlcKE(dO{~GNQ|yVl}ES0xnxLlo_%bGgjXGGG>bWPnyuu+}L{D z`iB4bxb3YJ>xml<iy~)V zl8F$y_)K=a%ke>1vGf=Lr07@dH2dwDyr7Xv*GQ?goT4zYt>Z5-SMBY@+}MLZVAF+q zR~Im+cHa3h?5|cmVqDeXv#~bZ@GBVm-6=1l7Kv5*G{yeIB4oNw9!%Y3;TEjo(m-5M zf_5w?q=wQ!Svd7bqS7fbK+@Y2gXPs@fxOd!=RE&v(=->ysDu55xyZe5J$3-Hm3>kdoM7p?v)#=}ff0rxs<7kAv zLt^u+;q+(|9{9a{%kJ{suS+!cyy;X6nBsP-?sHfMd16P2?*8hP7myI`i%KRO5wW@# zpJ@x5 zR)eOSmPt~^_;C{PC%3D7+y-AfDakXg%Naf5-Ox);8+^!jFnTU(=q0LOyxN_|+HpbB ze6RxGRj&{|FExSdQj8mN*)9XhNr*Gr=g*V2>q!I{A)SvG%r7Xs)8(SjDeU?Mh=uSB zvZzH@x9?ApddIrPfAufN0sXu$8uilT8wI?jv2yYh43@0WCyc+`w35BkoBT7gMW`qB z4M?IL2B5xr8F@OAZRvKbi_QzHoZ5-^jWQNrWe-^~G1riZdzn1Wqt)+4;$;S3WRZvv zkBMS6945X_mIX`lUJ-~JwG)Mp3pYbnROdNN?|*vy?4W7ox&|ZU;nw5lf0*$aB%H(1 z3y+J)>kKp)s!d}gnTsgyt!h2ZG(*c~71O_2)lT3WiLwYOWL=mQ~0It z#%J+}8qdf&3?*^lv?M)aDpNSHb6s_1>s-Z1Mcv04u!vqn^U%OZWK%?p{qw%~yuzy6 zM;Ph03Z(ZpK`Tj)SIm-pzC5KyR5^jGA9b=aW$Q|-Z3U}sTGp)JoDP^;eqDjEw{OuT7e*zWD+k-`Lf)gu zOHp6s=j>5EOTK^fo~1b}R}-4qz*>re-}i-^F(l9lC{l)F{A_NC-lBHM?a6S>NHQbk z&+dHE$TWo@iFR?V)d`0%E&C+JsEKg>TE&O5Y>^?%qM4?S2x^CS(u-+C_&9JdeOJI+ zOw*ncxJI5dzI)^M_n$1fPY2P|JG%AqiQ)%}5J@ba!Uq;d4=ILRJC;qPDq7&ldHOkC zMNW@MScVPXc!g^CU0A5LtS+Tu`Y3f(UDf5%Wo#@7zu;{xj>2CW%AAleO@kX!b>7Bl zoW=z<)RkJsKGv2@<2lX;HNIbcGQ0C&6OXbKbbSkbnSSJzv>z&*ggcGgq|3k4wFQ5b zQTRL>@^3VX^B*+I9%2ZUC5s2&2*de~kN1Rxd5?~EK@$qppjuiR;UfGX0(Ee(?e6X@ zA}RplP@shb;!1ma8yy{Q5J(ki8F2#xZO}FX!6OZXGKed+wY~1>d^0f61KL9g*w_yr z-hoKa_wQdUt&Bm!$>o+KC_{lpQb?`{s0A%A&#UV2i-`+?;*X)T0C>Uz7v%*xCnZh3 zfDCy2YthnK2~eAQ@+1vpp~@?YcXrks9IRDU6-32^K(@)+PYAS}44edImH9M`_=VxT zcY=LyxjKnU2;U100%$kt!?cc zop0a0$9HvqAoTS15&H)|4i0_#JUlWw_GNrxa_Z~1@6$6sX6NP?el9L8udM!BTi@8+ z+TPjS`@Mf~cyxSn`seKY?*)X6noF;ts4EU&5_Kdt6n{vd=QjY+q>`Q__WuD*dR;!0 zuXOkSfF?N&H2rUA(#*h{n#q?g{|!xY`UoC*v;SM7tF)|f9%_HHKH1>*@tJW)^XB)~ zyX!xOI$E}8@p1p5CJ`Tt-Tc(q_IqXch2e9Px9tb(Q?GqzKfUcZ+MfH6#AEud^B*+n z^Sifyj&^>2d~W*w-T6Og(t9vlAr$brXeg`qT+Dx>Npo@ZI`Db)f1pW~^YL7vtMdu4 zf6yfF1suG*av@Q?d37O4x)=U4`5!cCx$n@BgJ2f zkIi&Mma?pDZZAEt^Q>CRb`1Tsl;aXFvYhLl{g0Zooafj4YdJrt_a8NBr7(QCYUNqv z;jfkF|ENivHvaedqrfP1<-ptRuGh-_fMd_05*K zc(JY4#cbcLw$<{Qt@e%P^{tMbUa{@Y{R!Xgx5vvh+waZ}*SFt8D8+a1P&U7vE;5#?A+NUGZH4v#sCmMGw1I?QSnu*v4)jEJ1va2&zeY{qTy~y#eu-jlGZ3ed50d zDj~ZRu+#fU3l{olfWeciFc3yP{6OLh< z2a_%d5{FanIsS)Vy({VtzxlOn9)1t%lQ^0Vne;!J316u@`Vo1wc{CeMDS14HW(zo; z#|qaUFC<^vI{uliD|xb*WgBp^lvX-L zPx8-3(`3M(&DNFrKUh~gTt>vF_S9E_$I(ADc^%-cc3jf$yl ziQTO2I~eKYVj3^K51ik2;*|!AFNYC7aG&lZAZSYH6Z8mtoV!>(qY}m(B0)%H7iX4S z!d#)(BWk~!Xg65G+CuD+jMz8`$q<<_?w$UF+{R ziP*b%Ttrg_*VP}e$lJ@RG%6Fd?H{md-+R)KTqf?N|Iz;2UUutXnPgc1N9WVM96U|A zbb|h%E9Y<@eL!2P@Q%`aegV{(cUjtwc~7499Zr7XikVnrs8Z z@hbbp^eL4nVS|xG`~4F3p-P==10$&s`!8U$ReHJxqnUa8rEuda1KWYo?DqXK>69uX zFN3kXZ~Ns+LsceW17pul_bU*z)n*9>UrIO+D)o%3Epi6Fl&c(6nWa=)RTzv{+aFZh zT?~NA}lr+FBP%!>Ml0!v?Hztt;Edsa}=CSLrFW?!ty&2kZ|UbBAg@uYLUbDdO;T5pA8f zuA%)+in*prV}BoV{I`kr<~NO2b$;f5zI|&{Y<~Tu&fhob`*eM1OZ{eDpy{RQx!%1d zIxHR<>EJlUeGNhmizdnKa3ED;%dSY-3c1_iK+ewAG5kdGp0DrBdY%P2#16th%@9rE z9R^{xLjV+rn+uAzka|=XBXs1)sy&_r3X3LHg2j+b9lcpnkm9>xh7}*gGg9M8E+Fxc zXwHIL^yh+jO2y&m%hAygP6R$C>4AYFoDTwE>nYh0vzHKvP7;_@;PWdpPvh%xlKiqV;Lh-m0ecuT4k zsc^6vsGLT>ogd#zY1>$0Z($uUH(8=>C|H&VyH5zRkrw4ZtQ^&!d+Cek_P(wD;3YMfHz&--g3=})T z21!lBfvTsCtvOg#AmiECSO?}CXm5IW+yukN#8e*)AJE1GJ7sKa2#l8(FAANUZNW+c zTL$c=sHpqe+8SWKfgJ~y4p?wt*@4I>C})a_3xUQa7=6Beo}d(}fKUaK4GciA(Lj?k zDG6imULp|PJnfo12C zo(e`NsD^?`TU}iSx}c%$ZFd@8g7heelpY?&CMKHR_HhG^P%ul8ww9p$34)?V#=36V zS)e!y_9+;}!FT;yT0Nu{CGWrMM30TBsf*ooQI%Cw05MFnkRVxg<=8kQB|R z`#c;(?Duy}Owh14%g)Kr)E4*fx*pQ}2J|+)Z@X!`IC>X7PtUN_urUWA(25GDhf(^@ zDT#g+<)HQn5}JW&0g6g+2S;0w{q)Fx8WygbUywaLJ+9~J2C|=^{|S1VAoy8SWFJ^t zjWAU6#oqq#!3VTGQRWEyAiF2o*1_3uDJ3~jGzC>s5I+6AA7kNR>XjfoK7LovR$JLn z=T0!{UUrCQjJuJOeni3jZ{P0OJJ^6usegc`^=*sknb3xYTLlGnNX_fYnhI*yuYoY> z>(_3eKKka3TUNi=KmI3Zgr>av58?CCqlo_`J?HQ|z#}7RU`~gWiG`hXDt(8N68G;q zWpIm5BiEoiGaZTLB5kC0xkG@F zS4l#xa2(r)H0;JCSVxf{34JnBc6ylE<8q^p+xHfR{`WX#id>83y-Gq?aIEA;vBnHu z$nP$A4XcrLFrG~HTW{ufYzx_LOlh-yH84{D-{Q1)D0e=dw-B(Wk0yKVnQaY4=*jYt zW)GK*>&%8n1k8*}JIqeJ>-Z;5FaA}hpMP+1xX<9Ff7{{2W^_a(hch9}GOy8JKR~>aC*bC zL>oX;s!7N2DTLqeW@fH=ZiBhE+tVu<9Im;%uYL*UvNps2O?rZH%6L$s14r~iQnm|E z1O-X;z^4ot3NZ}Grf1P9rE5|z@|Ci4L{ot~HLJ)Ai>32uFDcEDL2w1HNGasHFc=PY zn(kPLL&$~xd`jTx>GS;3Vh&+!K<3xw9O#Jrt!D&Q-;Gy9A>V~(97tF+OE3AUm;($4 zc>+OCL86)K7t*7R{)%S~)rAZxOkN^IBk*)F-CLZ zC3J>7PgHZbNWXLh=#$bT)7!|p%3|(8R(ajJ-9#OwU!vakZ`bKw18j0TbAlcb4<`dl2RQ+FN2=Uq&GX@0%0`Dy|^R~3F?Q0 zc*>}yG>v9w>o>gTvR@TjFk2B-nE0nozn3c@IZ!aXCdJeBA5+s+9}>tMk25eTj-_{E z(nK;wO*OQ;3puG1l<+@hNW1VD1Zfuj1MtW;$DWKd^3utCMp#qpm}mF(=EY`3p7Ywr zUiJUfscHTtLNqlg4PVBpYlh_i;_T1=q59+hfBej9>|@^u1RPhWCDbE!h+aaGdMR~_Rz~S1Jqk=97Tc_5px=uAE(@u z9El>4EGdiM9~)}X-QD|7oVIgxF(9yj$-L3LNGp?IxU)M}qKDRwxhC-7fh-4-09(DS z2xcII#(F`JGfUw#DvyZ(&JE{YP0pT8$Gt?_FB3lv{#Tu{zIWifi~^Vf++ruD6KLbm zNP}9Gs7xf+t+le4{I6B<_aGP+-qr5M%KPDOG}hpc*ayTz)9y`QD_E0EXmxQp_)neM zlr~AbZPD<7O89AuNvsGFTCZ9+!|#)fQAj;yYC8;d>HYxCg0nj$F@Y&=NKshUS8vXw zn4?)Y&y=M$lP*}h`jeumwx2A495Lg&0 zQ_=a{0fb`!R{}w8@M=8GKMDd#h!GVbKtQ9!?5!a88P1#$Kd_0qCaMMfhrKXC;fG2N?{4@oUS0 zvh)A|{j@M{oK&4d8ZPgtr0UP<$|(9@b(*pN441JkNZ~ecCMgv4i^VM&7vxE3J^oLf z?wCLR4j7KjgB||HSE) z_Pb60e~8n?sr4XGbw|cX%0i zH^Q87}3#dfD&(*u*<5xy4o5IlvU_LEHV!5LHOI4F|Gc^GC^`bey<>IlZ~KXkmyn$MBrd~Qqk9}xteiZYZ+M=@B?pgg z%Kp{onW~LbY7}IOu+!tGTc|VmCdTMB0XYNq^l8%cbP3Y)zsJJ-bRYIQQ^`4ySYYxB zpx)YK6DX)}r&AGNm0=P!!Q;S!RNy?(mWB$gX(s6=Kk+?^;Gg&V&V;oI;YkIV z69eFe^=qE`9JPKX=L5aHl-Z&)c9cf=WI((t#54l~h_Oz7PZrMS>~S72iI083kh=X? zx(Vf!XcjW4-o8Xt8{Z5I3UP~!Tm&jqRBJm!)LI~)sq)}HwSImfxvE1ur!5i7GHGUc zs*Dj5dt$rGA5=!K;n8f75fFY)me-xDr~?D^hi2LNZ7^tb0;cfIlHS9I3&`7tgTH;G zwL#9a-GKuNNIYZeUm?ytl+hZ;%JHBoF<#<^u`$N6(wyx#ChE^ z2$||Eox94v^LstY37h||YnyU&7u_m&zs1Xyd!;iD(?{IBWwgFHRi;u83ZVDN3__J* zR1Ugb9_&4KMa?1ZogH@*cSFNF0p};wAoS=d4M!2JF!gH*&GR)#KrdIfky$+LYJyRS z;8z%d)?`Kw(sP${>#idzAXHT*V_Gg2=^D_?+&4kjgK_Uf(#3ybK&;Ygi_l4_F!Q0P zQHDsUEe-T3kyj1LKXl{0hx>bWL8VW$&n*$Gd6x1V3~O)zOQG#?Cea-*Ac|;I6bSU& zqN+9)@74u7*rH5Z?a&jVKatS@5WR&)ZlYo}LT^*m(z_WTt#WVAJ&oO@Ah8676`R-# zAnL#Xy0Kass3nA8fc#u`SAm7b?+P#&p!gi`L_*T+PwD7;IE7+3Ch<=H-iOb>Y)i*IoqI`n`A#!{ge=IUGpRgvg`5WFFC6UA?G0(KusrL+oz z$;bPGlw9@^n{4zJYRp%i5u5!q2?W}BxDsCu)kV)x7!uKwK^u)sXI_vGu6ywBn4H?` z7O7;^1te!9cqRzIJRT|C;=GSZ=}XJFaFG^i1QbfpZ57{`KnjXe(@Va}kU6`^@svub zk^mG5NcXOO@$yR5oQ;;DZR__YT-xNdm!c{=UpCW7iBcLl{S zB8|4J=-yX%zCgSa!$p?ZAwO0wAnMIMs)y-mYC?R}Gy)fqzmQ}Y6T>w)S%xE@AdW#( z=-vjTJ-&)y0_PVm1gIM(Ydqwp%!_6iC3YkLe1H;TxI26@^H)IF&z}}1O%@&Tk=9<> zLl+|$?&+?dE2nc^+q*EGg z6`JNjnoD@%-86!PYGiQA^{usCvx;0wm4u81SAhZj;IX)MEm<^3GP zKaN`!2}3!l8)3kg)od*Bfww#dn+IaO)>pVk@v1XbZPAl&pPv9gQSt(NK^k?CdO06U znQLVcSU%tcihe3l9LSm>Y>X7WfE2$--D;a?c-8Sq^Lkc)x&ysq7v zp7J9LJfc*RR0*fG-B6?R6r}g$D*R5!*>+}_GkU?qPSbD)7!gA<-twE8V5pQtmJxEM zQ4As`^$x=_^)ipB-524JY1E#Uki9cIAZ@jZ-$T~#61ldtezU(`mX`Wq zKs8QH8oE!TB_Y*^qGmgPd)*0_pBHTih};Uw;LpzrRB9^sXxb_!QXi?xO9ay0jCm~K z2d#}k?7xIQtgfqo1_Npk9}B2T)|Icw~_8K zCVuvYr4C`hr!AIVZrY$LfSVxzzUl;o7x{mF0-b2Ey2_m;6&7+7N6Xo^G?~5++>m4s z?*eFI!@~2B!81iP<>iejZN9MtBDSKafhV&01#Rny9uyt%7DHbI&@4fLk}G$*2=vd7 zYN|fbR2I>2OGMI5ChB?>kf2w(4GT2S7CXz@S~hr0R|4u>yy&YXk#lJJO*H+SbKw++ z%R*ihG?3xyZ{K(L8vWth>F-%Guf1}k0tP8GyN8Gu&UqRd97V}(CGu@IuC&osrgx}n zVOQys&?;?|fFG9_n8cB>7-yMxbT0!U-@_w6CzT8G=8O3BHYU)0!_(7Wxga?h#3?~7 z#~~=M8myfAh_3FT4^N0r{1q*Zu74ug`VL)}H1TK*<5W=&SNaRjV`g6i#|BHO^Hd5M6;s!!vJ`o*E666j-`19+zP023Dg{{8@M(7!#lzO zDId?Cm*&kWPb^Tcg$EDaIk}v8*3p;3Yx^#MVf_L<%U}A|k9R-C^89dj@+@HfqD%K- zzj*y%kXJqhyEIgm;yRL;LsiRo*`DVfDxE2jXAl^<6{Z*bl%`{~_oLu2Hxu;R{-bi< z(Tnitjb{3pi?-TrBZz?h-lb7}D#+A6{nr5cm9)BG<*sEAWB>N(($d=xCvR7I$JR8* zHXO#bqQV#YF2 z2QsxD*oaLI4+;snMv1>k;WUk9VUcldOpjzVo9qn@yCj+&V>!9FJ`oO{(mY_blxMRE zWTWn9a{{qD>NC3svPaaFl%E}-g|w!5-g02XIhU|gmGT3quhW+Tr;X(&HTWF(3tPCW zEx3Heb^qZld?(clr`d&p`!2`_OkA0kT(kjPgnF(*LEuR``zozkpv$z@;tXH)oF3mS zc5>Rfkj0dBCh-0=us#Q+HS*y@_g+131ia3=K8K^{iCAmg$h>t5Fr951u@^xvHNCDs7Pc^RSkXPpZ#t2yeT zS+s4~z8uVkYLI`(BM*rJvQq;8K#Cw;6l4li+k;}5V)m$CWQU%klBVx|WnaFgq`%#8 zyg@Oow$L{cy4YDVb!NG|a~r!xKhviAA)&y6O`*^0YYG1{dcm>sb;SJQ#}9gTE2TSz z4O3ZPmS;u_XN)?he@1`UuI66-xBUAp;g!~k@sjK3uNKjct5jpRmZUz8MXxSJziaSi zX);5~D+t3u*5Rtm7wd(!m{~G|ER!iU93&Aw7@!U2uqzhTLiO!b<7PWoqxdEj*$R5# zA;wEm?tEPouGLFs>+@P}onbQ?BdU6(6*_Mr+ojCE zx!JjSPVjn2-}T}CriP!@o7PAVhEOO)e#Tjem z==(MOuo7`3iKH_HWXhUEy3hrz?(4Cb3;7Dr0x;0!JNIHr@@6AUNqh6@qUHw~7xkLW zpqjy^#*zoYpV&q_?>KE3obLGWZ#Xh+T7O%?U)8ER?ezcF*{&`4)GsA)>>AJVmZ90M zjqFxJ#ZFw|7aZNE9{v{H!41r}t(kATFULxP&qH2!ErwHfx=53wuUYRh0Apa8*0+R7 z7n#CznfFsNQu=ypV8uWsy`3pVpvd^>I{?(mf%q$*F|F}XtIid!@5HWfpO<*Vgn7~J zOw*gFJbo7t))GXk+z_%j$W~Cp|M92NK4q)nj9;H$M`-@ihXwi%jEvbYL%zdTB0+nX zqwc1#tb9K_Q)-#GTapdmQXb#;(pp7+SP#hf!Q{6(#Q9@J_`oP3#o*&7t_Jzk zf{3evM2Uj*x&m)+U{Ju`9yg$^hr9y-{HgnskZm~9!K{n z++Kbwf=*X_7bv&o=5GPHe)PI#3;v)aS|)^D=R5U-L+SBD4s*9BT}S?BEH9#u$xqZ^ z?OQNcqsV*T4GNDl$-nhdeww-cj(+)L=k=m;-A9LYWloTFsHuuajEc7vi_f~s6@OVV z07!f+2}Y?ELx5S4LpHhJB>%7TX1}>+)=T+ov-gfpHx7x6yW?+97~~F-{>KK=CYjwk zvI5ygXG6PtT00LIe;OYjWxm`+kN+Fu|5MbxJEn8m{oyp5>nr%fXNB(5eVuv4*v_#3 zQ16Em^5dg(q~|Jz1f%E27QSZ`oB8^$xu9RP;Ji|1%LzS3gaRW0SeaO)}o;ZPd(7glyszNdTv;0?ao|v zzPp+sS=MPQZ#UhtePMbv>EGf^l~t2VX7TdyZL#@ASDmi@_qJk7O}F0UbSBMxx!xA_ zFvI=YQGji;{q*Vm_wQ=f`hp-FW3&s^PR|oWY0ES&e)k+H{>#izJ+Xgtv_Q&#&Vl>e z*-m`XuNswM#Qfqpx3pyGErXzh@|QRacp8EIo%Vkx6kUUr>%2ZI3RIDdX6rY~)TV5|pF z3CvCjqfhkfpVoEILTdp+QOb=6Aku24oE+k>UZAeTt&K@tAx0ldV_^ti+8dcOE0J0( z4_m|Z;39jc;xMfoloih~Tf9F$2)~b<;<`F&sf4>JJcY+v+`nuD^1L+QwY(;qU13;Au@sCxaC^rRKrm*kmo2QIC!5wm;KKQWX%ha*Sp zU+c-X_@k)?%eVzI4xEYm#sjD5_2|0mDXOwrHzJAutX+x5vy+bZd>z@wML4#U=Bwjm zBxqA=S}!diVK&%nK)sRP&4=GVQwiJ@v|m(I@>L!&c-QR=VxRM+Ru%J^wNCj5Gf zT+4KM@u&8spZTkX9LKDmuFntHuDB&r!{6>yg>9rakUH6UR+p^@QX0vFv36fgzKrm= zwT`o&tmsWIX)F)4jZHfAUi*L^NdG(ccdu9K+56}H%Bo9BOrLx?EOVJi4~yiWNEE%a z?ahA)F+LwUzLC<96l!X+9V)K6cU_!k<(|NzE+do^0$zXca=kjUeVVbR~gU!>Tzd~^*r(ATTv+-LuMF&;fN`bG?^6T=elyJCfajm_R@tGa(z2QS^X@BE*XIShVJ0h zbdxxtq4guY*enW(%DLwp*odQZ=X{-KhoBYab%CYUcN`IJX?rExZ6HG^xC{F(Og{y- zKHTIv(MpTVh48E$#$vP{z6{)c#LJYNhsn8+Mlu#zS(zKq`8(-PfH*ukN~sW`iL>-G zb6BsLvZJK-Pug^YU8_Aaaa4=xNl}Vx{M{`Bm{6umo^%3Ku5-xTLVWsz4QG~R+h&|3 z)2%e#8*e1J+J}9SnR+K8BBBee)y8!x>%#BZFL`Q%WAl%RF#Y$jvS9|B#+jXUuuC=Sa_{S8pv&FP|^0wp4pA zng``f7c{W0s5IcAq3j>2ODzpGl51mv=cXSY_1&yAcxZ9=aQaE%=ri#%W3xbpnIbBE zPr{{#_&AlBr;Kcy+JfqqNn2LQZ1*J$l-n#Low7;6-(`}((&*#_Ca@q%#mgbo~&pX!$*KtD3z0ov*w9ZQ|Lho97 z>h(lUSFe34^JebB41~OhbY#dVZa)!yD@_uli_5u^*+gGHaEW&84~%j2v%yd&t_|D;Zb3xr8yHv|Fbd1;MRd9-V4_g^i$U_i>{sG4${=;v& ziF)_xg&VsxQcIH}PfXEaA)}KidnxfzXylWlu8U3$yq13}6%DQacdAN6{?AmE>UW)P zC>V$^is85BR|4fvKuOYfCZ9;xV-abvOIO;aQs9^jYGj4F10ZnvOS4pO)et!|BPDGkvFo6S;0?hvX^m$tH=4Qa3ZK!M{U=Qr*!_A z+99@fRE9WHN*!AS6Ep4HB`UR3=M}-+X>|z>M(MG(MQKH8UrS3%=Y2OcC4dnz=H)2MK?|t)%7olo{LxHy*+;VeSfTAKM z0!QeL{>}}pd-zSQqtZm)W076TP}z*RgmMm!^KzVKOvULnZii@86}ypa)O#v>2=G6X z-Qe@dZp?h!$0#N^cpw<*qXYpV(x3{Y&T3u!(YGF;znrSq-5weX^i{;E_M+3eR`@`K z+|V%kd%>amy$2Z-xEVr-8tSaeluD&fH4uI5j4q+JjrhSfo6xiDH%SVQ+7n<4Q#m2l z-Mud226>-%7WtMpAPp4iy0l95SJQSpxqI*Uz1&d$$C#bfp--2;Xr-=RdU|v`_Gx`@ zFWY$4#A;JlhoI#no3@wf@JWseGx`eq>y3Rpw4hd zOk89I+++LP1OoNP5F+$E`$~8mEj3Il2RR9p>oSv-}VHa zaVx%9ickVkhBWkpqzJOkZ7V@!qiry)H1He(m;(m5`B+(_cJOhGyRgBEf`Qx5Y8@oP z_B{mQ(2VAcg(bs?tI(Uru~qN;x7J!BrO1qmh#Q`9&b9SUtr}9nRM36cFC?6fCxIai z+Hb}9O)}O!((pPeA!4-l(d+tBu7vUAK}Jb(2&?KCZ9EYH9{Jl;Do6;!0B1G?Zhai* z>pI>AYQ3*@xymdl@}-aJ@vnalXEQ`R9;D92E)4ar@`@^Cr9mZZ+J;&_CRNnsS6_HD zoW!^HMu2+KsOxwBV`;kds@%*`UaI`o!m6&HJG^#GrD`w4s)P}DR&l^QE|@bRsC8H% zvKulVhnGnBmE4_wJRH>eDjxw3p~zIH&>AJgxCX@8pc1$x+KEFtl2wU#fC5&FBjRhp zwGd(gd}T@>IEK-@NCdrzbvH2$WJL@V46IzDs8oRbg3(yyi1%~{DWKi?1{E|sHm0cO zoR`Y@MZq3Jh_hxi#Q@Aa2s{P|ny0>ufID#_W_^rE0cP{O&1Xa<#Ji2y@5qEm3}IY> zW=xohgy?b1H1fd!o@xq#y~R!WZwL5jC1X;Jiu3wT>bJaZj(ix+1nTIZoD-tX2e)lSt^u8ZwK7t|Y-F zX$Lj;FM{(ZU<8!NISICl%SXdjh9RJ(Nq0_t6q}aVUl|RxCTTQu?WGo9W0^>M@p<%NT$wYe*$J{&R|=`UXc(pr}l+@rCcK-};P4nTq8~El#b+X(h*L zipS+$i$d(jjp^BrpuB1#xR1%&^xR#MSe(?`mlsHnf6$3x6iPEiy1oX_1k=R&R&@I! z5ruyhiJq?@dHDTD@Brvs5vCtfdwwnm#+rm6B;^Gn29_LmsX~2gF_ukP-Pnrz9KK?h zc3IM~Ha{H0%a%|%0{vw)fPezGMH50{fXFWyS2blYCbo1W#sLir_^C6L@>*(kI;J8% zNg5%=E0+|~5zE#?a*p#rb_C!D&xm-txK0fZBkolw)^R;&g7@tPj^G6&1XWGD2op4` zs{6*Vjc&xEbsBoFdyjo`7TiDQL zL0Y#@<7DCdD;1-NG}v9ZMnB=8TyEA#<)=m!czo$P3@B{CyL`QrAw@;U7Edyo%eR~J zIHwfu#^KeJa}W^RF-C3(X3H6CsD}0{)b|%946>4~)s)Q|5`y1OhW)C(y-XcpvjiR@ zhySWZxG5M0Kvzgm$)8|XBZC!Y7+3X(q>aSckn*%h0;$P}gqdHPnKlksepg7I;X{Ou z)+%P#5Ygu2B*%Bzj%Udec3X7tV4g;Yzjn`7HPc0}cKVFD2dd`7@Q?Ur5APHcdWY>M!akyiv*;RvNKxWU?`36R@Z6D~z`O^-SQovB0O>0wsmUY1A3ng^Q(M z1&(8fuk45yzQ7UF;Q1^FIvaf=YUDL7MT16}lvgw91`z}xc> zfy~#-q~ps(#PoRn6iFi1dA*y0O`h;aulTe(woaXR; zf!4P2b%yoQGY5s?3P)VS0vn8LymyMglo|Mi!TrN^g{SY2kY;0`&Me5o2>YJ%E*1Nu* zKoied3{$my<+#9A&kUT~{YcM*EqTXR=D9r+E=3AncDA*m{V-)JSic*}q}xQBkjavu zE}`$`NtG+>Y-Km+g^Vx!;1!WJ96zyYYGU9@AQ#K-n9d`R>Mx~7^b1)jH6^@`CNf=a$1^1XE!XLWSvM?`BH8t2&&od;!OKrtIRR|(Si z81qmOYZ7{hRC_BiYVehYa$9o(nJzAN=|()+NYc&2*iJLC-P4#&EsAG5>YDLISKb8K zHNJ0{-W0iixO?}fr+IFzwX>Fn64(`3un<;ZE-xtOO?6=R} z8qZ#7GM?zlzVByTbbt5>Lyil5cY3f_EsXHe;Z=6(1T5PU9Pq6uQwONg`K$PijM%Z0 zz^o+2l*-Bm|Elg2B|uHpUAIjEjQ`fuX4UEDkHcz}@ZB1C%?dL#o!(Gl`oqM2tTQ1# z#&eqKCk(IFBP$G;u4;PYVIonn-kvw`QiJW8j{Hvh@OQCP5B49G^qj+b@IdS;2oO@z zy-tCPp7-en=-S|6VfeL4D>I!!wZ+9JNA&1QU;DpWxUJyDw_VyAbV5mo2OkC&_^Dpc zblsG%dUICrA*x0XwYT>!a|K%vB>KrZHh4Drbt|vMh9qNG3nX~tahZRB*V&DxI3sq% zt-QFPJoqh6Td2op_%qzI+JxZM*~0d?WBB(Pxd5hud3Ts zSdxr>>Wd@9lKnZiN3@U$uFkQgkz||wcW&SOV-R3}iK|c*aVRPS0eqQZ(6?pP%;U`;- z+{_2U{h%Sx_33X1By)Rp^5MY+KSnNlnJTCD&xfiTYO;GXIHkV$~Gsx zS1+PJy>TId?xe*XMkbhtj!a54>OsmuUr6WBXQSKqZT3l~;XY*i@!8O`bnApBy9xNc z**NQcKfcg9bYXk&&!%`(?B${6IPv>w9{J@TIz z?fuAZ)#t9qf3+zTXG@q9<#yVo$XEn8%;;)9`R`C}RLa!BtMbT^!BR82Heb&7Z*(gA zue7!uolJ^HvuEDP?~O7gfxM36Znehw6FyJLNrtD5q2Bu~4E{S?(kZWe_wU2ezZI&} zRgTk-;-_n>r|X8N8&^&@Z=P<2oqmcx-OfGzTz} z6Ddy%a8P|lgs=7uaw*D}qkQCN)(T+i*$WC%2a<*q0D9Ig;-FT%(wD@c=(l?;zcG{{ z-fbEg@H)*L3O_fHmV9$e`hNye_F*u+t6TM~vdMhqe@IW2Z%b`q;^c(6b8T)$1z+JU zAdb<)spmy6$q(No=0J-OPVy#syNeBsPt*&%!q)n8{XaO9%wpp~2nvCzBR-J{D@_te z3BMgpPWbVn`(B#P-Bl)d(H+oTj>qTF?Q)bqz4|eV{2$Wu?01fB;1OHPM+g{?!3W9! z_}F`NiFgtQdJMwAc*HpQZ5E^zgzqbk)h{H2g**rVozJ-$gBqy{djR43$a0qpKw^;` zbfp+N*3U-SsejBquVmxRyjIV0E;59>TaiFw*JA$<>FHr$`Y*>Nj0YYM1{l%KHVJy! zt;qkgnASQ42oE8P!j?B73?(VUt%wU~(goxLZFZ{CH1GmIfM}nm%(t_D-E^<&`lEq49NP@d4Qqu77VCKqLKlgf%lDX*`1D{Y7hcTwNo9kj{8-39Y^_D zoBu(2`Z$?>@K8m5$FObP<#iY`62}o(1*!I;|=eJ=RT17 z`RwD{Lv#?)Xmls1f=UDp%wfjzHJ=n933KkrX~eaV)q7kD~KrXW;gf zL>#`j!$May z4g6xV^x#$yHfXBGow^SMpq4PaL%8^De+$;WRo${;WI0pga5B^PLLIG4JMgSE!FGhB=&t%(ilJq8| zw95Oo()F#KrycfXY9-JALwfQ(6f1y!r}p{gCJy8Q;`%rte5kD2|9Dc{s9%L1zBEvp za@1mECczMW*YdcBSm@d^^@cu%ld`Pz{WkGsj*W%P(ZyCJxmJCGQzf>YlC}+PXTkv4k^1a;H`w?dpD=@w0G^_qWwjgED45W zRgo9}jBvE?(tfh1cAJsq2oT=4_=zGQy+SVX{rl^%?)%wme2MoA|2l)LT6>q@>w$P( zRMVGKdsxc6<+#q4(h=t=FEMTT<6cS-dv^ z7Y)^4&lcQ_SYZM1RVc~bUUhK}Fw)O~F(uK9O3xPq3Y-wJxgW9_-PUC8=az{(l5_79 zIZ6+kA+r1LeGnV~y00x)+0TH5GMP3;609Gk!L14*2K5>qSq64QyqBD4x}i|PqgngR zKC&#jD{Q^=Uk98WC0JKd@TMBmm*mUDPjqqI z>(Cq9gDlfn8t6oHKN0&Seywxw?)dpdsLwGe?ezT-qEPWtE?|NppyrUo z3z1^&6Ry&IM%@R7GyG9b|ATc#yP)9U>+rbzHgVpmZcm6Sd(q~Gi7UW3fkMpuSSSY$;xNUT^$R!CT-SXf&~ z#GqKjTu9WmSky^K%%fP$Pe?qpSp2S##0?wHK0Di#HJn`!BMN1gCuCGqEU6Ba;wH0> z_P|akjCsJ-Aqt}%MKWUzV@-hP0sOC^FaklI1aOp+WxwB$P$|&^sGXnN8)MdSOQv>s zVI#W|oUz@I#^?mU9HDqVHLDu?3 zNt}93iQ=iNt~CX`TB4Ln#xR%ad6rz^Ej5x5(Lcz{qEqDxzu=^pYRhazMmJp)XPsU??h#mSBy^qq-vk4F>^HLsYsy z0bB297$xGBF$U}s9r}*0?hpmR3*zfIPYul4^}fecVd<=~eA48r9`0BQhKjY!g?-Dt zfa)3p`Ic8{b0X`U3f%Q(BPa~#$g2Hg7AxfdgC+2eL;%k9q%Y@VSbH_k)7 zOt(tZ`LQS#!Du22^HYpN-<9wf~QlNe~!nk ze2n+qGK{B(4gXqP#|TTo)jhjQ0UM_60Fa(Flg>$oD8DhsB$`uG+?a6T-}=H8w)kH4 zm{$PZNGLC1%v_DYeS9Ori4sx60{9U4cl*E&1SfVJqM{sIfi=#axzSv1-XZ?1?^D#= z%{w*XQ7RSY1wd3yGUjB4{DBa)1C8eHqob^wI}?KtJ`T;q_|$&Mng;ZC3LG+AP9CmcB}1Mj zRn{hrBXI>|Uf6le<2y7J374+X0PJ}nctA4XgT;1W7%&uS5fTGMSorw)b6}^kF{w;~ z0PGW(3kXqQur8~2PCfHwmaAi`FO%yeXGgj5=WSa%5k9};Q}i0b@MQE3X~Ja}vb za3ToYN@tY~-*=vh?L1bfd^!BwDW3pH08ffuwAH_8mwXNc5Sgn8fEtBGvjC$NK%@!hzZ)_OWF`dVDSo$e zgBCcE1~{d8kz_}aUM$pCuY&+|j9^40CTYl%=AJZ4M2v*YG(U7+44MXbmZ*RR%@2NZ*W(Mo zP(=bO?&s-S-67&OGxV1j`PYq?@tl3XCHt26$+{n^0f#+|+aBil{8meK5wf~SKP;XA zu$~`XLYi#NDGl_D0ryw7?}WLJ7eV2aAcKU_Sc&~RcWN+w1R#Nk+3)#81AT4}##YF& zh418mF~{uC-`r$C019Hk!NvE%-Fv44dwbtM#-$O1LYGJHo^99PzV^ii9-VU461Ddni6I$q&A z-CcRuwOU>2`b;EQIIKnh1YFz5)TXBFrd6(`CS=y{V^adTN&>lG9_)^70pj%-&miGk zNs-rn{6_)YU7ShQ@dx%aOppir+t7pElJdh;T{kSXG*HdpAx}$@fAM@-_64os*Pb>4 zZ3yC$Wt9RCF0*Z0aKlbfM^U$kBB(}4CtX#tI165u{1WEmdr=Pe@6v$)V{kqAdp(I^ zRkn|g2S?8c9ZmXSwg3RP(}C)vD{9D+^ThdC2$t}DZ5pxB8_@+w#-wg))}hWXVIm%0cdOYQ)h3SXwexxDi93=-*Uo zKmdji;Q8G~>sz0(cxBt`O}74LzXZqYk1HFUtr}fcl&=l`SZ%tUAi5*N(koh}9qTlp?55PIXm*Bh$M z7g(SOS}b-{?+ZIFKm+Q)LUw>q?nH(~#)O6^hjPFNnewc3=O^j&lKC&-vbu^P7jPtv z9vm(_=v~#>DFhn=@c&f#avF*iQJWIO#mbQxs{HkoKyfiGLH9l-D&n*_pfR7)Lsoty zAH8f)>Qhb(`0CdTx_8!qIsSCVT=fwSmK6EX1G)F_vFBkZo zA6Aq?L)68djc93MSTQ}?5q|AJ7KSMc`xg6H7}q8R?PNSx60Akv_9Ex|~E{20(&P={JnHp)-xH z+!I}+4NA~0V+Qi1955xNHQlb7{kkPvr`=Wj0kQz#nxE`r=+mzmgEl`jx2C;>J)YJ z$CH~G3X$2@f6rSHvhRMzqOjZ&6Pifq=iHgk<=R-fdk5VW7?JKT;_H}@vmf`mSLIYc zhM_Q?%(Y+u6axo|SR*iS9(6RkfrDZ%jw^vl-h@_4Z`(f}&UNSB_|M!11rs}?{SO2U zb2K0RAJS8aZeg%cbp=Wv5#l*bYog;9m4ExzyZ=RchWfs53H;>OZXf2q(oLk|&@KoM zTpx`7TT3X22>vww)G+sdk)Cxo-*pv6hV8BN#B=C8j`|Pjd8PYtbmYR8Hf%~0Z~g&P#{dE|AX}OndqSsOu_e3U#Qyexw+`+`T!pPRkxE_RM${szGC<1U2$xOmlvWX&@%%629jg%D9r3U%* zeWu=so6%r~fhpZmf}vj}){tAaf!U;~QJOIFsG|?T&NsP4MmylK?riBf8SoKtfUOHcs$Hsw$-UOM9@WzHzqX(m&PZ?Q8HUfs1 zJLJ*MAxny-I{Xo(v~N`Idp^`Wkw!6e1U;Wk(|Ik_1XyY4+RWmJ^r5}_lf#qgh3KYH zyXK5%UJD6o3mHZoA)B*}H`ywCthiGbgmW!D=tr3xURB!82T!{17fB1LOVDX_w30JP zLc^qG05LI;>`2-^lc2Muu@fr^TQ3ZI>h^kmGvluOCD9zCP-9WyP`0Vul@!|pp&Y#F zAJx^^-Dhfok@7-zPAN#+JePYQc00jH#mV&SG#s4ZmNIV^{xQ|L7Q!KC`lf=J&+^rI zgV4Z1FT*(8Ho`gFg8hwaE?bhGq27Syc`ql&r8}QfFTd)mKy`%wa8J@`6=5&q;BEmh zdc)!Csd2JJ+w~nD8bXCv%-`*GKWoPsS~66&r;`zckGZBG^adB0-FtmJfR+>XEul@K zh(3k&=;zMO`sFDGY|ViCQ;gA|Rn`bg#>rPT=jwuAI+x{8j7lQkB!0Z*NMd^%0NUoY z7-VGEx~*sW?#wYb-Ri*6P#J{m04!M*G(+SK<@idp{PY{x8}>r(z9v@W?Au&`r z@pzsu@ ze#iH%B~m9wT)u&8Y)#v`$arU}#7Va*H%*vfFJ)k#k6xAY1;Za|GId1U9>KC#fm=86 zdSfBynRw1XEY8HxV`NCcmCXo%)&_YB6{Q+XzJ!^N2WOjH#);*nORjxRqJC5IZg^-FzG*~ve54<1<X}zCpd=mSd|S|2&*hw63khE*^TSE!fR(R zbR3yQzR=4|{Qu+Vtizgm|37?|tboy@bR#5%5z@-&PL+`O45UjyI%M=nDG3P)rIAz` z2BLs~f}nso5fw!d5hX7- zo0Eiq=@NC#`7@K;;0xuFD0+6IcX{wrDH@5E8Wl8UsNhxaU^x_U7W_ zUv<@5uutu_vM0V%LqxmYY%#9!)wQMGz4Bdv47vhuzbEw4HSon*J3N>#Ua+2=EXnD- zo-rVQo|r5wRIequp0#FS%rXFAY<6|92ZJX8=U#)^EfDAFG${7gU>;Jic09JwUD>N3 z6|IW%)Uz;7S5W*QAhSNCl!XWaVJDAY=DL&MB<%e9RPKs>QR=wyexu>ER;&I4ix>In zf)YxYbp0uuTRTBF$upG+1r<3z$HErQ3lD>U@^8tyu-h@V;E(A5;{=vcd4 z>P@ckPvTehC;vOKT}QAe1M|rda>(4$VM`CR)^+=AU%q~2KCXY&3%VHfvM0D4M%js0 z<00lguMA)LObt_H*j3mvYqJZodNul%_||uEO85M-={N7+Kf6Ph)_A~aH@6V_q{jpy z%yA?q7Jkc|+Tho*PF58JhT$LD(_JVwEYBzToBrr_eD}Jjxwsnp(nFaSd|Brg|5A5E zRc-()#Yf)bB}%Ez{Ly>%JVZ(^ne`#~f|h9KRaYoa=uaCDtG9Hw{Cl9ht?5grpJa#a zdGd%{v3{&UkYnr#&$7IEu_o|x69&Z6nojH_|ET;CJhu7oc9hM8=NMbZHh06Rk~ieuvnTUK-q{&ZmIK!< zez-}ha=r{5m4CyN*Nbj6n{a`YReUvVi@K>`Zw+r(~<$C2CuXd%!QZ1i9@R9E# zZDPMi8Z?&3>F;Ge(JcLY;@Z!0SeG)z7&j1ULlsH^UVRiuQDR?7X&sM<%{9(=&Hgt$ zUF#o8eevUEi=T=~Lldl`wA|wz+A%knll(9=s{WHm>)s#sBdj$j^)8SdK#*-227rIA zR^WU#;5GanV_i~YstF)@Z{2^&2%Erhg9~n=q5Z53suw|;DE4>~+ZyQ4xyEpwzaDnG ze<|nN%kKv&>_D;3B@tcwY6Z`cQn(g7o z4kPWybO|k?HI4#buKw6wiW5W9@amkIoK6Kxcbe+dOXcSLA>*T zGo!JIFCoM#t>fUObn{^~hczKVhyxHZHUC56RsXma@EOY$!r?ey<{rZP`6+LR4c{#r zqqzL~^}F0-9Vfnbibf#-!^B9r=2#J3>=SAvJ?~!^%02-LzAm&R?G8 z0=`|<($f`;7(?r_iykYHEOb>hiM-#)mwb}WzFE{B21qU4dS`p&JMO43ba#n{MQ2Tw ziDJ8Y7sCuXA#l91inFq!yYe}&T?N}BgAiq-aAlXEFr)Zgqr@d$MG!Ap=V8*WalW$2 zjWCn49+S#llNx2yJ7K0xJ*I8Drk%=W_rlEjd(4J+&Bm0?ABLGv_n6P^nlC6@JYPBy zO=rm#Vf#oVc+gpjFI#-ywVdR}K&v5iWlIp9iKs$!-A%W9tXY4X{4TO$7ZH0w!`#J- zA%0tnhubD9+wk3x5xHS|Cj7j%vQ0S+&WT6%C`B1V;axN)Ph>Lb=z<%L3uj#Z8CrD$a7-;kgakrM? zxgr$_Ll@yd3k-^f%c*!?e4)F0!JcEB7fM5D{ec63!_SL=vkF0gdG}<`_&?r)w>_EG zgR5k(-rrtVd4Y)g-ih~pDq(Y}P%DA0c;B^%E45aA8|N&NEXBAJe(j-F zlM>#IC;d}Rep+`iz@G9xDVYJPwhMi4$L5gaqMLX{H)W7TM=E0N17kyvFRAqqY{OtvF_ z30<)&nC{Ew5}{h)=*E&4yD71KPxGxM3hj+bKkWxv_N!Z&t44D{-sb{Zjn+xe<8vDh zvFhj3`SYXuN+Erv4F25wE4YHn0}XByf+Q-<^*XR5RtN&pxyM&pe5$Qx2(S6P+iDh zCOV#fE4n7@LDh=a&A>0e!=%2&NCC}K=~}FnOD1KrFYrQ_j;Erlu1=97)*H1@A?HlL z==$*)eytrsR&dF+Gbz$)0^wq)N2Y4G|N|$a-z$x z->j(=P-hbXTG1VNjoi?NPJtI$CuhSEG9Jj#9&;R3Vf^MFvoC&xbZgV&6d8Zzr38ksf3^TDQ^;XthuGp>7V@1JpGaGiyYMF z-(j)@-qta>Gj-qLmYSEQiXB?nPZNsYgGF9pkaR=yoJHbG z*1#B>RrY0#!6F5bCjc#;-QBz^aMSX6j@$R=mj<)HtfXXE+^++5EN$Iy%Wm&o$Lm^` zWtI0O$Cf6PkCqGc!;Vyn1OducJfZyNopPX6Zc!_!h07g}+`)I<9TeOeyjSpVO7qJT zK~csC%9%M&59YcnuC^(%_NFIh-1jRq_c+H@FB1;}yv4n)Z<29CdrZl+{6{vCxL~)8@S_Qv-1~Q~ zkCaV}JQP#hEAR6ZqWK<)VFf4OXek8|MOEgHCi)mC-5{RvoBFVBq(VAo4gQo#kVP)V zaKd@qp&zZzn)GpmZZJAt<4duLA70OlKEbcd9PRJ|!J6syze>@9eLNaVfk$&DE=p>h zq9mIyDmvUP(YR$Ifh_k^l`=`{!Rmt$DZRlqv$R> zzYunLP%u(hC?`aa2T@ty-2B3Z_mvHE=X63_crNEv$Fj2+cmLA#KgBd#u@MjP7XCS! zs@=<@+{Ed`I~K>BHfvw@^~y4Q+G}q`e#N=P1_oR(yBgpV3&GQ4+H? zIsB;U`0MWz`r4kL1*9QUY-z^xCA5f#kIpHibcrx`m6 z+P}^u{8AtNb(ZlbZj7)0ox$ioLIL=mQ^|i; z-Qm|L2!!4qSFOc=VT4aTmX{g(@|V56NmoGh|4!>2tgexB7;@Fx1kUH;INpPM35wEW z(7BR>%3F#9jK9mehkxCV_|^`sYHemB{=P|2xJ#Djb$57>ptyFD`1n7depGHt``_N~ zKMWDNHgY0EsrvFf}Ige!}|aL1mIDQ z0^^_2;ap)FxY^KWhMls&S25$zV2f<&aNYuCU+YIy(KB3cn`~vL#@NBK+$kYl^x1lQ z&8UB0FTP)B1&<**d_R2FX?2Jen2_%HXqFeY`Eoc*wf!wKF+Kc;R_maTrJx1RRoL8~ z!h)+NxJ!4^1VKd?ck!g)OweO6Hz0)=ALDtfYp#avprglFW7OpP@H~VM60rCBbXi)W zKrb{=tGbo;tQ6J;x4kFbk<1Iapm+s-Tvjdcx=%)|!ew4o*s~&`Rj3cro1R=Qe)WE~ z+VJ7;Z?6Uu*tJKF4t6(R$v2kLgke!hTJSthUN15cfd&`>I#_YE7JeMcS$YSqgGbO( zIc3)WOmLwaiFvFj1TC3U!W@p!{rlT~9<5Fa))mp{zyqSNFL>Yt2|q@Ks3B;HAs3O{ zP&`7=8JkO%SDok||M17r1#jifP@(8T1 zZmoa^FRx>Gu%I~njrFPMBDM<~HBk&pv%q^VT(bi2zYKcy_LeZ^Jz&nbb6e+Hn++Zd z19RJ8*>hNxYe)(Rd>SbZ0TdzUIJsTX@c2!Di`4~BK|%-w3Kvv?<6|ozBw-FzVjc{v zuR0&dc0N221uk-)pEuwNQ)Xu=>mWgG#g=~Sc&(1N1HPpJrye&&NR#HzXtPDH7g$+F ze_WC-HbA1y4HV0`lg+pXZbTYJn9I3I|oQC4QsM$@1F4r(4&r z9ey>ty#m!oFR4?c6Xi6%Sg10zZnr?HgF1krw{@{D00b(FhgVx;_ujPO6|HHIbMqOA zr0+md~HJ)LEY_7BmOnm1+&oRc(W zQ{E>sKvWXmxtdQWuTg)PBZWL=g5ZHkPz1Tzpb8h9_rFd)(E1v3J?>lGNmY>oQL$|5 zPqXRBOsY}%9gmzJ?jnp!EEEY;mo1v(_Bb17OF}7@{Sr4q-0~5p;{ih5e81Mup_i#h zH_rsBImEf#r&CH{NKq~t&sS;zKidQ~;oBYg1mrBa)=KO$mWDv6-z9M7m-G_GNtSMn zn;-!Cck|XJxdgVASB>|NdQQrWo=v99X86`&U~V1!mr!D1^SO8k%q(q2?(CTn2qnfy*GeIZI|VbFE4-fsJ}6Q41R10YG=kig2Uf5)fnH0dW6A zFfSe~4kTht3arl%4)l-Xsb~+~>`dxGVs+5$Q)JY2thk&$2(3nR z`uP$8+(V9?J^^boHfa`1^a#da8=Eg?flq*zn5|3OH0>#3jTyKaVkWt{8EpMRTo$D` z;4E=M6t&#Ae;@`8tSQ60EUhePcH|9r(#206e075oc0U2TSsyg0=cq*o?V zN)MNUQjh~;z}bp%jE$f;lW41v`}4bfUJBvm?OmCu%v;S(;qY`Ni%ZSsDmeoeoItdh zfv*w0LrmK~ODz)AN^+j6n1Zj65{b^Y*_hA-Khsf6XDcBvJcH%*#^*t^&Ks9G)Pq7L zMBbzq5#VR{+oGRlz1^)}MuAtnjE|FXe+GI*`8Ue{TW@)L^fhwy=wl#md>ePR>GP<- z>KOhp8aSn<10-*w6aS*$Bg~@4nO4$N`GEKSa}-5&DyfLq_&qi&YC^0^CQUxO4IeiS zX7wR)3)!#XW}+S`-|ft~lKnwwGip+6tMhsSW*v`?p3;}=%D84)ex62X&wUe zh4;hKejoV`hFw~?EqAXR=K>fhtussS^!dbu{YD%jm0YnNs0;^xinurGX{Cx{O89mJ&zZ3CUoz7;`{}}mXtAKst zqmof{jqelR;$KdmwsOPg&L3Z`JX!HsjOFkN!|hsFEqnYr=E}h0=C}{gGlqptPmq|7 zM17CA4}p!{Bn-%M`8h^FuUH@15OK>l~H}+NHf7`2BuHRQx2M?01j&HNLyjzp# z{~mqP&pZ9(i?0cP-eg>79C1OP$6I4ChMkP)mTDy^JXplv69$7^hO(BqDU8 z!obUs^J&*)r&7oNz`-1>plY0g1EAE1gE>SCrYEDOC|ZbEEH1IDA+g)u-*6@If?9f1 zV~Uthg85$T30!IvE=qRUH^d>)v?0}MB{hp0_#XmLki;^2qbrD%Jj0;k$YhcHWKC*{ zs6&b#E;fE8t9H%BLZ#`=K8Z;Vv6g)~ zU5Ff?$SkMEtS=j$Lo4vSZFmwMo5KRMY_t4EV8VG>fA6y}+p9{c+2FB^CW*Xdwba%9 zjB5@N61Ws2wY)cx5dojC)cEASLu7IErw>G??taeHEXg-t$^42a$UKEAH!7&3XSt9= zp!o$bI_6(rh&@Z*J0mI*nXcFr&sLgZ*OwQ$pS+?Ld9E+A#XA-2=1-@(-(8MxZphK_ z&N|6oV1@L0#EVR`W_WYKK^WSo$`SV}qK- za!^V|mR<8Lb56^7UQiZ$p=@`dtOR+}?o|F&#hYroW!oV)YnpD_6c1E=v@Q`qhp!8y!-dhw$zIkN z<0f4nzMzf?wsZMf#edKG^5goz7>=Kd%(z*~)l`rCwLUVlf!#*>x((=!QZ3E^uoBb#cGqGSb(J%4^jhwtJXEQ>Tvy@jW=#KSapa3C?FlrvI)np>S-tYHPtRE$}(VWKV3zFX1%LO*lc;v5*3^+vjS@M^~sg(S@-}2(6mxH5sbVu6@J4kqOM%ASp z2%kS+L;wtbofiZdqO-BSMlK4GZn)l-lIGO=NV5zsl^! zV#evEGG=W^w{lJ0!yFC8;vjn>RxH0-{;k#nJ?D?y=8*!O;Y+I>GWtQH|C->DYL0iR@sr^eWGvB{r{ zgV<)0zj5^%4>s@Xup#ErRWjHKYt)@Q7puRnP$Ig;3{{oMQz^Q+dQ0iVh3s+a=NGP5P0MiePGQNAvj1I15kE5z3_^Y6V|M6Nu^+pF?2S-EhOkJ$r@;%eMPHRE@K**a^<}g?7<)+;Te<>=f+7wC{p^NDVDwRaC{684tOcEQtU5@v z0ga$x1}K<4Yt~tykGUm$O9A%i=w@cBMeLuV0KdsLBNX6AM^NnR$poP(mImCZijzVH zz&9-B`8;~68XbjUcR3s%qN5Tj*qAdJRi=z_D3*;l`@mhcaMv(PMJh>8h!)kK7<~|Z zl`p3)yV&?B{eD@WO`OMhb1byF`(a!>5FDRk0_h~XRnRe`K)mA@ME*Q1nik!vg?-rC z4Ue7miRXT-jCBNt!7UZg#4+nxVnuRDZ0l{Qp+*ckts>egE<6-l2 zx3W$uyLeBMvCzCn0cDBbC=8%I7@MNiz9w>yVunUA-KuFw1RfIyLm^0P`9hc>fD4@e z+)0?zCFdUaY*(qyyvrQ=94i-7{9Q=1m)Clsz%e;YS`bNOMF6bkQH4JuQtoU-uSBjG zzR5WEy7wM#;=Dt*u<=O0{c4HDYDwU#{G69067ZE-gks^>Dc6Y|N{*y(80~*v@2{sq z|3!7MTL8$$Y-m0@p7N?c2U|BBy+H0Y|2HSlmPnPw%%Yj|8?2DVaVa!=k_G0e1?Dyp zEjnZ06MRoW0hwfhonvL47k;zYhT!F$zS5>7bO(h1P@9Ip=Xmz$9AHL}>wj`@@&l3l zH$O-dWry_+4+R^n<~0^S;tl7CgWg` z*?G({2zXC<0(JYKHbR@lzZG#C|Hul&e{Zt>huW%iQ6M~tLr;r@y!}m1Z*RRe99R6V z@15RCvfH(1`8mU^uH8IMg#~kKJwBgggjWN%=)~b@j^lw*Ywx5y)O|C+m5foYzEKN6 zgnqxjIh6)gSo4g-Mz8@9@Ed8&!M^LHKmbKEAE|GeB{eC5ogk!#Lx-*sX>0l6!* zbM(CUV*hKYYf}rZ=T@({ri8e5Tpd}0Qf{OX*}%mo|0m-HMuCp*j(^?wCmG-|WEo}a zOAvOs>U++}n)@}Z%XhY&S^LQx*2?bJ;Dy(P)o-Dvv3IbTJ3^BK*4V#qe-xd2+je*T zbLCsY*xN1Eccp}P?}K|cvzOO#^qlW2-Oia4TT33tD}s(manp38xKBYr&lcpqyYT|; zc0ib=K9@aEM~6vZxax<4M)BC25?ic;8DcKjJo23K(;lFV`0Q)}+w;F@td*Ppi zePx&9KNRTG58@b_so}00nuqB8X1UJa@ESBmXT5v;GSp%jihU6kxas~+B7Qg?+}U{t zpL<0nCTnh`(>yYGdL`;z>8@Qu#>$K+>qyz~YWnDo(~F(Y{@63y-yZ?U{F4VG#(-xr zGSL-s509m(Z9unwz1!S(l{hHW4$aMl>mH>;tDhEC4HQtGXm&rLpds);o9?{31df$W z^LO?-e-GUL?){PYVU9LE0SsFKNMVf2yZJ8R1!kSN5+Bzb9_ePi!y;8=qFxk>jM6+< zkn>M?|7vBed`05cN7g6L42SP!BzW+q-G_6aJ+dD{bi&~TMA@?g?<2-=XC5}h`mi|i zuoZy?K~Yd^EQJIfNg5L+QOIK^h|(`Rux0@zXex@6CWZu^xi}Rz++07yj15w;trx!i{SPwzd^^Lfj;1)+=?H1_^xw%uInI+M-M>?RdXUET)*u8Nn zZ){BLXr_HVuiRSik=hVeo#o_h;)DBOh)qArX2?vL*D36$0q$~9h@pUg&rd@kZNbJK z@PM)S4TM6N6ptoAH4qfMXJT;X!?&dQJ85(s3a_M~NPUs5#`fb=U}LFNUi0zlSu^6p zu-SS5B~?gE(ngpNEl^-!ya@fXFu&9&#_-S#tIWf%UjVeYg?n8nbzC&-HS@XZUk_y+uBya1#%{cj3a~`{WcZ zyC}Cb!K%G?yuVXf1b7Me%@^2(Uo4SxH2>^h&eP+K_9!q@Iq)btZx`)Z>=bd}S$erR z+UutO{R6Lxt1qIxt788gcvmO$#`x4`sT}&;F0_mBoq`7+`ZnJ3it%f1xqs-_%8?u6 z-_ZT%(7)pWZ*0Iq-`kr3J&Sg+f%m&rG{4^eP#hb?7}&ga5ZL(rMeLQB2UFvCnQQYq zZ}|Ux3P?LitzOtJR%Fo_VV~gM=?>A&eacdF5SzQCp-5hBc9HNE$Mt1@}DoXfBOu@OMWl5cD|(Z;Ilg9 zoZ(lFDiXjUFmvwh50~__lbihL|GGDFw68_~c{TYH1u~`_hkd!6^53=1$zJVi-}|q8 zyA};1CX5W)9PoEU?!k-;V^X^5S5Cjm5C5**~l<^oP;6SK)M z(VxYn_u<6kY%;?86Oo*>@d0j|t1u}7U|BjYbALNkK}!T3y26gtR<``2jS$Oo5YFklD2rIY5L z6w420edNeD;T$^JbyBdw^+g$eED4$voEY_pLY?=h*Ka}sFa!ns%HtE-@={(hic|$Z zy?f%Ad%WEUbS#cUqbf+r?Sz@3~nP5Xu6h6A<^6nI3R59D~uVc2Yx%1KR+H zISEW=HhgkR19FmXus3nzT)frb(^`Jmpn5 zvw#?)f%tGq2oa+CG>Xzy{P3HJtskI-1)-#|z<<4hD_ei=<5e6ekT`ONeuWzhrzYoZ zwdOdVS=>`^a2lIOyRBnJl|D3p77#h4bpKAx)$qCfC6!1!4WLbQM zbt^b4mJ{WKdm!*B_zN_6d1&jmf-bY?!bLM zv$*;sN{(7(^(+Z?bRhO>v&!9kcp*rD#tWa;l?T!NlL4m{NgfKz6o!IlKIDse_W(6k z%B9iOnRIJ$E7EK zDp}40#cCPP+b``DX1Uw~I+B1>C8d2b@C{vwfrb1NukNV+`;w?Vy~Of^^De^~(D|lvFMhg77*cWy2@M9R=zsue zd1D2%E(=J%2JcRi0X#s1n#MYZwj>>+VcWl>zZkFCNgWh~eqP$J;6y+2d&IMZr{r@{ z5BK>nhjTw5+9NX5pWUjz z27%r4qwoHX?rCQHof+l+Hu3{K%2TKVG9Km9mmZuNJJ3XOi0N>JAs3Nqz=l$OCPq{X zDO-M4ChU&vyb3qD5Un9Bw>q4((IrVPlmdX$`*JWq%Ql&^45nO`mI~5kJ4MVvJJs+gIux zy0i4-8VqDdl$S)WK>(GMHq~zu>H#$O?ktnmi9&kgfMVA9)`knW@1I@+Fi?u6GF57S zB8dW$qtzAw;lhcJqcyd$D zId}SM>9?yH4$d2P1BPy5hNo_yOa}ClJ77YklhGKXc9N0wP@l}}$v>+n=w@f-dyrAw zdWy<=$`>9aNg4p9{b(AH9%qcfj=()e1#BrS`;;^Y@TuEqKi@cco1)^Zz*3#^(k%IO zmtp((qofVyQa9?}o_x$8n*=MPE!GvmyZVOEL~G^#GXZ*ODO2gYQ%O;p6O`!zTKmAh zNp-eyvT>8stU=K?14Cu1uo^@aCvhAyD9}2UH9M7~OwA2L<|&Wn%T5;#nYdms0rE^r zlo9+L#@Wi$c5agbZlEx3x@}^hSUMT?WTEzI+UA1syfdbj+X952v!696F}9pAma>jj zCsbR!I%4`?mCBG!5CMcmwShDG-S%Qa=hJLRmOVaQ*y(tj!} zN)S&6s8$a*EJ6F05?tmW`tT(EXhrWbAiTE-SYbxL{Nndr@-Br=Z4_VE?uTpw@P`1&zI!&Dxmc zzKasNmu1`y?hw>@Eu{Hj*BscGXI_!_u@Vl{8YG!^lb=l(Hw`FJ)v*AAh(MivHXoMZ z`Lb5{OcuxK1+IHWJT98N7p?v!E~MYIA)d{^w`D1vL2wx?Y$l%PKSNb)%hCwUR$!ek zWZ=vnAug1V&0#JV`UwF2$i_C*s0e3%MpMfQ0tn8`KQW(DnFV`JnI=0V8!1tZ?u@?Y z*7oW$!V!hVq9%EH)WBWpd{Nz2u-WtEGlFImm}H{pkp+mdG++!WQ_N!Kv94#0?3{*^ z`jV$!*FPA%XbLr8y=ZI&d!B@SKJApKdo{zh(sn~D!w)v=FMQGO7Z8j}nqF5)4z`QS zdV!SbK>;#B|1O@Nv*a^>ZsdN^K77%EhvMjB|3C@hGxyx(`^A#Rv#~JX^Rx3t1sAP1 z?c7g0Ol+(2o=H03um*c#T+Z5cTVF8z=WuTo1Yna8wJnqY>e$f#7m8bhkqkWatq9iQ zqlx831(dOr93CQ8n#}D0%tI&@gHHw;A$f6(+U)zQ`kvSnp*9Gabq>;EJD-fXd z`K7x#oof{@@`hHopE*|jc5HWORjvl3J1D0$oF=MmyRok;-mF&rTZM2Xap57`SBc3h zuZrUxM`4tcL@I~D zi3Q?V45#t8H&p&o^OUYTWoMr(2f*BN>RIN&1)6j8o-AQ{lL!%{5@5zf)&R{XGY4Zn zU0pB&%fFDN?&e7BC?SA|=AEH;6UI*6QRKU!NNtB!pB;+HdGhZYP4MGa7H{TFlK%_3 z`R?#+Mid<+gqH(tTwDqezT!z6Ai5pgc~^fys_Ld>i32$$G(#e|%|`>OUTuX`$vVoZ z|M&eJ0YV0yq9-WgaU?S3kbXxRfxh4H{P};!o(^v++(E{4oME+k`k>=T^kFu>!d6XDSab<$MXKJCP>&$^8#i&{v z%WVC(`V-`J*Q@JOR1f>&>`TSjj`y?AP&`%r^0)3>_Nc!(&Sh`z`02?Ma8$_Qty1R8 z#(IG_$L|Hkr{2wN+RH=zlLy=9+sI_gC)}ZrvW0O_@5^8bEJY_T|7uW0=yA3`TTayd z>@e5Q5!bxk`@N$;-XUy0iH6zymdni~f!5w;Q<;g7K|BMV7udB4#rfuD&JLd`p9F73cciyz5&YR9-gX%aoc{ z-Mv|{S98LzR?e@EY2L8(yW{FtALQ3?&95=nuc??@m?=h3>oafq+Tw+4d-S#G z*smj~z&40r3TOkgVm)+n!`+;UTdCm64)HWo22|7Xb_o_`gJ5oCJ!oX`yVfgJg z$AfQ$Gab(Kb zPZZI4XgWe9SQ;HDl?=7+`NSL8-8YPF&(tucNSF2{Z3icZXAr9)+QyWNa0>S1PfosC z{|}e-1+ua7RQ$=%V1p1`X(&uJw6zYxN=>}GhT1wM1hV?oa1QDvkc8l5=M0{!GKJ&% zko-PZ*Ixdol3v+_)6n>p{EiU;n$SmrSAyl#ks{c&FNYwDxW!Zk`SUl7z2^1+4`TFH3P%gZZuj_A*rc>yn0(b>hZNJ|c}t zJ^@+MeM!_`KB0gH17#N(?v)gN;rgkIkr|HiO_vgGO9o4Z+I|RI;9az1w$y(Sq}H=a zI-b5KDF)lNZ<1EyQ+CLiQODP`fuOqxqv8sgu+t9U8K++g2hzrWp0*jHra4w3>N{krQTw~=h^VaUy z%crnJ5GMHji)dRfjb!Ok4KLLGFp*kw>#kBM*wQEpz{QG5{!RVd#FE=j>OFwV6Yj>Y(4wqTJ>pGgmDihKAOdjb%G&jSV>6&qRiiIKVX)Iug9BgAA z7O5kK%rZ{-iGSZz>C5RSiNx1Y2>+dMQp^iB8cRm- zt~2pAj}RMjm9$6(uPEBPxFhoPTuXjGd}(P=DzV@O7W*Uw$ey-$*S)slQKswbYd0Ts zOMD&B<3?Ev0ES}gNIg@ZDX#cVjvi-D3~OR}kZ6W6_A=pEzcyp$Kqt=?>6tHPEX}zf z44_eDy-VybMHUJ!x%y(G#?%jP12&wbv<&nRKKbhI!HS4AbgitRDt2d;(QqpPEYMhe z^rpl4Dw1=;GZ~*KMF4SMQu8bZ_Qh#9!3g8|^o)N!l$$da`69rA8*fFV{1)^kpeUeU zm*c!en@64nJ9=B|a{8_}iLyR);Hl?a|Iz?9CwvS=u)&1W#H9{Bb={=P=G$qOMzpeF zn zMc)nKgfo6Vhv!b8Bp5W?yx6(vm#tJ_I6n*qys^-pW8+&x4_E3pZ!{jS%iKeY8Wn{i z&y>g(UvmA%tFs!<-3Bb4;^*Kin6V6UA)m--4%V zcmZ}KEmhymDePb_^It&!r)gkN668jm(%?6g`2KRumg~QvpOd1uhIZmO^Pm~*L)DMi z(Iotx4(x@W&3x|k{QCu&(L=k3r^vdl~4utPcop!q*aSei68zZ zN1yCR|C&JAW_-uEneGx^$r|&6SN}1%C4q0gKVntT@2%8uq!)3)DQHQ;zi$%tgeVaV z&|wfhLcDwFp+wY7xd=~-&qEn^g=l!E{{7}_GXI-AW6}X8Ar+%MkIN+ zND{_r@~FXDl0z`8Q-Sk<)&T{e5X;t!Jfg-c#dWZUV`=Afh)+VB>vYbsZC=;htv!p(n4u?~K!$V#&bL zb)5)u8fQP*7HR`7ng0y&xM5@KZJvl^tcO!mo@YT$<5N1;B{?{WUg|Qq6l-OAijdYu zAs~6@=5Z8B=M+{|0rH~$t0NO$3MHKr znFx7HpfGEsDk`y8)xYTRBI4_CBin|{lKYxjJ2 z6gF+?NPM%RCqfK|0NnA6_O>@H9mZ#+7C-s*4C$(L6;#T4GW2XEMIN>nf0Q}ziY*D? za6gst@!JLd7UjtkZC%YSr~REaUp6?u=rLOOHlXES%Q^r4o}*4%Q0(TbcVNEulK4zk zSu#knM+WndGL9`KQgI%Hz6<$nVJ-e|Hr-X3vRk>x!Ob^6l2nJ*gyo}W{NMhnRUQ87 z!t|AHzTF#F9oearkIz@6{9RKWJ$xgd@OSea1FS{^pCBfp1LzP@wK0?{F!w?6u-b&k355)^fHkf0z6TNa{PaL0v(m%oN`x zJYIds%&jRtM&`1Zf%>pru~K%e@3OS~)R3YexmvK4L{IsH@+DOy8Gl=rx6Y&YP3)}} z4);>HJpDRAY_CYP&P%oSTK{eTn~(4^UP`$VAEJw!a&$+Qm*HoD7yv9g@8D39o^aHP zJdpYO#ORDmuQ?#s?S;>oDIbofR_z55C^2g?^smc5?58_w&s*L;K8ue(UGgRN2ZJ&M z5O?-V!|Ipx!wyFoAOs_j5sOgc9ZwW%0mrCyIGf=I>!!iROYeWE-s|Y`DOYW(e#Nf{ znn(V8Z)xoOzJ4wD>r5l(?Zj)3t_C??=xv{USr_5=6A$a8cK33E7vF`Wz2^Rm?F)wJ z7oFMywL^0ty@7T_?tZ#w=PRv{ZD+~bu`tS9aN3=>T+H+FFADo;Mv=FtR4Yh6Nk8)74n3eON&p=({Z&mD3Ej| zp&(EFGuK)yS6kG`Q>#QwTWMTO)p55umfXRm5bVhk2GREhqkTGnz74w_l-}81p>wN% zjeGlMZrJx+STtud34vI>Yd$giyNBhwoiP^}&vp~8($wB$;nrBnQrPbg=rXjc4vic$ zDMzZ18R##Dekzd*&d~yBU7Pr?lir7=zy3l5sorE30#>G1{_3wgAOC%MF&p|UOkguc z2n@d82F-tpwi@o8%pMgVA@|)jJYN6i{n-5zF&i--8qnR&A{#dIHS+KmC*OyFl0Pe- zB9_hmy z8ll@3HT?TtDA!1jr4qrE0htvjU^e6eu{|6riS(4osYfJ32{0%D+1nB_I1~c2lRudd zNYB|IQ_2nlHxpwV(;h!df1j0iG;;mYGmIe$S_D{2A*^ty;0%;@X3!!91|#MXB7C^y zR1N_9K#=`CI;e*=RG&?U5+RA9V$qy{zh@0GPyRdC%Rv5b3l6)(3Gcncp??vv4X5)V z>IYKL(O3X*yS61?*kPcOQr13?euj&jr&zCH5jnU~PfG9UZw#!$d)cO^6X}-JgItVe5+2;NShu8IE167Kpsj^V7{!#iBpookE-B-R>k9B0BkBwLxJk7Ba9}U z^aj9}VBS&*<*t+wUW&Nr&cY92I_zP~ATcF^T%(G!=NC^G6tXJn@fhkUeIvLx;*5Pn z6n`%QS4JixnM0u$D-y-x@I8p%^GxJrwY1AW@)q05Dm0oZG}EvLLwNA{GE{$ACrBhx z(vzTC`84ja+5c}oY(UCcwriKBKI3B&*|i@wB+8j zaK$W7`t9VqY-7nU-D;Pqp31uDafN4veb=z2Tt z;n!1S4lf8>IP#eLsy~zvxh)HHqn2mED1oL!K5S=9nhQ#iu-2qwDwX$xpl; zw90$`YNVfcf~uIeoK0}HSk#rPX$8VwE>EJbiG^$JD1m68>N2!wQ40XyuJJ?2 z#f*jbtY&gTu2nHh=oJ~}zg(}COW+?`2NGl6G6O=AkjNyT%Hd0SvNhG&$g2N-JcO^8 zLJ4I`vt?Fu3?foM!RLkOMo@;-+yP5XesA*JT$~NnYUF6X6V~zy@0Gmv)wp$SD#_LuMHn$Z!BS znaK2k1(+oOmH=}lgma;o7rjs^8cXxh@)rSy3__kOBr==GosINS6&L*mAQpQ0&H$p~ zn?(7*G(xN$2Du}pL(H4Ep-xHY`mxzbE+6Jj+0Bn~3Ez=h*UjpHP2C%hy0<}_40n8) zV>btX6Yj-dsLw%;)4n$plyZEVjNh7iP{;kuC#lVfhcfxOAo0sWE(-u`1oEd_i$OJ8 zB~NAEb;yhi%Yf0%ps7ul1sSmETl&KNY z_k1>RBuioRzs$Q?F1p!OE(h4_spESaTXcD^|Jw-CBGADJ+DSsgyL^d&RLV@ahK}mn zgMbclpnQlT3cY zUIa%I_Hq)}ROILD31~72UG(fXG$8xGT-EvK|1k^sFe-H7o+rr!{5wznrGw5k3pgGg zu_6AfE8hCg>>PDvl0!+a*r>tAqM@P1FX;~Xn_z&ku);6KiyWqgbR&dd&!312-#@JI z!yJ*L+1#Uo#0*t&y@ux}s$U@=Hl=A{K?+d$a1(VbV5+d+v2l!fye5x4eBepZ*sGcE|l8oH|rl;UE*{lkcF+D_B{V9 zNB__N5lTh$zV|ag;=`dN?u0f`K1)GFoK zJlu=l2g#o7%El;^-VdCf<&thKLkqbuGC>7`ONS!(ht3C>8y?DaY;tBS{}S_g^p*^FA=l)ovi@!U^eO<9F4cIXuOPF1J}6xoCgUl6HyFspNL5Cypu ztpCORW!vNCqy`myz$uH|L<^Y5-h|52Di`Mq+s=Hqu*`E8a!p;Ii@JSP`Oy-4_R=>f z|AF?O8kaLGoUrCBB~{|dPks4dgXfcFT>#>=VQ3z*TkvD9>PLZ$ba+TJEM^}yB6bc1 zuHRE7`&m-wWfGv_aQsR6b4Gw9O7CV~B#*$Mp&Jz;nL=oCWsr0Cf8xHH{E-Y0E;Y!# zqp`M$^@+T=zKD&aqTkYIc1)_}uYVFhD;~?S_EJvy_MqQOn#a2(YUi0)KfeuQ(}R#C zLxv#TA($bTWl+e=iLbu88-9z9{<+8i^QKGCGXVJqc(z{q+8X3|28@ObL+`W*-ia3P zzgtlsgIbGNz5PBegbOtlta(lUvZ~khmQaC$+)~~isjs>zEy3k0uXiup?-08k)-0Gp zfz{~^XwP!*xW?2SQV_oOC^A8*3AW_&MTTt7siq}n2m=Iqq+lu=DfRN&&v8-UNl^SJ zNXJ+=5535VNf(pX4ot#|b$V$x9;uB)ZXg{g;9 zo9f2ev%jhr#{^0n);QWqq_(QxU!3HwWC)NRNKZHG%9qLHYabQ8>#A_~=3Cw@^Sdt^ ztFx6mbbZuwSuQ=!9eiwm_|W7iOL?&J1z&z)$AJ1VN!-LUchHk1ukPO6q^rM^D!6io zGBY%a$jcfK?w{A$;0!iV{HDvj(``Q0KVg!#Of?YrNDng{pi{p#gt=f$D})mD*x3y@ z1IZONyw|xnF%AUrQo=*(@1P<8@dbHZAv#K(FItCsC9`O%q}Q-;Oie-SpU}Ktj#SzQ za;*yz-Op|qg|w+ON-OMGJ)tEj9IQ354ks_KYPPZ#N0-yA++>C}GP%!l`0?$0+c5VV zT2}%!zbp07Igxl{lRT~dHl68wGsngE4Z>>J!(mFc7=e7oylRWmlur+9muAOHpLDdI zblwbo+E>|SAO7Lvas)2C7av8Qn;c8gY%dHmk8x#~=xiu?)psSL_vXJ3fBt@?*9J^o z39H8`EKW1hub!W1G|+c~hGu&XO(Szd50NnY-MMX%g*O9tW#n-|+=iU&F$1hhDS&SB);$+Wwn=CNB6$^6!5F)v3mxK<*&dC(@ER|B99z+aBwbSo$ zZ7MHJTqOK3HI)AAu3y*9+d*s&Yeh;Chl>Ul7X@i1obyq2o92->t6#B&fj!Ocu4n}w zGq`AJ87=F8S(rqty*2?+DC2IshbqhF{mZ`)pHN_xt$#H^C&P^0w@PQ{9(A4tYzHim zE5!5w{2`qwNaP6&WFWCYxfug(ARrzB^#GJH^kNUB8U*i8VPfAx3^XE`pq^3Sz6I?X zR|6rSGL^6S|2I5mau3O`Cxe9s~`Jj&{|*|Yn7SZ8_sp*Gc&$aIAT_vz{}Q zd*+^CMCidrO5`o7U}X5wuOE}G_oyo*d0>cCcsC;fraqxj2ZG7+2=!gY&|Z#;Vh7FIu{S94=i4X53l0RO3@_=qHptSm@a>`XyPE#J5%rB%Y$UC&O|~&Zj*D5g z1+(Got!?VVxXqt_3Vf?yhRxnm{ea!U_F@Fbgww~0tO*yt zt}m9(x4vgjx<&lsm?B<$lRf2eU;DSTd-lbgX|G2SoGxyek8);w>bE3jd|!Ug`Rd>G zFQ@wY8-ZL`(;jWE@4;U#=6+Xv7r`}qXZca?Z0J@O*If9)_uRS2fB(2BB!pnz|AYkG z^RXOmdGqlCk=zT3qQ!X&$+F$ti>aq)^A^*zssC{=Wf%$OFNO6DdOQUV%!KZTPns4I zn9E)6E;HILLZ5^{LSnE_2O@{J zYNW_y(`tV-slM>3*U@@UXK~Tqu=*To_}(Bq^&&U+v1CVdkgnz`qFodcwg9md4?+Wr@KOhN5P+&?$=S|Kgr1 z42fd>5+S1oA?&I;ZyP)R*Kq0=s-F=8qS-l!k6z+i7m?>L@2g9IPP0%>3BIp`H9 zF<9(x>qx8YO6Zh6GXse0z8D2JYXE{-6bzg1!F7F53)h&6sW*_SAJX!bqptz>A)qo51ax->^=G#;m=#E}(K&He1v#K_ zYg6ZJ*uw`h$_T;C9vG)hD-9`0(Ys8-zzGths*soUTb^v^u|N$j3uMs*VJTjf>Bvv% zH^ZZVerfL*V`=kfmn>l{C%Qx~v9h8r_+LYLFJj)iKnmXWhV7NEOzSt z=t~1yjd{3X9^Qv%k6}t`xeqrh4(vABo3Bxl>MOzTZ90;X+~~}l z?AQlG#oc^M!~0TR(|?>NQ$w>=r9Ym1ho`GB7@?X4ih54XWX{G}GVG?8{@W0^ z8}^MyxGUA(I^88V3M#l0#dyz#3CevpgNjKC&>3WgW#($pmF`@cKKEzYk}hiDBC}0v z-^FdA`|`8RvzS+~?|A*m_VByRKk7=A*H3GH48-E1_XUd9 zB7W!K^xW8X)q#$$^6SATr@sEWjne%+(D7^UcK^wq+(E;ZSntNO*?svf9{;4B<8@Ne^6lnzsCo|;LrFX2;>C|Kd5s!-{ z?#EZeI8<%BF~wSqGS~!2dI#1GQa|D+HifpUU^~QrX|=mK3vhc<{qX?Y)&_Bs2!ct& zt|6BQtn&rm1c@9VHq-2~82fa)efbr(J`5k7{G zq=g0ms&zy2PDpPW9A=BAZ!G5>HEoaqoM#^(DakG@ZDMs$n&U8NkdBY#9qBE4=slja zffpV_z71f}v;=Yr-ZCT{=X2JtEbp2~$}7y?6STdMEifjqok&19OW|3kFhZDEEybtD zKQc!cfs!p~-RjcO$HY`&K4zfaOTFf#jA$${*ZmON_C>rxCXwQye=`us1FB6J+jl1PHf zP|)j)sRh!fYRFI-@>QCMv1R-?kSLu?kb+P+If)QM0t1PJh7(Rj-q;@>#rv`f(?9r3 zXb{*Km%~{8^CAdp3d4WX3Relu#RM$h0(yx!ZED5wPFDVpoq}Sy!aNG8?LkkVK0#WL zk8NyE2oHb@4xz9BX(mCnJQUUI@eP!m;~GVVPYSo1N;2$JdfqN&=`-n;%kwPAzxNS8 z8f7V{#c7dXIl_W>0R3-$#`S&zoP^TxpgW9LCy~?B9_;@of10OULDxp$C#&X*PfaR% z;5>ynU!QJ@#LSGGn;^n1N}1BU<<2E&I%1_p*tEZVk{Sluj}qz2%9%gBVA4Q>88&+H zlqQO@HiSKFMtOLfO{({%mTh|Qc_d;AOE*y(!Ml%FC7qHWg-oy&yV>e4E6+W%*EDc2 z{O(P|0-MNba+l)o5|?gJDh#J94bQSkC#JiMCm5Tso7`*;>ctwwP*-o*1xwvgF?QM4 zj?J>X(=7U8!8m<6JjcPLgx&1^s!5cJndqCdwe03E_U}YGm{-S{b+TLZIamy2S-ksf z@sZu~lY`}CmgU#amUHY@iw;(+SymgLt$wmw|8lVYlVyGK*_z6313PC!pKXKsVzavH zUqJE>eJc)0_9Mo6cmGd_R_-lg*I9mbU(}u@+g|gW<%&drtF^H}w!V3S)ZSZd9qgnx z{9KnlWNZ1H_PO&{U+ToJ+)`0EtGh3i$S&o7`kdoAM z>PK7XBl8X%tBs8-Z#jKIoliRL+?su%ej(Du`)|S82Gl#%Ul{e9IzX2Uxw1}7t{lZ% zAmfUAqdv2FD|yHGoLbv1WlVu(=j9#W>+jYW?Rs>RKWt6v0|ywt zb@A)14J}%~WsVeaka*2h(qG~$AiH;-^ECOLK=R7dd74l9k*}kl3y4MjP&hwWjwQq6 zFGGGWsyh$q9Mhwk4B zycDS^GDoWS#}(V(MdR0`JVI#mkbvJX7U={0VLZO7H%B6dq#;}+vWp~7 z_Oyr>1tx~^$af8B^Tt4^dUk0$KZT)~2yr0)3iPoGp+2oHAcYP*hB?h43Se~FnRzM77GndsZr)B?;56plKD3-~Ug8ykC-fql!()jtQ zlxjK(J&EINy`d>g$G#_)jeBsDDv9%ErRqXwC9r9_)M=g(ES$|GxF6^Qg2Ved0&#HT; zzZr(43}`_aN=NZ|SW)Jw;KyW@Tc!8Hr$TAfmQ}vtxxGVmy$J!()FVk=2zIpGBN0Np z`-Yro(1u?jfN(NCnhaqty;Q588sIUSxA0M`{JtMec%2QjEJt3+davF8{&eGe>=Z;J zn)$x0X_S4W9mV@ zB%xhO@CYxgK9edfh8(>w&I6>>8ReV-(v*&qhP6|Ym(-+v+SPP>r@MWl!}DjEc?ua` zF2{d34I!*QtzCb{EW%Fy&_=Dr*Zn+Wo2KOOY_%o7M(YEFV6~*Ru$%e=&zYBf@)p8h z%2B@kcSWLTPG-gHnPhlc=#zy)=bS%p71?!rIRimCE_C;8dyxU9=+vFrkvhCxF0=na z8J?G3%tex}fcFw|zC&(REC^yQUwEOz+GHCFpVl2tUS-wrh8C1VC?8~a!Kiv1E?`fX zg|Uu)E5~Dp@#hZX0y4LHPp2I3JPnbE8XE_fH1+>%)6r`1V5-)Y+2u9Qh0A)bl^tD! z=|U0bLH*cF*3Hmr`D0RmJ3E9jIZmwna~rlbJu^SF9x^PW^K*{U;Xse&-NR%*dWzwWrv`p*zd(@WgKZ zl$7}@W$_hna{&^Ek>c(w|9<>HkiZyEiEGq<+4EfboJ$MrLfh&->PkT!ZwGU&IVP^H z@hflBy_*cuQaKhT^!fV8k{V=s1}pa}UKmqhK6yy^>pmwd<p zid-ea{Uy|LWxf+J&sTVvqENQKRIjktcROBdM$5=GK^l7BR@{|T8^dd1+Bk}OYPBrG z_Ie;wR4oq~F0#y+Qi$TW#`}Lejab#q_eAW23iEO$Wmxg2AK(v;k#^Cja)1gft#z7) zZhQH}lCnC!$v{YGpP?rRAa+Gb?3$g@wCli|Ym(rf%%{EEyJ3$L{z`g>jrg75E3JV) zMB0sYjO`z76Cj2U8kYS&Y~N*JqWtb_&=561ou~JTz4OSUlR>Ium}4T_7O_nztfZ3babj8UsU`^&|J8#-K+Av1!tosU*R#3FFaAmrbL~&pW^yS zo4UXT$I>6RN+mv$UkK4qG-B@7etquZ?9gXI$_*(Qc7s-7-LZ$d|JbC~KD{myW(u!r zrz>*klLK{C4vJTe2Ei1rd$c@qbDK)f4CSdMX9^SeUFEle+r74>kr z+*FEVB19($u2)1_MpM{iN+G;hMiT2~87xmJIIa}j>~q^3DBgTGyZKRY>yz6SO)&6v zc56;>d(mxswRn4DcKfH`&tGmo{}lhENd>6Ib8=t8HQc1&bCRkYH8cG?tVD*Jcc zUhfR!YZ9V9V8W8=b+iSA&N~)LApg?Cs{gFmg9z-4;S zQr9EkcqPD2%L%h8xzb>1F~?H%1SbpziJq_r#>WH`Y38flxzT^lUiuk#u+Ko1EWLLy z)^Ok+d+dJcLiMGadBP!HCYE4CGQ9fzjG>dHC5R-@2U8G&M5NDBMux6*|7*#?xucU= zmkR3g6Jcs?32I9K3y}P#4W&IXNCr0yLAb0h0Wcwnz!ql^dmeuHWUz6uhXHDMhyU#O zVsAXmPsXX?2BiQmdYN|wONtwb!Wzwf8+uXwv4jxAC}7rHGge{xkScX?xcP~FBE0jm8B)`^zpU!?T71%%DhMt)zPiVlPf9_-uHFGgKg^s(PXcpIX52l9*8e7j z%*|1PY;u8mXePnRGCiO0!}%-FyK3%`ZS z948->h<+BEnc^t3P$(%QlN}1Vl4Ie27F~$#jU9am{oY6d?i&47P=8i`( z2TplWJye?5+)nu=0#? zC=HvJp__}>^lwKZe9?5QrWx_zyr+yFkAt1c=yObzv|Kwh&m7I3?4}pZ%1J5fCy04! z6`%#pON$8Fp8Rp3lGAVq%95xMMZ2+-8uyFaTa30ahlORlQL#Uy2}^|@?T^Evuz<^~ z4oiYrYc-M>?=uofJcfia{b6P2P+Goqsq;A?p&eep&#b;u2HNI3H%H;_ek$W;%G!$G zUaD>%E@qg>9W7;vXO+OAGL75~UB(C3!AS%F=c&x>-e@7=pAg)nre-lOnB z{fqFy9Wqon-M=q|3R5J;0wr`}$9i3Wq$+=9E0!Sqm?idzm7@zwK*HZ!*=#vfDP(NF z5>n|hsBk_!pN&T;Q0_s$$)OLsDjGETzQ(xPSh0Ku`+CwJie|Q-yO;c#ZS9;LvI6B_ z1@+&yDnUpT+&?~31eiJvd1cJ7#fHRkHqeZOrCNFtQGnKhx{39?3%}te%oP3l%jQQc z=IeK{*g2?Q5Wz4q+`vi}75?C6|>B$rz<|_yC+ecTG^x-rwd$08R9`@L=}_Hj+J&1s)ie+^m2*#upJJuq0vjSo*(Z54bQ#G(CH%8w*54Zv{(I zREvF(BZ3qwvC)g_CjbvLQbk_yVDw! zbkLyCW1R?a;i)NE217PxFI#LAnuOTK#zmV!5F<*1>Nt;RgduQ%*@|njELcVN+n2q# zYkDN{)Dmz%xWmaIB7R{n!$er*0iAjjkh4MO?2^ph@C_Q_*WYVsc$OikxW|%g<#su$ zJCC6}S%ft#Ndjre1Z_*L@J5oPxP5YGBuxqQKD7Dieq?X#5{hB`Q_jSxDxAQQ%7EEK zQ^7%7jK;9l&gSwaX^FbJc%Lx zj4D?f1p>_@{qXi61wl(~JT(mUnsz1=N-1dOwNIDVq(Cq0xY_zw->WdmiHx$42vKQI zA4HSzNw!L@`1f^!!qv~}3t(>`bZ|{ygYuGD$dimP&WOEyGQ)1*S+N=u5Qxxkn$ciwrPrgCA!}x=b>zP7J&jDo z^ILFiy!ZJa>!X*d^?lvV8aw@64)8Bu+>vUtvlUHDv~=}guQ+qBg9DkFBJ%yu#9?<} z+KZx9i>nF5Wk2_z>lk=oLa#T3%st>^-FO7|;J{j77?qcu7`?212omWH>>2$3E{F9!H zbKT*nF|E24&S1B0{p*@f7^|Ndg0fL^zCF+J?X!^fcb^>@%do#FqI#S|!>$$ilOz8f zq-nd%YZRV*TeE6at_Xrd)XH3@8Od+`GdSp$!RWLwfsOUxjKMvg!iwvyY@CnKkp?qz zA{Ul)|LT*NDUeTpwf0wL9zm_y3@I#QdM5>=n3ximDX!bMjRIXW?y@b-Hf?+Ns-Mr4 zC+~fwD_e475H9nlFZ|XgHrU?V=`$zBPAss-pt ze8A)m1m!6@@{MKQz4_qD$p(?7bLtWY2lc{Y_UqFF$-dyPW+%E7ijB67K4WS0;?sAx z<+G;}nKpzTIR8Q%HG*i@B8t41G-{Y=$~j4dMdy9TF*p$zus#`c82Gla!e$|2?~w0B z=!WX0u;E)W=p$J|K4^<+s(%&zieCMF^S>p6RikEH1plh_P3;xb_)&}vQPdu5%IdF} z!4dV~_wXsHTV)a7Wp4h7fimMz#Y`Q z9opdLcTmzes2PCAW~eQ$+(N0vFq@*)*3dB|tSeEOMF9>gi$js)+>r6ZSFgO!4Nmg_ z`hif-21TiubIfD}S0JS8SJWkZw1{^!{aCCucN|nP?%bNUV_w{asklpnr(0KVt+yr> zO(hktp>tJX3~FdxgLqmFDES2kYB-wg(H5gE;AE5&a=iixo*v@r@3>$NjWg}eie+4k z+@{$2sx#21jD)C7o77DqKe2@ZfOl85O36(ST9i*uQN!=O@H?6*s z29;!M!Xu;L*NDVl1a!Z5>fjypN@5zaJZ*Cjv5idkQ%Wy5Ov3U!5M~G|psl3PL}nb! zmq1S%bG)tq6|v~k9qNn9_12n`C4PSJ5l+&J^9!l`8$ny8R`X<&IMI>*|OF1s@n^G;|l7I3L1C{@8=gZ zITvot!z#QAJK76hO&4|_6_R<1dew{ior~VyEgH-(8g4HdnJ)TpR5Z%-Xk7i#XXi%~ zcOOmVKbmQO^lkdl?9n3%Pw|3!@se}#%H86%{NnZY;?3#e?W5uyo|3(5(oSP=cS>mF zll;3^@^x;M2)ZM5(Yd;1C5rPU`OX?Zs`U1lBb^W0PJy0l2c{cnY^ql(fP?8~6jD#l zvU2)p{Y^rj3cbrqgq{gxe|i?p4xmzuP~LoY?t((*oDw7F(!05chj-COwpzSC?BW_F zI>UL~O1y1i6^28(LhBeHUMYx)h0T-+mQ_YS$+t+Rp)`-di>oLCl1PGc_>^&wAaRe~ zT;?ko#ww8KD;eA$L+9z;lyDeA8Q#6h*ayvrExX6*rMUapz2o|&<`VBvw(~yPB3%7HNkJV1BKNZ9f{T=GfXKZzPYWaKWYo3(k4?Dte&k&gykuQ&p zc

    L2NE z0PaPgRdYjwmM|Z*MmBN3kHm<=JYofba4=vvj*_8-nGgw0P$d)xlz|;E0`5nEM=io9 zW}-Pw-$VSt!BC75&8P)hg7OjUnhflqCG65eaQI;`g!28qX6y!93^)^~QV~7MA_k9+ zpa71y*#ovLi`=z{CCz7pNI`w!=opHDScXwh2kf~+?8z30nLYO861XHI5>F`h@#Bwm z6(3N`v8xn80mw4w^DF3x0nS4#P^2RII|Fo4V4~*-l$GwI^iNt2ER1?ZkWCAekB6Y% z9?!P|TNH-3LmDLWGvRB+2U8I6{X_8B5(q!wRkK3HM{sm{1AqY9(6A6@X z5HP6O64>J^?h)1}1QrcMD*|H)Eam=L6CRxI9`n!v2jdXzUxpK02C=ma@b~y)7Z5uP z4Nk!dhG{`v9}^6WfW=}z8(adcJIP%5Ba|SC{zH7h<77jlATa}UacC%^KVCHtYSa~B z8C`Nq{!24f)D9k09y)?t#grGZIPkEf)~l4Wi{ufW)P9=O36E4!^VFFishl~f^H-@6 zYpF{(JZUymX{#P-D1`r9aKHl60_bB9NCrIxEd=-s^f3^}K;r_H3|w&dr;=$Is5u0A z=$U9Lt}fu1LSz(>)qrKCjRvI3H(h9+MUE4~+ZbTk1O4O~DdEXo1mTSQk2 z=x;SOh0V=nptgZz1fm?MWT2QiMFp&~GJ(PtR})!XT?DEfs6bvRVc@icZd5o>bqk?EK=d^S`@Cg3$gr|Nr$sDZABQ=O6Pw4V3i^J(?GXU;|L^*q0PdeYgo@Mt4kA{!_#I4YmiMO* zH-Cr1LTH!6s1hxf|McN<1Y`BzKBQfV;`rN#>v=1G`fw!%4yFV8ki>HJPam!#<77Gi z1fn?I+TTD-&@}rKh^|{}|HnYwNOfP&-vIpn)8Ae^OnH9ykz4_n^W{Jflk?Si7}?d`&{F8ZCK$|LV?48fqcQakgJ5SqQ{BqwYzF6?S*t=LnU@~7W1wDFq`8$lJ z1{WHV47^|XL_5B;H08R#^Ut=QU!0i**NV6L9l2cCz4FkIl3SF(*T=`e^^HWOQ; zr;ViUFqkze6W3g_{mJZM2=_qd1Gk=bitEErIBpg+6mb4ej>05mvj{)+bWrmig)2q@ z&R?>VUi&CQ^Iy*YzcT-KL?~PnVO^YWL^0k)y%3wp!{hBcigxFKkjs@znAv9#_zZl7 zVM@i4rnJR2z^Q16wb~g;mt!K9P+pe7u%z0u(84oTX&ALc5_xNwjZ z>vt%TdnXRzk*u&N5rJq1I(yBR0pkigRQ51*Vv5lL<#-j6ja>`~`3HHhb_Rh8RE&?Q zd`M=1h~Ufy9sK+-!b|>n`t|C@5w#*hpU?<1P%(fy0v>C&jvxdj7!WZMC?E!oq3Sb1 z@FVk}h~>8QuW%4J0}J~@+$j_WqN98@f|aPeoE5^F|C;E7@^<37J^$>s}3vAnfIw z>9SVACXir;uu(3kXX{0j0ZxKzTmA@w{=_*J@)a93Clh&?PyIXsQbf{LD3p==yk#4w zgs`nB2*z;UV5KG$HBO|)-SJ?ZcUr?;jo8f=LtF5J#;(#sknLHQo&ej7WK{gapFyIA z#g8-{g8zpt{lGNWaI1{1R?t2y>8JS@;hOU|px z-WS{45g}%0&#S9bZ5i$R=VrG_NE+An?DPrV&Oexb*xATL*_aMkm45E{0KxuL;(_9%pL!j@2+c-T-uiW!6}Oe|C-^}Vtk7xjI$rLaLh z{U+??#=zK?7pKV*_g%u^sDYB_kSGbXn&;qWtfEK~@)QVo@k3i!tPouyEbLsot+g?=-uZrix!fRzGIKTL-t;|1;lsw8IgjC-L#K2UU2LI^FC*Ek9BBjs*kU_hMl*#qR#oi;M~g3O zs@e>_#Hlz;_v8sd(|r|X0F#X{w0gt-o zy?0(Wb4w3uYP;q39g}b7H|1;UrU&<3>u-J?M%OfK$Q^jj-7H)V)ihlU9{AqeEQ0WB zTQKDh1ITWdAPTi@kA@CI_-=ngV`@8Sbdq*+y8*|q8wr&^%_6(olvJo2`!sZ# z!*{o(7*jWqD}Pp?bGNNITsKuSbXMYZw_|``KhrILUXgsaYoSm-J3Vw>U4OS{A5%ZS zA%9Ufcen38T)%KJbkTHk2QdGJB}|3O?l!Xf{~PDuxGAA*He6w(Kf6;>9bQr2|yG(|>>``bs{xp2M&WF4jiD^2`Rk+*M zL0-=cH=WlE-|c%LZEZkHdgR? /dev/null +(( ${+EPOCHSECONDS} )) || zmodload zsh/datetime # Global associative array for internal use typeset -gA ZSHZ +# Fallback utilities in case Zsh lacks zsh/files (as is the case with MobaXterm) +ZSHZ[CHOWN]='chown' +ZSHZ[MV]='mv' +ZSHZ[RM]='rm' +# Try to load zsh/files utilities +if [[ ${builtins[zf_chown]-} != 'defined' || + ${builtins[zf_mv]-} != 'defined' || + ${builtins[zf_rm]-} != 'defined' ]]; then + zmodload -F zsh/files b:zf_chown b:zf_mv b:zf_rm &> /dev/null +fi +# Use zsh/files, if it is available +[[ ${builtins[zf_chown]-} == 'defined' ]] && ZSHZ[CHOWN]='zf_chown' +[[ ${builtins[zf_mv]-} == 'defined' ]] && ZSHZ[MV]='zf_mv' +[[ ${builtins[zf_rm]-} == 'defined' ]] && ZSHZ[RM]='zf_rm' + + +# Load zsh/system, if necessary +[[ ${modules[zsh/system]-} == 'loaded' ]] || zmodload zsh/system &> /dev/null + # Make sure ZSHZ_EXCLUDE_DIRS has been declared so that other scripts can # simply append to it (( ${+ZSHZ_EXCLUDE_DIRS} )) || typeset -gUa ZSHZ_EXCLUDE_DIRS @@ -145,7 +155,7 @@ is-at-least 5.3.0 && ZSHZ[PRINTV]=1 zshz() { # Don't use `emulate -L zsh' - it breaks PUSHD_IGNORE_DUPS - setopt LOCAL_OPTIONS NO_KSH_ARRAYS NO_SH_WORD_SPLIT EXTENDED_GLOB + setopt LOCAL_OPTIONS NO_KSH_ARRAYS NO_SH_WORD_SPLIT EXTENDED_GLOB UNSET (( ZSHZ_DEBUG )) && setopt LOCAL_OPTIONS WARN_CREATE_GLOBAL local REPLY @@ -277,7 +287,7 @@ zshz() { if (( ret != 0 )); then # Avoid clobbering the datafile if the write to tempfile failed - zf_rm -f "$tempfile" + ${ZSHZ[RM]} -f "$tempfile" return $ret fi @@ -285,16 +295,17 @@ zshz() { owner=${ZSHZ_OWNER:-${_Z_OWNER}} if (( ZSHZ[USE_FLOCK] )); then - zf_mv "$tempfile" "$datafile" 2> /dev/null || zf_rm -f "$tempfile" + ${ZSHZ[MV]} "$tempfile" "$datafile" 2> /dev/null || ${ZSHZ[RM]} -f "$tempfile" if [[ -n $owner ]]; then - zf_chown ${owner}:"$(id -ng ${owner})" "$datafile" + ${ZSHZ[CHOWN]} ${owner}:"$(id -ng ${owner})" "$datafile" fi else if [[ -n $owner ]]; then - zf_chown "${owner}":"$(id -ng "${owner}")" "$tempfile" + ${ZSHZ[CHOWN]} "${owner}":"$(id -ng "${owner}")" "$tempfile" fi - zf_mv -f "$tempfile" "$datafile" 2> /dev/null || zf_rm -f "$tempfile" + ${ZSHZ[MV]} -f "$tempfile" "$datafile" 2> /dev/null || + ${ZSHZ[RM]} -f "$tempfile" fi # In order to make z -x work, we have to disable zsh-z's adding @@ -306,7 +317,7 @@ zshz() { } ############################################################ - # Read the curent datafile contents, update them, "age" them + # Read the current datafile contents, update them, "age" them # when the total rank gets high enough, and print the new # contents to STDOUT. # @@ -884,6 +895,9 @@ alias ${ZSHZ_CMD:-${_Z_CMD:-z}}='zshz 2>&1' # ZSHZ ############################################################ _zshz_precmd() { + # Protect against `setopt NO_UNSET' + setopt LOCAL_OPTIONS UNSET + # Do not add PWD to datafile when in HOME directory, or # if `z -x' has just been run [[ $PWD == "$HOME" ]] || (( ZSHZ[DIRECTORY_REMOVED] )) && return @@ -931,7 +945,7 @@ add-zsh-hook chpwd _zshz_chpwd # Completion ############################################################ -# Standarized $0 handling +# Standardized $0 handling # https://zdharma-continuum.github.io/Zsh-100-Commits-Club/Zsh-Plugin-Standard.html 0="${${ZERO:-${0:#$ZSH_ARGZERO}}:-${(%):-%N}}" 0="${${(M)0:#/*}:-$PWD/$0}" @@ -958,7 +972,7 @@ ZSHZ[FUNCTIONS]='_zshz_usage # Enable WARN_NESTED_VAR for functions listed in # ZSHZ[FUNCTIONS] ############################################################ -(( ZSHZ_DEBUG )) && () { +(( ${+ZSHZ_DEBUG} )) && () { if is-at-least 5.4.0; then local x for x in ${=ZSHZ[FUNCTIONS]}; do From fa770f9678477febe0ed99566d9f3331f3714eca Mon Sep 17 00:00:00 2001 From: Jordan Galby Date: Sun, 31 Dec 2023 11:17:37 +0100 Subject: [PATCH 463/672] fix(clipboard): remove clippaste additional newline on wayland (#12140) So clippaste behaves the same as on X11 (xsel, xclip). --- lib/clipboard.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/clipboard.zsh b/lib/clipboard.zsh index 4b37abc9b..5d149f056 100644 --- a/lib/clipboard.zsh +++ b/lib/clipboard.zsh @@ -62,7 +62,7 @@ function detect-clipboard() { function clippaste() { powershell.exe -noprofile -command Get-Clipboard; } elif [ -n "${WAYLAND_DISPLAY:-}" ] && (( ${+commands[wl-copy]} )) && (( ${+commands[wl-paste]} )); then function clipcopy() { cat "${1:-/dev/stdin}" | wl-copy &>/dev/null &|; } - function clippaste() { wl-paste; } + function clippaste() { wl-paste --no-newline; } elif [ -n "${DISPLAY:-}" ] && (( ${+commands[xsel]} )); then function clipcopy() { cat "${1:-/dev/stdin}" | xsel --clipboard --input; } function clippaste() { xsel --clipboard --output; } From a9b6af5b231227f8ab91f922adc5e0d0a2e6fc08 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Tue, 2 Jan 2024 21:01:17 +0100 Subject: [PATCH 464/672] refactor(minikube): standardize completion generation Closes #10763 --- plugins/minikube/minikube.plugin.zsh | 24 ++++++++++++------------ 1 file changed, 12 insertions(+), 12 deletions(-) diff --git a/plugins/minikube/minikube.plugin.zsh b/plugins/minikube/minikube.plugin.zsh index e87abceaf..0d2737052 100644 --- a/plugins/minikube/minikube.plugin.zsh +++ b/plugins/minikube/minikube.plugin.zsh @@ -1,13 +1,13 @@ -# Autocompletion for Minikube. -# -if (( $+commands[minikube] )); then - __MINIKUBE_COMPLETION_FILE="${ZSH_CACHE_DIR}/minikube_completion" - - if [[ ! -f $__MINIKUBE_COMPLETION_FILE ]]; then - minikube completion zsh >! $__MINIKUBE_COMPLETION_FILE - fi - - [[ -f $__MINIKUBE_COMPLETION_FILE ]] && source $__MINIKUBE_COMPLETION_FILE - - unset __MINIKUBE_COMPLETION_FILE +if (( ! $+commands[minikube] )); then + return fi + +# If the completion file doesn't exist yet, we need to autoload it and +# bind it to `minikube`. Otherwise, compinit will have already done that. +if [[ ! -f "$ZSH_CACHE_DIR/completions/_minikube" ]]; then + typeset -g -A _comps + autoload -Uz _minikube + _comps[minikube]=_minikube +fi + +minikube completion zsh >| "$ZSH_CACHE_DIR/completions/_minikube" &| From b5583a321644218702c4ef588934575f46a2159b Mon Sep 17 00:00:00 2001 From: Jared Allard Date: Wed, 3 Jan 2024 04:02:43 -0800 Subject: [PATCH 465/672] fix(rtx)!: rename `rtx` plugin to `mise` (#12143) BREAKING CHANGE: Rename `rtx` plugin to `mise`. The project swapped name in `v2024.1.0`. Replace references to `rtx` with `mise` while maintaining backwards compatibility for `rtx` installations. Co-authored-by: Carlo Sala --- plugins/mise/README.md | 32 ++++++++++++++++++++++++++++++++ plugins/mise/mise.plugin.zsh | 23 +++++++++++++++++++++++ plugins/rtx/README.md | 30 ------------------------------ plugins/rtx/rtx.plugin.zsh | 20 ++------------------ 4 files changed, 57 insertions(+), 48 deletions(-) create mode 100644 plugins/mise/README.md create mode 100644 plugins/mise/mise.plugin.zsh delete mode 100644 plugins/rtx/README.md diff --git a/plugins/mise/README.md b/plugins/mise/README.md new file mode 100644 index 000000000..8ec05aab9 --- /dev/null +++ b/plugins/mise/README.md @@ -0,0 +1,32 @@ +# mise + +Adds integration with [mise](https://github.com/jdx/mise) (formerly `rtx`), a runtime executor compatible with +npm, nodenv, pyenv, etc. mise is written in rust and is very fast. 20x-200x faster than asdf. With that being +said, mise is compatible with asdf plugins and .tool-versions files. It can be used as a drop-in replacement. + +## Installation + +1. [Download & install mise](https://github.com/jdx/mise#installation) by running the following: + +```bash +curl https://mise.jdx.dev/install.sh | sh +``` + +2. [Enable mise](https://github.com/jdx/mise#quickstart) by adding it to your `plugins` definition in + `~/.zshrc`. + +```bash +plugins=(mise) +``` + +## Usage + +See the [mise readme](https://github.com/jdx/mise#table-of-contents) for information on how to use mise. Here +are a few examples: + +```bash +mise install node Install the current version specified in .tool-versions/.mise.toml +mise use -g node@system Use system node as global default +mise install node@20.0.0 Install a specific version number +mise use -g node@20 Use node-20.x as global default +``` diff --git a/plugins/mise/mise.plugin.zsh b/plugins/mise/mise.plugin.zsh new file mode 100644 index 000000000..1b4d3ae81 --- /dev/null +++ b/plugins/mise/mise.plugin.zsh @@ -0,0 +1,23 @@ +# TODO: 2024-01-03 remove rtx support +local __mise=mise +if (( ! $+commands[mise] )); then + if (( $+commands[rtx] )); then + __mise=rtx + else + return + fi +fi + +# Load mise hooks +eval "$($__mise activate zsh)" + +# If the completion file doesn't exist yet, we need to autoload it and +# bind it to `mise`. Otherwise, compinit will have already done that. +if [[ ! -f "$ZSH_CACHE_DIR/completions/_$__mise" ]]; then + typeset -g -A _comps + autoload -Uz _$__mise + _comps[$__mise]=_$__mise +fi + +# Generate and load mise completion +$__mise completion zsh >| "$ZSH_CACHE_DIR/completions/_$__mise" &| diff --git a/plugins/rtx/README.md b/plugins/rtx/README.md deleted file mode 100644 index c6436d3a7..000000000 --- a/plugins/rtx/README.md +++ /dev/null @@ -1,30 +0,0 @@ -## rtx - - -Adds integration with [rtx](https://github.com/jdx/rtx), a runtime executor compatible with npm, nodenv, pyenv, etc. rtx is written in rust and is very fast. 20x-200x faster than asdf. With that being said, rtx is compatible with asdf plugins and .tool-versions files. It can be used as a drop-in replacement. - -### Installation - -1. [Download & install rtx](https://github.com/jdx/rtx#installation) by running the following: - - ``` - curl https://rtx.pub/install.sh | sh - ``` - - -2. [Enable rtx](https://github.com/jdx/rtx#quickstart) by adding it to your `plugins` definition in `~/.zshrc`. - - ``` - plugins=(rtx) - ``` - -### Usage - -See the [rtx readme](https://github.com/jdx/rtx#table-of-contents) for information on how to use rtx. Here are a few examples: - -``` -rtx install node Install the current version specified in .tool-versions/.rtx.toml -rtx use -g node@system Use system node as global default -rtx install node@20.0.0 Install a specific version number -rtx use -g node@20 Use node-20.x as global default -``` diff --git a/plugins/rtx/rtx.plugin.zsh b/plugins/rtx/rtx.plugin.zsh index a01828afd..43127a25f 100644 --- a/plugins/rtx/rtx.plugin.zsh +++ b/plugins/rtx/rtx.plugin.zsh @@ -1,18 +1,2 @@ -# rtx needs to be in $PATH -if (( ! ${+commands[rtx]} )); then - return -fi - -# Load rtx hooks -eval "$(rtx activate zsh)" - -# If the completion file doesn't exist yet, we need to autoload it and -# bind it to `rtx`. Otherwise, compinit will have already done that. -if [[ ! -f "$ZSH_CACHE_DIR/completions/_rtx" ]]; then - typeset -g -A _comps - autoload -Uz _rtx - _comps[rtx]=_rtx -fi - -# Generate and load rtx completion -rtx completion zsh >! "$ZSH_CACHE_DIR/completions/_rtx" &| +# TODO: 2024-01-03 remove rtx support +echo "[oh-my-zsh] 'rtx' plugin has been renamed to 'mise'" From f4435a4522c1070b04d4e3a5b6b705bcebc309e5 Mon Sep 17 00:00:00 2001 From: Zacharias Knudsen Date: Thu, 4 Jan 2024 10:30:14 +0100 Subject: [PATCH 466/672] feat(rails): update completion script (#12145) Source: https://github.com/zsh-users/zsh-completions/blob/f7c3173886f4f56bf97d622677c6d46ab005831f/src/_rails --- plugins/rails/_rails | 1004 +++++++++++++++++++----------------------- 1 file changed, 459 insertions(+), 545 deletions(-) diff --git a/plugins/rails/_rails b/plugins/rails/_rails index ac90d45cc..48fd1909e 100644 --- a/plugins/rails/_rails +++ b/plugins/rails/_rails @@ -1,6 +1,6 @@ #compdef rails # ------------------------------------------------------------------------------ -# Copyright (c) 2016 GitHub zsh-users - http://github.com/zsh-users +# Copyright (c) 2016 GitHub zsh-users - https://github.com/zsh-users # All rights reserved. # # Redistribution and use in source and binary forms, with or without @@ -28,136 +28,494 @@ # Description # ----------- # -# Completion script for Ruby on Rails (http://rubyonrails.org/). +# Completion script for Ruby on Rails 7.1.0 (https://rubyonrails.org/). # # ------------------------------------------------------------------------------ # Authors # ------- # # * Kazuya Takeshima (https://github.com/mitukiii) +# * Shohei Yoshida (https://github.com/syohex) # # ------------------------------------------------------------------------------ - _rails() { - local context state line curcontext="$curcontext" + local context state state_descr line curcontext="$curcontext" + typeset -A opt_args - if (( CURRENT > 2 )); then - (( CURRENT-- )) - shift words - _call_function - "_rails_${words[1]}" || _nothing - else - __rails_commands - fi -} - -__rails_commands() { - local context state line curcontext="$curcontext" - - local -a rails_options - __rails_setup_rails_options - - _arguments -C \ - $rails_options \ - ': :->command' - - case "$state" in - command) - local -a commands - local application_directory - __rails_setup_application_directory - - if [ -n "$application_directory" ]; then - commands=( - {generate,g}'[Generate new code]' - {console,c}'[Start the Rails console]' - {server,s}'[Start the Rails server]' - {dbconsole,db}'[Start a console for the database specified in config/database.yml]' - application'[Generate the Rails application code]' - {destroy,d}'[Undo code generated with "generate"]' - benchmarker'[See how fast a piece of code runs]' - profiler'[Get profile information from a piece of code]' - plugin'[Install a plugin]' - {runner,r}'[Run a piece of code in the application environment]' - {test,t}'[Run tests]' - ) - else - commands=( - new'[Create a new Rails application]' - ) - fi - - _values 'command' $commands - ;; - esac -} - -__rails_setup_application_directory() { - application_directory="$(pwd)" - - while [ -n "$application_directory" ]; do - if [ -f "${application_directory}/script/rails" -o -f "${application_directory}/bin/rails" ]; then - return - fi - application_directory="${application_directory%/*}" - done - - application_directory= -} - -__rails_setup_rails_options() { - rails_options=( - {-h,--help}'[Show this help message and quit]' - {-v,--version}'[Show Rails version number and quit]' + local -a runtime_options rails_options + runtime_options=( + '(- *)'{-h,--help}'[Show this help message and quit]' + '(- *)'{-v,--version}'[Show Rails version and quit]' ) -} -__rails_setup_runtime_options() { runtime_options=( '(-f --force)'{-f,--force}'[Overwrite files that already exist]' '(-p --pretend)'{-p,--pretend}'[Run but do not make any changes]' '(-q --quiet)'{-q,--quiet}'[Suppress status output]' '(-s --skip)'{-s,--skip}'[Skip files that already exist]' ) + + local ret=1 + + _arguments -C \ + $rails_options \ + '1: :_rails_subcommands' \ + '*:: :->command' && ret=0 + + case "$state" in + (command) + case $words[1] in + (new) + _rails_new && ret=0 + ;; + (generate|g|destroy|d) + _rails_generate && ret=0 + ;; + (console|c) + _arguments \ + '(- *)'{-h,--help}'[Show this help message and quit]' \ + '(-e --environment)'{-e,--environment=}'[The environment to run "console" in]:env:(test development production)' \ + '(-s --sandbox)'{-s,--sandbox}'[Rollback database modifications on exit]' \ + && ret=0 + ;; + (server|s) + _arguments \ + '(- *)'{-h,--help}'[Show this help message and quit]' \ + '(-e --environment)'{-e,--environment=}'[The environment to run "server" in]:env:(test development production)' \ + '(-p --port)'{-p,--port}'[Run Rails on the specified port]:port' \ + '(-b --binding)'{-b,--binding=}'[Bind Rails to the specified IP]:binding' \ + '(-c --config)'{-c,--config=}'[Use a custom rackup configuration]:config file:_files -g "*.ru"' \ + '(-d --daemon)'{-d,--daemon}'[Run server as a Daemon]' \ + '(-u --using)'{-u,--using=}'[Specify the Rack server used to run the application]:server:(thin puma webrick)' \ + '(-P --pid)'{-P,--pid=}'[Specify the PID file]:pid file:_files -g "*.pid"' \ + '(-C --dev-caching --no-dev-caching)'{-C,--dev-caching}'[Perform caching in development]' \ + '(-C --dev-caching --no-dev-caching)--no-dev-caching[Not perform caching in development]' \ + '--early-hints[Enable HTTP/2 early hints]' \ + '(--log-to-stdout --no-log-to-stdout)--log-to-stdout[Log to stdout]' \ + '(--log-to-stdout --no-log-to-stdout)--no-log-to-stdout[Not log to stdout]' \ + && ret=0 + ;; + (dbconsole|db) + _arguments \ + '(- *)'{-h,--help}'[Show this help message and quit]' \ + '(-e --environment)'{-e,--environment=}'[The environment to run "server" in]:env:(test development production)' \ + '(-p --include-password)'{-p,--include-password}'[Automatically provide the password from database.yml]' \ + '--mode=[Automatically put the sqlite3 database in the specified mode]:mode:(html list line column)' \ + '(--header --no-header)--header[Display header]' \ + '(--header --no-header)--no-header[Not display header]' \ + '(--db --database)'{--db=,--database=}'[Specify the database to use]:database:_files' \ + && ret=0 + ;; + (test|t|test:system) + _arguments \ + '(- *)'{-h,--help}'[Show this help message and quit]' \ + '--no-plugins[Bypass minitest plugin auto-loading]' \ + '(-s --seed)'{-s,--seed=}'[Sets random seed]:seed' \ + '(-v -verbose)'{-v,--verbose}'[Show progress processing files]' \ + '--show-skips[Show skipped at the end of run]' \ + \*{-n,--name=}'[Filter run on /regexp/ or string]:pattern' \ + *--exclude='[Exclude /regexp/ or string from run]:pattern' \ + \*{-S,--skip=}'[Skip reporting of certain types of results]' \ + '(-w --warnings)'{-w,--warnings}'[Run with Ruby warnings enabled]' \ + '(-e --environment)'{-e,--environment=}'[Run tests in the given environment]' \ + '(-b --backtrace)'{-b,--backtrace}'[Show the complete backtrace]' \ + '(-d --defer-output)'{-d,--defer-output}'[Output test failures and errors after the test run]' \ + '(-f --fail-fast)'{-f,--fail-fast}'[Abort test run on first failure or error]' \ + '(-c --color --no-color)'{-c,--color}'[Enable color in the output]' \ + '(-c --color --no-color)--no-color[Disable color in the output]' \ + '--profile=[Enable profiling of tests and list the slowest test cases]:count' \ + '(-p --pride)'{-p,--pride}'[Show your testing pride]' \ + '*:: :_files -g "*.rb"' \ + && ret=0 + ;; + (runner|r) + _arguments \ + '(- *)'{-h,--help}'[Show this help message and quit]' \ + '(-e --environment)'{-e,--environment=}'[The environment to run "runner"]:env:(test development production)' \ + '*:: :_files -g "*.rb"' \ + && ret=0 + ;; + (plugin) + _arguments \ + '1: :(new)' \ + '*:: :_rails_new' \ + && ret=0 + ;; + (routes) + _arguments \ + '(- *)'{-h,--help}'[Show this help message and quit]' \ + '(-c --controller)'{-c,--controller=}'[Filter by a specific controller]:controller' \ + '(-g --grep)'{-g,--grep}'[Grep routes by a specific pattern]' \ + '(-E --expanded)'{-E,--expanded}'[Print routes expanded vertically with parts explained]' \ + '(-u --unused)'{-u,--unused}'[Print unused routes]' \ + && ret=0 + ;; + (*) + _arguments \ + '(- *)'{-h,--help}'[Show help message and quit]' \ + '*:: :_files' \ + && ret=0 + ;; + esac + ;; + esac + + return ret } -__rails_setup_generators_options() { - local -a runtime_options - __rails_setup_runtime_options +(( $+functions[_rails_subcommands] )) || +_rails_subcommands() { + local -a commands - generators_options=( - $runtime_options - --skip-namespace'[Skip namespace (affects only isolated applications)]' - --old-style-hash"[Force using old style hash (:foo => 'bar') on Ruby >= 1.9]" + _rails_is_in_app + + if (( $? == 1 )); then + # is not in rails app directory + commands=( + new'[Create a new Rails application]' + ) + else + commands=( + {generate,g}'[Generate new code]' + {console,c}'[Start the Rails console]' + {server,s}'[Start the Rails server]' + {test,t}'[Run tests]' + "test\\:system[Run systems test only]" + {dbconsole,db}'[Start a console for the database specified in config/database.yml]' + plugin'[Install a plugin]' + + # generated by ./bin/rails --help | ruby -ne '(b=$2;printf("%s[%s]\n", $1.gsub(/:/,"\\:"),b.strip)) if /^([a-z0-9_:]+)\S*\s+([^(\n]+)/' + "about[List versions of all Rails frameworks and the environment]" + "action_mailbox\:ingress\:exim[Relay an inbound email from Exim to Action Mailbox]" + "action_mailbox\:ingress\:postfix[Relay an inbound email from Postfix to Action Mailbox]" + "action_mailbox\:ingress\:qmail[Relay an inbound email from Qmail to Action Mailbox]" + "action_mailbox\:install[Install Action Mailbox and its dependencies]" + "action_mailbox\:install\:migrations[Copy migrations from action_mailbox to application]" + "action_text\:install[Copy over the migration, stylesheet, and JavaScript files]" + "action_text\:install\:migrations[Copy migrations from action_text to application]" + "active_storage\:install[Copy over the migration needed to the application]" + "app\:template[Apply the template supplied by LOCATION=]" + "app\:update[Update configs and some other initially generated files]" + "assets\:clean[Remove old compiled assets]" + "assets\:clobber[Remove compiled assets]" + "assets\:environment[Load asset compile environment]" + "assets\:precompile[Compile all the assets named in config.assets.precompile]" + "cache_digests\:dependencies[Lookup first-level dependencies for TEMPLATE]" + "cache_digests\:nested_dependencies[Lookup nested dependencies for TEMPLATE]" + "credentials\:diff[Enroll/disenroll in decrypted diffs of credentials using git]" + "credentials\:edit[Open the decrypted credentials in $VISUAL or $EDITOR for editing]" + "credentials\:show[Show the decrypted credentials]" + "db\:create[Create the database from DATABASE_URL or config/database.yml for the current RAILS_ENV]" + "db\:drop[Drop the database from DATABASE_URL or config/database.yml for the current RAILS_ENV]" + "db\:encryption\:init[Generate a set of keys for configuring Active Record encryption in a given environment]" + "db\:environment\:set[Set the environment value for the database]" + "db\:fixtures\:load[Load fixtures into the current environment's database]" + "db\:migrate[Migrate the database]" + "db\:migrate\:down[Run the 'down' for a given migration VERSION]" + "db\:migrate\:redo[Roll back the database one migration and re-migrate up]" + "db\:migrate\:status[Display status of migrations]" + "db\:migrate\:up[Run the 'up' for a given migration VERSION]" + "db\:prepare[Run setup if database does not exist, or run migrations if it does]" + "db\:reset[Drop and recreate all databases from their schema for the current environment and load the seeds]" + "db\:rollback[Roll the schema back to the previous version]" + "db\:schema\:cache\:clear[Clear a db/schema_cache.yml file]" + "db\:schema\:cache\:dump[Create a db/schema_cache.yml file]" + "db\:schema\:dump[Create a database schema file]" + "db\:schema\:load[Load a database schema file]" + "db\:seed[Load the seed data from db/seeds.rb]" + "db\:seed\:replant[Truncate tables of each database for current environment and load the seeds]" + "db\:setup[Create all databases, load all schemas, and initialize with the seed data]" + "db\:system\:change[Change 'config/database.yml' and your database gem to the target database]" + "db\:version[Retrieve the current schema version number]" + "destroy[Remove code generated by 'bin/rails generate']" + "dev\:cache[Toggle development mode caching on/off]" + "encrypted\:edit[Open the decrypted file in $VISUAL or $EDITOR for editing]" + "encrypted\:show[Show the decrypted contents of the file]" + "importmap\:install[Setup Importmap for the app]" + "initializers[Print out all defined initializers in the order they are invoked by Rails.]" + "log\:clear[Truncate all/specified *.log files in log/ to zero bytes]" + "middleware[Print out your Rack middleware stack]" + "notes[Show comments in your code annotated with FIXME, OPTIMIZE, and TODO]" + "restart[Restart app by touching tmp/restart.txt]" + "routes[List all the defined routes]" + "runner[Run Ruby code in the context of your application]" + "secret[Generate a cryptographically secure secret key]" + "secrets\:edit[**deprecated** Open the secrets in $VISUAL or $EDITOR for editing]" + "secrets\:show[**deprecated** Show the decrypted secrets]" + "stats[Report code statistics]" + "stimulus\:install[Install Stimulus into the app]" + "stimulus\:install\:importmap[Install Stimulus on an app running importmap-rails]" + "stimulus\:install\:node[Install Stimulus on an app running node]" + "test\:all[Run all tests, including system tests]" + "test\:channels[Run tests in test/channels]" + "test\:controllers[Run tests in test/controllers]" + "test\:db[Reset the database and run 'bin/rails test']" + "test\:functionals[Run tests in test/controllers, test/mailers, and test/functional]" + "test\:generators[Run tests in test/lib/generators]" + "test\:helpers[Run tests in test/helpers]" + "test\:integration[Run tests in test/integration]" + "test\:jobs[Run tests in test/jobs]" + "test\:mailboxes[Run tests in test/mailboxes]" + "test\:mailers[Run tests in test/mailers]" + "test\:models[Run tests in test/models]" + "test\:units[Run tests in test/models, test/helpers, and test/unit]" + "time\:zones[List all time zones, list by two-letter country code]" + "tmp\:clear[Clear cache, socket and screenshot files from tmp/]" + "tmp\:create[Create tmp directories for cache, sockets, and pids]" + "turbo\:install[Install Turbo into the app]" + "turbo\:install\:importmap[Install Turbo into the app with asset pipeline]" + "turbo\:install\:node[Install Turbo into the app with webpacker]" + "turbo\:install\:redis[Switch on Redis and use it in development]" + "version[Show the Rails version]" + "yarn\:install[Install all JavaScript dependencies as specified via Yarn]" + "zeitwerk\:check[Check project structure for Zeitwerk compatibility]" + ) + fi + + _values 'command' $commands +} + +# rails new +(( $+functions[_rails_new] )) || +_rails_new() { + local ret=1 + + _arguments \ + $runtime_options \ + $rails_options \ + --skip-namespace'[Skip namespace]' \ + '(-n --name)'{-n,--name=}'[Name of the app]:name' \ + '(-r --ruby)'{-r,--ruby=}'[Path to the Ruby binary of your choice]:path:_files' \ + '(-b --builder)'{-b,--builder=}'[Path to a application builder(can be a filesystem path or URL)]: :_rails_path_or_url' \ + '(-m --template)'{-m,--template=}'[Path to an application template(can be a filesystem path or URL)]: :_rails_path_or_url' \ + '(-d --database)'{-d,--database=}'[Preconfigure for selected database]:database:(mysql trilogy oracle postgresql sqlite3 frontbase ibm_db sqlserver jdbcmysql jdbcsqlite3 jdbcpostgresql jdbc)' \ + --skip-gemfile"[Don't create a Gemfile]" \ + --skip-bundle"[Don't run bundle install]" \ + '(-G --skip-git)'{-G,--skip-git}'[Skip git init]' \ + --skip-docker'[Skip Dockerfile]' \ + --skip-keeps'[Skip source control .keep files]' \ + '(-M --skip-action-mailer)'{-M,--skip-action-mailer}'[Skip Action Mailer files]' \ + --skip-action-mailbox'[Skip Action Mailbox gem]' \ + --skip-action-text'[Skip Action Text gem]' \ + '(-O --skip-active-record)'{-O,--skip-active-record}'[Skip Active Record files]' \ + --skip-active-job'[Skip Active Job]' \ + --skip-active-storage'[Skip Active Storage files]' \ + '(-C --skip-action-cable)'{-C,--skip-action-cable}'[Skip Action Cable files]' \ + '(-A --skip-asset-pipeline)'{-A,--skip-asset-pipeline}'[Skip asset pipeline]' \ + '(-a --asset-pipeline)'{-a,--asset-pipeline=}'[Choose your asset pipeline]:asset pipeline:(sprockets propshaft)' \ + '(-J --skip-js)'{-J,--skip-js}'[Skip JavaScript files]' \ + --skip-hotwire'[Skip Hotwire integration]' \ + --skip-jbuilder'[Skip jbuilder gem]' \ + '(-T --skip-test)'{-T,--skip-test}'[Skip test files]' \ + --skip-system-test'[Skip system test files]' \ + --skip-bootsnap'[Skip bootsnap gem]' \ + --skip-dev-gems'[Skip development gems(e.g. web-console)]' \ + --dev'[Setup the application with Gemfile pointing to your Rails checkout]' \ + --edge'[Setup the application with Gemfile pointing to Rails repository]' \ + --master'[Set up the application with Gemfile pointing to Rails repository main branch]' \ + --rc='[Path to file containing extra configuration options for rails command]:rc:_files' \ + --api'[Preconfigure smaller stack for API only apps]' \ + --minimal'[Preconfigure a minimal rails app]' \ + '(-j --js)'{-j,--js=}'[Choose JavaScript approach]:javascript:(importmap bun webpack esbuild rollup)' \ + '(-c --css)'{-c,--css=}'[Choose CSS processor]:css processor:(tailwind bootstrap bulma postcss sass)' \ + '(-B --skip-bundle)'{-B,--skip-bundle}"[Don't run bundle install]" \ + --skip-decrypted-diffs"[Don't configure git to show decrypted diffs of encrypted credentials]" \ + ':app path:_directories' && ret=0 + + return ret +} + +# rails generate +(( $+functions[_rails_generate] )) || +_rails_generate() { + local ret=1 + + _arguments -C \ + '(- *)'{-h,--help}"[Print generator's options and usage]" \ + $runtime_options \ + '1:generator:_rails_generate_generator' \ + '*:: :->generate' && ret=0 + + case "$state" in + (generate) + local -a opts + opts=( + '(- *)'{-h,--help}'[Show this help message and quit]' + $runtime_options + '--skip-namespace[Skip namespace]' + '--skip-collision-check[Skip collision check]' + ) + + case $words[1] in + (application_record|migration|model|resource|scaffold|scaffold_controller) + opts+=( + '(-o --orm)'{-o,--orm=}'[ORM to be invoked]:orm:(active_record)' + ) + ;| + (channel) + opts+=( + '--no-assets[Not generate assets]' + ) + ;| + (controller|resource|scaffold|scaffold_controller) + opts+=( + '--skip-routes[Do not add routes to config/routes.rb]' + '--no-helper[Not generate helper]' + ) + ;| + (controller|job|model|resource|scaffold) + opts+=( + '--parent=[The parent class for the generated controler]:parent class' + ) + ;| + (controler|mailer|resource|scaffold|scaffold_controller) + opts+=( + '(-e --template-engine)'{-e,--template-engine=}'[Template engine to be invoked]:engine:(erb)' + ) + ;| + (channel|controller|generator|helper|job|mailbox|mailer|model|scaffold|scaffold_controller) + opts+=( + '(-t --test-framework)'{-t,--test-framework=}'[Test framework to be invoked]:test_framework:(test_unit)' + ) + ;| + (generator|test_unit:channel) + opts+=( + '--no-namespace[Not generate namespace generate]' + ) + ;| + (integration_test) + opts+=( + '--integration-tool=[Integration tool to be invoked]:tool:(test_unit)' + ) + ;| + (jbuilder|resource|scaffold|scaffold_controller) + opts+=( + '--model-name=[ModelName to be used]:name' + ) + ;| + (jbuilder|model|resource|scaffold|scaffold_controller) + opts+=( + '--force-plural[Do not singularize the model name]' + ) + ;| + (jbuilder|migration|model|resource|scaffold_controller) + opts+=( + '--no-timestamps[Not generate timestamps]' + ) + ;| + (job) + opts+=( + '--queue=[The queue name for the generated job]:name' + ) + ;| + (migration|model|resource|scaffold) + opts+=( + '--primary-key-type=[The type for primary key]' + '(--db --database)'{--db,--database=}'[The database for your migration]:db' + ) + ;| + (model|resource|scaffold) + opts+=( + '--no-migration[Not generate migration]' + '--no-indexes[Not add indexes for references and belongs_to columns]' + '--no-fixture[Not generate fixture]' + '(-r --fixture-replacement)'{-r,--fixture-replacement=}'[Fixture replacement to be invoked]:fixture' + ) + ;| + (resource) + opts+=( + '(-c --resource-controller)'{-c,--resource-controller=}'[Resource controller to be invoked]:controller:(controller)' + '(-a --actions)'{-a,--actions=}'[Actions for the source controller]:action' + ) + ;| + (resource|scaffold|scaffold_controller) + opts+=( + '--no-resource-route[Not generate resource route]' + ) + ;| + (scaffold) + opts+=( + '(-c --scaffold-controller)'{-c,--scaffold-controller=}'[Scaffold controller to be invoked]:controller:(scaffold_controller)' + + ) + ;| + (scaffold|scaffold_controller) + opts+=( + '--api[Generate API-only controller and tests, with no view templates]' + '--no-jbuilder[Not generate jbuilder]' + ) + ;| + (scaffold|scaffold_controller|system_test) + opts+=( + '--system-tests=[System test framework to be invoked]:framework:(test_unit)' + ) + ;| + (stimulus) + opts+=( + '--skip-manifest[Do not update the stimulus manifest]' + ) + ;| + (jbuilder|migration|resource|scaffold) + opts+=( + '*:field:_rails_migration_fields' + ) + ;| + esac + + _arguments $opts && ret=0 + ;; + esac + + return ret +} + +(( $+functions[_rails_generate_generator] )) || +_rails_generate_generator() { + local -a generators=( + # rails + application_record benchmark channel controller generator helper integration_test + jbuilder job mailbox mailer migration model resource scaffold scaffold_controller + system_test task + + # active record + "active_record\\:application_record" + "active_record\\:multi_db" + + # Stimulus + stimulus + + # TestUnit + "test_unit\\:channel" "test_unit\\:generator" "test_unit\\:install" + "test_unit\\:mailbox" "test_unit\\:plugin" ) + + _values 'generators' $generators } -__rails_setup_model_generators_options() { - local -a generators_options - __rails_setup_generators_options +# Utilities +(( $+functions[_rails_is_in_app] )) || +_rails_is_in_app() { + local dir="$PWD" + while [ -n "$dir" ]; do + if [[ -f "${dir}/bin/rails" ]]; then + return 0 + fi + dir="${dir/*}" + done - model_generators_options=( - $generators_options - '(-o --orm)'{-o,--orm=}'[Orm to be invoked]:orm' - ) + return 1 } -__rails_setup_resource_generators_options() { - local -a model_generators_options - __rails_setup_model_generators_options - - resource_generators_options=( - $model_generators_options - --force-plural'[Forces the use of a plural ModelName]' - --resource-route'[Indicates when to generate resource route]: :__rails_boolean' - ) +(( $+functions[_rails_path_or_url] )) || +_rails_path_or_url() { + _alternative \ + 'files:path:_files -g "*.rb"' \ + 'url:url:_urls' } -__rails_boolean() { - _values 'boolean' 'true' 'false' -} - -__rails_migration_fields() { +(( $+functions[_rails_migration_fields] )) || +_rails_migration_fields() { if compset -P '*:*:'; then _values 'index' 'index' 'uniq' else @@ -169,450 +527,6 @@ __rails_migration_fields() { fi } -_rails_generate() { - local context state line curcontext="$curcontext" - - if (( CURRENT > 2 )); then - (( CURRENT-- )) - shift words - _call_function - "_rails_generate_${words[1]}" || _rails_generate_default - else - __rails_generate_commands - fi -} - -_rails_g() { - _rails_generate -} - -__rails_generate_commands() { - local context curcontext="$curcontext" update_policy - - zstyle -s ":completion:${curcontext}:" cache-policy update_policy - if [ -z "$update_policy" ]; then - zstyle ":completion:${curcontext}:" cache-policy _rails_generate_commands_caching_policy - fi - - local application_directory - __rails_setup_application_directory - local cache_name - cache_name="rails/${application_directory##*/}/all_generators" - if ! _retrieve_cache ${cache_name}; then - local -a all_generators - all_generators=($(_call_program rails_generators rails generate 2> /dev/null | awk '/^ [a-zA-Z_]+/{ print $1 }')) - _store_cache ${cache_name} all_generators - fi - - local -a rails_generators - rails_generators=(${all_generators:#*:*}) - _describe -t rails_generators 'rails generator' rails_generators - - local -a -U namespaces - local namespace - local -a generators - namespaces=(${(R)${(M)all_generators:#*:*}%:*}) - for namespace in $namespaces; do - generators=(${${(M)all_generators:#${namespace}:*}/:/\\:}) - _describe -t ${namespace}_generators "${namespace/_/ } generator" generators - done -} - -_rails_generate_commands_caching_policy() { - local application_directory - __rails_setup_application_directory - - if [ "${application_directory}/Gemfile" -nt "$1" ]; then - return 0 - fi - - local -a oldp - oldp=( "$1"(Nmw+1) ) - (( $#oldp )) -} - -_rails_generate_default() { - local -a generators_options - __rails_setup_generators_options - - _arguments \ - $generators_options \ - '*:argument' -} - -_rails_generate_assets() { - local -a generators_options - __rails_setup_generators_options - - _arguments \ - $generators_options \ - '(-j --javascripts)'{-j,--javascripts}'[Generate JavaScripts]: :__rails_boolean' \ - '(-y --stylesheets)'{-y,--stylesheets}'[Generate Stylesheets]: :__rails_boolean' \ - '(-je --javascript-engine)'{-je,--javascript-engine=}'[Engine for JavaScripts]:javascript engine' \ - '(-se --stylesheet-engine)'{-se,--stylesheet-engine=}'[Engine for Stylesheets]:stylesheet engine' \ - ': :_guard "^-*" "name"' -} - -_rails_generate_controller() { - local -a generators_options - __rails_setup_generators_options - - _arguments \ - $generators_options \ - '(-e --template-engine)'{-e,--template-engine=}'[Template engine to be invoked]:template engine' \ - '(-t --test-framework)'{-t,--test-framework=}'[Test framework to be invoked]:test framework' \ - --helper'[Indicates when to generate helper]: :__rails_boolean' \ - --assets'[Indicates when to generate assets]: :__rails_boolean' \ - ': :_guard "^-*" "name"' \ - '*: :_guard "^-*" "action"' -} - -_rails_generate_generator() { - local -a generators_options - __rails_setup_generators_options - - _arguments \ - $generators_options \ - --namespace'[Namespace generator under lib/generators/name]: :__rails_boolean' \ - ': :_guard "^-*" "name"' -} - -_rails_generate_helper() { - local -a generators_options - __rails_setup_generators_options - - _arguments \ - $generators_options \ - '(-t --test-framework)'{-t,--test-framework=}'[Test framework to be invoked]:test framework' \ - ': :_guard "^-*" "name"' \ -} - -_rails_generate_integration_test() { - local -a generators_options - __rails_setup_generators_options - - _arguments \ - $generators_options \ - --integration-tool='[Integration tool to be invoke]:integration tool' \ - ': :_guard "^-*" "name"' \ -} - -_rails_generate_jbuilder() { - local -a generators_options - __rails_setup_generators_options - - _arguments \ - $generators_options \ - ': :_guard "^-*" "name"' \ - '*: :__rails_migration_fields' -} - -_rails_generate_mailer() { - local -a generators_options - __rails_setup_generators_options - - _arguments \ - $generators_options \ - '(-e --template-engine)'{-e,--template-engine=}'[Template engine to be invoked]:template engine' \ - '(-t --test-framework)'{-t,--test-framework=}'[Test framework to be invoked]:test framework' \ - ': :_guard "^-*" "name"' \ - '*: :_guard "^-*" "method"' -} - -_rails_generate_migration() { - local -a modelgenerators_options - __rails_setup_model_generators_options - - _arguments \ - $model_generators_options \ - ': :_guard "^-*" "name"' \ - '*: :__rails_migration_fields' -} - -_rails_generate_model() { - _rails_generate_migration -} - -_rails_generate_observer() { - local -a model_generators_options - __rails_setup_model_generators_options - - _arguments \ - $model_generators_options \ - ': :_guard "^-*" "name"' -} - -_rails_generate_performance_test() { - local -a generators_options - __rails_setup_generators_options - - _arguments \ - $generators_options \ - --performance-tool='[Performance tool to be invoked]:performance tool' \ - ': :_guard "^-*" "name"' \ -} - -_rails_generate_resource() { - local context state line curcontext="$curcontext" - - local -a resource_generators_options - __rails_setup_resource_generators_options - - _arguments -C \ - $resource_generators_options \ - '(-c --resource-controller)'{-c,--resource-controller=}'[Resource controller to be invoked]:name' \ - '(-a --actions)'{-a,--actions=}'[Actions for the resource controller]: :->actions' \ - ': :->name' \ - '*: :->fields' - - if (( words[(I)(--actions=*|-a)] > 0 && words[(I)(--actions=*|-a)] == words[(I)-*] )); then - state=actions - fi - - case "$state" in - actions) - _guard "[[:alnum:]_]#" "actions" - ;; - name) - _guard "^-*" "name" - ;; - fields) - __rails_migration_fields - ;; - esac -} - -_rails_generate_scaffold() { - local -a resource_generators_options - __rails_setup_resource_generators_options - - _arguments \ - $resource_generators_options \ - '(-y --stylesheets)'{-y,--stylesheets}'[Generate Stylesheets]: :__rails_boolean' \ - '(-se --stylesheet-engine)'{-se,--stylesheet-engine=}'[Engine for Stylesheets]:stylesheet engine' \ - '(-c --scaffold-controller)'{-c,--scaffold-controller=}'[Scaffold controller to be invoked]:name' \ - --assets'[Indicates when to generate assets]:boolean:(true false)' \ - ': :_guard "^-*" "name"' \ - '*: :__rails_migration_fields' -} - -_rails_generate_scaffold_controller() { - local -a model_generators_options - __rails_setup_model_generators_options - - _arguments \ - $model_generators_options \ - '(-e --template-engine)'{-e,--template-engine=}'[Template engine to be invoked]:template engine' \ - '(-t --test-framework)'{-t,--test-framework=}'[Test framework to be invoked]:test framework' \ - --helper'[Indicates when to generate helper]: :__rails_boolean' \ - ': :_guard "^-*" "name"' -} - -_rails_generate_session_migration() { - local -a model_generators_options - __rails_setup_model_generators_options - - _arguments \ - $model_generators_options \ - ': :_guard "^-*" "name"' -} - -_rails_generate_task() { - local -a generators_options - __rails_setup_generators_options - - _arguments \ - $generators_options \ - ': :_guard "^-*" "name"' \ - '*: :_guard "^-*" "action"' -} - -_rails_console() { - _arguments \ - '(- *)'{-h,--help}'[Show this help message]' \ - '(-s --sandbox)'{-s,--sandbox}'[Rollback database modifications on exit]' \ - --debugger'[Enable ruby-debugging for the console]' -} - -_rails_c() { - _rails_console -} - -_rails_server() { - _arguments \ - '(- *)'{-h,--help}'[Show this help message]' \ - '(-p --port)'{-p,--port=}'[Runs Rails on the specified port]: :_guard "[[\:digit\:]]#" "port"' \ - '(-b --binding)'{-b,--binding=}'[Binds Rails to the specified ip]:ip:_hosts' \ - '(-c --config)'{-c,--config=}'[Use custom rackup configuration file]:file:_files -g "*.ru"' \ - '(-d --daemon)'{-d,--daemon}'[Make server run as a Daemon]' \ - '(-u --debugger)'{-u,--debugger}'[Enable ruby-debugging for the server]' \ - '(-e --environment)'{-e,--environment=}'[Specifies the environment to run this server under (test/development/production)]:name:(test development production)' \ - '(-P --pid)'{-P,--pid=}'[Specifies the PID file]:pid:_files -g "*.pid"' -} - -_rails_s() { - _rails_server -} - -_rails_dbconsole() { - _arguments \ - '(- *)'--help'[Show this help message]' \ - '(-p --include-password)'{-p,--include-password}'[Automatically provide the password from database.yml]' \ - --mode'[Automatically put the sqlite3 database in the specified mode (html, list, line, column)]:mode:(html list line column)' \ - --header -} - -_rails_new() { - local context state line curcontext="$curcontext" - - local _a rails_options runtime_options - __rails_setup_rails_options - __rails_setup_runtime_options - - _arguments -C \ - $rails_options \ - $runtime_options \ - '(-r --ruby)'{-r,--ruby=}'[Path to the Ruby binary of your choice]:path' \ - '(-b --builder)'{-b,--builder=}'[Path to a application builder (can be a filesystem path or URL)]: :->path_or_url' \ - '(-m --template)'{-m,--template=}'[Path to an application template (can be a filesystem path or URL)]: :->path_or_url' \ - --skip-gemfile"[Don't create a Gemfile]" \ - --skip-bundle"[Don't run bundle install]" \ - '(-G --skip-git)'{-G,--skip-git}'[Skip Git ignores and keeps]' \ - '(-O --skip-active-record)'{-O,--skip-active-record}'[Skip Active Record files]' \ - '(-S --skip-sprockets)'{-S,--skip-sprockets}'[Skip Sprockets files]' \ - '(-d --database)'{-d,--database=}'[Preconfigure for selected database]:database:(mysql oracle postgresql sqlite3 frontbase ibm_db sqlserver jdbcmysql jdbcsqlite3 jdbcpostgresql jdbc)' \ - '(-j --javascript)'{-j,--javascript=}'[Preconfigure for selected JavaScript library]:javascript' \ - '(-J --skip-javascript)'{-J,--skip-javascript}'[Skip JavaScript files]' \ - --dev'[Setup the application with Gemfile pointing to your Rails checkout]' \ - --edge'[Setup the application with Gemfile pointing to Rails repository]' \ - '(-T --skip-test-unit)'{-T,--skip-test-unit}'[Skip Test::Unit files]' \ - --old-style-hash"[Force using old style hash (:foo => 'bar') on Ruby >= 1.9]" \ - ':app path:_directories' - - case "$state" in - path_or_url) - _alternative \ - 'files:path:_files -g "*.rb"' \ - 'url:url:_urls' - ;; - esac -} - -_rails_application() { - _rails_new -} - -_rails_db() { - _rails_dbconsole -} - -_rails_destroy() { - _rails_generate -} - -_rails_d() { - _rails_destroy -} - -_rails_benchmarker() { - _arguments \ - '(- *)'{-h,--help}'[Show this help message]' \ - '(-r --runs)'{-r,--runs}'[Number of runs]: :_guard "[[\:digit\:]]#" "number"' \ - '(-o --output)'{-o,--output}'[Directory to use when writing the results]:directory:_directories' \ - '(-m --metrics)'{-m,--metrics}'[Metrics to use]: :_values -s "," "metrics" "wall_time" "memory" "objects" "gc_runs" "gc_time"' \ - '*: :_guard "^-*" "ruby code"' -} - -_rails_profiler() { - _arguments \ - '(- *)'{-h,--help}'[Show this help message]' \ - '(-r --runs)'{-r,--runs}'[Number of runs]: :_guard "[[\:digit\:]]#" "number"' \ - '(-o --output)'{-o,--output}'[Directory to use when writing the results]:directory:_directories' \ - '(-m --metrics)'{-m,--metrics}'[Metrics to use]: :_values -s "," "metrics" "process_time" "memory" "objects"' \ - '(-f --formats)'{-f,--formats}'[Formats to output to]: :_values -s "," "formats" "flat" "graph" "html" "call_tree" "call_stack"' \ - '*: :_guard "^-*" "ruby code"' -} - -_rails_plugin() { - local context state line curcontext="$curcontext" - - if (( CURRENT > 2 )); then - (( CURRENT-- )) - shift words - _call_function - "_rails_plugin_${words[1]}" || _nothing - else - __rails_plugin_commands - fi -} - -__rails_plugin_commands() { - _values 'plugin command' \ - install'[Install plugin(s) from known repositories or URLs]' \ - remove'[Uninstall plugins]' \ - new -} - -_rails_plugin_install() { - _arguments \ - '(-x --externals)'{-x,--externals}'[Use svn:externals to grab the plugin. Enables plugin updates and plugin versioning]' \ - '(-o --checkout)'{-o,--checkout}'[Use svn checkout to grab the plugin. Enables updating but does not add a svn:externals entry]' \ - '(-e --export)'{-e,--export}'[Use svn export to grab the plugin. Exports the plugin, allowing you to check it into your local repository. Does not enable updates or add an svn:externals entry]' \ - '(-q --quiet)'{-q,--quiet}'[Suppresses the output from installation. Ignored if -v is passed (rails plugin -v install ...)]' \ - '(-r --revision)'{-r,--revision=}'[Checks out the given revision from subversion or git. Ignored if subversion/git is not used]:revision' \ - '(-f --force)'{-f,--force}"[Reinstalls a plugin if it's already installed]" \ - '*:plugin:_urls' -} - -_rails_plugin_remove() { - local -a plugins - - plugins=($(_call_program rails_plugins ls -1 vendor/plugins)) - - _describe -t plugins 'plugin' plugins -} - -_rails_plugin_new() { - _rails_new -} - -_rails_runner() { - local context state line curcontext="$curcontext" - - _arguments -C \ - '(- *)'{-h,--help}'[Show this help message]' \ - '(-e --environment)'{-e,--environment=}'[Specifies the environment for the runner to operate under (test/development/production)]:name:(test development production)' \ - ': :->code_or_path' - - case "$state" in - code_or_path) - _alternative \ - 'files:filename:_files -g "*.rb"' \ - 'codes:ruby code:_guard "^-*" "ruby code"' - ;; - esac -} - -_rails_r() { - _rails_runner -} - -_rails_test() { - local context state line curcontext="$curcontext" - - _arguments -C \ - ': :->path' - - case "$state" in - path) - _alternative \ - 'files:filename:_files -g "*.rb"' - ;; - esac -} - -_rails_t() { - _rails_test -} - _rails "$@" # Local Variables: From 8980ffebbc8e38e8a25cdeba2ef78d7e5d0d0d62 Mon Sep 17 00:00:00 2001 From: Mete Date: Fri, 5 Jan 2024 12:38:26 +0300 Subject: [PATCH 467/672] feat(gcloud): add asdf installation dir (#12146) --- plugins/gcloud/gcloud.plugin.zsh | 1 + 1 file changed, 1 insertion(+) diff --git a/plugins/gcloud/gcloud.plugin.zsh b/plugins/gcloud/gcloud.plugin.zsh index 9a4213aaf..cf3d650ea 100644 --- a/plugins/gcloud/gcloud.plugin.zsh +++ b/plugins/gcloud/gcloud.plugin.zsh @@ -17,6 +17,7 @@ if [[ -z "${CLOUDSDK_HOME}" ]]; then "/opt/google-cloud-sdk" "/opt/google-cloud-cli" "/opt/local/libexec/google-cloud-sdk" + "$HOME/.asdf/installs/gcloud/*/" ) for gcloud_sdk_location in $search_locations; do From 428866e28def25593e7dd73f1c3bd909db47635b Mon Sep 17 00:00:00 2001 From: Johan Kaving Date: Sat, 6 Jan 2024 12:32:18 +0100 Subject: [PATCH 468/672] fix(macos): print usage for `man-preview` with no args (#12147) --- plugins/macos/macos.plugin.zsh | 2 ++ 1 file changed, 2 insertions(+) diff --git a/plugins/macos/macos.plugin.zsh b/plugins/macos/macos.plugin.zsh index e27d412c8..a4347005e 100644 --- a/plugins/macos/macos.plugin.zsh +++ b/plugins/macos/macos.plugin.zsh @@ -224,6 +224,8 @@ function quick-look() { } function man-preview() { + [[ $# -eq 0 ]] && >&2 echo "Usage: $0 command1 [command2 ...]" && return 1 + local page for page in "${(@f)"$(man -w $@)"}"; do command mandoc -Tpdf $page | open -f -a Preview From 5ea2c68be88452b33b35ba8004fc9094618bcd87 Mon Sep 17 00:00:00 2001 From: ChaosInventor Date: Mon, 8 Jan 2024 11:02:20 +0100 Subject: [PATCH 469/672] fix(rkj-repos): check if `~/.hgrc` exists (#12148) --- themes/rkj-repos.zsh-theme | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/themes/rkj-repos.zsh-theme b/themes/rkj-repos.zsh-theme index 3cb452335..a9fe1a9af 100644 --- a/themes/rkj-repos.zsh-theme +++ b/themes/rkj-repos.zsh-theme @@ -1,7 +1,7 @@ # user, host, full path, and time/date on two lines for easier vgrepping function hg_prompt_info { - if (( $+commands[hg] )) && grep -q "prompt" ~/.hgrc; then + if (( $+commands[hg] )) && [[ -e ~/.hgrc ]] && grep -q "prompt" ~/.hgrc; then hg prompt --angle-brackets "\ %{$reset_color%}><:%{$fg[magenta]%}%{$reset_color%}>\ %{$reset_color%}>\ From 1c8dee848dad169c9eb1a7b0148842b48a99cad1 Mon Sep 17 00:00:00 2001 From: Albert Still Date: Wed, 10 Jan 2024 20:41:43 +0000 Subject: [PATCH 470/672] docs(git): align `gpristine` alias (#12155) Co-authored-by: Carlo Sala --- plugins/git/README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/git/README.md b/plugins/git/README.md index b7b9a6635..cbdfdca0f 100644 --- a/plugins/git/README.md +++ b/plugins/git/README.md @@ -163,7 +163,7 @@ plugins=(... git) | `grhh` | `git reset --hard` | | `grhk` | `git reset --keep` | | `grhs` | `git reset --soft` | -| `gpristine` | `git reset --hard && git clean -dffx` | +| `gpristine` | `git reset --hard && git clean --force -dfx` | | `groh` | `git reset origin/$(git_current_branch) --hard` | | `grs` | `git restore` | | `grss` | `git restore --source` | From 15479ca5aee5cd430540794d1f5aae90e2f59cd0 Mon Sep 17 00:00:00 2001 From: reda Date: Sat, 13 Jan 2024 12:36:26 +0100 Subject: [PATCH 471/672] feat(terraform): add new terraform and helm aliases (#11923) --- plugins/helm/README.md | 13 +++++++------ plugins/helm/helm.plugin.zsh | 1 + plugins/terraform/README.md | 3 +++ plugins/terraform/terraform.plugin.zsh | 2 ++ 4 files changed, 13 insertions(+), 6 deletions(-) diff --git a/plugins/helm/README.md b/plugins/helm/README.md index 8be024bfb..dcbb30b6c 100644 --- a/plugins/helm/README.md +++ b/plugins/helm/README.md @@ -10,9 +10,10 @@ plugins=(... helm) ## Aliases -| Alias | Full command | -| ----- | ------------ | -| h | helm | -| hin | helm install | -| hse | helm search | -| hup | helm upgrade | +| Alias | Full command | +| ----- | -------------- | +| h | helm | +| hin | helm install | +| hun | helm uninstall | +| hse | helm search | +| hup | helm upgrade | diff --git a/plugins/helm/helm.plugin.zsh b/plugins/helm/helm.plugin.zsh index 7fc05be98..e754a6541 100644 --- a/plugins/helm/helm.plugin.zsh +++ b/plugins/helm/helm.plugin.zsh @@ -14,5 +14,6 @@ fi alias h='helm' alias hin='helm install' +alias hun='helm uninstall' alias hse='helm search' alias hup='helm upgrade' diff --git a/plugins/terraform/README.md b/plugins/terraform/README.md index fc9a9f005..135fd78ef 100644 --- a/plugins/terraform/README.md +++ b/plugins/terraform/README.md @@ -26,6 +26,9 @@ plugins=(... terraform) | `tfo` | `terraform output` | | `tfp` | `terraform plan` | | `tfv` | `terraform validate` | +| `tfs` | `terraform state` | +| `tfsh`| `terraform show` | + ## Prompt function diff --git a/plugins/terraform/terraform.plugin.zsh b/plugins/terraform/terraform.plugin.zsh index ccca54684..f66a8eac9 100644 --- a/plugins/terraform/terraform.plugin.zsh +++ b/plugins/terraform/terraform.plugin.zsh @@ -24,3 +24,5 @@ alias tfi='terraform init' alias tfo='terraform output' alias tfp='terraform plan' alias tfv='terraform validate' +alias tfs='terraform state' +alias tfsh='terraform show' From 11b0ea33d1c770d69b1418bc78b27a936cc5a17e Mon Sep 17 00:00:00 2001 From: Gautam krishna R Date: Sat, 13 Jan 2024 23:17:54 +0530 Subject: [PATCH 472/672] fix(python): add support for cli args (#12159) --- plugins/python/python.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/python/python.plugin.zsh b/plugins/python/python.plugin.zsh index 3d7ca55c9..77d4bf425 100644 --- a/plugins/python/python.plugin.zsh +++ b/plugins/python/python.plugin.zsh @@ -44,7 +44,7 @@ function pyuserpaths() { alias pygrep='grep -nr --include="*.py"' # Run proper IPython regarding current virtualenv (if any) -alias ipython="python3 -c 'import IPython; IPython.terminal.ipapp.launch_new_instance()'" +alias ipython='python3 -c "import IPython, sys; sys.exit(IPython.start_ipython())"' # Share local directory as a HTTP server alias pyserver="python3 -m http.server" From cb7ff9fb148d14b19699d9bc35272253b698c3d8 Mon Sep 17 00:00:00 2001 From: Mladen Plavsic Date: Sat, 13 Jan 2024 18:54:56 +0100 Subject: [PATCH 473/672] feat(git): add `gcann!` alias (#12041) --- plugins/git/README.md | 1 + plugins/git/git.plugin.zsh | 1 + 2 files changed, 2 insertions(+) diff --git a/plugins/git/README.md b/plugins/git/README.md index cbdfdca0f..be3f85827 100644 --- a/plugins/git/README.md +++ b/plugins/git/README.md @@ -70,6 +70,7 @@ plugins=(... git) | `gca!` | `git commit --verbose --all --amend` | | `gcan!` | `git commit --verbose --all --no-edit --amend` | | `gcans!` | `git commit --verbose --all --signoff --no-edit --amend` | +| `gcann!` | `git commit --verbose --all --date=now --no-edit --amend` | | `gc!` | `git commit --verbose --amend` | | `gcn!` | `git commit --verbose --no-edit --amend` | | `gcs` | `git commit -S` | diff --git a/plugins/git/git.plugin.zsh b/plugins/git/git.plugin.zsh index bee9eb67d..f2e472f06 100644 --- a/plugins/git/git.plugin.zsh +++ b/plugins/git/git.plugin.zsh @@ -194,6 +194,7 @@ alias gca='git commit --verbose --all' alias gca!='git commit --verbose --all --amend' alias gcan!='git commit --verbose --all --no-edit --amend' alias gcans!='git commit --verbose --all --signoff --no-edit --amend' +alias gcann!='git commit --verbose --all --date=now --no-edit --amend' alias gc!='git commit --verbose --amend' alias gcn!='git commit --verbose --no-edit --amend' alias gcf='git config --list' From 8be4789bbbef06fe5eed581dc8c58df51e3cd9fd Mon Sep 17 00:00:00 2001 From: Mohammad Al Zouabi Date: Sun, 14 Jan 2024 01:56:23 +0800 Subject: [PATCH 474/672] feat(git): add `greva` and `grevc` aliases (#12042) --- plugins/git/git.plugin.zsh | 2 ++ 1 file changed, 2 insertions(+) diff --git a/plugins/git/git.plugin.zsh b/plugins/git/git.plugin.zsh index f2e472f06..5c3064e8a 100644 --- a/plugins/git/git.plugin.zsh +++ b/plugins/git/git.plugin.zsh @@ -354,6 +354,8 @@ alias grss='git restore --source' alias grst='git restore --staged' alias gunwip='git rev-list --max-count=1 --format="%s" HEAD | grep -q "\--wip--" && git reset HEAD~1' alias grev='git revert' +alias greva='git revert --abort' +alias grevc='git revert --continue' alias grm='git rm' alias grmc='git rm --cached' alias gcount='git shortlog --summary --numbered' From 35a5357704ace1d9732a15cc3a5d792df53f2170 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E3=81=A8=E3=82=93=E3=81=A8=E3=82=93=E3=81=BC?= <70003919+KaitoMuraoka@users.noreply.github.com> Date: Tue, 16 Jan 2024 18:37:13 +0900 Subject: [PATCH 475/672] feat(web-search): add `deepL` (#12165) --- plugins/web-search/README.md | 1 + plugins/web-search/web-search.plugin.zsh | 2 ++ 2 files changed, 3 insertions(+) diff --git a/plugins/web-search/README.md b/plugins/web-search/README.md index 6e4b4d7b8..cf5bab3f7 100644 --- a/plugins/web-search/README.md +++ b/plugins/web-search/README.md @@ -45,6 +45,7 @@ Available search contexts are: | `scholar` | `https://scholar.google.com/scholar?q=` | | `ask` | `https://www.ask.com/web?q=` | | `youtube` | `https://www.youtube.com/results?search_query=` | +| `deepl` | `https://www.deepl.com/translator#auto/auto/` | Also there are aliases for bang-searching DuckDuckGo: diff --git a/plugins/web-search/web-search.plugin.zsh b/plugins/web-search/web-search.plugin.zsh index a8848fd95..1b42abe86 100644 --- a/plugins/web-search/web-search.plugin.zsh +++ b/plugins/web-search/web-search.plugin.zsh @@ -26,6 +26,7 @@ function web_search() { scholar "https://scholar.google.com/scholar?q=" ask "https://www.ask.com/web?q=" youtube "https://www.youtube.com/results?search_query=" + deepl "https://www.deepl.com/translator#auto/auto/" ) # check whether the search engine is supported @@ -68,6 +69,7 @@ alias archive='web_search archive' alias scholar='web_search scholar' alias ask='web_search ask' alias youtube='web_search youtube' +alias deepl='web_search deepl' #add your own !bang searches here alias wiki='web_search duckduckgo \!w' From d93401c642d1e5c87b06d7622bddb9bfd5eab383 Mon Sep 17 00:00:00 2001 From: Tabrez Mohammed Date: Tue, 16 Jan 2024 01:39:45 -0800 Subject: [PATCH 476/672] feat(history-substring-search): update to upstream (#12164) --- plugins/history-substring-search/README.md | 80 +++++- .../history-substring-search.plugin.zsh | 8 +- .../history-substring-search.zsh | 231 ++++++++++++------ 3 files changed, 231 insertions(+), 88 deletions(-) diff --git a/plugins/history-substring-search/README.md b/plugins/history-substring-search/README.md index 6d8b56425..eee279dfd 100644 --- a/plugins/history-substring-search/README.md +++ b/plugins/history-substring-search/README.md @@ -23,7 +23,15 @@ Install Using the [Homebrew]( https://brew.sh ) package manager: brew install zsh-history-substring-search - echo 'source /usr/local/share/zsh-history-substring-search/zsh-history-substring-search.zsh' >> ~/.zshrc + echo 'source $(brew --prefix)/share/zsh-history-substring-search/zsh-history-substring-search.zsh' >> ~/.zshrc + +Using [Fig](https://fig.io): + +Fig adds apps, shortcuts, and autocomplete to your existing terminal. + +Install `zsh-history-substring-search` in just one click. + + Using [Oh-my-zsh](https://github.com/robbyrussell/oh-my-zsh): @@ -33,24 +41,63 @@ Using [Oh-my-zsh](https://github.com/robbyrussell/oh-my-zsh): 2. Activate the plugin in `~/.zshrc`: - plugins=( [plugins...] history-substring-search) + plugins=( [plugins...] zsh-history-substring-search) -3. Source `~/.zshrc` to take changes into account: +3. Run `exec zsh` to take changes into account: - source ~/.zshrc + exec zsh + +Using [zplug](https://github.com/zplug/zplug): + +1. Add this repo to `~/.zshrc`: + + zplug "zsh-users/zsh-history-substring-search", as: plugin + +Using [antigen](https://github.com/zsh-users/antigen): + +1. Add the `antigen bundle` command just before `antigen apply`, like this: + +``` +antigen bundle zsh-users/zsh-history-substring-search +antigen apply +``` + +2. Then, **after** `antigen apply`, add the key binding configurations, like this: + +``` +# zsh-history-substring-search configuration +bindkey '^[[A' history-substring-search-up # or '\eOA' +bindkey '^[[B' history-substring-search-down # or '\eOB' +HISTORY_SUBSTRING_SEARCH_ENSURE_UNIQUE=1 +``` + +Using [Zinit](https://github.com/zdharma-continuum/zinit): + +1. Use the `Oh-my-zsh` Zinit snippet in `~/.zshrc`: + + zinit snippet OMZ::plugins/git/git.plugin.zsh` + +2. Load the plugin in `~/.zshrc`: + + zinit load 'zsh-users/zsh-history-substring-search + zinit ice wait atload'_history_substring_search_config' + +3. Run `exec zsh` to take changes into account: + + exec zsh Usage ------------------------------------------------------------------------------ 1. Load this script into your interactive ZSH session: - % source zsh-history-substring-search.zsh + source zsh-history-substring-search.zsh If you want to use [zsh-syntax-highlighting][6] along with this script, then make sure that you load it *before* you load this script: - % source zsh-syntax-highlighting.zsh - % source zsh-history-substring-search.zsh + source zsh-syntax-highlighting.zsh + source zsh-history-substring-search.zsh 2. Bind keyboard shortcuts to this script's functions. @@ -73,6 +120,10 @@ Usage bindkey "$terminfo[kcuu1]" history-substring-search-up bindkey "$terminfo[kcud1]" history-substring-search-down + Users have also observed that `[OA` and `[OB` are correct values, + _even if_ these were not the observed values. If you are having trouble + with the observed values, give these a try. + You might also want to bind the Control-P/N keys for use in EMACS mode: bindkey -M emacs '^P' history-substring-search-up @@ -115,7 +166,7 @@ Configuration ------------------------------------------------------------------------------ This script defines the following global variables. You may override their -default values only after having loaded this script into your ZSH session. +default values. * `HISTORY_SUBSTRING_SEARCH_HIGHLIGHT_FOUND` is a global variable that defines how the query should be highlighted inside a matching command. Its default @@ -141,6 +192,12 @@ default values only after having loaded this script into your ZSH session. value, causes this script to perform a fuzzy search by words, matching in given order e.g. `ab c` will match `*ab*c*` +* `HISTORY_SUBSTRING_SEARCH_PREFIXED` is a global variable that defines how + the command history will be searched for your query. If set to a non-empty + value, your query will be matched against the start of each history entry. + For example, if this variable is empty, `ls` will match `ls -l` and `echo + ls`; if it is non-empty, `ls` will only match `ls -l`. + * `HISTORY_SUBSTRING_SEARCH_ENSURE_UNIQUE` is a global variable that defines whether all search results returned are _unique_. If set to a non-empty value, then only unique search results are presented. This behaviour is off @@ -155,6 +212,9 @@ default values only after having loaded this script into your ZSH session. receive globally unique search results only once, then use this configuration variable, or use `setopt HIST_IGNORE_ALL_DUPS`. +* `HISTORY_SUBSTRING_SEARCH_HIGHLIGHT_TIMEOUT` is a global variable that + defines a timeout in seconds for clearing the search highlight. + History ------------------------------------------------------------------------------ @@ -187,8 +247,8 @@ https://github.com/zsh-users/zsh-history-substring-search. This downstream copy was last updated from the following upstream commit: - SHA: 0f80b8eb3368b46e5e573c1d91ae69eb095db3fb - Commit date: 2019-05-12 17:35:54 -0700 + SHA: 8dd05bfcc12b0cd1ee9ea64be725b3d9f713cf64 + Commit date: 2023-11-23 12:12:14 +0200 Everything above this section is a copy of the original upstream's README, so things may differ slightly when you're using this inside OMZ. In particular, you do not diff --git a/plugins/history-substring-search/history-substring-search.plugin.zsh b/plugins/history-substring-search/history-substring-search.plugin.zsh index 63f0bdd42..05bdbcd75 100644 --- a/plugins/history-substring-search/history-substring-search.plugin.zsh +++ b/plugins/history-substring-search/history-substring-search.plugin.zsh @@ -1,9 +1,5 @@ -# Handle $0 according to the standard: -# https://zdharma-continuum.github.io/Zsh-100-Commits-Club/Zsh-Plugin-Standard.html -0="${${ZERO:-${0:#$ZSH_ARGZERO}}:-${(%):-%N}}" -0="${${(M)0:#/*}:-$PWD/$0}" - -source ${0:A:h}/history-substring-search.zsh +0=${(%):-%N} +source ${0:A:h}/zsh-history-substring-search.zsh # Bind terminal-specific up and down keys diff --git a/plugins/history-substring-search/history-substring-search.zsh b/plugins/history-substring-search/history-substring-search.zsh index c326778d4..471cc9ad1 100644 --- a/plugins/history-substring-search/history-substring-search.zsh +++ b/plugins/history-substring-search/history-substring-search.zsh @@ -43,11 +43,12 @@ # declare global configuration variables #----------------------------------------------------------------------------- -typeset -g HISTORY_SUBSTRING_SEARCH_HIGHLIGHT_FOUND='bg=magenta,fg=white,bold' -typeset -g HISTORY_SUBSTRING_SEARCH_HIGHLIGHT_NOT_FOUND='bg=red,fg=white,bold' -typeset -g HISTORY_SUBSTRING_SEARCH_GLOBBING_FLAGS='i' -typeset -g HISTORY_SUBSTRING_SEARCH_ENSURE_UNIQUE='' -typeset -g HISTORY_SUBSTRING_SEARCH_FUZZY='' +: ${HISTORY_SUBSTRING_SEARCH_HIGHLIGHT_FOUND='bg=magenta,fg=white,bold'} +: ${HISTORY_SUBSTRING_SEARCH_HIGHLIGHT_NOT_FOUND='bg=red,fg=white,bold'} +: ${HISTORY_SUBSTRING_SEARCH_GLOBBING_FLAGS='i'} +: ${HISTORY_SUBSTRING_SEARCH_ENSURE_UNIQUE=''} +: ${HISTORY_SUBSTRING_SEARCH_FUZZY=''} +: ${HISTORY_SUBSTRING_SEARCH_PREFIXED=''} #----------------------------------------------------------------------------- # declare internal global variables @@ -64,6 +65,7 @@ typeset -g -i _history_substring_search_raw_match_index typeset -g -a _history_substring_search_matches typeset -g -i _history_substring_search_match_index typeset -g -A _history_substring_search_unique_filter +typeset -g -i _history_substring_search_zsh_5_9 #----------------------------------------------------------------------------- # the main ZLE widgets @@ -97,6 +99,11 @@ zle -N history-substring-search-down #----------------------------------------------------------------------------- zmodload -F zsh/parameter +autoload -Uz is-at-least + +if is-at-least 5.9 $ZSH_VERSION; then + _history_substring_search_zsh_5_9=1 +fi # # We have to "override" some keys and widgets if the @@ -117,80 +124,125 @@ if [[ $+functions[_zsh_highlight] -eq 0 ]]; then } # - # The following snippet was taken from the zsh-syntax-highlighting project: + # Check if $1 denotes the name of a callable function, i.e. it is fully + # defined or it is marked for autoloading and autoloading it at the first + # call to it will succeed. In particular, if $1 has been marked for + # autoloading but is not available in $fpath, then it will return 1 (false). # - # https://github.com/zsh-users/zsh-syntax-highlighting/blob/56b134f5d62ae3d4e66c7f52bd0cc2595f9b305b/zsh-syntax-highlighting.zsh#L126-161 + # This is based on the zsh-syntax-highlighting plugin. # - # Copyright (c) 2010-2011 zsh-syntax-highlighting contributors - # All rights reserved. + _history-substring-search-function-callable() { + if (( ${+functions[$1]} )) && ! [[ "$functions[$1]" == *"builtin autoload -X"* ]]; then + return 0 # already fully loaded + else + # "$1" is either an autoload stub, or not a function at all. + # We expect 'autoload +X' to return non-zero if it fails to fully load + # the function. + ( autoload -U +X -- "$1" 2>/dev/null ) + return $? + fi + } + # - # Redistribution and use in source and binary forms, with or without - # modification, are permitted provided that the following conditions are - # met: + # The zsh-syntax-highlighting plugin uses zle-line-pre-redraw hook instead + # of the legacy "bind all widgets" if 1) zsh has the memo= feature (added in + # version 5.9) and 2) add-zle-hook-widget is available. # - # * Redistributions of source code must retain the above copyright - # notice, this list of conditions and the following disclaimer. - # - # * Redistributions in binary form must reproduce the above copyright - # notice, this list of conditions and the following disclaimer in the - # documentation and/or other materials provided with the distribution. - # - # * Neither the name of the zsh-syntax-highlighting contributors nor the - # names of its contributors may be used to endorse or promote products - # derived from this software without specific prior written permission. - # - # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS - # IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, - # THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR - # PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR - # CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, - # EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, - # PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR - # PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF - # LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING - # NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS - # SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - # - #--------------8<-------------------8<-------------------8<----------------- - # Rebind all ZLE widgets to make them invoke _zsh_highlights. - _zsh_highlight_bind_widgets() - { - # Load ZSH module zsh/zleparameter, needed to override user defined widgets. - zmodload zsh/zleparameter 2>/dev/null || { - echo 'zsh-syntax-highlighting: failed loading zsh/zleparameter.' >&2 - return 1 + if [[ $_history_substring_search_zsh_5_9 -eq 1 ]] && _history-substring-search-function-callable add-zle-hook-widget; then + # + # The following code is based on the zsh-syntax-highlighting plugin. + # + autoload -U add-zle-hook-widget + + _history-substring-search-zle-line-finish() { + # + # Reset $WIDGET since the 'main' highlighter depends on it. + # + # Since $WIDGET is declared by zle as read-only in this function's scope, + # a nested function is required in order to shadow its built-in value; + # see "User-defined widgets" in zshall. + # + () { + local -h -r WIDGET=zle-line-finish + _zsh_highlight + } } - # Override ZLE widgets to make them invoke _zsh_highlight. - local cur_widget - for cur_widget in ${${(f)"$(builtin zle -la)"}:#(.*|_*|orig-*|run-help|which-command|beep|yank*)}; do - case $widgets[$cur_widget] in + _history-substring-search-zle-line-pre-redraw() { + # + # If the zsh-syntax-highlighting plugin has been loaded (after our plugin + # plugin, otherwise this hook wouldn't be called), remove our hooks. + # + if [[ $+ZSH_HIGHLIGHT_VERSION -eq 1 ]]; then + autoload -U add-zle-hook-widget + add-zle-hook-widget -d zle-line-pre-redraw _history-substring-search-zle-line-pre-redraw + add-zle-hook-widget -d zle-line-finish _history-substring-search-zle-line-finish + return 0 + fi + # + # Set $? to 0 for _zsh_highlight. Without this, subsequent + # zle-line-pre-redraw hooks won't run, since add-zle-hook-widget happens to + # call us with $? == 1 in the common case. + # + true && _zsh_highlight "$@" + } - # Already rebound event: do nothing. - user:$cur_widget|user:_zsh_highlight_widget_*);; + if [[ -o zle ]]; then + add-zle-hook-widget zle-line-pre-redraw _history-substring-search-zle-line-pre-redraw + add-zle-hook-widget zle-line-finish _history-substring-search-zle-line-finish + fi + else + # + # The following snippet was taken from the zsh-syntax-highlighting project: + # https://github.com/zsh-users/zsh-syntax-highlighting/blob/56b134f5d62ae3d4e66c7f52bd0cc2595f9b305b/zsh-syntax-highlighting.zsh#L126-161 + # + # SPDX-SnippetBegin + # SPDX-License-Identifier: BSD-3-Clause + # SPDX-SnippetCopyrightText: 2010-2011 zsh-syntax-highlighting contributors + #--------------8<-------------------8<-------------------8<----------------- + # Rebind all ZLE widgets to make them invoke _zsh_highlights. + _zsh_highlight_bind_widgets() + { + # Load ZSH module zsh/zleparameter, needed to override user defined widgets. + zmodload zsh/zleparameter 2>/dev/null || { + echo 'zsh-syntax-highlighting: failed loading zsh/zleparameter.' >&2 + return 1 + } - # User defined widget: override and rebind old one with prefix "orig-". - user:*) eval "zle -N orig-$cur_widget ${widgets[$cur_widget]#*:}; \ - _zsh_highlight_widget_$cur_widget() { builtin zle orig-$cur_widget -- \"\$@\" && _zsh_highlight }; \ - zle -N $cur_widget _zsh_highlight_widget_$cur_widget";; + # Override ZLE widgets to make them invoke _zsh_highlight. + local cur_widget + for cur_widget in ${${(f)"$(builtin zle -la)"}:#(.*|_*|orig-*|run-help|which-command|beep|yank*)}; do + case $widgets[$cur_widget] in - # Completion widget: override and rebind old one with prefix "orig-". - completion:*) eval "zle -C orig-$cur_widget ${${widgets[$cur_widget]#*:}/:/ }; \ - _zsh_highlight_widget_$cur_widget() { builtin zle orig-$cur_widget -- \"\$@\" && _zsh_highlight }; \ - zle -N $cur_widget _zsh_highlight_widget_$cur_widget";; + # Already rebound event: do nothing. + user:$cur_widget|user:_zsh_highlight_widget_*);; - # Builtin widget: override and make it call the builtin ".widget". - builtin) eval "_zsh_highlight_widget_$cur_widget() { builtin zle .$cur_widget -- \"\$@\" && _zsh_highlight }; \ - zle -N $cur_widget _zsh_highlight_widget_$cur_widget";; + # User defined widget: override and rebind old one with prefix "orig-". + user:*) eval "zle -N orig-$cur_widget ${widgets[$cur_widget]#*:}; \ + _zsh_highlight_widget_$cur_widget() { builtin zle orig-$cur_widget -- \"\$@\" && _zsh_highlight }; \ + zle -N $cur_widget _zsh_highlight_widget_$cur_widget";; - # Default: unhandled case. - *) echo "zsh-syntax-highlighting: unhandled ZLE widget '$cur_widget'" >&2 ;; - esac - done - } - #-------------->8------------------->8------------------->8----------------- + # Completion widget: override and rebind old one with prefix "orig-". + completion:*) eval "zle -C orig-$cur_widget ${${widgets[$cur_widget]#*:}/:/ }; \ + _zsh_highlight_widget_$cur_widget() { builtin zle orig-$cur_widget -- \"\$@\" && _zsh_highlight }; \ + zle -N $cur_widget _zsh_highlight_widget_$cur_widget";; - _zsh_highlight_bind_widgets + # Builtin widget: override and make it call the builtin ".widget". + builtin) eval "_zsh_highlight_widget_$cur_widget() { builtin zle .$cur_widget -- \"\$@\" && _zsh_highlight }; \ + zle -N $cur_widget _zsh_highlight_widget_$cur_widget";; + + # Default: unhandled case. + *) echo "zsh-syntax-highlighting: unhandled ZLE widget '$cur_widget'" >&2 ;; + esac + done + } + #-------------->8------------------->8------------------->8----------------- + # SPDX-SnippetEnd + + _zsh_highlight_bind_widgets + fi + + unfunction _history-substring-search-function-callable fi _history-substring-search-begin() { @@ -243,10 +295,17 @@ _history-substring-search-begin() { fi # - # Escape and join query parts with wildcard character '*' as separator - # `(j:CHAR:)` join array to string with CHAR as separator + # Escape and join query parts with wildcard character '*' as seperator + # `(j:CHAR:)` join array to string with CHAR as seperator # - local search_pattern="*${(j:*:)_history_substring_search_query_parts[@]//(#m)[\][()|\\*?#<>~^]/\\$MATCH}*" + local search_pattern="${(j:*:)_history_substring_search_query_parts[@]//(#m)[\][()|\\*?#<>~^]/\\$MATCH}*" + + # + # Support anchoring history search to the beginning of the command + # + if [[ -z $HISTORY_SUBSTRING_SEARCH_PREFIXED ]]; then + search_pattern="*${search_pattern}" + fi # # Find all occurrences of the search pattern in the history file. @@ -304,12 +363,21 @@ _history-substring-search-begin() { _history-substring-search-end() { setopt localoptions extendedglob + local highlight_memo= _history_substring_search_result=$BUFFER + if [[ $_history_substring_search_zsh_5_9 -eq 1 ]]; then + highlight_memo='memo=history-substring-search' + fi + # the search was successful so display the result properly by clearing away # existing highlights and moving the cursor to the end of the result buffer if [[ $_history_substring_search_refresh_display -eq 1 ]]; then - region_highlight=() + if [[ -n $highlight_memo ]]; then + region_highlight=( "${(@)region_highlight:#*${highlight_memo}*}" ) + else + region_highlight=() + fi CURSOR=${#BUFFER} fi @@ -329,7 +397,9 @@ _history-substring-search-end() { if [[ $query_part_match_index -le ${#BUFFER:$highlight_start_index} ]]; then highlight_start_index=$(( $highlight_start_index + $query_part_match_index )) highlight_end_index=$(( $highlight_start_index + ${#query_part} )) - region_highlight+=("$(($highlight_start_index - 1)) $(($highlight_end_index - 1)) $_history_substring_search_query_highlight") + region_highlight+=( + "$(($highlight_start_index - 1)) $(($highlight_end_index - 1)) ${_history_substring_search_query_highlight}${highlight_memo:+,$highlight_memo}" + ) fi done fi @@ -338,6 +408,23 @@ _history-substring-search-end() { # zle -R "mn: "$_history_substring_search_match_index" m#: "${#_history_substring_search_matches} # read -k -t 200 && zle -U $REPLY + # + # When this function returns, z-sy-h runs its line-pre-redraw hook. It has no + # logic for determining highlight priority, when two different memo= marked + # region highlights overlap; instead, it always prioritises itself. Below is + # a workaround for dealing with it. + # + if [[ $_history_substring_search_zsh_5_9 -eq 1 ]]; then + zle -R + # + # After line redraw with desired highlight, wait for timeout or user input + # before removing search highlight and exiting. This ensures no highlights + # are left lingering after search is finished. + # + read -k -t ${HISTORY_SUBSTRING_SEARCH_HIGHLIGHT_TIMEOUT:-1} && zle -U $REPLY + region_highlight=( "${(@)region_highlight:#*${highlight_memo}*}" ) + fi + # Exit successfully from the history-substring-search-* widgets. return 0 } From d2ffe8306a7a901569764979be917384d7e97f0f Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Tue, 16 Jan 2024 10:47:06 +0100 Subject: [PATCH 477/672] feat(history-substring-search): use new dependencies updater --- .github/dependencies.yml | 7 + .../update-from-upstream.zsh | 129 ------------------ 2 files changed, 7 insertions(+), 129 deletions(-) delete mode 100755 plugins/history-substring-search/update-from-upstream.zsh diff --git a/.github/dependencies.yml b/.github/dependencies.yml index 6d138736c..be46a7973 100644 --- a/.github/dependencies.yml +++ b/.github/dependencies.yml @@ -18,3 +18,10 @@ dependencies: set -e test -e _zshz && mv -f _zshz _z test -e zsh-z.plugin.zsh && mv -f zsh-z.plugin.zsh z.plugin.zsh + plugins/history-substring-search: + repo: zsh-users/zsh-history-substring-search + branch: master + version: 8f5d8a5aa9942da7b2a764c7fa79e0f36ba802f7 + precopy: | + set -e + test -e zsh-history-substring-search.plugin.zsh && mv zsh-history-substring-search.plugin.zsh history-substring-search.plugin.zsh diff --git a/plugins/history-substring-search/update-from-upstream.zsh b/plugins/history-substring-search/update-from-upstream.zsh deleted file mode 100755 index 81e1942a5..000000000 --- a/plugins/history-substring-search/update-from-upstream.zsh +++ /dev/null @@ -1,129 +0,0 @@ -#!/usr/bin/env zsh -# -# update-from-upstream.zsh -# -# This script updates the Oh My Zsh version of the zsh-history-substring-search -# plugin from the independent upstream repo. This is to be run by OMZ developers -# when they want to pull in new changes from upstream to OMZ. It is not run -# during normal use of the plugin. -# -# The official upstream repo is zsh-users/zsh-history-substring-search -# https://github.com/zsh-users/zsh-history-substring-search -# -# This is a zsh script, not a function. Call it with `zsh update-from-upstream.zsh` -# from the command line, running it from within the plugin directory. -# -# You can set the environment variable REPO_PATH to point it at an upstream -# repo you have already prepared. Otherwise, it will do a clean checkout of -# upstream's HEAD to a temporary local repo and use that. - - -# Just bail on any error so we don't have to do extra checking. -# This is a developer-use script, so terse output like that should -# be fine. -set -e - - -upstream_basename=zsh-history-substring-search -plugin_basename=history-substring-search -UPSTREAM_REPO=zsh-users/$upstream_basename -need_repo_cleanup=false -upstream_github_url="https://github.com/$UPSTREAM_REPO" - -if [[ -z "$UPSTREAM_REPO_PATH" ]]; then - # Do a clean checkout - my_tempdir=$(mktemp -d -t omz-update-histsubstrsrch) - UPSTREAM_REPO_PATH="$my_tempdir/$upstream_basename" - git clone "$upstream_github_url" "$UPSTREAM_REPO_PATH" - need_repo_cleanup=true - print "Checked out upstream repo to $UPSTREAM_REPO_PATH" -else - print "Using existing $upstream_basename repo at $UPSTREAM_REPO_PATH" -fi - -upstream="$UPSTREAM_REPO_PATH" - -# Figure out what we're pulling in -upstream_sha=$(cd $upstream && git rev-parse HEAD) -upstream_commit_date=$(cd $upstream && git log -1 --pretty=format:%ci) -upstream_just_date=${${=upstream_commit_date}[1]} -print "upstream SHA: $upstream_sha" -print "upstream commit time: $upstream_commit_date" -print "upstream commit date: $upstream_just_date" -print - -# Copy the files over, using the OMZ plugin's names where needed -cp -v "$upstream"/* . -mv -v zsh-history-substring-search.zsh $plugin_basename.zsh -mv -v zsh-history-substring-search.plugin.zsh $plugin_basename.plugin.zsh - -if [[ $need_repo_cleanup == true ]]; then - print "Removing temporary repo at $my_tempdir" - rm -rf "$my_tempdir" -fi - -# Do OMZ-specific edits - -print -print "Updating files with OMZ-specific stuff" -print - -# OMZ binds the keys as part of the plugin loading - -cat >> $plugin_basename.plugin.zsh <> README.md < Date: Tue, 16 Jan 2024 11:01:39 +0100 Subject: [PATCH 478/672] fix(history-substring-search): source properly plugin --- .../history-substring-search.plugin.zsh | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/plugins/history-substring-search/history-substring-search.plugin.zsh b/plugins/history-substring-search/history-substring-search.plugin.zsh index 05bdbcd75..63f0bdd42 100644 --- a/plugins/history-substring-search/history-substring-search.plugin.zsh +++ b/plugins/history-substring-search/history-substring-search.plugin.zsh @@ -1,5 +1,9 @@ -0=${(%):-%N} -source ${0:A:h}/zsh-history-substring-search.zsh +# Handle $0 according to the standard: +# https://zdharma-continuum.github.io/Zsh-100-Commits-Club/Zsh-Plugin-Standard.html +0="${${ZERO:-${0:#$ZSH_ARGZERO}}:-${(%):-%N}}" +0="${${(M)0:#/*}:-$PWD/$0}" + +source ${0:A:h}/history-substring-search.zsh # Bind terminal-specific up and down keys From d44ec1492bd46f6f0f9d6606649fee3fc11aac13 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Tue, 16 Jan 2024 11:02:07 +0100 Subject: [PATCH 479/672] ci(dependencies): create history-substring-search files as expected --- .github/dependencies.yml | 6 +++++- .../dependencies/OMZ-README.md | 19 +++++++++++++++++++ 2 files changed, 24 insertions(+), 1 deletion(-) create mode 100644 plugins/history-substring-search/dependencies/OMZ-README.md diff --git a/.github/dependencies.yml b/.github/dependencies.yml index be46a7973..f644322ff 100644 --- a/.github/dependencies.yml +++ b/.github/dependencies.yml @@ -24,4 +24,8 @@ dependencies: version: 8f5d8a5aa9942da7b2a764c7fa79e0f36ba802f7 precopy: | set -e - test -e zsh-history-substring-search.plugin.zsh && mv zsh-history-substring-search.plugin.zsh history-substring-search.plugin.zsh + rm -f zsh-history-substring-search.plugin.zsh + test -e zsh-history-substring-search.zsh && mv zsh-history-substring-search.zsh history-substring-search.zsh + postcopy: | + set -e + test -e dependencies/OMZ-README.md && cat dependencies/OMZ-README.md >> README.md diff --git a/plugins/history-substring-search/dependencies/OMZ-README.md b/plugins/history-substring-search/dependencies/OMZ-README.md new file mode 100644 index 000000000..9a2ef4d46 --- /dev/null +++ b/plugins/history-substring-search/dependencies/OMZ-README.md @@ -0,0 +1,19 @@ + +--- + +## Oh My Zsh Distribution Notes + +What you are looking at now is Oh My Zsh's repackaging of zsh-history-substring-search as an OMZ module inside +the Oh My Zsh distribution. + +The upstream repo, zsh-users/zsh-history-substring-search, can be found on GitHub at +https://github.com/zsh-users/zsh-history-substring-search. + +This downstream copy was last updated from the following upstream commit: + +SHA: 8dd05bfcc12b0cd1ee9ea64be725b3d9f713cf64 Commit date: 2023-11-23 12:12:14 +0200 + +Everything above this section is a copy of the original upstream's README, so things may differ slightly when +you're using this inside OMZ. In particular, you do not need to set up key bindings for the up and down arrows +yourself in `~/.zshrc`; the OMZ plugin does that for you. You may still want to set up additional emacs- or +vi-specific bindings as mentioned above. From c0074974313215360a9529e01204792cdf6ca473 Mon Sep 17 00:00:00 2001 From: "ohmyzsh[bot]" <54982679+ohmyzsh[bot]@users.noreply.github.com> Date: Tue, 16 Jan 2024 11:06:19 +0100 Subject: [PATCH 480/672] feat(history-substring-search): update to version 8dd05bfc (#12167) Co-authored-by: ohmyzsh[bot] <54982679+ohmyzsh[bot]@users.noreply.github.com> Co-authored-by: Carlo Sala --- .github/dependencies.yml | 2 +- plugins/history-substring-search/README.md | 27 +++++++------------ .../dependencies/OMZ-README.md | 4 --- 3 files changed, 11 insertions(+), 22 deletions(-) diff --git a/.github/dependencies.yml b/.github/dependencies.yml index f644322ff..12beaecbb 100644 --- a/.github/dependencies.yml +++ b/.github/dependencies.yml @@ -21,7 +21,7 @@ dependencies: plugins/history-substring-search: repo: zsh-users/zsh-history-substring-search branch: master - version: 8f5d8a5aa9942da7b2a764c7fa79e0f36ba802f7 + version: 8dd05bfcc12b0cd1ee9ea64be725b3d9f713cf64 precopy: | set -e rm -f zsh-history-substring-search.plugin.zsh diff --git a/plugins/history-substring-search/README.md b/plugins/history-substring-search/README.md index eee279dfd..71a389535 100644 --- a/plugins/history-substring-search/README.md +++ b/plugins/history-substring-search/README.md @@ -235,24 +235,17 @@ History * March 2016: Geza Lore (@gezalore) greatly refactored it in pull request #55. ------------------------------------------------------------------------------- -Oh My Zsh Distribution Notes ------------------------------------------------------------------------------- +--- -What you are looking at now is Oh My Zsh's repackaging of zsh-history-substring-search -as an OMZ module inside the Oh My Zsh distribution. +## Oh My Zsh Distribution Notes -The upstream repo, zsh-users/zsh-history-substring-search, can be found on GitHub at +What you are looking at now is Oh My Zsh's repackaging of zsh-history-substring-search as an OMZ module inside +the Oh My Zsh distribution. + +The upstream repo, zsh-users/zsh-history-substring-search, can be found on GitHub at https://github.com/zsh-users/zsh-history-substring-search. -This downstream copy was last updated from the following upstream commit: - - SHA: 8dd05bfcc12b0cd1ee9ea64be725b3d9f713cf64 - Commit date: 2023-11-23 12:12:14 +0200 - -Everything above this section is a copy of the original upstream's README, so things -may differ slightly when you're using this inside OMZ. In particular, you do not -need to set up key bindings for the up and down arrows yourself in `~/.zshrc`; the OMZ -plugin does that for you. You may still want to set up additional emacs- or vi-specific -bindings as mentioned above. - +Everything above this section is a copy of the original upstream's README, so things may differ slightly when +you're using this inside OMZ. In particular, you do not need to set up key bindings for the up and down arrows +yourself in `~/.zshrc`; the OMZ plugin does that for you. You may still want to set up additional emacs- or +vi-specific bindings as mentioned above. diff --git a/plugins/history-substring-search/dependencies/OMZ-README.md b/plugins/history-substring-search/dependencies/OMZ-README.md index 9a2ef4d46..c5967bb7d 100644 --- a/plugins/history-substring-search/dependencies/OMZ-README.md +++ b/plugins/history-substring-search/dependencies/OMZ-README.md @@ -9,10 +9,6 @@ the Oh My Zsh distribution. The upstream repo, zsh-users/zsh-history-substring-search, can be found on GitHub at https://github.com/zsh-users/zsh-history-substring-search. -This downstream copy was last updated from the following upstream commit: - -SHA: 8dd05bfcc12b0cd1ee9ea64be725b3d9f713cf64 Commit date: 2023-11-23 12:12:14 +0200 - Everything above this section is a copy of the original upstream's README, so things may differ slightly when you're using this inside OMZ. In particular, you do not need to set up key bindings for the up and down arrows yourself in `~/.zshrc`; the OMZ plugin does that for you. You may still want to set up additional emacs- or From c6ce22f1d221ea99e0d63edb445038a747c78884 Mon Sep 17 00:00:00 2001 From: Ali Sajid Imami <395482+AliSajid@users.noreply.github.com> Date: Wed, 17 Jan 2024 10:50:23 -0500 Subject: [PATCH 481/672] feat(vscode): add `vscp` alias (#12092) Co-authored-by: Carlo Sala --- plugins/vscode/README.md | 28 +++++++++++++++++----------- plugins/vscode/vscode.plugin.zsh | 2 ++ 2 files changed, 19 insertions(+), 11 deletions(-) diff --git a/plugins/vscode/README.md b/plugins/vscode/README.md index 726b23d35..f91b533c9 100644 --- a/plugins/vscode/README.md +++ b/plugins/vscode/README.md @@ -1,6 +1,7 @@ # VS Code -This plugin provides useful aliases to simplify the interaction between the command line and VS Code or VSCodium editor. +This plugin provides useful aliases to simplify the interaction between the command line and VS Code or +VSCodium editor. To start using it, add the `vscode` plugin to your `plugins` array in `~/.zshrc`: @@ -14,26 +15,30 @@ This plugin requires to have a flavour of VS Code installed and it's executable You can install either: -* VS Code (code) -* VS Code Insiders (code-insiders) -* VSCodium (codium) +- VS Code (code) +- VS Code Insiders (code-insiders) +- VSCodium (codium) ### MacOS + While Linux installations will add the executable to PATH, MacOS users might still have to do this manually: -[For VS Code and VS Code Insiders](https://code.visualstudio.com/docs/setup/mac#_launching-from-the-command-line), open -the Command Palette via (F1 or ⇧⌘P) and type shell command to find the Shell Command: +[For VS Code and VS Code Insiders](https://code.visualstudio.com/docs/setup/mac#_launching-from-the-command-line), +open the Command Palette via (F1 or ⇧⌘P) and type shell command to find the Shell Command: + > Shell Command: Install 'code' command in PATH -[For VSCodium](https://github.com/VSCodium/vscodium/blob/master/DOCS.md#how-do-i-open-vscodium-from-the-terminal), open -the Command Palette via (F1 or ⇧⌘P) and type shell command to find the Shell Command: +[For VSCodium](https://github.com/VSCodium/vscodium/blob/master/DOCS.md#how-do-i-open-vscodium-from-the-terminal), +open the Command Palette via (F1 or ⇧⌘P) and type shell command to find the Shell Command: + > Shell Command: Install 'codium' command in PATH ## Using multiple flavours -If for any reason, you ever require to use multiple flavours of VS Code i.e. VS Code (stable) and VS Code Insiders, you can -manually specify the flavour's executable. Add the following line to the .zshrc file (between the `ZSH_THEME` and the `plugins=()` lines). -This will make the plugin use your manually defined executable. +If for any reason, you ever require to use multiple flavours of VS Code i.e. VS Code (stable) and VS Code +Insiders, you can manually specify the flavour's executable. Add the following line to the .zshrc file +(between the `ZSH_THEME` and the `plugins=()` lines). This will make the plugin use your manually defined +executable. ```zsh ZSH_THEME=... @@ -61,6 +66,7 @@ source $ZSH/oh-my-zsh.sh | vscr | code --reuse-window | Force to open a file or folder in the last active window. | | vscw | code --wait | Wait for the files to be closed before returning. | | vscu `dir` | code --user-data-dir `dir` | Specifies the directory that user data is kept in. Can be used to open multiple distinct instances of Code. | +| vscp `profile` | code --profile `profile` | Specifies the profile to open Code with. | ## Extensions aliases diff --git a/plugins/vscode/vscode.plugin.zsh b/plugins/vscode/vscode.plugin.zsh index 356c62360..77367bcac 100644 --- a/plugins/vscode/vscode.plugin.zsh +++ b/plugins/vscode/vscode.plugin.zsh @@ -3,6 +3,7 @@ # https://github.com/MarsiBarsi (original author) # https://github.com/babakks # https://github.com/SteelShot +# https://github.com/AliSajid # Verify if any manual user choice of VS Code exists first. if [[ -n "$VSCODE" ]] && ! which $VSCODE &>/dev/null; then @@ -38,6 +39,7 @@ alias vscn="$VSCODE --new-window" alias vscr="$VSCODE --reuse-window" alias vscw="$VSCODE --wait" alias vscu="$VSCODE --user-data-dir" +alias vscp="$VSCODE --profile" alias vsced="$VSCODE --extensions-dir" alias vscie="$VSCODE --install-extension" From 486e56aba890e143dd02265bcd05ae32751eb55b Mon Sep 17 00:00:00 2001 From: Brian McKenna Date: Thu, 18 Jan 2024 03:09:43 +1100 Subject: [PATCH 482/672] feat(autojump): add path for nix per-user (#11935) Co-authored-by: Carlo Sala --- plugins/autojump/autojump.plugin.zsh | 27 ++++++++++++++------------- 1 file changed, 14 insertions(+), 13 deletions(-) diff --git a/plugins/autojump/autojump.plugin.zsh b/plugins/autojump/autojump.plugin.zsh index 1b868ee8d..84333a89f 100644 --- a/plugins/autojump/autojump.plugin.zsh +++ b/plugins/autojump/autojump.plugin.zsh @@ -1,18 +1,19 @@ declare -a autojump_paths autojump_paths=( - $HOME/.autojump/etc/profile.d/autojump.zsh # manual installation - $HOME/.autojump/share/autojump/autojump.zsh # manual installation - $HOME/.nix-profile/etc/profile.d/autojump.sh # NixOS installation - /run/current-system/sw/share/autojump/autojump.zsh # NixOS installation - /usr/share/autojump/autojump.zsh # Debian and Ubuntu package - /etc/profile.d/autojump.zsh # manual installation - /etc/profile.d/autojump.sh # Gentoo installation - /usr/local/share/autojump/autojump.zsh # FreeBSD installation - /usr/pkg/share/autojump/autojump.zsh # NetBSD installation - /opt/local/etc/profile.d/autojump.sh # macOS with MacPorts - /usr/local/etc/profile.d/autojump.sh # macOS with Homebrew (default) - /opt/homebrew/etc/profile.d/autojump.sh # macOS with Homebrew (default on M1 macs) - /etc/profiles/per-user/$USER/etc/profile.d/autojump.sh # macOS Nix, Home Manager and flakes + $HOME/.autojump/etc/profile.d/autojump.zsh # manual installation + $HOME/.autojump/share/autojump/autojump.zsh # manual installation + $HOME/.nix-profile/etc/profile.d/autojump.sh # NixOS installation + /run/current-system/sw/share/autojump/autojump.zsh # NixOS installation + /etc/profiles/per-user/$USER/share/autojump/autojump.zsh # Home Manager, NixOS with user-scoped packages + /usr/share/autojump/autojump.zsh # Debian and Ubuntu package + /etc/profile.d/autojump.zsh # manual installation + /etc/profile.d/autojump.sh # Gentoo installation + /usr/local/share/autojump/autojump.zsh # FreeBSD installation + /usr/pkg/share/autojump/autojump.zsh # NetBSD installation + /opt/local/etc/profile.d/autojump.sh # macOS with MacPorts + /usr/local/etc/profile.d/autojump.sh # macOS with Homebrew (default) + /opt/homebrew/etc/profile.d/autojump.sh # macOS with Homebrew (default on M1 macs) + /etc/profiles/per-user/$USER/etc/profile.d/autojump.sh # macOS Nix, Home Manager and flakes ) for file in $autojump_paths; do From d43f03ba91c47934a40b436a6ea9e79449a4583a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?J=C3=BAlio=20Selva?= Date: Thu, 18 Jan 2024 15:34:30 -0300 Subject: [PATCH 483/672] feat(virtualenvwrapper): run function on startup (#12163) --- plugins/virtualenvwrapper/virtualenvwrapper.plugin.zsh | 1 + 1 file changed, 1 insertion(+) diff --git a/plugins/virtualenvwrapper/virtualenvwrapper.plugin.zsh b/plugins/virtualenvwrapper/virtualenvwrapper.plugin.zsh index d359e0c21..e037241e4 100644 --- a/plugins/virtualenvwrapper/virtualenvwrapper.plugin.zsh +++ b/plugins/virtualenvwrapper/virtualenvwrapper.plugin.zsh @@ -88,4 +88,5 @@ if [[ ! $DISABLE_VENV_CD -eq 1 ]]; then # http://zsh.sourceforge.net/Doc/Release/Functions.html autoload -U add-zsh-hook add-zsh-hook chpwd workon_cwd + [[ $PWD != ~ ]] && workon_cwd fi From f7b647e1b13ed9cd2f34f3559c112e61b8c03108 Mon Sep 17 00:00:00 2001 From: Michal Date: Sun, 21 Jan 2024 05:25:50 +0100 Subject: [PATCH 484/672] feat(spectrum): add `FX[dim]` format (#12172) --- lib/spectrum.zsh | 1 + 1 file changed, 1 insertion(+) diff --git a/lib/spectrum.zsh b/lib/spectrum.zsh index 97f5c360a..31e37792c 100644 --- a/lib/spectrum.zsh +++ b/lib/spectrum.zsh @@ -7,6 +7,7 @@ typeset -AHg FX FG BG FX=( reset "%{%}" bold "%{%}" no-bold "%{%}" + dim "%{%}" no-dim "%{%}" italic "%{%}" no-italic "%{%}" underline "%{%}" no-underline "%{%}" blink "%{%}" no-blink "%{%}" From e656377d36077b0ca757d995c9c35f0fea7c7fdd Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Wed, 24 Jan 2024 10:10:55 +0100 Subject: [PATCH 485/672] fix(web-search): encode spaces as `%20` --- plugins/web-search/web-search.plugin.zsh | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/plugins/web-search/web-search.plugin.zsh b/plugins/web-search/web-search.plugin.zsh index 1b42abe86..0fa2852dc 100644 --- a/plugins/web-search/web-search.plugin.zsh +++ b/plugins/web-search/web-search.plugin.zsh @@ -37,9 +37,14 @@ function web_search() { # search or go to main page depending on number of arguments passed if [[ $# -gt 1 ]]; then + # if search goes in the query string ==> space as +, otherwise %20 + # see https://stackoverflow.com/questions/1634271/url-encoding-the-space-character-or-20 + local param="-P" + [[ "$urls[$1]" =~ .*\?.*=$ ]] && param="" + # build search url: # join arguments passed with '+', then append to search engine URL - url="${urls[$1]}$(omz_urlencode ${@[2,-1]})" + url="${urls[$1]}$(omz_urlencode $param ${@[2,-1]})" else # build main page url: # split by '/', then rejoin protocol (1) and domain (2) parts with '//' From 652037ebdfbe581e4c7dfcd0862ac2d1577c86d9 Mon Sep 17 00:00:00 2001 From: ditzy Date: Thu, 25 Jan 2024 03:19:01 -0600 Subject: [PATCH 486/672] fix(jump)!: only resolve mark symlink (#11074) BREAKING CHANGE: Previously, `jump` would resolve the symlink to the mark directory and resolve again if the mark directory was also a symlink. It only resolves once after this commit. --- plugins/jump/jump.plugin.zsh | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/plugins/jump/jump.plugin.zsh b/plugins/jump/jump.plugin.zsh index 829c9d9cb..c2b21e92e 100644 --- a/plugins/jump/jump.plugin.zsh +++ b/plugins/jump/jump.plugin.zsh @@ -8,8 +8,10 @@ # export MARKPATH=$HOME/.marks + jump() { - builtin cd -P "$MARKPATH/$1" 2>/dev/null || {echo "No such mark: $1"; return 1} + local markpath="$(readlink $MARKPATH/$1)" || {echo "No such mark: $1"; return 1} + builtin cd "$markpath" 2>/dev/null || {echo "Destination does not exist for mark [$1]: $markpath"; return 2} } mark() { From 80c114cb3a64044ea50b623f96a35bc022db5e8d Mon Sep 17 00:00:00 2001 From: Eemil Lagerspetz Date: Thu, 25 Jan 2024 10:23:07 +0100 Subject: [PATCH 487/672] fix(awesomepanda): new line wrap Closes #5982 Co-authored-by: Carlo Sala --- themes/awesomepanda.zsh-theme | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/themes/awesomepanda.zsh-theme b/themes/awesomepanda.zsh-theme index 85036e4ac..000697397 100644 --- a/themes/awesomepanda.zsh-theme +++ b/themes/awesomepanda.zsh-theme @@ -1,6 +1,6 @@ # the svn plugin has to be activated for this to work. local ret_status="%(?:%{$fg_bold[green]%}➜ :%{$fg_bold[red]%}➜ %s)" -PROMPT='${ret_status}%{$fg_bold[green]%} %{$fg[cyan]%}%c %{$fg_bold[blue]%}$(git_prompt_info)%{$fg_bold[blue]%}$(svn_prompt_info)%{$reset_color%}' +PROMPT='%{${ret_status}%}%{$fg_bold[green]%} %{$fg[cyan]%}%c %{$fg_bold[blue]%}$(git_prompt_info)%{$fg_bold[blue]%}$(svn_prompt_info)%{$reset_color%}' ZSH_THEME_GIT_PROMPT_PREFIX="git:(%{$fg[red]%}" ZSH_THEME_GIT_PROMPT_SUFFIX="%{$reset_color%}" From 8b2ce98578da743fbc4a208285f33744d6abd3cf Mon Sep 17 00:00:00 2001 From: Frank Dana Date: Tue, 30 Jan 2024 05:43:03 -0500 Subject: [PATCH 488/672] feat(ssh): add plugin (#12186) Closes #2707 Co-authored-by: Frank Wittig Co-authored-by: Frank Wittig --- plugins/ssh/ssh.plugin.zsh | 46 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 46 insertions(+) create mode 100644 plugins/ssh/ssh.plugin.zsh diff --git a/plugins/ssh/ssh.plugin.zsh b/plugins/ssh/ssh.plugin.zsh new file mode 100644 index 000000000..085e71fa1 --- /dev/null +++ b/plugins/ssh/ssh.plugin.zsh @@ -0,0 +1,46 @@ +############################################################ +# Take all host sections in .ssh/config and offer them for +# completion as hosts (e.g. for ssh, rsync, scp and the like) +# Filter out wildcard host sections. +_ssh_configfile="$HOME/.ssh/config" +if [[ -f "$_ssh_configfile" ]]; then + _hosts=($(egrep '^Host.*' "$_ssh_configfile" | awk '{print $2}' | grep -v '^*' | sed -e 's/\.*\*$//')) + zstyle ':completion:*:hosts' hosts $_hosts + unset _hosts +fi +unset _ssh_configfile + +############################################################ +# Remove host key from known hosts based on a host section +# name from .ssh/config +function ssh_rmhkey { + local ssh_configfile="$HOME/.ssh/config" + local ssh_host="$1" + if [[ -z "$ssh_host" ]]; then return; fi + ssh-keygen -R $(grep -A10 "$ssh_host" "$ssh_configfile" | grep -i HostName | head -n 1 | awk '{print $2}') +} +compctl -k hosts ssh_rmhkey + +############################################################ +# Load SSH key into agent +function ssh_load_key() { + local key="$1" + if [[ -z "$key" ]]; then return; fi + local keyfile="$HOME/.ssh/$key" + local keysig=$(ssh-keygen -l -f "$keyfile") + if ( ! ssh-add -l | grep -q "$keysig" ); then + ssh-add "$keyfile" + fi +} + +############################################################ +# Remove SSH key from agent +function ssh_unload_key { + local key="$1" + if [[ -z "$key" ]]; then return; fi + local keyfile="$HOME/.ssh/$key" + local keysig=$(ssh-keygen -l -f "$keyfile") + if ( ssh-add -l | grep -q "$keysig" ); then + ssh-add -d "$keyfile" + fi +} From e195c7cb438224e8bcea20bdbc2e4b8a6bb3949b Mon Sep 17 00:00:00 2001 From: Gauthier Delacroix <1533042+gdlx@users.noreply.github.com> Date: Tue, 30 Jan 2024 21:36:18 +0100 Subject: [PATCH 489/672] fix(aws): pass default region to fetch regions (#12175) Co-authored-by: Gauthier Delacroix --- plugins/aws/aws.plugin.zsh | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/plugins/aws/aws.plugin.zsh b/plugins/aws/aws.plugin.zsh index fd00714e7..7a2e08a7c 100644 --- a/plugins/aws/aws.plugin.zsh +++ b/plugins/aws/aws.plugin.zsh @@ -202,8 +202,17 @@ function aws_change_access_key() { } function aws_regions() { + local region + if [[ $AWS_DEFAULT_REGION ]];then + region="$AWS_DEFAULT_REGION" + elif [[ $AWS_REGION ]];then + region="$AWS_REGION" + else + region="us-west-1" + fi + if [[ $AWS_DEFAULT_PROFILE || $AWS_PROFILE ]];then - aws ec2 describe-regions |grep RegionName | awk -F ':' '{gsub(/"/, "", $2);gsub(/,/, "", $2);gsub(/ /, "", $2); print $2}' + aws ec2 describe-regions --region $region |grep RegionName | awk -F ':' '{gsub(/"/, "", $2);gsub(/,/, "", $2);gsub(/ /, "", $2); print $2}' else echo "You must specify a AWS profile." fi From 4efad7ab1ba0d1715af62e484c6852808581cfb9 Mon Sep 17 00:00:00 2001 From: Rejman Nascimento <72097727+rejmann@users.noreply.github.com> Date: Thu, 1 Feb 2024 12:54:24 -0300 Subject: [PATCH 490/672] feat(git-commit): add `wip` kind (#12188) --- plugins/git-commit/README.md | 4 +++- plugins/git-commit/git-commit.plugin.zsh | 1 + 2 files changed, 4 insertions(+), 1 deletion(-) diff --git a/plugins/git-commit/README.md b/plugins/git-commit/README.md index 91cc73b44..a00983935 100644 --- a/plugins/git-commit/README.md +++ b/plugins/git-commit/README.md @@ -29,8 +29,9 @@ Where `type` is one of the following: - `rev` - `style` - `test` +- `wip` -> NOTE: the alias for `revert` type is `rev`, as otherwise it conflicts with the git command of the same name. +> NOTE: the alias for `revert` type is `rev`, as otherwise it conflicts with the git command of the same name. > It will still generate a commit message in the format `revert: ` ## Examples @@ -38,5 +39,6 @@ Where `type` is one of the following: | Git alias | Command | | --------------------------------------------- | ---------------------------------------------------- | | `git style "remove trailing whitespace"` | `git commit -m "style: remove trailing whitespace"` | +| `git wip "work in progress"` | `git commit -m "work in progress"` | | `git fix -s "router" "correct redirect link"` | `git commit -m "fix(router): correct redirect link"` | | `git rev -s "api" "rollback v2"` | `git commit -m "revert(api): rollback v2"` | diff --git a/plugins/git-commit/git-commit.plugin.zsh b/plugins/git-commit/git-commit.plugin.zsh index 72cecb1d6..3f0c2121d 100644 --- a/plugins/git-commit/git-commit.plugin.zsh +++ b/plugins/git-commit/git-commit.plugin.zsh @@ -11,6 +11,7 @@ _git_commit_aliases=( 'revert' 'style' 'test' + 'wip' ) local alias type From 6f215cd6922a76cf8ac6f629d0de386c3eb6667a Mon Sep 17 00:00:00 2001 From: Harkesh <100549064+harkeshbirman@users.noreply.github.com> Date: Thu, 1 Feb 2024 21:30:27 +0530 Subject: [PATCH 491/672] feat(git): add `grf` alias (#12176) --- plugins/git/README.md | 1 + plugins/git/git.plugin.zsh | 1 + 2 files changed, 2 insertions(+) diff --git a/plugins/git/README.md b/plugins/git/README.md index be3f85827..4acb0c858 100644 --- a/plugins/git/README.md +++ b/plugins/git/README.md @@ -152,6 +152,7 @@ plugins=(... git) | `grbd` | `git rebase $(git_develop_branch)` | | `grbm` | `git rebase $(git_main_branch)` | | `grbom` | `git rebase origin/$(git_main_branch)` | +| `grf` | `git reflog` | | `gr` | `git remote` | | `grv` | `git remote --verbose` | | `gra` | `git remote add` | diff --git a/plugins/git/git.plugin.zsh b/plugins/git/git.plugin.zsh index 5c3064e8a..692a36a73 100644 --- a/plugins/git/git.plugin.zsh +++ b/plugins/git/git.plugin.zsh @@ -335,6 +335,7 @@ alias grbs='git rebase --skip' alias grbd='git rebase $(git_develop_branch)' alias grbm='git rebase $(git_main_branch)' alias grbom='git rebase origin/$(git_main_branch)' +alias grf='git reflog' alias gr='git remote' alias grv='git remote --verbose' alias gra='git remote add' From 05bf69c604e34300b02406462d4376c86d595470 Mon Sep 17 00:00:00 2001 From: 0rxa Date: Thu, 1 Feb 2024 17:11:13 +0100 Subject: [PATCH 492/672] feat(aws): implement permanent state (#12018) Co-authored-by: Rei Arifi Co-authored-by: Hysen Ndregjoni --- plugins/aws/README.md | 5 +++++ plugins/aws/aws.plugin.zsh | 36 ++++++++++++++++++++++++++++++++++++ 2 files changed, 41 insertions(+) diff --git a/plugins/aws/README.md b/plugins/aws/README.md index dbf8dcfeb..0d0773f63 100644 --- a/plugins/aws/README.md +++ b/plugins/aws/README.md @@ -47,6 +47,11 @@ plugins=(... aws) Some themes might overwrite the value of RPROMPT instead of appending to it, so they'll need to be fixed to see the AWS profile/region prompt. +* Set `AWS_PROFILE_STATE_ENABLED=true` in your zshrc file if you want the aws profile to persist between shell sessions. + This option might slow down your shell startup time. + By default the state file path is `/tmp/.aws_current_profile`. This means that the state won't survive a reboot or otherwise GC. + You can control the state file path using the `AWS_STATE_FILE` environment variable. + ## Theme The plugin creates an `aws_prompt_info` function that you can use in your theme, which displays diff --git a/plugins/aws/aws.plugin.zsh b/plugins/aws/aws.plugin.zsh index 7a2e08a7c..071dd1f0b 100644 --- a/plugins/aws/aws.plugin.zsh +++ b/plugins/aws/aws.plugin.zsh @@ -6,10 +6,26 @@ function agr() { echo $AWS_REGION } +# Update state file if enabled +function _aws_update_state() { + if [[ "$AWS_PROFILE_STATE_ENABLED" == true ]]; then + test -d $(dirname ${AWS_STATE_FILE}) || exit 1 + echo "${AWS_PROFILE} ${AWS_REGION}" > "${AWS_STATE_FILE}" + fi +} + +function _aws_clear_state() { + if [[ "$AWS_PROFILE_STATE_ENABLED" == true ]]; then + test -d $(dirname ${AWS_STATE_FILE}) || exit 1 + echo -n > "${AWS_STATE_FILE}" + fi +} + # AWS profile selection function asp() { if [[ -z "$1" ]]; then unset AWS_DEFAULT_PROFILE AWS_PROFILE AWS_EB_PROFILE AWS_PROFILE_REGION + _aws_clear_state echo AWS profile cleared. return fi @@ -28,6 +44,8 @@ function asp() { export AWS_PROFILE_REGION=$(aws configure get region) + _aws_update_state + if [[ "$2" == "login" ]]; then if [[ -n "$3" ]]; then aws sso login --sso-session $3 @@ -43,6 +61,7 @@ function asp() { function asr() { if [[ -z "$1" ]]; then unset AWS_DEFAULT_REGION AWS_REGION + _aws_update_state echo AWS region cleared. return fi @@ -56,6 +75,7 @@ function asr() { export AWS_REGION=$1 export AWS_DEFAULT_REGION=$1 + _aws_update_state } # AWS profile switch @@ -255,6 +275,22 @@ if [[ "$SHOW_AWS_PROMPT" != false && "$RPROMPT" != *'$(aws_prompt_info)'* ]]; th RPROMPT='$(aws_prompt_info)'"$RPROMPT" fi +if [[ "$AWS_PROFILE_STATE_ENABLED" == true ]]; then + AWS_STATE_FILE="${AWS_STATE_FILE:-/tmp/.aws_current_profile}" + test -s "${AWS_STATE_FILE}" || return + + aws_state=($(cat $AWS_STATE_FILE)) + + export AWS_DEFAULT_PROFILE="${aws_state[1]}" + export AWS_PROFILE="$AWS_DEFAULT_PROFILE" + export AWS_EB_PROFILE="$AWS_DEFAULT_PROFILE" + + test -z "${aws_state[2]}" && AWS_REGION=$(aws configure get region) + + export AWS_REGION=${AWS_REGION:-$aws_state[2]} + export AWS_DEFAULT_REGION="$AWS_REGION" +fi + # Load awscli completions # AWS CLI v2 comes with its own autocompletion. Check if that is there, otherwise fall back From d6658f9af321e615a9b8be696f557a113cd6b026 Mon Sep 17 00:00:00 2001 From: Eric Schultz Date: Thu, 1 Feb 2024 10:16:34 -0600 Subject: [PATCH 493/672] feat(stripe): add completion plugin (#12064) Co-authored-by: Carlo Sala --- plugins/stripe/README.md | 9 +++++++++ plugins/stripe/stripe.plugin.zsh | 13 +++++++++++++ 2 files changed, 22 insertions(+) create mode 100644 plugins/stripe/README.md create mode 100644 plugins/stripe/stripe.plugin.zsh diff --git a/plugins/stripe/README.md b/plugins/stripe/README.md new file mode 100644 index 000000000..9f0f32bc2 --- /dev/null +++ b/plugins/stripe/README.md @@ -0,0 +1,9 @@ +# Struoe + +This plugin provides completion for the [Stripe CLI](https://stripe.com/docs/stripe-cli). + +To use it add stripe to the plugins array in your zshrc file. + +```bash +plugins=(... stripe) +``` diff --git a/plugins/stripe/stripe.plugin.zsh b/plugins/stripe/stripe.plugin.zsh new file mode 100644 index 000000000..e2041bef2 --- /dev/null +++ b/plugins/stripe/stripe.plugin.zsh @@ -0,0 +1,13 @@ +if (( ! $+commands[stripe] )); then + return +fi + +# If the completion file doesn't exist yet, we need to autoload it and +# bind it to `stripe`. Otherwise, compinit will have already done that. +if [[ ! -f "$ZSH_CACHE_DIR/completions/_stripe" ]]; then + typeset -g -A _comps + autoload -Uz _stripe + _comps[stripe]=_stripe +fi + +stripe completion --shell zsh --write-to-stdout >| "$ZSH_CACHE_DIR/completions/_stripe" &| From b5e6392f2140b7aa49c248aa6c232a6922d3311b Mon Sep 17 00:00:00 2001 From: Markus Hofbauer Date: Thu, 1 Feb 2024 17:37:37 +0100 Subject: [PATCH 494/672] feat(hazel): add some aliases (#12070) --- plugins/bazel/README.md | 12 ++++++++++-- plugins/bazel/bazel.plugin.zsh | 5 +++++ 2 files changed, 15 insertions(+), 2 deletions(-) create mode 100644 plugins/bazel/bazel.plugin.zsh diff --git a/plugins/bazel/README.md b/plugins/bazel/README.md index fc375d219..eba4175bc 100644 --- a/plugins/bazel/README.md +++ b/plugins/bazel/README.md @@ -1,7 +1,6 @@ # Bazel plugin -This plugin adds completion for [bazel](https://bazel.build), an open-source build and -test tool that scalably supports multi-language and multi-platform projects. +This plugin adds completion and aliases for [bazel](https://bazel.build), an open-source build and test tool that scalably supports multi-language and multi-platform projects. To use it, add `bazel` to the plugins array in your zshrc file: @@ -12,3 +11,12 @@ plugins=(... bazel) The plugin has a copy of [the completion script from the git repository][1]. [1]: https://github.com/bazelbuild/bazel/blob/master/scripts/zsh_completion/_bazel + +## Aliases + +| Alias | Command | Description | +| ------- | -------------------------------------- | ------------------------------------------------------ | +| bzb | `bazel build` | The `bazel build` command | +| bzt | `bazel test` | The `bazel test` command | +| bzr | `bazel run` | The `bazel run` command | +| bzq | `bazel query` | The `bazel query` command | diff --git a/plugins/bazel/bazel.plugin.zsh b/plugins/bazel/bazel.plugin.zsh new file mode 100644 index 000000000..d239a06b5 --- /dev/null +++ b/plugins/bazel/bazel.plugin.zsh @@ -0,0 +1,5 @@ +# Aliases for bazel +alias bzb='bazel build' +alias bzt='bazel test' +alias bzr='bazel run' +alias bzq='bazel query' From 69b0dfeadf35a6da8de41501149cf3a3817218cf Mon Sep 17 00:00:00 2001 From: lutra <49721741+lutra@users.noreply.github.com> Date: Fri, 2 Feb 2024 17:12:36 +0100 Subject: [PATCH 495/672] fix(kubectx): k8s contexts with spaces (#12191) --- plugins/kubectx/kubectx.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/kubectx/kubectx.plugin.zsh b/plugins/kubectx/kubectx.plugin.zsh index 6096feeae..a3210facc 100644 --- a/plugins/kubectx/kubectx.plugin.zsh +++ b/plugins/kubectx/kubectx.plugin.zsh @@ -9,5 +9,5 @@ function kubectx_prompt_info() { # use value in associative array if it exists # otherwise fall back to the context name - echo "${kubectx_mapping[$current_ctx]:-${current_ctx:gs/%/%%}}" + echo "${kubectx_mapping[\"$current_ctx\"]:-${current_ctx:gs/%/%%}}" } From bebd9ea59f6f5ed629b659dc1f230ac71b1fd1a8 Mon Sep 17 00:00:00 2001 From: Markus Hofbauer Date: Sat, 3 Feb 2024 10:18:33 +0100 Subject: [PATCH 496/672] chore(brew): remove duplicated alias (#12192) --- plugins/brew/brew.plugin.zsh | 1 - 1 file changed, 1 deletion(-) diff --git a/plugins/brew/brew.plugin.zsh b/plugins/brew/brew.plugin.zsh index 447036376..b15137e0f 100644 --- a/plugins/brew/brew.plugin.zsh +++ b/plugins/brew/brew.plugin.zsh @@ -36,7 +36,6 @@ fi alias bcubc='brew upgrade --cask && brew cleanup' alias bcubo='brew update && brew outdated --cask' -alias bcubc='brew upgrade --cask && brew cleanup' alias brewp='brew pin' alias brewsp='brew list --pinned' alias bubc='brew upgrade && brew cleanup' From 70bf12402ceb5599f209bd687d4ee9d9dbf1776a Mon Sep 17 00:00:00 2001 From: Taylor Cochran Date: Sat, 3 Feb 2024 13:50:44 -0800 Subject: [PATCH 497/672] fix(prompt): quote ruby prompt (#12195) --- lib/prompt_info_functions.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/prompt_info_functions.zsh b/lib/prompt_info_functions.zsh index 3dc9b6d10..29aca9b48 100644 --- a/lib/prompt_info_functions.zsh +++ b/lib/prompt_info_functions.zsh @@ -40,5 +40,5 @@ ZSH_THEME_RVM_PROMPT_OPTIONS="i v g" # use this to enable users to see their ruby version, no matter which # version management system they use function ruby_prompt_info() { - echo $(rvm_prompt_info || rbenv_prompt_info || chruby_prompt_info) + echo "$(rvm_prompt_info || rbenv_prompt_info || chruby_prompt_info)" } From 212437090032ea1c8c7ccbc1bc2937083c2e7185 Mon Sep 17 00:00:00 2001 From: Rayzeq Date: Sun, 4 Feb 2024 18:21:31 +0100 Subject: [PATCH 498/672] fix(sublime): pass user's env to `sst` (#12194) --- plugins/sublime/sublime.plugin.zsh | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/plugins/sublime/sublime.plugin.zsh b/plugins/sublime/sublime.plugin.zsh index dadf37574..cc84de737 100644 --- a/plugins/sublime/sublime.plugin.zsh +++ b/plugins/sublime/sublime.plugin.zsh @@ -4,7 +4,7 @@ alias st=subl alias stt='subl .' # Define sst only if sudo exists -(( $+commands[sudo] )) && alias sst='sudo subl' +(( $+commands[sudo] )) && alias sst='sudo -EH subl' alias stp=find_project alias stn=create_project @@ -62,7 +62,7 @@ alias stn=create_project for _sublime_path in $_sublime_paths; do if [[ -a $_sublime_path ]]; then alias subl="'$_sublime_path'" - (( $+commands[sudo] )) && alias sst="sudo '$_sublime_path'" + (( $+commands[sudo] )) && alias sst="sudo -EH '$_sublime_path'" break fi done From 883da63320806532f3d3246b03f934e15aff3bab Mon Sep 17 00:00:00 2001 From: Mateus Fernandes de Mello Date: Tue, 6 Feb 2024 07:26:30 -0300 Subject: [PATCH 499/672] feat(web-search): add programming packages search (#12199) --- plugins/web-search/README.md | 4 ++++ plugins/web-search/web-search.plugin.zsh | 8 ++++++++ 2 files changed, 12 insertions(+) diff --git a/plugins/web-search/README.md b/plugins/web-search/README.md index cf5bab3f7..d21c81ca9 100644 --- a/plugins/web-search/README.md +++ b/plugins/web-search/README.md @@ -46,6 +46,10 @@ Available search contexts are: | `ask` | `https://www.ask.com/web?q=` | | `youtube` | `https://www.youtube.com/results?search_query=` | | `deepl` | `https://www.deepl.com/translator#auto/auto/` | +| `dockerhub` | `https://hub.docker.com/search?q=` | +| `npmpkg` | `https://www.npmjs.com/search?q=` | +| `packagist` | `https://packagist.org/?query=` | +| `gopkg` | `https://pkg.go.dev/search?m=package&q=` | Also there are aliases for bang-searching DuckDuckGo: diff --git a/plugins/web-search/web-search.plugin.zsh b/plugins/web-search/web-search.plugin.zsh index 0fa2852dc..2fe4aea84 100644 --- a/plugins/web-search/web-search.plugin.zsh +++ b/plugins/web-search/web-search.plugin.zsh @@ -27,6 +27,10 @@ function web_search() { ask "https://www.ask.com/web?q=" youtube "https://www.youtube.com/results?search_query=" deepl "https://www.deepl.com/translator#auto/auto/" + dockerhub "https://hub.docker.com/search?q=" + npmpkg "https://www.npmjs.com/search?q=" + packagist "https://packagist.org/?query=" + gopkg "https://pkg.go.dev/search?m=package&q=" ) # check whether the search engine is supported @@ -75,6 +79,10 @@ alias scholar='web_search scholar' alias ask='web_search ask' alias youtube='web_search youtube' alias deepl='web_search deepl' +alias dockerhub='web_search dockerhub' +alias npmpkg='web_search npmpkg' +alias packagist='web_search packagist' +alias gopkg='web_search gopkg' #add your own !bang searches here alias wiki='web_search duckduckgo \!w' From 43613d7b710f9a06971fac48dea3301bbc15b579 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Wed, 7 Feb 2024 11:16:36 +0100 Subject: [PATCH 500/672] fix(web-search): use pattern instead of regex Closes #12202 --- plugins/web-search/web-search.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/web-search/web-search.plugin.zsh b/plugins/web-search/web-search.plugin.zsh index 2fe4aea84..c602e0623 100644 --- a/plugins/web-search/web-search.plugin.zsh +++ b/plugins/web-search/web-search.plugin.zsh @@ -44,7 +44,7 @@ function web_search() { # if search goes in the query string ==> space as +, otherwise %20 # see https://stackoverflow.com/questions/1634271/url-encoding-the-space-character-or-20 local param="-P" - [[ "$urls[$1]" =~ .*\?.*=$ ]] && param="" + [[ "$urls[$1]" == *\?*= ]] && param="" # build search url: # join arguments passed with '+', then append to search engine URL From fff073b55defed72a0a1aac4e853b165f208735b Mon Sep 17 00:00:00 2001 From: vladislav doster <10052309+vladdoster@users.noreply.github.com> Date: Thu, 8 Feb 2024 08:41:34 -0600 Subject: [PATCH 501/672] style(completion): remove extra space (#12206) --- lib/completion.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/completion.zsh b/lib/completion.zsh index 63379b53f..5a233a322 100644 --- a/lib/completion.zsh +++ b/lib/completion.zsh @@ -49,7 +49,7 @@ zstyle ':completion:*:*:*:users' ignored-patterns \ adm amanda apache at avahi avahi-autoipd beaglidx bin cacti canna \ clamav daemon dbus distcache dnsmasq dovecot fax ftp games gdm \ gkrellmd gopher hacluster haldaemon halt hsqldb ident junkbust kdm \ - ldap lp mail mailman mailnull man messagebus mldonkey mysql nagios \ + ldap lp mail mailman mailnull man messagebus mldonkey mysql nagios \ named netdump news nfsnobody nobody nscd ntp nut nx obsrun openvpn \ operator pcap polkitd postfix postgres privoxy pulse pvm quagga radvd \ rpc rpcuser rpm rtkit scard shutdown squid sshd statd svn sync tftp \ From bdcb4d9d1f36d5d82720dfd53f0c95242ab62dae Mon Sep 17 00:00:00 2001 From: SgtDaJim Date: Mon, 12 Feb 2024 16:43:52 +0800 Subject: [PATCH 502/672] feat(bira): add support for `kube-ps1` prompt (#8437) --- themes/bira.zsh-theme | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/themes/bira.zsh-theme b/themes/bira.zsh-theme index 42a70a018..f909afa62 100644 --- a/themes/bira.zsh-theme +++ b/themes/bira.zsh-theme @@ -6,10 +6,15 @@ local current_dir="%B%{$fg[blue]%}%~ %{$reset_color%}" local vcs_branch='$(git_prompt_info)$(hg_prompt_info)' local rvm_ruby='$(ruby_prompt_info)' local venv_prompt='$(virtualenv_prompt_info)' +if [[ "${plugins[@]}" =~ 'kube-ps1' ]]; then + local kube_prompt='$(kube_ps1)' +else + local kube_prompt='' +fi ZSH_THEME_RVM_PROMPT_OPTIONS="i v g" -PROMPT="╭─${user_host}${current_dir}${rvm_ruby}${vcs_branch}${venv_prompt} +PROMPT="╭─${user_host}${current_dir}${rvm_ruby}${vcs_branch}${venv_prompt}${kube_prompt} ╰─%B${user_symbol}%b " RPROMPT="%B${return_code}%b" From 8f22370af8bd390ea3b8610da1ccf388826d909d Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Mon, 12 Feb 2024 09:48:38 +0100 Subject: [PATCH 503/672] fix(key-bindings): bind default arrow keys to `beginning-search` Fixes #12197 --- lib/key-bindings.zsh | 21 ++++++++++++++------- 1 file changed, 14 insertions(+), 7 deletions(-) diff --git a/lib/key-bindings.zsh b/lib/key-bindings.zsh index aaa73046e..a5650dd81 100644 --- a/lib/key-bindings.zsh +++ b/lib/key-bindings.zsh @@ -32,19 +32,26 @@ if [[ -n "${terminfo[knp]}" ]]; then fi # Start typing + [Up-Arrow] - fuzzy find history forward -if [[ -n "${terminfo[kcuu1]}" ]]; then - autoload -U up-line-or-beginning-search - zle -N up-line-or-beginning-search +autoload -U up-line-or-beginning-search +zle -N up-line-or-beginning-search +bindkey -M emacs "^[[A" up-line-or-beginning-search +bindkey -M viins "^[[A" up-line-or-beginning-search +bindkey -M vicmd "^[[A" up-line-or-beginning-search +if [[ -n "${terminfo[kcuu1]}" ]]; then bindkey -M emacs "${terminfo[kcuu1]}" up-line-or-beginning-search bindkey -M viins "${terminfo[kcuu1]}" up-line-or-beginning-search bindkey -M vicmd "${terminfo[kcuu1]}" up-line-or-beginning-search fi -# Start typing + [Down-Arrow] - fuzzy find history backward -if [[ -n "${terminfo[kcud1]}" ]]; then - autoload -U down-line-or-beginning-search - zle -N down-line-or-beginning-search +# Start typing + [Down-Arrow] - fuzzy find history backward +autoload -U down-line-or-beginning-search +zle -N down-line-or-beginning-search + +bindkey -M emacs "^[[B" down-line-or-beginning-search +bindkey -M viins "^[[B" down-line-or-beginning-search +bindkey -M vicmd "^[[B" down-line-or-beginning-search +if [[ -n "${terminfo[kcud1]}" ]]; then bindkey -M emacs "${terminfo[kcud1]}" down-line-or-beginning-search bindkey -M viins "${terminfo[kcud1]}" down-line-or-beginning-search bindkey -M vicmd "${terminfo[kcud1]}" down-line-or-beginning-search From 514d5736ea7b1af2cb2e6617048236aa9b34fc51 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Tue, 13 Feb 2024 17:25:16 +0100 Subject: [PATCH 504/672] ci: enable dependabot --- .github/dependabot.yml | 12 ++++++++++++ 1 file changed, 12 insertions(+) create mode 100644 .github/dependabot.yml diff --git a/.github/dependabot.yml b/.github/dependabot.yml new file mode 100644 index 000000000..4dc9f3854 --- /dev/null +++ b/.github/dependabot.yml @@ -0,0 +1,12 @@ +version: 2 +updates: + - package-ecosystem: github-actions + directory: / + schedule: + interval: "weekly" + day: "sunday" + - package-ecosystem: "pip" + directory: "/.github/workflows/dependencies" + schedule: + interval: "weekly" + day: "sunday" From f9bbf6047b35ff00ea398857d2a09ffea5cd8bfa Mon Sep 17 00:00:00 2001 From: Raphael Boidol Date: Tue, 13 Feb 2024 17:32:44 +0100 Subject: [PATCH 505/672] ci: bump `actions/checkout` version (#12210) --- .github/workflows/installer.yml | 4 ++-- .github/workflows/main.yml | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/.github/workflows/installer.yml b/.github/workflows/installer.yml index cad5d445b..5593c9175 100644 --- a/.github/workflows/installer.yml +++ b/.github/workflows/installer.yml @@ -26,7 +26,7 @@ jobs: - macos-latest steps: - name: Set up git repository - uses: actions/checkout@v3 + uses: actions/checkout@v4 - name: Install zsh if: runner.os == 'Linux' run: sudo apt-get update; sudo apt-get install zsh @@ -42,7 +42,7 @@ jobs: - test steps: - name: Checkout - uses: actions/checkout@v3 + uses: actions/checkout@v4 - name: Install Vercel CLI run: npm install -g vercel - name: Setup project and deploy diff --git a/.github/workflows/main.yml b/.github/workflows/main.yml index de7d98262..264ac31f3 100644 --- a/.github/workflows/main.yml +++ b/.github/workflows/main.yml @@ -24,7 +24,7 @@ jobs: if: github.repository == 'ohmyzsh/ohmyzsh' steps: - name: Set up git repository - uses: actions/checkout@v3 + uses: actions/checkout@v4 - name: Install zsh run: sudo apt-get update; sudo apt-get install zsh - name: Check syntax From 872b5cd4086a5547dbf788dda4e96ab3868cf59b Mon Sep 17 00:00:00 2001 From: Frederik Ring Date: Wed, 14 Feb 2024 12:14:08 +0100 Subject: [PATCH 506/672] docs(kubectx): add quoting to array keys (#12216) --- plugins/kubectx/README.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/plugins/kubectx/README.md b/plugins/kubectx/README.md index 98f1cf032..d924e745c 100644 --- a/plugins/kubectx/README.md +++ b/plugins/kubectx/README.md @@ -17,9 +17,9 @@ One can rename default context name for better readability. _Example_. Add to **.zshrc**: ``` -kubectx_mapping[minikube]="mini" -kubectx_mapping[context_name_from_kubeconfig]="$emoji[wolf_face]" -kubectx_mapping[production_cluster]="%{$fg[yellow]%}prod!%{$reset_color%}" +kubectx_mapping["minikube"]="mini" +kubectx_mapping["context_name_from_kubeconfig"]="$emoji[wolf_face]" +kubectx_mapping["production_cluster"]="%{$fg[yellow]%}prod!%{$reset_color%}" ``` ![staging](stage.png) From 15ffbdd346daa58de6701d3421787012420aa6cc Mon Sep 17 00:00:00 2001 From: Julian <489233+naydichev@users.noreply.github.com> Date: Mon, 19 Feb 2024 10:29:37 +0100 Subject: [PATCH 507/672] feat(zoxide): add option to override cmd (#12218) --- plugins/zoxide/README.md | 3 +++ plugins/zoxide/zoxide.plugin.zsh | 2 +- 2 files changed, 4 insertions(+), 1 deletion(-) diff --git a/plugins/zoxide/README.md b/plugins/zoxide/README.md index f326effe6..45f77bdf5 100644 --- a/plugins/zoxide/README.md +++ b/plugins/zoxide/README.md @@ -10,5 +10,8 @@ To use it, add `zoxide` to the plugins array in your `.zshrc` file: ```zsh plugins=(... zoxide) ``` +## Overriding `z` Alias + +You can set the `ZOXIDE_CMD_OVERRIDE`, which will be passed to the `--cmd` flag of `zoxide init`. This allows you to set your `z` command to a default of `cd`. **Note:** you have to [install zoxide](https://github.com/ajeetdsouza/zoxide#step-1-install-zoxide) first. diff --git a/plugins/zoxide/zoxide.plugin.zsh b/plugins/zoxide/zoxide.plugin.zsh index e5658b8f0..25d2e8377 100644 --- a/plugins/zoxide/zoxide.plugin.zsh +++ b/plugins/zoxide/zoxide.plugin.zsh @@ -1,5 +1,5 @@ if (( $+commands[zoxide] )); then - eval "$(zoxide init zsh)" + eval "$(zoxide init --cmd ${ZOXIDE_CMD_OVERRIDE:-z} zsh)" else echo '[oh-my-zsh] zoxide not found, please install it from https://github.com/ajeetdsouza/zoxide' fi From 40ff950fcd081078a8cd3de0eaab784f85c681d5 Mon Sep 17 00:00:00 2001 From: Oren Date: Tue, 20 Feb 2024 11:59:12 +0200 Subject: [PATCH 508/672] fix(docker): support completion on snap installs (#12224) --- plugins/docker/docker.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/docker/docker.plugin.zsh b/plugins/docker/docker.plugin.zsh index 7e657f2df..b429ae211 100644 --- a/plugins/docker/docker.plugin.zsh +++ b/plugins/docker/docker.plugin.zsh @@ -57,6 +57,6 @@ fi ! is-at-least 23.0.0 ${${(s:,:z)"$(command docker --version)"}[3]}; then command cp "${0:h}/completions/_docker" "$ZSH_CACHE_DIR/completions/_docker" else - command docker completion zsh >| "$ZSH_CACHE_DIR/completions/_docker" + command docker completion zsh | tee "$ZSH_CACHE_DIR/completions/_docker" > /dev/null fi } &| From fcab8f161139d04fb1137be815d8130584a99713 Mon Sep 17 00:00:00 2001 From: Juan Morete Date: Fri, 23 Feb 2024 11:25:53 +0100 Subject: [PATCH 509/672] docs(ansible): remove duplicated alias entry (#12235) --- plugins/ansible/README.md | 1 - 1 file changed, 1 deletion(-) diff --git a/plugins/ansible/README.md b/plugins/ansible/README.md index e0e6a19bb..ce21e7075 100644 --- a/plugins/ansible/README.md +++ b/plugins/ansible/README.md @@ -21,7 +21,6 @@ plugins=(... ansible) | `acon` | command `ansible-console` | | `ainv` | command `ansible-inventory` | | `aplaybook` | command `ansible-playbook` | -| `ainv` | command `ansible-inventory` | | `adoc` | command `ansible-doc` | | `agal` | command `ansible-galaxy` | | `apull` | command `ansible-pull` | From c891b7e6ada5427f4c8cca05c8ed1ae33cb49943 Mon Sep 17 00:00:00 2001 From: Dusk Date: Tue, 27 Feb 2024 15:09:02 -0400 Subject: [PATCH 510/672] feat(tmux): add option for detached mode (#12242) --- plugins/tmux/README.md | 15 ++++++++------- plugins/tmux/tmux.plugin.zsh | 6 ++++-- 2 files changed, 12 insertions(+), 9 deletions(-) diff --git a/plugins/tmux/README.md b/plugins/tmux/README.md index b4516ef26..a253457f2 100644 --- a/plugins/tmux/README.md +++ b/plugins/tmux/README.md @@ -19,13 +19,13 @@ The plugin also supports the following: | ---------- | -------------------------- | -------------------------------------------------------- | | `ta` | tmux attach -t | Attach new tmux session to already running named session | | `tad` | tmux attach -d -t | Detach named tmux session | -| `ts` | tmux new-session -s | Create a new named tmux session | -| `tl` | tmux list-sessions | Displays a list of running tmux sessions | -| `tksv` | tmux kill-server | Terminate all running tmux sessions | +| `tds` | `_tmux_directory_session` | Creates or attaches to a session for the current path | | `tkss` | tmux kill-session -t | Terminate named running tmux session | +| `tksv` | tmux kill-server | Terminate all running tmux sessions | +| `tl` | tmux list-sessions | Displays a list of running tmux sessions | | `tmux` | `_zsh_tmux_plugin_run` | Start a new tmux session | | `tmuxconf` | `$EDITOR $ZSH_TMUX_CONFIG` | Open .tmux.conf file with an editor | -| `tds` | `_tmux_directory_session` | Creates or attaches to a session for the current path | +| `ts` | tmux new-session -s | Create a new named tmux session | ## Configuration Variables @@ -35,10 +35,11 @@ The plugin also supports the following: | `ZSH_TMUX_AUTOSTART_ONCE` | Autostart only if tmux hasn't been started previously (default: `true`) | | `ZSH_TMUX_AUTOCONNECT` | Automatically connect to a previous session if it exits (default: `true`) | | `ZSH_TMUX_AUTOQUIT` | Automatically closes terminal once tmux exits (default: `ZSH_TMUX_AUTOSTART`) | +| `ZSH_TMUX_CONFIG` | Set the configuration path (default: `$HOME/.tmux.conf`, `$XDG_CONFIG_HOME/tmux/tmux.conf`) | +| `ZSH_TMUX_DEFAULT_SESSION_NAME` | Set tmux default session name when autostart is enabled | +| `ZSH_TMUX_DETACHED` | Set the detached mode (default: `false`) | | `ZSH_TMUX_FIXTERM` | Sets `$TERM` to 256-color term or not based on current terminal support | -| `ZSH_TMUX_ITERM2` | Sets the `-CC` option for iTerm2 tmux integration (default: `false`) | | `ZSH_TMUX_FIXTERM_WITHOUT_256COLOR` | `$TERM` to use for non 256-color terminals (default: `screen`) | | `ZSH_TMUX_FIXTERM_WITH_256COLOR` | `$TERM` to use for 256-color terminals (default: `screen-256color` | -| `ZSH_TMUX_CONFIG` | Set the configuration path (default: `$HOME/.tmux.conf`, `$XDG_CONFIG_HOME/tmux/tmux.conf`) | +| `ZSH_TMUX_ITERM2` | Sets the `-CC` option for iTerm2 tmux integration (default: `false`) | | `ZSH_TMUX_UNICODE` | Set `tmux -u` option to support unicode | -| `ZSH_TMUX_DEFAULT_SESSION_NAME` | Set tmux default session name when autostart is enabled | diff --git a/plugins/tmux/tmux.plugin.zsh b/plugins/tmux/tmux.plugin.zsh index 72cdd4818..0ecb0a5b5 100644 --- a/plugins/tmux/tmux.plugin.zsh +++ b/plugins/tmux/tmux.plugin.zsh @@ -14,6 +14,8 @@ fi # Automatically close the terminal when tmux exits : ${ZSH_TMUX_AUTOQUIT:=$ZSH_TMUX_AUTOSTART} # Set term to screen or screen-256color based on current terminal support +: ${ZSH_TMUX_DETACHED:=false} +# Set detached mode : ${ZSH_TMUX_FIXTERM:=true} # Set '-CC' option for iTerm2 tmux integration : ${ZSH_TMUX_ITERM2:=false} @@ -79,9 +81,9 @@ function _zsh_tmux_plugin_run() { # Try to connect to an existing session. if [[ -n "$ZSH_TMUX_DEFAULT_SESSION_NAME" ]]; then - [[ "$ZSH_TMUX_AUTOCONNECT" == "true" ]] && $tmux_cmd attach -t $ZSH_TMUX_DEFAULT_SESSION_NAME + [[ "$ZSH_TMUX_AUTOCONNECT" == "true" ]] && $tmux_cmd attach ${ZSH_TMUX_DETACHED:+"-d"} -t $ZSH_TMUX_DEFAULT_SESSION_NAME else - [[ "$ZSH_TMUX_AUTOCONNECT" == "true" ]] && $tmux_cmd attach + [[ "$ZSH_TMUX_AUTOCONNECT" == "true" ]] && $tmux_cmd attach ${ZSH_TMUX_DETACHED:+"-d"} fi # If failed, just run tmux, fixing the TERM variable if requested. From 51bf9fc2def19f1d3059c15059df21ddddb518fd Mon Sep 17 00:00:00 2001 From: Pandu E POLUAN Date: Wed, 28 Feb 2024 16:52:09 +0700 Subject: [PATCH 511/672] feat(tmux): prioritize `tmux` terminfo (#12243) Co-authored-by: Carlo Sala --- plugins/tmux/README.md | 32 ++++++++++++++++---------------- plugins/tmux/tmux.plugin.zsh | 16 ++++++++++++---- 2 files changed, 28 insertions(+), 20 deletions(-) diff --git a/plugins/tmux/README.md b/plugins/tmux/README.md index a253457f2..50f8b2c2f 100644 --- a/plugins/tmux/README.md +++ b/plugins/tmux/README.md @@ -1,7 +1,7 @@ # tmux -This plugin provides aliases for [tmux](https://tmux.github.io/), the terminal multiplexer. -To use it add `tmux` to the plugins array in your zshrc file. +This plugin provides aliases for [tmux](https://tmux.github.io/), the terminal multiplexer. To use it add +`tmux` to the plugins array in your zshrc file. ```zsh plugins=(... tmux) @@ -29,17 +29,17 @@ The plugin also supports the following: ## Configuration Variables -| Variable | Description | -| ----------------------------------- | ------------------------------------------------------------------------------------------- | -| `ZSH_TMUX_AUTOSTART` | Automatically starts tmux (default: `false`) | -| `ZSH_TMUX_AUTOSTART_ONCE` | Autostart only if tmux hasn't been started previously (default: `true`) | -| `ZSH_TMUX_AUTOCONNECT` | Automatically connect to a previous session if it exits (default: `true`) | -| `ZSH_TMUX_AUTOQUIT` | Automatically closes terminal once tmux exits (default: `ZSH_TMUX_AUTOSTART`) | -| `ZSH_TMUX_CONFIG` | Set the configuration path (default: `$HOME/.tmux.conf`, `$XDG_CONFIG_HOME/tmux/tmux.conf`) | -| `ZSH_TMUX_DEFAULT_SESSION_NAME` | Set tmux default session name when autostart is enabled | -| `ZSH_TMUX_DETACHED` | Set the detached mode (default: `false`) | -| `ZSH_TMUX_FIXTERM` | Sets `$TERM` to 256-color term or not based on current terminal support | -| `ZSH_TMUX_FIXTERM_WITHOUT_256COLOR` | `$TERM` to use for non 256-color terminals (default: `screen`) | -| `ZSH_TMUX_FIXTERM_WITH_256COLOR` | `$TERM` to use for 256-color terminals (default: `screen-256color` | -| `ZSH_TMUX_ITERM2` | Sets the `-CC` option for iTerm2 tmux integration (default: `false`) | -| `ZSH_TMUX_UNICODE` | Set `tmux -u` option to support unicode | +| Variable | Description | +| ----------------------------------- | ----------------------------------------------------------------------------------------------------------- | +| `ZSH_TMUX_AUTOSTART` | Automatically starts tmux (default: `false`) | +| `ZSH_TMUX_AUTOSTART_ONCE` | Autostart only if tmux hasn't been started previously (default: `true`) | +| `ZSH_TMUX_AUTOCONNECT` | Automatically connect to a previous session if it exits (default: `true`) | +| `ZSH_TMUX_AUTOQUIT` | Automatically closes terminal once tmux exits (default: `ZSH_TMUX_AUTOSTART`) | +| `ZSH_TMUX_CONFIG` | Set the configuration path (default: `$HOME/.tmux.conf`, `$XDG_CONFIG_HOME/tmux/tmux.conf`) | +| `ZSH_TMUX_DEFAULT_SESSION_NAME` | Set tmux default session name when autostart is enabled | +| `ZSH_TMUX_DETACHED` | Set the detached mode (default: `false`) | +| `ZSH_TMUX_FIXTERM` | Sets `$TERM` to 256-color term or not based on current terminal support | +| `ZSH_TMUX_FIXTERM_WITHOUT_256COLOR` | `$TERM` to use for non 256-color terminals (default: `tmux` if available, `screen` otherwise) | +| `ZSH_TMUX_FIXTERM_WITH_256COLOR` | `$TERM` to use for 256-color terminals (default: `tmux-256color` if available, `screen-256color` otherwise) | +| `ZSH_TMUX_ITERM2` | Sets the `-CC` option for iTerm2 tmux integration (default: `false`) | +| `ZSH_TMUX_UNICODE` | Set `tmux -u` option to support unicode | diff --git a/plugins/tmux/tmux.plugin.zsh b/plugins/tmux/tmux.plugin.zsh index 0ecb0a5b5..09e326344 100644 --- a/plugins/tmux/tmux.plugin.zsh +++ b/plugins/tmux/tmux.plugin.zsh @@ -20,13 +20,21 @@ fi # Set '-CC' option for iTerm2 tmux integration : ${ZSH_TMUX_ITERM2:=false} # The TERM to use for non-256 color terminals. -# Tmux states this should be screen, but you may need to change it on +# Tmux states this should be tmux|screen, but you may need to change it on # systems without the proper terminfo -: ${ZSH_TMUX_FIXTERM_WITHOUT_256COLOR:=screen} +if [[ -e /usr/share/terminfo/t/tmux ]]; then + : ${ZSH_TMUX_FIXTERM_WITHOUT_256COLOR:=tmux} +else + : ${ZSH_TMUX_FIXTERM_WITHOUT_256COLOR:=screen} +fi # The TERM to use for 256 color terminals. -# Tmux states this should be screen-256color, but you may need to change it on +# Tmux states this should be (tmux|screen)-256color, but you may need to change it on # systems without the proper terminfo -: ${ZSH_TMUX_FIXTERM_WITH_256COLOR:=screen-256color} +if [[ -e /usr/share/terminfo/t/tmux-256color ]]; then + : ${ZSH_TMUX_FIXTERM_WITH_256COLOR:=tmux-256color} +else + : ${ZSH_TMUX_FIXTERM_WITH_256COLOR:=screen-256color} +fi # Set the configuration path if [[ -e $HOME/.tmux.conf ]]; then : ${ZSH_TMUX_CONFIG:=$HOME/.tmux.conf} From 6a65ac90259d87f7549c581372403405ef01b7d2 Mon Sep 17 00:00:00 2001 From: Pandu E POLUAN Date: Thu, 29 Feb 2024 15:40:40 +0700 Subject: [PATCH 512/672] feat(eza): create plugin (#12237) Co-authored-by: Carlo Sala --- .github/CODEOWNERS | 5 +- plugins/eza/README.md | 101 +++++++++++++++++++++++++++++++++++++ plugins/eza/eza.plugin.zsh | 62 +++++++++++++++++++++++ 3 files changed, 166 insertions(+), 2 deletions(-) create mode 100644 plugins/eza/README.md create mode 100644 plugins/eza/eza.plugin.zsh diff --git a/.github/CODEOWNERS b/.github/CODEOWNERS index 0c5f3acee..361ed624b 100644 --- a/.github/CODEOWNERS +++ b/.github/CODEOWNERS @@ -1,13 +1,14 @@ # Plugin owners plugins/archlinux/ @ratijas +plugins/dbt/ @msempere +plugins/eza/ @pepoluan plugins/genpass/ @atoponce plugins/git-lfs/ @hellovietduc plugins/gitfast/ @felipec plugins/react-native @esthor plugins/sdk/ @rgoldberg plugins/shell-proxy/ @septs +plugins/starship/ @axieax plugins/universalarchive/ @Konfekt plugins/wp-cli/ @joshmedeski plugins/zoxide/ @ajeetdsouza -plugins/starship/ @axieax -plugins/dbt/ @msempere diff --git a/plugins/eza/README.md b/plugins/eza/README.md new file mode 100644 index 000000000..5de935c2c --- /dev/null +++ b/plugins/eza/README.md @@ -0,0 +1,101 @@ +# eza plugin + +This provides aliases that invoke the [`eza`](https://github.com/eza-community/eza) utility rather than `ls` + +To use it add `eza` to the plugins array in your zshrc file: + +```zsh +plugins=(... eza) +``` + +## Configuration + +All configurations are done using the `zstyle` command in the `:omz:plugins:eza` namespace. + +**NOTE:** The configuring needs to be done prior to OMZ loading the plugins. When the plugin is loaded, +changing the `zstyle` won't have any effect. + +### `dirs-first` + +```zsh +zstyle ':omz:plugins:eza' 'dirs-first' yes|no +``` + +If `yes`, directories will be grouped first. + +Default: `no` + +### `git-status` + +```zsh +zstyle ':omz:plugins:eza' 'git-status' yes|no +``` + +If `yes`, always add `--git` flag to indicate git status (if tracked / in a git repo). + +Default: `no` + +### `header` + +```zsh +zstyle ':omz:plugins:eza' 'header' yes|no +``` + +If `yes`, always add `-h` flag to add a header row for each column. + +Default: `no` + +### `show-group` + +```zsh +zstyle ':omz:plugins:eza' 'show-group' yes|no +``` + +If `yes` (default), always add `-g` flag to show the group ownership. + +Default: `yes` + +### `size-prefix` + +```zsh +zstyle ':omz:plugins:eza' 'size-prefix' (binary|none|si) +``` + +Choose the prefix to be used in displaying file size: + +- `binary` -- use [binary prefixes](https://en.wikipedia.org/wiki/Binary_prefix) such as "Ki", "Mi", "Gi" and + so on +- `none` -- don't use any prefix, show size in bytes +- `si` (default) -- use [Metric/S.I. prefixes](https://en.wikipedia.org/wiki/Metric_prefix) + +Default: `si` + +### `time-style` + +```zsh +zstyle ':omz:plugins:eza' 'time-style' $TIME_STYLE +``` + +Sets the `--time-style` option of `eza`. (See `man eza` for the options) + +Default: Not set, which means the default behavior of `eza` will take place. + +## Aliases + +**Notes:** + +- Aliases may be modified by Configuration +- The term "files" without "only" qualifier means both files & directories + +| Alias | Command | Description | +| ------ | ----------------- | -------------------------------------------------------------------------- | +| `la` | `eza -la` | List all files (except . and ..) as a long list | +| `ldot` | `eza -ld .*` | List dotfiles only (directories shown as entries instead of recursed into) | +| `lD` | `eza -lD` | List only directories (excluding dotdirs) as a long list | +| `lDD` | `eza -laD` | List only directories (including dotdirs) as a long list | +| `ll` | `eza -l` | List files as a long list | +| `ls` | `eza` | Plain eza call | +| `lsd` | `eza -d` | List specified files with directories as entries, in a grid | +| `lsdl` | `eza -dl` | List specified files with directories as entries, in a long list | +| `lS` | `eza -l -ssize` | List files as a long list, sorted by size | +| `lT` | `eza -l -snewest` | List files as a long list, sorted by date (newest last) | diff --git a/plugins/eza/eza.plugin.zsh b/plugins/eza/eza.plugin.zsh new file mode 100644 index 000000000..6d7f720bd --- /dev/null +++ b/plugins/eza/eza.plugin.zsh @@ -0,0 +1,62 @@ +if ! (( $+commands[eza] )); then + print "zsh eza plugin: eza not found. Please install eza before using this plugin." >&2 + return 1 +fi + +typeset -a _EZA_HEAD +typeset -a _EZA_TAIL + +function _configure_eza() { + local _val + # Get the head flags + if zstyle -T ':omz:plugins:eza' 'show-group'; then + _EZA_HEAD+=("g") + fi + if zstyle -t ':omz:plugins:eza' 'header'; then + _EZA_HEAD+=("h") + fi + zstyle -s ':omz:plugins:eza' 'size-prefix' _val + case "${_val:l}" in + binary) + _EZA_HEAD+=("b") + ;; + none) + _EZA_HEAD+=("B") + ;; + esac + # Get the tail long-options + if zstyle -t ':omz:plugins:eza' 'dirs-first'; then + _EZA_TAIL+=("--group-directories-first") + fi + if zstyle -t ':omz:plugins:eza' 'git-status'; then + _EZA_TAIL+=("--git") + fi + zstyle -s ':omz:plugins:eza' 'time-style' _val + if [[ $_val ]]; then + _EZA_TAIL+=("--time-style='$_val'") + fi +} + +_configure_eza + +function _alias_eza() { + local _head="${(j::)_EZA_HEAD}$2" + local _tail="${(j: :)_EZA_TAIL}" + alias "$1"="eza${_head:+ -}${_head}${_tail:+ }${_tail}${3:+ }$3" +} + +_alias_eza la la +_alias_eza ldot ld ".*" +_alias_eza lD lD +_alias_eza lDD lDa +_alias_eza ll l +_alias_eza ls +_alias_eza lsd d +_alias_eza lsdl dl +_alias_eza lS "l -ssize" +_alias_eza lT "l -snewest" + +unfunction _alias_eza +unfunction _configure_eza +unset _EZA_HEAD +unset _EZA_TAIL From 65b23a3328bfd7ddf3234de4538fa7c3e9644491 Mon Sep 17 00:00:00 2001 From: Jonathan De Troye Date: Thu, 29 Feb 2024 13:05:54 -0500 Subject: [PATCH 513/672] fix(tmux): do not pass empty flags to aliases (#12232) This enables compatibility with tmux >3.3a Co-authored-by: Carlo Sala --- plugins/tmux/tmux.plugin.zsh | 23 ++++++++++++++++++----- 1 file changed, 18 insertions(+), 5 deletions(-) diff --git a/plugins/tmux/tmux.plugin.zsh b/plugins/tmux/tmux.plugin.zsh index 09e326344..436e2671d 100644 --- a/plugins/tmux/tmux.plugin.zsh +++ b/plugins/tmux/tmux.plugin.zsh @@ -47,14 +47,27 @@ fi : ${ZSH_TMUX_UNICODE:=false} # ALIASES -alias ta='tmux attach -t' -alias tad='tmux attach -d -t' -alias ts='tmux new-session -s' -alias tl='tmux list-sessions' +function _build_tmux_alias { + eval "function $1 { + if [[ -z \$1 ]] || [[ \${1::1} == '-' ]]; then + tmux $2 \"\$@\" + else + tmux $2 $3 \"\$@\" + fi + }" +} + alias tksv='tmux kill-server' -alias tkss='tmux kill-session -t' +alias tl='tmux list-sessions' alias tmuxconf='$EDITOR $ZSH_TMUX_CONFIG' +_build_tmux_alias "ta" "attach" "-t" +_build_tmux_alias "tad" "attach -d" "-t" +_build_tmux_alias "ts" "new-session" "-s" +_build_tmux_alias "tkss" "kill-session" "-t" + +unfunction _build_tmux_alias + # Determine if the terminal supports 256 colors if [[ $terminfo[colors] == 256 ]]; then export ZSH_TMUX_TERM=$ZSH_TMUX_FIXTERM_WITH_256COLOR From 50fd98e5a6c9d7c36b0cc678f577f7ce1d181bea Mon Sep 17 00:00:00 2001 From: Gam <1348187+Y3K@users.noreply.github.com> Date: Thu, 29 Feb 2024 14:59:27 -0600 Subject: [PATCH 514/672] fix(ssh): allow multiple definitions per host (#12227) --- plugins/ssh/ssh.plugin.zsh | 13 ++++++++++--- 1 file changed, 10 insertions(+), 3 deletions(-) diff --git a/plugins/ssh/ssh.plugin.zsh b/plugins/ssh/ssh.plugin.zsh index 085e71fa1..b5b050536 100644 --- a/plugins/ssh/ssh.plugin.zsh +++ b/plugins/ssh/ssh.plugin.zsh @@ -4,9 +4,16 @@ # Filter out wildcard host sections. _ssh_configfile="$HOME/.ssh/config" if [[ -f "$_ssh_configfile" ]]; then - _hosts=($(egrep '^Host.*' "$_ssh_configfile" | awk '{print $2}' | grep -v '^*' | sed -e 's/\.*\*$//')) - zstyle ':completion:*:hosts' hosts $_hosts - unset _hosts + _ssh_hosts=($( + egrep '^Host.*' "$_ssh_configfile" |\ + awk '{for (i=2; i<=NF; i++) print $i}' |\ + sort |\ + uniq |\ + grep -v '^*' |\ + sed -e 's/\.*\*$//' + )) + zstyle ':completion:*:hosts' hosts $_ssh_hosts + unset _ssh_hosts fi unset _ssh_configfile From 9730915910c6cc7640f8af6063ffb93becf0414a Mon Sep 17 00:00:00 2001 From: Artem Babii Date: Thu, 29 Feb 2024 23:07:10 +0200 Subject: [PATCH 515/672] feat(kube-ps1): add symlink support (#12208) --- plugins/kube-ps1/README.md | 1 + plugins/kube-ps1/kube-ps1.plugin.zsh | 27 ++++++++++++++++++++------- 2 files changed, 21 insertions(+), 7 deletions(-) diff --git a/plugins/kube-ps1/README.md b/plugins/kube-ps1/README.md index 1ed3e4438..dd49eff39 100644 --- a/plugins/kube-ps1/README.md +++ b/plugins/kube-ps1/README.md @@ -136,6 +136,7 @@ the following environment variables: | `KUBE_PS1_SUFFIX` | `)` | Prompt closing character | | `KUBE_PS1_CLUSTER_FUNCTION` | No default, must be user supplied | Function to customize how cluster is displayed | | `KUBE_PS1_NAMESPACE_FUNCTION` | No default, must be user supplied | Function to customize how namespace is displayed | +| `KUBE_PS1_KUBECONFIG_SYMLINK` | `false` | Treat `KUBECONFIG` and `~/.kube/config` files as symbolic links | For terminals that do not support UTF-8, the symbol will be replaced with the string `k8s`. diff --git a/plugins/kube-ps1/kube-ps1.plugin.zsh b/plugins/kube-ps1/kube-ps1.plugin.zsh index 894e0f7f0..7edc62de8 100644 --- a/plugins/kube-ps1/kube-ps1.plugin.zsh +++ b/plugins/kube-ps1/kube-ps1.plugin.zsh @@ -40,6 +40,7 @@ KUBE_PS1_NS_COLOR="${KUBE_PS1_NS_COLOR-cyan}" KUBE_PS1_BG_COLOR="${KUBE_PS1_BG_COLOR}" KUBE_PS1_KUBECONFIG_CACHE="${KUBECONFIG}" +KUBE_PS1_KUBECONFIG_SYMLINK="${KUBE_PS1_KUBECONFIG_SYMLINK:-false}" KUBE_PS1_DISABLE_PATH="${HOME}/.kube/kube-ps1/disabled" KUBE_PS1_LAST_TIME=0 KUBE_PS1_CLUSTER_FUNCTION="${KUBE_PS1_CLUSTER_FUNCTION}" @@ -190,14 +191,26 @@ _kube_ps1_file_newer_than() { local file=$1 local check_time=$2 - if [[ "${KUBE_PS1_SHELL}" == "zsh" ]]; then - mtime=$(zstat +mtime "${file}") - elif stat -c "%s" /dev/null &> /dev/null; then - # GNU stat - mtime=$(stat -L -c %Y "${file}") + if [[ "${KUBE_PS1_KUBECONFIG_SYMLINK}" == "true" ]]; then + if [[ "${KUBE_PS1_SHELL}" == "zsh" ]]; then + mtime=$(zstat -L +mtime "${file}") + elif stat -c "%s" /dev/null &> /dev/null; then + # GNU stat + mtime=$(stat -c %Y "${file}") + else + # BSD stat + mtime=$(stat -f %m "$file") + fi else - # BSD stat - mtime=$(stat -L -f %m "$file") + if [[ "${KUBE_PS1_SHELL}" == "zsh" ]]; then + mtime=$(zstat +mtime "${file}") + elif stat -c "%s" /dev/null &> /dev/null; then + # GNU stat + mtime=$(stat -L -c %Y "${file}") + else + # BSD stat + mtime=$(stat -L -f %m "$file") + fi fi [[ "${mtime}" -gt "${check_time}" ]] From 0008534147a28eeeea52cfd92154ae2e801678ae Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Fri, 1 Mar 2024 16:44:20 +0100 Subject: [PATCH 516/672] fix(tmux): regression with detached sessions See https://github.com/ohmyzsh/ohmyzsh/pull/12242#issuecomment-1973236605 --- plugins/tmux/tmux.plugin.zsh | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/plugins/tmux/tmux.plugin.zsh b/plugins/tmux/tmux.plugin.zsh index 436e2671d..11550d687 100644 --- a/plugins/tmux/tmux.plugin.zsh +++ b/plugins/tmux/tmux.plugin.zsh @@ -100,11 +100,13 @@ function _zsh_tmux_plugin_run() { [[ "$ZSH_TMUX_ITERM2" == "true" ]] && tmux_cmd+=(-CC) [[ "$ZSH_TMUX_UNICODE" == "true" ]] && tmux_cmd+=(-u) + local _detached="" + [[ "$ZSH_TMUX_DETACHED" == "true" ]] && _detached="-d" # Try to connect to an existing session. if [[ -n "$ZSH_TMUX_DEFAULT_SESSION_NAME" ]]; then - [[ "$ZSH_TMUX_AUTOCONNECT" == "true" ]] && $tmux_cmd attach ${ZSH_TMUX_DETACHED:+"-d"} -t $ZSH_TMUX_DEFAULT_SESSION_NAME + [[ "$ZSH_TMUX_AUTOCONNECT" == "true" ]] && $tmux_cmd attach $_detached -t $ZSH_TMUX_DEFAULT_SESSION_NAME else - [[ "$ZSH_TMUX_AUTOCONNECT" == "true" ]] && $tmux_cmd attach ${ZSH_TMUX_DETACHED:+"-d"} + [[ "$ZSH_TMUX_AUTOCONNECT" == "true" ]] && $tmux_cmd attach $_detached fi # If failed, just run tmux, fixing the TERM variable if requested. From e3216d15c2d2ee81716e4c2cbc999b4bed5694d9 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Sat, 2 Mar 2024 00:57:26 +0100 Subject: [PATCH 517/672] fix(git-commit)!: allow alias update BREAKING CHANGE: Prior to this commit, git aliases were not being updated after every update of oh-my-zsh. In case you were using git-commit plugin before this commit, please remove your git aliases to proceed. --- plugins/git-commit/git-commit.plugin.zsh | 24 ++++++++++++++---------- 1 file changed, 14 insertions(+), 10 deletions(-) diff --git a/plugins/git-commit/git-commit.plugin.zsh b/plugins/git-commit/git-commit.plugin.zsh index 3f0c2121d..207c37e21 100644 --- a/plugins/git-commit/git-commit.plugin.zsh +++ b/plugins/git-commit/git-commit.plugin.zsh @@ -1,3 +1,8 @@ +if git config --global --get-all alias.$_alias >/dev/null 2>&1 \ + && ! git config --global --get-all oh-my-zsh.git-commit-alias >/dev/null 2>&1; then + return +fi + local -a _git_commit_aliases _git_commit_aliases=( 'build' @@ -14,19 +19,18 @@ _git_commit_aliases=( 'wip' ) -local alias type -for type in "${_git_commit_aliases[@]}"; do +local _alias _type +for _type in "${_git_commit_aliases[@]}"; do # an alias can't be named "revert" because the git command takes precedence # https://stackoverflow.com/a/3538791 - case "$type" in - revert) alias=rev ;; - *) alias=$type ;; + case "$_type" in + revert) _alias=rev ;; + *) _alias=$_type ;; esac - local func='!a() { if [ "$1" = "-s" ] || [ "$1" = "--scope" ]; then local scope="$2"; shift 2; git commit -m "'$type'(${scope}): ${@}"; else git commit -m "'$type': ${@}"; fi }; a' - if ! git config --global --get-all alias.${alias} >/dev/null 2>&1; then - git config --global alias.${alias} "$func" - fi + local _func='!a() { if [ "$1" = "-s" ] || [ "$1" = "--scope" ]; then local scope="$2"; shift 2; git commit -m "'$type'(${scope}): ${@}"; else git commit -m "'$type': ${@}"; fi }; a' + + git config --global alias.$_alias "$_func" done -unset _git_commit_aliases alias type func +git config --global oh-my-zsh.git-commit-alias "true" From 3ee108ccb301dd4143080e8bfd8f9ae869957a2e Mon Sep 17 00:00:00 2001 From: Rejman Date: Sat, 2 Mar 2024 01:21:30 +0100 Subject: [PATCH 518/672] feat(git-commit): add `-a | --attention` flag Refactor function as well to reduce flaws and increase stability Closes #12234 Co-authored-by: Carlo Sala --- plugins/git-commit/git-commit.plugin.zsh | 25 +++++++++++++++++++++++- 1 file changed, 24 insertions(+), 1 deletion(-) diff --git a/plugins/git-commit/git-commit.plugin.zsh b/plugins/git-commit/git-commit.plugin.zsh index 207c37e21..7ad349735 100644 --- a/plugins/git-commit/git-commit.plugin.zsh +++ b/plugins/git-commit/git-commit.plugin.zsh @@ -28,7 +28,30 @@ for _type in "${_git_commit_aliases[@]}"; do *) _alias=$_type ;; esac - local _func='!a() { if [ "$1" = "-s" ] || [ "$1" = "--scope" ]; then local scope="$2"; shift 2; git commit -m "'$type'(${scope}): ${@}"; else git commit -m "'$type': ${@}"; fi }; a' + local _func='!a() { +local _scope _attention _message +while [ $# -ne 0 ]; do +case $1 in + -s | --scope ) + if [ -z $2 ]; then + echo "Missing scope!" + return 1 + fi + _scope="$2" + shift 2 + ;; + -a | --attention ) + _attention="!" + shift 1 + ;; + * ) + _message+=" $1" + shift 1 + ;; +esac +done +git commit -m "'$_type'${_scope:+(${_scope})}${_attention}:${_message}" +}; a' git config --global alias.$_alias "$_func" done From 8e088ded8289a9db2a9f2c03cab618d6dd017dd7 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Sat, 2 Mar 2024 01:25:20 +0100 Subject: [PATCH 519/672] docs(git-commit): document attention flag --- plugins/git-commit/README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/git-commit/README.md b/plugins/git-commit/README.md index a00983935..49072d0fb 100644 --- a/plugins/git-commit/README.md +++ b/plugins/git-commit/README.md @@ -11,7 +11,7 @@ plugins=(... git-commit) ## Syntax ```zsh -git [(-s, --scope) ""] "" +git [(-s, --scope) ""] [(-a, --attention)] "" ``` > ⚠️ Single/Double quotes around the scope and message are required From 2c62584b8389cb9510c12f7c28b5ca7970619277 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E5=BC=A0=E5=A4=A9=E6=B3=BD?= <35888946+zhangtianze1997@users.noreply.github.com> Date: Sat, 2 Mar 2024 16:12:34 +0800 Subject: [PATCH 520/672] fix(tmux): use full offset parameter (#12249) --- plugins/tmux/tmux.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/tmux/tmux.plugin.zsh b/plugins/tmux/tmux.plugin.zsh index 11550d687..791592d8f 100644 --- a/plugins/tmux/tmux.plugin.zsh +++ b/plugins/tmux/tmux.plugin.zsh @@ -49,7 +49,7 @@ fi # ALIASES function _build_tmux_alias { eval "function $1 { - if [[ -z \$1 ]] || [[ \${1::1} == '-' ]]; then + if [[ -z \$1 ]] || [[ \${1:0:1} == '-' ]]; then tmux $2 \"\$@\" else tmux $2 $3 \"\$@\" From b6c1de87b01aaf5eb434b86b1d32b92cb37467bb Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Sat, 2 Mar 2024 10:05:44 +0100 Subject: [PATCH 521/672] fix(git-commit): add omz version check --- plugins/git-commit/git-commit.plugin.zsh | 7 +++---- 1 file changed, 3 insertions(+), 4 deletions(-) diff --git a/plugins/git-commit/git-commit.plugin.zsh b/plugins/git-commit/git-commit.plugin.zsh index 7ad349735..121ae59de 100644 --- a/plugins/git-commit/git-commit.plugin.zsh +++ b/plugins/git-commit/git-commit.plugin.zsh @@ -1,7 +1,8 @@ -if git config --global --get-all alias.$_alias >/dev/null 2>&1 \ - && ! git config --global --get-all oh-my-zsh.git-commit-alias >/dev/null 2>&1; then +local _rev="$(git -C $ZSH rev-parse HEAD 2> /dev/null)" +if [[ $_rev == $(git config --global --get oh-my-zsh.git-commit-alias 2> /dev/null) ]]; then return fi +git config --global oh-my-zsh.git-commit-alias "$_rev" local -a _git_commit_aliases _git_commit_aliases=( @@ -55,5 +56,3 @@ git commit -m "'$_type'${_scope:+(${_scope})}${_attention}:${_message}" git config --global alias.$_alias "$_func" done - -git config --global oh-my-zsh.git-commit-alias "true" From 458fc2e1df4757e64b036edee17ccdefdde41f73 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Sat, 2 Mar 2024 10:05:54 +0100 Subject: [PATCH 522/672] docs(git-commit): add warning --- plugins/git-commit/README.md | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/plugins/git-commit/README.md b/plugins/git-commit/README.md index 49072d0fb..f812ee23f 100644 --- a/plugins/git-commit/README.md +++ b/plugins/git-commit/README.md @@ -1,6 +1,8 @@ # git-commit plugin -The git-commit plugin adds several [git aliases](https://www.git-scm.com/docs/git-config#Documentation/git-config.txt-alias) for [conventional commit](https://www.conventionalcommits.org/en/v1.0.0/#summary) messages. +The git-commit plugin adds several +[git aliases](https://www.git-scm.com/docs/git-config#Documentation/git-config.txt-alias) for +[conventional commit](https://www.conventionalcommits.org/en/v1.0.0/#summary) messages. To use it, add `git-commit` to the plugins array in your zshrc file: @@ -14,8 +16,6 @@ plugins=(... git-commit) git [(-s, --scope) ""] [(-a, --attention)] "" ``` -> ⚠️ Single/Double quotes around the scope and message are required - Where `type` is one of the following: - `build` @@ -34,6 +34,9 @@ Where `type` is one of the following: > NOTE: the alias for `revert` type is `rev`, as otherwise it conflicts with the git command of the same name. > It will still generate a commit message in the format `revert: ` +> ⚠️ Enabling this plugin will (potentially) overwrite all `alias.` that you manually set. Use with +> care! + ## Examples | Git alias | Command | From 70395a64637ad1a94b11f6007f29ee0c0d716884 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Sun, 3 Mar 2024 11:22:25 +0100 Subject: [PATCH 523/672] fix(git): do not use `+=` in sh script Fixes #12251 --- plugins/git-commit/git-commit.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/git-commit/git-commit.plugin.zsh b/plugins/git-commit/git-commit.plugin.zsh index 121ae59de..c4df77c80 100644 --- a/plugins/git-commit/git-commit.plugin.zsh +++ b/plugins/git-commit/git-commit.plugin.zsh @@ -46,7 +46,7 @@ case $1 in shift 1 ;; * ) - _message+=" $1" + _message="${_message} $1" shift 1 ;; esac From 97a86ed1678022683d9f0113ada51f4ed8aa7375 Mon Sep 17 00:00:00 2001 From: Maxime Brunet Date: Sun, 3 Mar 2024 10:56:40 +0000 Subject: [PATCH 524/672] feat(terraform): update completion to `v1.7` (#12252) --- plugins/terraform/_terraform | 820 ++++++++++++++++++++--------------- 1 file changed, 469 insertions(+), 351 deletions(-) diff --git a/plugins/terraform/_terraform b/plugins/terraform/_terraform index 625834563..aad1c6096 100644 --- a/plugins/terraform/_terraform +++ b/plugins/terraform/_terraform @@ -1,411 +1,529 @@ #compdef terraform +compdef _terraform terraform -local -a _terraform_cmds opt_args -_terraform_cmds=( - 'apply:Builds or changes infrastructure' - 'console:Interactive console for Terraform interpolations' - 'destroy:Destroy Terraform-managed infrastructure' - 'fmt:Rewrites config files to canonical format' - 'force-unlock:Manually unlock the terraform state' - 'get:Download and install modules for the configuration' - 'graph:Create a visual graph of Terraform resources' - 'import:Import existing infrastructure into Terraform' - 'init:Initialize a Terraform working directory' +(( ${+functions[_terraform_commands]} )) || _terraform_commands() { + local -a _terraform_cmds + _terraform_cmds=( + 'apply:Create or update infrastructure' + 'console:Try Terraform expressions at an interactive command prompt' + 'destroy:Destroy previously-created infrastructure' + 'fmt:Reformat your configuration in the standard style' + 'force-unlock:Release a stuck lock on the current workspace' + 'get:Install or upgrade remote Terraform modules' + 'graph:Generate a Graphviz graph of the steps in an operation' + 'import:Associate existing infrastructure with a Terraform resource' + 'init:Prepare your working directory for other commands' 'login:Obtain and save credentials for a remote host' 'logout:Remove locally-stored credentials for a remote host' - 'output:Read an output from a state file' - 'plan:Generate and show an execution plan' - 'providers:Prints a tree of the providers used in the configuration' - 'refresh:Update local state file against real resources' - 'show:Inspect Terraform state or plan' + 'metadata:Metadata related commands' + 'output:Show output values from your root module' + 'plan:Show changes required by the current configuration' + 'providers:Show the providers required for this configuration' + 'refresh:Update the state to match remote systems' + 'show:Show the current state or a saved plan' 'state:Advanced state management' - 'taint:Manually mark a resource for recreation' - 'untaint:Manually unmark a resource as tainted' - 'validate:Validates the Terraform files' - 'version:Prints the Terraform version' + 'taint:Mark a resource instance as not fully functional' + 'test:Execute integration tests for Terraform modules' + 'untaint:Remove the '\''tainted'\'' state from a resource instance' + 'validate:Check whether the configuration is valid' + 'version:Show the current Terraform version' 'workspace:Workspace management' - '0.12upgrade:Rewrites pre-0.12 module source code for v0.12' - '0.13upgrade:Rewrites pre-0.13 module source code for v0.13' -) + ) + if ((CURRENT == 1)); then + _describe -t commands 'terraform commands' _terraform_cmds + return + fi -__012upgrade() { + local curcontext="${curcontext}" + cmd="${${_terraform_cmds[(r)$words[1]:*]%%:*}}" + curcontext="${curcontext%:*:*}:terraform-${cmd}:" + + if (( ${+functions[_terraform_$cmd]} )); then + "_terraform_${cmd}" + else + _message "no more options" + fi +} + +(( ${+functions[_terraform_apply]} )) || _terraform_apply() { _arguments \ - '-yes[Skip the initial introduction messages and interactive confirmation. This can be used to run this command in batch from a script.]' \ - '-force[ Override the heuristic that attempts to detect if a configuration is already written for v0.12 or later. Some of the transformations made by this command are not idempotent, so re-running against the same module may change the meanings expressions in the module.]' + '-auto-approve[Skip interactive approval of plan before applying.]' \ + '-backup=[(path) Path to backup the existing state file before modifying. Defaults to the "-state-out" path with ".backup" extension. Set to "-" to disable backup.]:backupfile:_files -g "*.backup"' \ + '-compact-warnings[If Terraform produces any warnings that are not accompanied by errors, show them in a more compact form that includes only the summary messages.]' \ + '-destroy[Destroy Terraform-managed infrastructure. The command "terraform destroy" is a convenience alias for this option.]' \ + '-lock=[(true) Don'\''t hold a state lock during the operation. This is dangerous if others might concurrently run commands against the same workspace.]:lock:(true false)' \ + '-lock-timeout=[(0s) Duration to retry a state lock.]' \ + '-input=[(true) Ask for input for variables if not directly set.]:input:(true false)' \ + '-no-color[If specified, output won'\''t contain any color.]' \ + '-parallelism=[(10) Limit the number of parallel resource operations.]' \ + '-refresh=[(true) Skip checking for external changes to remote objects while creating the plan. This can potentially make planning faster, but at the expense of possibly planning against a stale record of the remote system state.]:refresh:(true false)' \ + '*-replace=[(resource) Force replacement of a particular resource instance using its resource address. If applying would'\''ve normally produced an update or no-op action for this instance, Terraform will replace it instead. You can use this option multiple times to replace more than one object.]:resource:__terraform_state_resources' \ + '-state=[(terraform.tfstate) Path to read and save state (unless state-out is specified).]:statefile:_files -g "*.tfstate"' \ + '-state-out=[(path) Path to write state to that is different than "-state". This can be used to preserve the old state.]:statefile:_files -g "*.tfstate"' \ + '*-target=[(resource) Limit the operation to only the given module, resource, or resource instance and all of its dependencies. You can use this option multiple times to include more than one object. This is for exceptional use only.]:target:__terraform_state_resources' \ + '*-var=[(for=bar) Set a value for one of the input variables in the root module of the configuration. Use this option more than once to set more than one variable.]' \ + '*-var-file=[(foo) Load variable values from the given file, in addition to the default files terraform.tfvars and *.auto.tfvars. Use this option more than once to include more than one variables file.]:file:_files -g "*.tfvars{,.json}"' \ + ':plan:_files -' } -__013upgrade() { +(( ${+functions[_terraform_console]} )) || _terraform_console() { _arguments \ - '-yes[Skip the initial introduction messages and interactive confirmation. This can be used to run this command in batch from a script.]' + '-state=[(terraform.tfstate) Legacy option for the local backend only. See the local backend'\''s documentation for more information.]' \ + '-plan[Create a new plan (as if running "terraform plan") and then evaluate expressions against its planned state, instead of evaluating against the current state. You can use this to inspect the effects of configuration changes that haven'\''t been applied yet.]' \ + '*-var=[(for=bar) Set a variable in the Terraform configuration. This flag can be set multiple times.]' \ + '*-var-file=[(foo) Set variables in the Terraform configuration from a file. If "terraform.tfvars" or any ".auto.tfvars" files are present, they will be automatically loaded.]:file:_files -g "*.tfvars{,.json}"' } -__apply() { - _arguments \ - '-auto-approve[Skip interactive approval of plan before applying.]' \ - '-backup=[(path) Path to backup the existing state file before modifying. Defaults to the "-state-out" path with ".backup" extension. Set to "-" to disable backup.]:backupfile:_files -g "*.backup"' \ - '-compact-warnings[If Terraform produces any warnings that are not accompanied by errors, show them in a more compact form that includes only the summary messages.]' \ - '-lock=[(true) Lock the state file when locking is supported.]:lock:(true false)' \ - '-lock-timeout=[(0s) Duration to retry a state lock.]' \ - '-input=[(true) Ask for input for variables if not directly set.]' \ - '-no-color[If specified, output will be colorless.]' \ - '-parallelism=[(10) Limit the number of parallel resource operations.]' \ - '-refresh=[(true) Update state prior to checking for differences. This has no effect if a plan file is given to apply.]' \ - '-state=[(terraform.tfstate) Path to read and save state (unless state-out is specified).]:statefile:_files -g "*.tfstate"' \ - '-state-out=[(path) Path to write state to that is different than "-state". This can be used to preserve the old state.]:statefile:_files -g "*.tfstate"' \ - '*-target=[(resource) Resource to target. Operation will be limited to this resource and its dependencies. This flag can be used multiple times.]:target:__statelist' \ - '*-var[("foo=bar") Set a variable in the Terraform configuration. This flag can be set multiple times.]' \ - '*-var-file=[(foo) Set variables in the Terraform configuration from a file. If "terraform.tfvars" or any ".auto.tfvars" files are present, they will be automatically loaded.]:file:_files -g "*.tfvars{,.json}"' -} - -__console() { - _arguments \ - '-state=[(terraform.tfstate) Path to read state.]' \ - '*-var[("foo=bar") Set a variable in the Terraform configuration. This flag can be set multiple times.]' \ - '*-var-file=[(foo) Set variables in the Terraform configuration from a file. If "terraform.tfvars" or any ".auto.tfvars" files are present, they will be automatically loaded.]:file:_files -g "*.tfvars{,.json}"' -} - -__destroy() { - _arguments \ - '-backup=[(path) Path to backup the existing state file before modifying. Defaults to the "-state-out" path with ".backup" extension. Set to "-" to disable backup.]:backupfile:_files -g "*.backup"' \ - '-auto-approve[Skip interactive approval before destroying.]' \ - '-force[Deprecated: same as auto-approve.]' \ - '-lock=[(true) Lock the state file when locking is supported.]:lock:(true false)' \ - '-lock-timeout=[(0s) Duration to retry a state lock.]' \ - '-no-color[If specified, output will contain no color.]' \ - '-parallelism=[(10) Limit the number of concurrent operations.]' \ - '-refresh=[(true) Update state prior to checking for differences. This has no effect if a plan file is given to apply.]' \ - '-state=[(terraform.tfstate) Path to read and save state (unless state-out is specified).]:statefile:_files -g "*.tfstate"' \ - '-state-out=[(path) Path to write state to that is different than "-state". This can be used to preserve the old state.]:statefile:_files -g "*.tfstate"' \ - '*-target=[(resource) Resource to target. Operation will be limited to this resource and its dependencies. This flag can be used multiple times.]:target:__statelist' \ - '*-var[("foo=bar") Set a variable in the Terraform configuration. This flag can be set multiple times.]' \ - '*-var-file=[(foo) Set variables in the Terraform configuration from a file. If "terraform.tfvars" or any ".auto.tfvars" files are present, they will be automatically loaded.]:file:_files -g "*.tfvars{,.json}"' -} - -__fmt() { - _arguments \ - '-list=[(true) List files whose formatting differs (always false if using STDIN)]' \ - '-write=[(true) Write result to source file instead of STDOUT (always false if using STDIN or -check)]' \ - '-diff=[(false) Display diffs of formatting changes]' \ - '-check=[(false) Check if the input is formatted. Exit status will be 0 if all input is properly formatted and non-zero otherwise.]' \ - '-recursive=[(false) Also process files in subdirectories. By default, only the given directory (or current directory) is processed.]' -} - -__force_unlock() { - _arguments \ - "-force[Don't ask for input for unlock confirmation.]" -} - -__get() { - _arguments \ - '-update=[(false) If true, modules already downloaded will be checked for updates and updated if necessary.]' \ - '-no-color[Disable text coloring in the output.]' -} - -__graph() { - _arguments \ - '-draw-cycles[Highlight any cycles in the graph with colored edges. This helps when diagnosing cycle errors.]' \ - '-type=[(plan) Type of graph to output. Can be: plan, plan-destroy, apply, validate, input, refresh.]' -} - -__import() { - _arguments \ - '-backup=[(path) Path to backup the existing state file before modifying. Defaults to the "-state-out" path with ".backup" extension. Set to "-" to disable backup.]:backupfile:_files -g "*.backup"' \ - '-config=[(path) Path to a directory of Terraform configuration files to use to configure the provider. Defaults to pwd. If no config files are present, they must be provided via the input prompts or env vars.]' \ - '-allow-missing-config[Allow import when no resource configuration block exists.]' \ - '-input=[(true) Ask for input for variables if not directly set.]' \ - '-lock=[(true) Lock the state file when locking is supported.]:lock:(true false)' \ - '-lock-timeout=[(0s) Duration to retry a state lock.]' \ - '-no-color[If specified, output will contain no color.]' \ - '-state=[(PATH) Path to the source state file. Defaults to the configured backend, or "terraform.tfstate"]:statefile:_files -g "*.tfstate"' \ - '-state-out=[(PATH) Path to the destination state file to write to. If this is not specified, the source state file will be used. This can be a new or existing path.]:statefile:_files -g "*.tfstate"' \ - '*-var[("foo=bar") Set a variable in the Terraform configuration. This flag can be set multiple times. This is only useful with the "-config" flag.]' \ - '*-var-file=[(foo) Set variables in the Terraform configuration from a file. If "terraform.tfvars" or any ".auto.tfvars" files are present, they will be automatically loaded.]:file:_files -g "*.tfvars{,.json}"' -} - -__init() { - _arguments \ - '-backend=[(true) Configure the backend for this configuration.]' \ - '-backend-config=[This can be either a path to an HCL file with key/value assignments (same format as terraform.tfvars) or a 'key=value' format. This is merged with what is in the configuration file. This can be specified multiple times. The backend type must be in the configuration itself.]' \ - '-force-copy[Suppress prompts about copying state data. This is equivalent to providing a "yes" to all confirmation prompts.]' \ - '-from-module=[(SOURCE) Copy the contents of the given module into the target directory before initialization.]' \ - '-get=[(true) Download any modules for this configuration.]' \ - '-get-plugins=[(true) Download any missing plugins for this configuration.]' \ - '-input=[(true) Ask for input if necessary. If false, will error if input was required.]' \ - '-lock=[(true) Lock the state file when locking is supported.]:lock:(true false)' \ - '-lock-timeout=[(0s) Duration to retry a state lock.]' \ - '-no-color[If specified, output will contain no color.]' \ - '-plugin-dir[Directory containing plugin binaries. This overrides all default search paths for plugins, and prevents the automatic installation of plugins. This flag can be used multiple times.]:plugin_dir:_files -/' \ - '-reconfigure[Reconfigure the backend, ignoring any saved configuration.]' \ - '-upgrade=[(false) If installing modules (-get) or plugins (-get-plugins), ignore previously-downloaded objects and install the latest version allowed within configured constraints.]' \ - '-verify-plugins=[(true) Verify the authenticity and integrity of automatically downloaded plugins.]' -} - -__login() { - _arguments \ - -} - -__logout() { - _arguments \ - -} - -__output() { - _arguments \ - '-state=[(path) Path to the state file to read. Defaults to "terraform.tfstate".]:statefile:_files -g "*.tfstate"' \ - '-no-color[If specified, output will contain no color.]' \ - '-json[If specified, machine readable output will be printed in JSON format]' -} - -__plan() { - _arguments \ - '-compact-warnings[If Terraform produces any warnings that are not accompanied by errors, show them in a more compact form that includes only the summary messages.]' \ - '-destroy[If set, a plan will be generated to destroy all resources managed by the given configuration and state.]' \ - '-detailed-exitcode[() Return detailed exit codes when the command exits. This will change the meaning of exit codes to: 0 - Succeeded, diff is empty (no changes); 1 - Errored, 2 - Succeeded; there is a diff]' \ - '-input=[(true) Ask for input for variables if not directly set.]' \ - '-lock=[(true) Lock the state file when locking is supported.]:lock:(true false)' \ - '-lock-timeout=[(0s) Duration to retry a state lock.]' \ - '-no-color[() If specified, output will contain no color.]' \ - '-out=[(path) Write a plan file to the given path. This can be used as input to the "apply" command.]' \ - '-parallelism=[(10) Limit the number of concurrent operations.]' \ - '-refresh=[(true) Update state prior to checking for differences.]' \ - '-state=[(statefile) Path to a Terraform state file to use to look up Terraform-managed resources. By default it will use the state "terraform.tfstate" if it exists.]:statefile:_files -g "*.tfstate"' \ - '*-target=[(resource) Resource to target. Operation will be limited to this resource and its dependencies. This flag can be used multiple times.]:target:__statelist' \ - '*-var[("foo=bar") Set a variable in the Terraform configuration. This flag can be set multiple times.]' \ - '*-var-file=[(foo) Set variables in the Terraform configuration from a file. If "terraform.tfvars" or any ".auto.tfvars" files are present, they will be automatically loaded.]:file:_files -g "*.tfvars{,.json}"' -} - -__providers() { - local -a __providers_cmds - __providers_cmds=( - 'mirror:Mirrors the provider plugins needed for the current configuration' - 'schema:Prints the schemas of the providers used in the configuration' - ) - _describe -t providers "providers commands" __providers_cmds - -} - -__providers_mirror() { - _arguments \ - '-platform=[(os_arch) Choose which target platform to build a mirror for.]' \ - "*:target_dir:_files -/" -} - -__providers_schema() { - _arguments \ - '-json[]' \ - '::' -} - -__refresh() { - _arguments \ - '-backup=[(path) Path to backup the existing state file before modifying. Defaults to the "-state-out" path with ".backup" extension. Set to "-" to disable backup.]::backupfile:_files -g "*.backup"' \ - '-compact-warnings[If Terraform produces any warnings that are not accompanied by errors, show them in a more compact form that includes only the summary messages.]' \ - '-input=[(true) Ask for input for variables if not directly set.]' \ - '-lock=[(true) Lock the state file when locking is supported.]:lock:(true false)' \ - '-lock-timeout=[(0s) Duration to retry a state lock.]' \ - '-no-color[If specified, output will not contain any color.]' \ - '-state=[(path) Path to read and save state (unless state-out is specified). Defaults to "terraform.tfstate".]:statefile:_files -g "*.tfstate"' \ - '-state-out=[(path) Path to write state to that is different than "-state". This can be used to preserve the old state.]:statefile:_files -g "*.tfstate"' \ - '*-target=[(resource) A Resource Address to target. Operation will be limited to this resource and its dependencies. This flag can be used multiple times.]:target:__statelist' \ - '*-var[("foo=bar") Set a variable in the Terraform configuration. This flag can be set multiple times.]' \ - '*-var-file=[(foo) Set variables in the Terraform configuration from a file. If "terraform.tfvars" or any ".auto.tfvars" files are present, they will be automatically loaded.]:file:_files -g "*.tfvars{,.json}"' -} - -__show() { - _arguments \ - '-json[If specified, output the Terraform plan or state in a machine-readable form.]' \ - '-no-color[If specified, output will not contain any color.]' -} - -__state() { - local -a __state_cmds - __state_cmds=( - 'list:List resources in the state' - 'mv:Move an item in the state' - 'pull:Pull current state and output to stdout' - 'push:Update remote state from a local state file' - 'replace-provider:Replace provider for resources in the Terraform state' - 'rm:Remove instances from the state' - 'show:Show a resource in the state' - ) - _describe -t state "state commands" __state_cmds -} - -__state_list() { +(( ${+functions[_terraform_destroy]} )) || _terraform_destroy() { _arguments \ - '-state=[(statefile) Path to a Terraform state file to use to look up Terraform-managed resources. By default, Terraform will consult the state of the currently-selected workspace.]' \ + '-auto-approve[Skip interactive approval of plan before applying.]' \ + '-backup=[(path) Path to backup the existing state file before modifying. Defaults to the "-state-out" path with ".backup" extension. Set to "-" to disable backup.]:backupfile:_files -g "*.backup"' \ + '-compact-warnings[If Terraform produces any warnings that are not accompanied by errors, show them in a more compact form that includes only the summary messages.]' \ + '-lock=[(true) Don'\''t hold a state lock during the operation. This is dangerous if others might concurrently run commands against the same workspace.]:lock:(true false)' \ + '-lock-timeout=[(0s) Duration to retry a state lock.]' \ + '-input=[(true) Ask for input for variables if not directly set.]:input:(true false)' \ + '-no-color[If specified, output won'\''t contain any color.]' \ + '-parallelism=[(10) Limit the number of parallel resource operations.]' \ + '-refresh=[(true) Update state prior to checking for differences. This has no effect if a plan file is given to apply.]:refresh:(true false)' \ + '-state=[(terraform.tfstate) Path to read and save state (unless state-out is specified).]:statefile:_files -g "*.tfstate"' \ + '-state-out=[(path) Path to write state to that is different than "-state". This can be used to preserve the old state.]:statefile:_files -g "*.tfstate"' \ + '*-target=[(resource) Limit the operation to only the given module, resource, or resource instance and all of its dependencies. You can use this option multiple times to include more than one object. This is for exceptional use only.]:target:__terraform_state_resources' \ + '*-var=[(for=bar) Set a value for one of the input variables in the root module of the configuration. Use this option more than once to set more than one variable.]' \ + '*-var-file=[(foo) Load variable values from the given file, in addition to the default files terraform.tfvars and *.auto.tfvars. Use this option more than once to include more than one variables file.]:file:_files -g "*.tfvars{,.json}"' +} + +(( ${+functions[_terraform_fmt]} )) || _terraform_fmt() { + _arguments \ + '-list=[(true) Don'\''t list files whose formatting differs (always disabled if using STDIN)]:list:(true false)' \ + '-write=[(true) Don'\''t write to source files (always disabled if using STDIN or -check)]:write:(true false)' \ + '-diff[Display diffs of formatting changes]' \ + '-check[Check if the input is formatted. Exit status will be 0 if all input is properly formatted and non-zero otherwise.]' \ + '-no-color[If specified, output won'\''t contain any color.]' \ + '-recursive[Also process files in subdirectories. By default, only the given directory (or current directory) is processed.]' \ + '*:targets:_files -' +} + +(( ${+functions[_terraform_force-unlock]} )) || _terraform_force-unlock() { + _arguments \ + '-force[Don'\''t ask for input for unlock confirmation.]' \ + ':lock_id:' +} + +(( ${+functions[_terraform_get]} )) || _terraform_get() { + _arguments \ + '-update[Check already-downloaded modules for available updates and install the newest versions available.]' \ + '-no-color[Disable text coloring in the output.]' \ + '-test-directory=[(tests) Set the Terraform test directory, defaults to "tests".]:test_directory:_files -/' +} + +(( ${+functions[_terraform_graph]} )) || _terraform_graph() { + _arguments \ + '-draw-cycles[Highlight any cycles in the graph with colored edges. This helps when diagnosing cycle errors. This option is supported only when illustrating a real evaluation graph, selected using the -type=TYPE option.]' \ + '-module-depth=[(-1) (deprecated) In prior versions of Terraform, specified the depth of modules to show in the output.]' \ + '-plan=[Render graph using the specified plan file instead of the configuration in the current directory. Implies -type=apply.]:plan:_files -' \ + '-type=[(plan) Type of operation graph to output. Can be: plan, plan-refresh-only, plan-destroy, or apply. By default Terraform just summarizes the relationships between the resources in your configuration, without any particular operation in mind. Full operation graphs are more detailed but therefore often harder to read.]:type:(plan plan-refresh-only plan-destroy apply)' +} + +(( ${+functions[_terraform_import]} )) || _terraform_import() { + _arguments \ + '-backup=[(path) Path to backup the existing state file before modifying. Defaults to the "-state-out" path with ".backup" extension. Set to "-" to disable backup.]:backupfile:_files -g "*.backup"' \ + '-config=[(path) Path to a directory of Terraform configuration files to use to configure the provider. Defaults to pwd. If no config files are present, they must be provided via the input prompts or env vars.]:config:_files -/' \ + '-input=[(true) Disable interactive input prompts.]:input:(true false)' \ + '-lock=[(true) Don'\''t hold a state lock during the operation. This is dangerous if others might concurrently run commands against the same workspace.]:lock:(true false)' \ + '-lock-timeout=[(0s) Duration to retry a state lock.]' \ + '-no-color[If specified, output will contain no color.]' \ + '-state=[(PATH) Path to the source state file. Defaults to the configured backend, or "terraform.tfstate"]:statefile:_files -g "*.tfstate"' \ + '-state-out=[(PATH) Path to the destination state file to write to. If this is not specified, the source state file will be used. This can be a new or existing path.]:statefile:_files -g "*.tfstate"' \ + '*-var=[(for=bar) Set a variable in the Terraform configuration. This flag can be set multiple times. This is only useful with the "-config" flag.]' \ + '*-var-file=[(foo) Set variables in the Terraform configuration from a file. If "terraform.tfvars" or any ".auto.tfvars" files are present, they will be automatically loaded.]:file:_files -g "*.tfvars{,.json}"' \ + ':addr:' \ + ':id:' +} + +(( ${+functions[_terraform_init]} )) || _terraform_init() { + _arguments \ + '-backend=[(true) Disable backend or Terraform Cloud initialization for this configuration and use what was previously initialized instead.]:backend:(true false)' \ + '-backend-config=[Configuration to be merged with what is in the configuration file'\''s '\''backend'\'' block. This can be either a path to an HCL file with key/value assignments (same format as terraform.tfvars) or a '\''key=value'\'' format, and can be specified multiple times. The backend type must be in the configuration itself.]:backend_config:_files -' \ + '-force-copy[Suppress prompts about copying state data. This is equivalent to providing a "yes" to all confirmation prompts.]' \ + '-from-module=[Copy the contents of the given module into the target directory before initialization.]:from_module:_files -/' \ + '-get=[(true) Disable downloading modules for this configuration.]:get:(true false)' \ + '-input=[(true) Disable interactive prompts. Note that some actions may require interactive prompts and will error if input is disabled.]:input:(true false)' \ + '-lock=[(true) Don'\''t hold a state lock during backend migration. This is dangerous if others might concurrently run commands against the same workspace.]:lock:(true false)' \ + '-lock-timeout=[(0s) Duration to retry a state lock.]' \ + '-no-color[If specified, output will contain no color.]' \ + '-plugin-dir[Directory containing plugin binaries. This overrides all default search paths for plugins, and prevents the automatic installation of plugins. This flag can be used multiple times.]:plugin_dir:_files -/' \ + '-reconfigure[Reconfigure the backend, ignoring any saved configuration.]' \ + '-migrate-state[Reconfigure a backend, and attempt to migrate any existing state.]' \ + '-upgrade[Install the latest module and provider versions allowed within configured constraints, overriding the default behavior of selecting exactly the version recorded in the dependency lockfile.]' \ + '-lockfile=[Set a dependency lockfile mode. Currently only "readonly" is valid.]:lockfile:( readonly )' \ + '-ignore-remote-version[A rare option used for Terraform Cloud and the remote backend only. Set this to ignore checking that the local and remote Terraform versions use compatible state representations, making an operation proceed even when there is a potential mismatch. See the documentation on configuring Terraform with Terraform Cloud for more information.]' \ + '-test-directory=[(tests) Set the Terraform test directory, defaults to "tests".]:test_directory:_files -/' +} + +(( ${+functions[_terraform_login]} )) || _terraform_login() { + _arguments \ + ':hostname:' +} + +(( ${+functions[_terraform_logout]} )) || _terraform_logout() { + _arguments \ + ':hostname:' +} + +(( ${+functions[_terraform_metadata]} )) || _terraform_metadata() { + local -a _metadata_cmds + _metadata_cmds=( + 'functions:Show signatures and descriptions for the available functions' + ) + if [[ "${CURRENT}" -lt 3 ]]; then + _describe -t commands "terraform metadata commands" _metadata_cmds + return + fi + + local curcontext="${curcontext}" + cmd="${${_metadata_cmds[(r)$words[2]:*]%%:*}}" + curcontext="${curcontext%:*:*}:terraform-metadata-${cmd}:" + + if (( ${+functions[_terraform_metadata_$cmd]} )); then + "_terraform_metadata_${cmd}" + else + _message "no more options" + fi +} + +(( ${+functions[_terraform_metadata_functions]} )) || _terraform_metadata_functions() { + _arguments \ + '-json' \ + '::' +} + +(( ${+functions[_terraform_output]} )) || _terraform_output() { + _arguments \ + '-state=[(path) Path to the state file to read. Defaults to "terraform.tfstate". Ignored when remote state is used.]:statefile:_files -g "*.tfstate"' \ + '-no-color[If specified, output will contain no color.]' \ + '-json[If specified, machine readable output will be printed in JSON format]' \ + '-raw[For value types that can be automatically converted to a string, will print the raw string directly, rather than a human-oriented representation of the value.]' \ + ':name:' +} + +(( ${+functions[_terraform_plan]} )) || _terraform_plan() { + _arguments \ + '-compact-warnings[If Terraform produces any warnings that are not accompanied by errors, show them in a more compact form that includes only the summary messages.]' \ + '-destroy[Select the "destroy" planning mode, which creates a plan to destroy all objects currently managed by this Terraform configuration instead of the usual behavior.]' \ + '-detailed-exitcode[Return detailed exit codes when the command exits. This will change the meaning of exit codes to: 0 - Succeeded, diff is empty (no changes); 1 - Errored, 2 - Succeeded; there is a diff]' \ + '-input=[(true) Ask for input for variables if not directly set.]:input:(true false)' \ + '-generate-config-out=[(path) (Experimental) If import blocks are present in configuration, instructs Terraform to generate HCL for any imported resources not already present. The configuration is written to a new file at PATH, which must not already exist. Terraform may still attempt to write configuration if the plan errors.]' \ + '-lock=[(true) Don'\''t hold a state lock during the operation. This is dangerous if others might concurrently run commands against the same workspace.]:lock:(true false)' \ + '-lock-timeout=[(0s) Duration to retry a state lock.]' \ + '-no-color[If specified, output will contain no color.]' \ + '-out=[(path) Write a plan file to the given path. This can be used as input to the "apply" command.]' \ + '-parallelism=[(10) Limit the number of concurrent operations.]' \ + '-refresh=[(true) Skip checking for external changes to remote objects while creating the plan. This can potentially make planning faster, but at the expense of possibly planning against a stale record of the remote system state.]:refresh:(true false)' \ + '-refresh-only[Select the "refresh only" planning mode, which checks whether remote objects still match the outcome of the most recent Terraform apply but does not propose any actions to undo any changes made outside of Terraform.]' \ + '*-replace=[(resource) Force replacement of a particular resource instance using its resource address. If the plan would'\''ve normally produced an update or no-op action for this instance, Terraform will plan to replace it instead. You can use this option multiple times to replace more than one object.]:replace:__terraform_state_resources' \ + '-state=[(statefile) Path to a Terraform state file to use to look up Terraform-managed resources. By default it will use the state "terraform.tfstate" if it exists.]:statefile:_files -g "*.tfstate"' \ + '*-target=[(resource) Limit the planning operation to only the given module, resource, or resource instance and all of its dependencies. You can use this option multiple times to include more than one object. This is for exceptional use only.]:target:__terraform_state_resources' \ + '*-var=[(for=bar) Set a value for one of the input variables in the root module of the configuration. Use this option more than once to set more than one variable.]' \ + '*-var-file=[(foo) Load variable values from the given file, in addition to the default files terraform.tfvars and *.auto.tfvars. Use this option more than once to include more than one variables file.]:file:_files -g "*.tfvars{,.json}"' +} + +(( ${+functions[_terraform_providers]} )) || _terraform_providers() { + local -a _providers_cmds + _providers_cmds=( + 'lock:Write out dependency locks for the configured providers' + 'mirror:Save local copies of all required provider plugins' + 'schema:Show schemas for the providers used in the configuration' + ) + + if [[ "${CURRENT}" -lt 3 ]]; then + _arguments \ + '-test-directory=[(path) Set the Terraform test directory, defaults to "tests".]:test_directory:_files -/' \ + '*:: :->command' + + _describe -t commands "terraform providers commands" _providers_cmds + return + fi + + local curcontext="${curcontext}" + cmd="${${_providers_cmds[(r)$words[2]:*]%%:*}}" + curcontext="${curcontext%:*:*}:terraform-providers-${cmd}:" + + if (( ${+functions[_terraform_providers_$cmd]} )); then + "_terraform_providers_${cmd}" + else + _message "no more options" + fi +} + +(( ${+functions[_terraform_providers_lock]} )) || _terraform_providers_lock() { + _arguments \ + '-fs-mirror=[(dir) Consult the given filesystem mirror directory instead of the origin registry for each of the given providers.]:fs_mirror:_files -/' \ + '-net-mirror=[(url) Consult the given network mirror (given as a base URL) instead of the origin registry for each of the given providers.]' \ + '*-platform=[(os_arch) Choose a target platform to request package checksums for.]' \ + '*:provider:' +} + +(( ${+functions[_terraform_providers_mirror]} )) || _terraform_providers_mirror() { + _arguments \ + '*-platform=[(os_arch) Choose which target platform to build a mirror for.]' \ + '::' \ + ':target_dir:_files -/' +} + +(( ${+functions[_terraform_providers_schema]} )) || _terraform_providers_schema() { + _arguments \ + '-json[]' \ + '::' +} + +(( ${+functions[_terraform_refresh]} )) || _terraform_refresh() { + _arguments \ + '-backup=[(path) Path to backup the existing state file before modifying. Defaults to the "-state-out" path with ".backup" extension. Set to "-" to disable backup.]::backupfile:_files -g "*.backup"' \ + '-compact-warnings[If Terraform produces any warnings that are not accompanied by errors, show them in a more compact form that includes only the summary messages.]' \ + '-input=[(true) Ask for input for variables if not directly set.]:input:(true false)' \ + '-lock=[(true) Don'\''t hold a state lock during the operation. This is dangerous if others might concurrently run commands against the same workspace.]:lock:(true false)' \ + '-lock-timeout=[(0s) Duration to retry a state lock.]' \ + '-no-color[If specified, output will not contain any color.]' \ + '-parallelism=[(10) Limit the number of parallel resource operations.]' \ + '-state=[(path) Path to read and save state (unless state-out is specified). Defaults to "terraform.tfstate".]:statefile:_files -g "*.tfstate"' \ + '-state-out=[(path) Path to write state to that is different than "-state". This can be used to preserve the old state.]:statefile:_files -g "*.tfstate"' \ + '*-target=[(resource) A Resource Address to target. Operation will be limited to this resource and its dependencies. This flag can be used multiple times.]:target:__terraform_state_resources' \ + '*-var=[(for=bar) Set a variable in the Terraform configuration. This flag can be set multiple times.]' \ + '*-var-file=[(foo) Set variables in the Terraform configuration from a file. If "terraform.tfvars" or any ".auto.tfvars" files are present, they will be automatically loaded.]:file:_files -g "*.tfvars{,.json}"' +} + +(( ${+functions[_terraform_show]} )) || _terraform_show() { + _arguments \ + '-json[If specified, output the Terraform plan or state in a machine-readable form.]' \ + '-no-color[If specified, output will not contain any color.]' \ + ':path:_files -g "*.tfstate"' +} + +(( ${+functions[_terraform_state]} )) || _terraform_state() { + local -a _state_cmds + _state_cmds=( + 'list:List resources in the state' + 'mv:Move an item in the state' + 'pull:Pull current state and output to stdout' + 'push:Update remote state from a local state file' + 'replace-provider:Replace provider in the state' + 'rm:Remove instances from the state' + 'show:Show a resource in the state' + ) + if [[ "${CURRENT}" -lt 3 ]]; then + _describe -t commands "terraform state commands" _state_cmds + return + fi + + local curcontext="${curcontext}" + cmd="${${_state_cmds[(r)$words[2]:*]%%:*}}" + curcontext="${curcontext%:*:*}:terraform-state-${cmd}:" + + if (( ${+functions[_terraform_state_$cmd]} )); then + "_terraform_state_${cmd}" + else + _message "no more options" + fi +} + +(( ${+functions[_terraform_state_list]} )) || _terraform_state_list() { + _arguments \ + '-state=[(statefile) Path to a Terraform state file to use to look up Terraform-managed resources. By default, Terraform will consult the state of the currently-selected workspace.]:statefile:_files -g "*.tfstate"' \ '-id=[(id) Filters the results to include only instances whose resource types have an attribute named id whose value equals the given id string.]' \ - "*:address:__statelist" + '*:address:__terraform_state_resources' } -__state_mv() { +(( ${+functions[_terraform_state_mv]} )) || _terraform_state_mv() { _arguments \ - "-dry-run[If set, prints out what would've been moved but doesn't actually move anything.]" \ + '-dry-run[If set, prints out what would'\''ve been moved but doesn'\''t actually move anything.]' \ '-backup=[(PATH) Path where Terraform should write the backup for the original state. This can"t be disabled. If not set, Terraform will write it to the same path as the statefile with a ".backup" extension.]:backupfile:_files -g "*.backup"' \ '-backup-out=[(PATH) Path where Terraform should write the backup for the destination state. This can"t be disabled. If not set, Terraform will write it to the same path as the destination state file with a backup extension. This only needs to be specified if -state-out is set to a different path than -state.]:backupfile:_files -g "*.backup"' \ - "-lock=[(true) Lock the state files when locking is supported.]:lock:(true false)" \ - "-lock-timeout=[(0s) Duration to retry a state lock.]" \ + '-ignore-remote-version[A rare option used for the remote backend only. See the remote backend documentation for more information.]' \ + '-lock=[(true) Don'\''t hold a state lock during the operation. This is dangerous if others might concurrently run commands against the same workspace.]:lock:(true false)' \ + '-lock-timeout=[(0s) Duration to retry a state lock.]' \ '-state=[(path) Path to the source state file. Defaults to the configured backend, or "terraform.tfstate"]:statefile:_files -g "*.tfstate"' \ '-state-out=[(path) Path to the destination state file to write to. If this isn"t specified, the source state file will be used. This can be a new or existing path.]:statefile:_files -g "*.tfstate"' \ - "::" \ - ":source:__statelist" \ - ":destination: " + '::' \ + ':source:__terraform_state_resources' \ + ':destination: ' } -__state_push() { +(( ${+functions[_terraform_state_push]} )) || _terraform_state_push() { _arguments \ - "-force[Write the state even if lineages don't match or the remote serial is higher.]" \ - '-lock=[(true) Lock the state file when locking is supported.]:lock:(true false)' \ - "-lock-timeout=[(0s) Duration to retry a state lock.]" \ - "::" \ - ":destination:_files" + '-force[Write the state even if lineages don'\''t match or the remote serial is higher.]' \ + '-lock=[(true) Don'\''t hold a state lock during the operation. This is dangerous if others might concurrently run commands against the same workspace.]:lock:(true false)' \ + '-lock-timeout=[(0s) Duration to retry a state lock.]' \ + '::' \ + ':destination:_files' } -__state_replace_provider() { +(( ${+functions[_terraform_state_replace-provider]} )) || _terraform_state_replace-provider() { _arguments \ '-auto-approve[Skip interactive approval.]' \ '-backup=[(PATH) Path where Terraform should write the backup for the state file. This can"t be disabled. If not set, Terraform will write it to the same path as the state file with a ".backup" extension.]:backupfile:_files -g "*.backup"' \ - "-lock=[(true) Lock the state files when locking is supported.]:lock:(true false)" \ - "-lock-timeout=[(0s) Duration to retry a state lock.]" \ + '-lock=[(true) Don'\''t hold a state lock during the operation. This is dangerous if others might concurrently run commands against the same workspace.]:lock:(true false)' \ + '-lock-timeout=[(0s) Duration to retry a state lock.]' \ '-state=[(PATH) Path to the source state file. Defaults to the configured backend, or "terraform.tfstate"]:statefile:_files -g "*.tfstate"' \ - ":from_provider_fqn:" \ - ":to_provider_fqn:" + '::' \ + ':from_provider_fqn:' \ + ':to_provider_fqn:' } -__state_rm() { +(( ${+functions[_terraform_state_rm]} )) || _terraform_state_rm() { _arguments \ - "-dry-run[If set, prints out what would've been removed but doesn't actually remove anything.]" \ + '-dry-run[If set, prints out what would'\''ve been removed but doesn'\''t actually remove anything.]' \ '-backup=[(PATH) Path where Terraform should write the backup for the original state.]::backupfile:_files -g "*.backup"' \ - "-lock=[(true) Lock the state file when locking is supported.]:lock:(true false)" \ - "-lock-timeout=[(0s) Duration to retry a state lock.]" \ + '-ignore-remote-version[Continue even if remote and local Terraform versions are incompatible. This may result in an unusable workspace, and should be used with extreme caution.]' \ + '-lock=[(true) Don'\''t hold a state lock during the operation. This is dangerous if others might concurrently run commands against the same workspace.]:lock:(true false)' \ + '-lock-timeout=[(0s) Duration to retry a state lock.]' \ '-state=[(PATH) Path to the state file to update. Defaults to the current workspace state.]:statefile:_files -g "*.tfstate"' \ - "*:address:__statelist" + '*:address:__terraform_state_resources' } - -__state_show() { +(( ${+functions[_terraform_state_show]} )) || _terraform_state_show() { _arguments \ '-state=[(statefile) Path to a Terraform state file to use to look up Terraform-managed resources. By default it will use the state "terraform.tfstate" if it exists.]:statefile:_files -g "*.tfstate"' \ - "*:address:__statelist" + "*:address:__terraform_state_resources" } -__statelist() { - compadd $(terraform state list $opt_args[-state]) +(( ${+functions[__terraform_state_resources]} )) || __terraform_state_resources() { + local resource + local -a resources + terraform state list -state="${opt_args[-state]}" 2>/dev/null | while read -r resource; do + resources+=( "${resource}" ) + done + compadd "${@}" - "${resources[@]}" } -__taint() { - _arguments \ - '-allow-missing[If specified, the command will succeed (exit code 0) even if the resource is missing.]' \ - '-backup=[(path) Path to backup the existing state file before modifying. Defaults to the "-state-out" path with ".backup" extension. Set to "-" to disable backup.]:backupfile:_files -g "*.backup"' \ - '-lock=[(true) Lock the state file when locking is supported.]:lock:(true false)' \ - '-lock-timeout=[(0s) Duration to retry a state lock.]' \ - '-module=[(path) The module path where the resource lives. By default this will be root. Child modules can be specified by names. Ex. "consul" or "consul.vpc" (nested modules).]' \ - '-state=[(path) Path to read and save state (unless state-out is specified). Defaults to "terraform.tfstate".]:statefile:_files -g "*.tfstate"' \ - '-state-out=[(path) Path to write updated state file. By default, the "-state" path will be used.]:statefile:_files -g "*.tfstate"' \ - "*:address:__statelist" -} - -__untaint() { - _arguments \ +(( ${+functions[_terraform_taint]} )) || _terraform_taint() { + _arguments \ '-allow-missing[If specified, the command will succeed (exit code 0) even if the resource is missing.]' \ '-backup=[(path) Path to backup the existing state file before modifying. Defaults to the "-state-out" path with ".backup" extension. Set to "-" to disable backup.]:backupfile:_files -g "*.backup"' \ - '-lock=[(true) Lock the state file when locking is supported.]:lock:(true false)' \ + '-ignore-remote-version[A rare option used for the remote backend only. See the remote backend documentation for more information.]' \ + '-lock=[(true) Don'\''t hold a state lock during the operation. This is dangerous if others might concurrently run commands against the same workspace.]:lock:(true false)' \ '-lock-timeout=[(0s) Duration to retry a state lock.]' \ - '-module=[(path) The module path where the resource lives. By default this will be root. Child modules can be specified by names. Ex. "consul" or "consul.vpc" (nested modules).]' \ '-state=[(path) Path to read and save state (unless state-out is specified). Defaults to "terraform.tfstate".]:statefile:_files -g "*.tfstate"' \ - '-state-out=[(path) Path to write updated state file. By default, the "-state" path will be used.]:statefile:_files -g "*.tfstate"' + '-state-out=[(path) Path to write updated state file. By default, the "-state" path will be used.]:statefile:_files -g "*.tfstate"' \ + '*:address:__terraform_state_resources' } -__validate() { - _arguments \ - '-no-color[If specified, output will not contain any color.]' \ +(( ${+functions[_terraform_test]} )) || _terraform_test() { + _arguments \ + '-cloud-run=[(source) If specified, Terraform will execute this test run remotely using Terraform Cloud. You must specify the source of a module registered in a private module registry as the argument to this flag. This allows Terraform to associate the cloud run with the correct Terraform Cloud module and organization.]' \ + '*-filter=[(testfile) If specified, Terraform will only execute the test files specified by this flag. You can use this option multiple times to execute more than one test file.]:testfile:_files -g "*.tftest.hcl"' \ + '-json[If specified, machine readable output will be printed in JSON format]' \ + '-no-color[If specified, machine readable output will be printed in JSON format]' \ + '-test-directory=[(path) Set the Terraform test directory, defaults to "tests".]:test_directory:_files -/' \ + '*-var=[(for=bar) Set a value for one of the input variables in the root module of the configuration. Use this option more than once to set more than one variable.]' \ + '*-var-file=[(foo) Load variable values from the given file, in addition to the default files terraform.tfvars and *.auto.tfvars. Use this option more than once to include more than one variables file.]:file:_files -g "*.tfvars{,.json}"' \ + '-verbose[Print the plan or state for each test run block as it executes.]' \ +} + +(( ${+functions[_terraform_untaint]} )) || _terraform_untaint() { + _arguments \ + '-allow-missing[If specified, the command will succeed (exit code 0) even if the resource is missing.]' \ + '-backup=[(path) Path to backup the existing state file before modifying. Defaults to the "-state-out" path with ".backup" extension. Set to "-" to disable backup.]:backupfile:_files -g "*.backup"' \ + '-lock=[(true) Don'\''t hold a state lock during the operation. This is dangerous if others might concurrently run commands against the same workspace.]:lock:(true false)' \ + '-lock-timeout=[(0s) Duration to retry a state lock.]' \ + '-state=[(path) Path to read and save state (unless state-out is specified). Defaults to "terraform.tfstate".]:statefile:_files -g "*.tfstate"' \ + '-state-out=[(path) Path to write updated state file. By default, the "-state" path will be used.]:statefile:_files -g "*.tfstate"' \ + ':name:__terraform_state_resources' +} + +(( ${+functions[_terraform_validate]} )) || _terraform_validate() { + _arguments \ '-json[Produce output in a machine-readable JSON format, suitable for use in text editor integrations and other automated systems.]' \ + '-no-color[If specified, output will not contain any color.]' \ + '-no-tests[If specified, Terraform will not validate test files.]' \ + '-test-directory=[(path) Set the Terraform test directory, defaults to "tests".]:test_directory:_files -/' \ ':dir:_files -/' } -__version() { - _arguments \ - '-json[Output the version information as a JSON object.]' +(( ${+functions[_terraform_version]} )) || _terraform_version() { + _arguments \ + '-json[Output the version information as a JSON object.]' \ + '::' } -__workspace() { - local -a __workspace_cmds - __workspace_cmds=( - 'delete:Delete a workspace' - 'list:List Workspaces' - 'new:Create a new workspace' - 'select:Select a workspace' - 'show:Show the name of the current workspace' - ) - _describe -t workspace "workspace commands" __workspace_cmds +(( ${+functions[_terraform_workspace]} )) || _terraform_workspace() { + local -a _workspace_cmds + _workspace_cmds=( + 'delete:Delete a workspace' + 'list:List Workspaces' + 'new:Create a new workspace' + 'select:Select a workspace' + 'show:Show the name of the current workspace' + ) + if [[ "${CURRENT}" -lt 3 ]]; then + _describe -t commands "terraform workspace commands" _workspace_cmds + return + fi + + local curcontext="${curcontext}" + cmd="${${_workspace_cmds[(r)$words[2]:*]%%:*}}" + curcontext="${curcontext%:*:*}:terraform-workspace-${cmd}:" + + if (( ${+functions[_terraform_workspace_$cmd]} )); then + "_terraform_workspace_${cmd}" + else + _message "no more options" + fi } -_arguments '*:: :->command' +(( ${+functions[_terraform_workspace_delete]} )) || _terraform_workspace_delete() { + _arguments \ + '-force[Remove a workspace even if it is managing resources. Terraform can no longer track or manage the workspace'\''s infrastructure.]' \ + '-lock=[(true) Don'\''t hold a state lock during the operation. This is dangerous if others might concurrently run commands against the same workspace.]:lock:(true false)' \ + '-lock-timeout=[(0s) Duration to retry a state lock.]' \ + '::' \ + ':name:__terraform_workspaces' +} -if (( CURRENT == 1 )); then - _describe -t commands "terraform command" _terraform_cmds - return +(( ${+functions[_terraform_workspace_list]} )) || _terraform_workspace_list() { + _arguments +} + +(( ${+functions[_terraform_workspace_new]} )) || _terraform_workspace_new() { + _arguments \ + '-lock=[(true) Don'\''t hold a state lock during the operation. This is dangerous if others might concurrently run commands against the same workspace.]:lock:(true false)' \ + '-lock-timeout=[(0s) Duration to retry a state lock.]' \ + '-state=[(path) Copy an existing state file into the new workspace.]:statefile:_files -g "*.tfstate"' \ + '::' \ + ':name:' +} + +(( ${+functions[_terraform_workspace_select]} )) || _terraform_workspace_select() { + _arguments \ + '-or-create=[(false) Create the Terraform workspace if it doesn'\''t exist.]:or_create:(true false)' \ + '::' \ + ':name:__terraform_workspaces' +} + +(( ${+functions[_terraform_workspace_show]} )) || _terraform_workspace_show() { + _arguments +} + +(( ${+functions[__terraform_workspaces]} )) || __terraform_workspaces() { + local workspace + local -a workspaces + terraform workspace list | while read -r workspace; do + if [[ -z "${workspace}" ]]; then + continue + fi + workspaces+=( "${workspace#[ *] }" ) + done + compadd "${@}" - "${workspaces[@]}" +} + +_terraform() { + _arguments \ + '-chdir=[(DIR) Switch to a different working directory before executing the given subcommand.]:chdir:_files -/' \ + '-help[Show this help output, or the help for a specified subcommand.]' \ + '-version[An alias for the "version" subcommand.]' \ + '*::terraform command:_terraform_commands' +} + +# don't run the completion function when being source-ed or eval-ed +if [ "${funcstack[1]}" = '_terraform' ]; then + _terraform fi - -local -a _command_args -case "$words[1]" in - 0.12upgrade) - __012upgrade ;; - 0.13upgrade) - __013upgrade ;; - apply) - __apply ;; - console) - __console;; - destroy) - __destroy ;; - fmt) - __fmt;; - force-unlock) - __force_unlock;; - get) - __get ;; - graph) - __graph ;; - import) - __import;; - init) - __init ;; - login) - __login ;; - logout) - __logout ;; - output) - __output ;; - plan) - __plan ;; - providers) - test $CURRENT -lt 3 && __providers - [[ $words[2] = "mirror" ]] && __providers_mirror - [[ $words[2] = "schema" ]] && __providers_schema - ;; - refresh) - __refresh ;; - show) - __show ;; - state) - test $CURRENT -lt 3 && __state - [[ $words[2] = "list" ]] && __state_list - [[ $words[2] = "mv" ]] && __state_mv - [[ $words[2] = "push" ]] && __state_push - [[ $words[2] = "replace-provider" ]] && __state_replace_provider - [[ $words[2] = "rm" ]] && __state_rm - [[ $words[2] = "show" ]] && __state_show - ;; - taint) - __taint ;; - untaint) - __untaint ;; - validate) - __validate ;; - version) - __version ;; - workspace) - test $CURRENT -lt 3 && __workspace ;; -esac From 12cd3b3e399d39b2b458fdd8f1f6286250253476 Mon Sep 17 00:00:00 2001 From: Robert Crews Date: Sun, 3 Mar 2024 04:04:19 -0800 Subject: [PATCH 525/672] feat(python): add auto venv activation (#12248) Co-authored-by: Carlo Sala --- plugins/python/README.md | 16 +++++++++++++--- plugins/python/python.plugin.zsh | 23 +++++++++++++++++++---- 2 files changed, 32 insertions(+), 7 deletions(-) diff --git a/plugins/python/README.md b/plugins/python/README.md index 7bf1b34ac..c99697b22 100644 --- a/plugins/python/README.md +++ b/plugins/python/README.md @@ -22,8 +22,18 @@ plugins=(... python) ## Virtual environments -The plugin provides two utilities to manage Python venvs: +The plugin provides three utilities to manage Python 3.3+ [venv](https://docs.python.org/3/library/venv.html) +virtual environments: -- `mkv [name]`: make a new virtual environment called `name` (default: `venv`) in current directory. +- `mkv [name]`: make a new virtual environment called `name` (default: if set `$PYTHON_VENV_NAME`, else + `venv`) in the current directory. -- `vrun [name]`: activate virtual environment called `name` (default: `venv`) in current directory. +- `vrun [name]`: Activate the virtual environment called `name` (default: if set `$PYTHON_VENV_NAME`, else + `venv`) in the current directory. + +- `auto_vrun`: Automatically activate the venv virtual environment when entering a directory containing + `/bin/activate`, and automatically deactivate it when navigating out of it (including + subdirectories!). + - To enable the feature, set `export PYTHON_AUTO_VRUN=true` before sourcing oh-my-zsh. + - The default virtual environment name is `venv`. To use a different name, set + `export PYTHON_VENV_NAME=`. For example: `export PYTHON_VENV_NAME=".venv"` diff --git a/plugins/python/python.plugin.zsh b/plugins/python/python.plugin.zsh index 77d4bf425..f6ea85027 100644 --- a/plugins/python/python.plugin.zsh +++ b/plugins/python/python.plugin.zsh @@ -51,11 +51,12 @@ alias pyserver="python3 -m http.server" ## venv utilities +: ${PYTHON_VENV_NAME:=venv} # Activate a the python virtual environment specified. -# If none specified, use 'venv'. +# If none specified, use $PYTHON_VENV_NAME, else 'venv'. function vrun() { - local name="${1:-venv}" + local name="${1:-$PYTHON_VENV_NAME}" local venvpath="${name:P}" if [[ ! -d "$venvpath" ]]; then @@ -72,12 +73,26 @@ function vrun() { echo "Activated virtual environment ${name}" } -# Create a new virtual environment, with default name 'venv'. +# Create a new virtual environment using the specified name. +# If none specfied, use $PYTHON_VENV_NAME function mkv() { - local name="${1:-venv}" + local name="${1:-$PYTHON_VENV_NAME}" local venvpath="${name:P}" python3 -m venv "${name}" || return echo >&2 "Created venv in '${venvpath}'" vrun "${name}" } + +if [[ "$PYTHON_AUTO_VRUN" == "true" ]]; then + # Automatically activate venv when changing dir + auto_vrun() { + if [[ -f "${PYTHON_VENV_NAME}/bin/activate" ]]; then + source "${PYTHON_VENV_NAME}/bin/activate" > /dev/null 2>&1 + else + (( $+functions[deactivate] )) && deactivate > /dev/null 2>&1 + fi + } + add-zsh-hook chpwd auto_vrun + auto_vrun +fi From f17aa2ffa8c12b71518f1b0233edca3a0dd7cade Mon Sep 17 00:00:00 2001 From: Maxime Brunet Date: Sun, 3 Mar 2024 20:22:41 +0000 Subject: [PATCH 526/672] fix(terraform): pass `-chdir` to completion commands (#12254) --- plugins/terraform/_terraform | 166 +++++++++++++++++++---------------- 1 file changed, 91 insertions(+), 75 deletions(-) diff --git a/plugins/terraform/_terraform b/plugins/terraform/_terraform index aad1c6096..f72f3e552 100644 --- a/plugins/terraform/_terraform +++ b/plugins/terraform/_terraform @@ -29,7 +29,7 @@ compdef _terraform terraform 'version:Show the current Terraform version' 'workspace:Workspace management' ) - if ((CURRENT == 1)); then + if (( CURRENT == 1 )); then _describe -t commands 'terraform commands' _terraform_cmds return fi @@ -38,6 +38,8 @@ compdef _terraform terraform cmd="${${_terraform_cmds[(r)$words[1]:*]%%:*}}" curcontext="${curcontext%:*:*}:terraform-${cmd}:" + local __chdir="${opt_args[-chdir]:-.}" + if (( ${+functions[_terraform_$cmd]} )); then "_terraform_${cmd}" else @@ -48,7 +50,7 @@ compdef _terraform terraform (( ${+functions[_terraform_apply]} )) || _terraform_apply() { _arguments \ '-auto-approve[Skip interactive approval of plan before applying.]' \ - '-backup=[(path) Path to backup the existing state file before modifying. Defaults to the "-state-out" path with ".backup" extension. Set to "-" to disable backup.]:backupfile:_files -g "*.backup"' \ + '-backup=[(path) Path to backup the existing state file before modifying. Defaults to the "-state-out" path with ".backup" extension. Set to "-" to disable backup.]:backupfile:_files -W __chdir -g "*.backup"' \ '-compact-warnings[If Terraform produces any warnings that are not accompanied by errors, show them in a more compact form that includes only the summary messages.]' \ '-destroy[Destroy Terraform-managed infrastructure. The command "terraform destroy" is a convenience alias for this option.]' \ '-lock=[(true) Don'\''t hold a state lock during the operation. This is dangerous if others might concurrently run commands against the same workspace.]:lock:(true false)' \ @@ -58,12 +60,12 @@ compdef _terraform terraform '-parallelism=[(10) Limit the number of parallel resource operations.]' \ '-refresh=[(true) Skip checking for external changes to remote objects while creating the plan. This can potentially make planning faster, but at the expense of possibly planning against a stale record of the remote system state.]:refresh:(true false)' \ '*-replace=[(resource) Force replacement of a particular resource instance using its resource address. If applying would'\''ve normally produced an update or no-op action for this instance, Terraform will replace it instead. You can use this option multiple times to replace more than one object.]:resource:__terraform_state_resources' \ - '-state=[(terraform.tfstate) Path to read and save state (unless state-out is specified).]:statefile:_files -g "*.tfstate"' \ - '-state-out=[(path) Path to write state to that is different than "-state". This can be used to preserve the old state.]:statefile:_files -g "*.tfstate"' \ + '-state=[(terraform.tfstate) Path to read and save state (unless state-out is specified).]:statefile:_files -W __chdir -g "*.tfstate"' \ + '-state-out=[(path) Path to write state to that is different than "-state". This can be used to preserve the old state.]:statefile:_files -W __chdir -g "*.tfstate"' \ '*-target=[(resource) Limit the operation to only the given module, resource, or resource instance and all of its dependencies. You can use this option multiple times to include more than one object. This is for exceptional use only.]:target:__terraform_state_resources' \ '*-var=[(for=bar) Set a value for one of the input variables in the root module of the configuration. Use this option more than once to set more than one variable.]' \ - '*-var-file=[(foo) Load variable values from the given file, in addition to the default files terraform.tfvars and *.auto.tfvars. Use this option more than once to include more than one variables file.]:file:_files -g "*.tfvars{,.json}"' \ - ':plan:_files -' + '*-var-file=[(foo) Load variable values from the given file, in addition to the default files terraform.tfvars and *.auto.tfvars. Use this option more than once to include more than one variables file.]:file:_files -W __chdir -g "*.tfvars{,.json}"' \ + ':plan:_files -W __chdir -' } (( ${+functions[_terraform_console]} )) || _terraform_console() { @@ -71,13 +73,13 @@ compdef _terraform terraform '-state=[(terraform.tfstate) Legacy option for the local backend only. See the local backend'\''s documentation for more information.]' \ '-plan[Create a new plan (as if running "terraform plan") and then evaluate expressions against its planned state, instead of evaluating against the current state. You can use this to inspect the effects of configuration changes that haven'\''t been applied yet.]' \ '*-var=[(for=bar) Set a variable in the Terraform configuration. This flag can be set multiple times.]' \ - '*-var-file=[(foo) Set variables in the Terraform configuration from a file. If "terraform.tfvars" or any ".auto.tfvars" files are present, they will be automatically loaded.]:file:_files -g "*.tfvars{,.json}"' + '*-var-file=[(foo) Set variables in the Terraform configuration from a file. If "terraform.tfvars" or any ".auto.tfvars" files are present, they will be automatically loaded.]:file:_files -W __chdir -g "*.tfvars{,.json}"' } (( ${+functions[_terraform_destroy]} )) || _terraform_destroy() { _arguments \ '-auto-approve[Skip interactive approval of plan before applying.]' \ - '-backup=[(path) Path to backup the existing state file before modifying. Defaults to the "-state-out" path with ".backup" extension. Set to "-" to disable backup.]:backupfile:_files -g "*.backup"' \ + '-backup=[(path) Path to backup the existing state file before modifying. Defaults to the "-state-out" path with ".backup" extension. Set to "-" to disable backup.]:backupfile:_files -W __chdir -g "*.backup"' \ '-compact-warnings[If Terraform produces any warnings that are not accompanied by errors, show them in a more compact form that includes only the summary messages.]' \ '-lock=[(true) Don'\''t hold a state lock during the operation. This is dangerous if others might concurrently run commands against the same workspace.]:lock:(true false)' \ '-lock-timeout=[(0s) Duration to retry a state lock.]' \ @@ -85,11 +87,11 @@ compdef _terraform terraform '-no-color[If specified, output won'\''t contain any color.]' \ '-parallelism=[(10) Limit the number of parallel resource operations.]' \ '-refresh=[(true) Update state prior to checking for differences. This has no effect if a plan file is given to apply.]:refresh:(true false)' \ - '-state=[(terraform.tfstate) Path to read and save state (unless state-out is specified).]:statefile:_files -g "*.tfstate"' \ - '-state-out=[(path) Path to write state to that is different than "-state". This can be used to preserve the old state.]:statefile:_files -g "*.tfstate"' \ + '-state=[(terraform.tfstate) Path to read and save state (unless state-out is specified).]:statefile:_files -W __chdir -g "*.tfstate"' \ + '-state-out=[(path) Path to write state to that is different than "-state". This can be used to preserve the old state.]:statefile:_files -W __chdir -g "*.tfstate"' \ '*-target=[(resource) Limit the operation to only the given module, resource, or resource instance and all of its dependencies. You can use this option multiple times to include more than one object. This is for exceptional use only.]:target:__terraform_state_resources' \ '*-var=[(for=bar) Set a value for one of the input variables in the root module of the configuration. Use this option more than once to set more than one variable.]' \ - '*-var-file=[(foo) Load variable values from the given file, in addition to the default files terraform.tfvars and *.auto.tfvars. Use this option more than once to include more than one variables file.]:file:_files -g "*.tfvars{,.json}"' + '*-var-file=[(foo) Load variable values from the given file, in addition to the default files terraform.tfvars and *.auto.tfvars. Use this option more than once to include more than one variables file.]:file:_files -W __chdir -g "*.tfvars{,.json}"' } (( ${+functions[_terraform_fmt]} )) || _terraform_fmt() { @@ -100,7 +102,7 @@ compdef _terraform terraform '-check[Check if the input is formatted. Exit status will be 0 if all input is properly formatted and non-zero otherwise.]' \ '-no-color[If specified, output won'\''t contain any color.]' \ '-recursive[Also process files in subdirectories. By default, only the given directory (or current directory) is processed.]' \ - '*:targets:_files -' + '*:targets:_files -W __chdir -' } (( ${+functions[_terraform_force-unlock]} )) || _terraform_force-unlock() { @@ -113,29 +115,29 @@ compdef _terraform terraform _arguments \ '-update[Check already-downloaded modules for available updates and install the newest versions available.]' \ '-no-color[Disable text coloring in the output.]' \ - '-test-directory=[(tests) Set the Terraform test directory, defaults to "tests".]:test_directory:_files -/' + '-test-directory=[(tests) Set the Terraform test directory, defaults to "tests".]:test_directory:_files -W __chdir -/' } (( ${+functions[_terraform_graph]} )) || _terraform_graph() { _arguments \ '-draw-cycles[Highlight any cycles in the graph with colored edges. This helps when diagnosing cycle errors. This option is supported only when illustrating a real evaluation graph, selected using the -type=TYPE option.]' \ '-module-depth=[(-1) (deprecated) In prior versions of Terraform, specified the depth of modules to show in the output.]' \ - '-plan=[Render graph using the specified plan file instead of the configuration in the current directory. Implies -type=apply.]:plan:_files -' \ + '-plan=[Render graph using the specified plan file instead of the configuration in the current directory. Implies -type=apply.]:plan:_files -W __chdir -' \ '-type=[(plan) Type of operation graph to output. Can be: plan, plan-refresh-only, plan-destroy, or apply. By default Terraform just summarizes the relationships between the resources in your configuration, without any particular operation in mind. Full operation graphs are more detailed but therefore often harder to read.]:type:(plan plan-refresh-only plan-destroy apply)' } (( ${+functions[_terraform_import]} )) || _terraform_import() { _arguments \ - '-backup=[(path) Path to backup the existing state file before modifying. Defaults to the "-state-out" path with ".backup" extension. Set to "-" to disable backup.]:backupfile:_files -g "*.backup"' \ - '-config=[(path) Path to a directory of Terraform configuration files to use to configure the provider. Defaults to pwd. If no config files are present, they must be provided via the input prompts or env vars.]:config:_files -/' \ + '-backup=[(path) Path to backup the existing state file before modifying. Defaults to the "-state-out" path with ".backup" extension. Set to "-" to disable backup.]:backupfile:_files -W __chdir -g "*.backup"' \ + '-config=[(path) Path to a directory of Terraform configuration files to use to configure the provider. Defaults to pwd. If no config files are present, they must be provided via the input prompts or env vars.]:config:_files -W __chdir -/' \ '-input=[(true) Disable interactive input prompts.]:input:(true false)' \ '-lock=[(true) Don'\''t hold a state lock during the operation. This is dangerous if others might concurrently run commands against the same workspace.]:lock:(true false)' \ '-lock-timeout=[(0s) Duration to retry a state lock.]' \ '-no-color[If specified, output will contain no color.]' \ - '-state=[(PATH) Path to the source state file. Defaults to the configured backend, or "terraform.tfstate"]:statefile:_files -g "*.tfstate"' \ - '-state-out=[(PATH) Path to the destination state file to write to. If this is not specified, the source state file will be used. This can be a new or existing path.]:statefile:_files -g "*.tfstate"' \ + '-state=[(PATH) Path to the source state file. Defaults to the configured backend, or "terraform.tfstate"]:statefile:_files -W __chdir -g "*.tfstate"' \ + '-state-out=[(PATH) Path to the destination state file to write to. If this is not specified, the source state file will be used. This can be a new or existing path.]:statefile:_files -W __chdir -g "*.tfstate"' \ '*-var=[(for=bar) Set a variable in the Terraform configuration. This flag can be set multiple times. This is only useful with the "-config" flag.]' \ - '*-var-file=[(foo) Set variables in the Terraform configuration from a file. If "terraform.tfvars" or any ".auto.tfvars" files are present, they will be automatically loaded.]:file:_files -g "*.tfvars{,.json}"' \ + '*-var-file=[(foo) Set variables in the Terraform configuration from a file. If "terraform.tfvars" or any ".auto.tfvars" files are present, they will be automatically loaded.]:file:_files -W __chdir -g "*.tfvars{,.json}"' \ ':addr:' \ ':id:' } @@ -143,21 +145,21 @@ compdef _terraform terraform (( ${+functions[_terraform_init]} )) || _terraform_init() { _arguments \ '-backend=[(true) Disable backend or Terraform Cloud initialization for this configuration and use what was previously initialized instead.]:backend:(true false)' \ - '-backend-config=[Configuration to be merged with what is in the configuration file'\''s '\''backend'\'' block. This can be either a path to an HCL file with key/value assignments (same format as terraform.tfvars) or a '\''key=value'\'' format, and can be specified multiple times. The backend type must be in the configuration itself.]:backend_config:_files -' \ + '-backend-config=[Configuration to be merged with what is in the configuration file'\''s '\''backend'\'' block. This can be either a path to an HCL file with key/value assignments (same format as terraform.tfvars) or a '\''key=value'\'' format, and can be specified multiple times. The backend type must be in the configuration itself.]:backend_config:_files -W __chdir -' \ '-force-copy[Suppress prompts about copying state data. This is equivalent to providing a "yes" to all confirmation prompts.]' \ - '-from-module=[Copy the contents of the given module into the target directory before initialization.]:from_module:_files -/' \ + '-from-module=[Copy the contents of the given module into the target directory before initialization.]:from_module:_files -W __chdir -/' \ '-get=[(true) Disable downloading modules for this configuration.]:get:(true false)' \ '-input=[(true) Disable interactive prompts. Note that some actions may require interactive prompts and will error if input is disabled.]:input:(true false)' \ '-lock=[(true) Don'\''t hold a state lock during backend migration. This is dangerous if others might concurrently run commands against the same workspace.]:lock:(true false)' \ '-lock-timeout=[(0s) Duration to retry a state lock.]' \ '-no-color[If specified, output will contain no color.]' \ - '-plugin-dir[Directory containing plugin binaries. This overrides all default search paths for plugins, and prevents the automatic installation of plugins. This flag can be used multiple times.]:plugin_dir:_files -/' \ + '-plugin-dir[Directory containing plugin binaries. This overrides all default search paths for plugins, and prevents the automatic installation of plugins. This flag can be used multiple times.]:plugin_dir:_files -W __chdir -/' \ '-reconfigure[Reconfigure the backend, ignoring any saved configuration.]' \ '-migrate-state[Reconfigure a backend, and attempt to migrate any existing state.]' \ '-upgrade[Install the latest module and provider versions allowed within configured constraints, overriding the default behavior of selecting exactly the version recorded in the dependency lockfile.]' \ '-lockfile=[Set a dependency lockfile mode. Currently only "readonly" is valid.]:lockfile:( readonly )' \ '-ignore-remote-version[A rare option used for Terraform Cloud and the remote backend only. Set this to ignore checking that the local and remote Terraform versions use compatible state representations, making an operation proceed even when there is a potential mismatch. See the documentation on configuring Terraform with Terraform Cloud for more information.]' \ - '-test-directory=[(tests) Set the Terraform test directory, defaults to "tests".]:test_directory:_files -/' + '-test-directory=[(tests) Set the Terraform test directory, defaults to "tests".]:test_directory:_files -W __chdir -/' } (( ${+functions[_terraform_login]} )) || _terraform_login() { @@ -171,17 +173,22 @@ compdef _terraform terraform } (( ${+functions[_terraform_metadata]} )) || _terraform_metadata() { + _arguments \ + '*::terraform metadata command:_terraform_metadata_commands' +} + +(( ${+functions[_terraform_metadata_commands]} )) || _terraform_metadata_commands() { local -a _metadata_cmds _metadata_cmds=( 'functions:Show signatures and descriptions for the available functions' ) - if [[ "${CURRENT}" -lt 3 ]]; then + if (( CURRENT == 1 )); then _describe -t commands "terraform metadata commands" _metadata_cmds return fi local curcontext="${curcontext}" - cmd="${${_metadata_cmds[(r)$words[2]:*]%%:*}}" + cmd="${${_metadata_cmds[(r)$words[1]:*]%%:*}}" curcontext="${curcontext%:*:*}:terraform-metadata-${cmd}:" if (( ${+functions[_terraform_metadata_$cmd]} )); then @@ -193,13 +200,12 @@ compdef _terraform terraform (( ${+functions[_terraform_metadata_functions]} )) || _terraform_metadata_functions() { _arguments \ - '-json' \ - '::' + '-json[]' } (( ${+functions[_terraform_output]} )) || _terraform_output() { _arguments \ - '-state=[(path) Path to the state file to read. Defaults to "terraform.tfstate". Ignored when remote state is used.]:statefile:_files -g "*.tfstate"' \ + '-state=[(path) Path to the state file to read. Defaults to "terraform.tfstate". Ignored when remote state is used.]:statefile:_files -W __chdir -g "*.tfstate"' \ '-no-color[If specified, output will contain no color.]' \ '-json[If specified, machine readable output will be printed in JSON format]' \ '-raw[For value types that can be automatically converted to a string, will print the raw string directly, rather than a human-oriented representation of the value.]' \ @@ -221,31 +227,32 @@ compdef _terraform terraform '-refresh=[(true) Skip checking for external changes to remote objects while creating the plan. This can potentially make planning faster, but at the expense of possibly planning against a stale record of the remote system state.]:refresh:(true false)' \ '-refresh-only[Select the "refresh only" planning mode, which checks whether remote objects still match the outcome of the most recent Terraform apply but does not propose any actions to undo any changes made outside of Terraform.]' \ '*-replace=[(resource) Force replacement of a particular resource instance using its resource address. If the plan would'\''ve normally produced an update or no-op action for this instance, Terraform will plan to replace it instead. You can use this option multiple times to replace more than one object.]:replace:__terraform_state_resources' \ - '-state=[(statefile) Path to a Terraform state file to use to look up Terraform-managed resources. By default it will use the state "terraform.tfstate" if it exists.]:statefile:_files -g "*.tfstate"' \ + '-state=[(statefile) Path to a Terraform state file to use to look up Terraform-managed resources. By default it will use the state "terraform.tfstate" if it exists.]:statefile:_files -W __chdir -g "*.tfstate"' \ '*-target=[(resource) Limit the planning operation to only the given module, resource, or resource instance and all of its dependencies. You can use this option multiple times to include more than one object. This is for exceptional use only.]:target:__terraform_state_resources' \ '*-var=[(for=bar) Set a value for one of the input variables in the root module of the configuration. Use this option more than once to set more than one variable.]' \ - '*-var-file=[(foo) Load variable values from the given file, in addition to the default files terraform.tfvars and *.auto.tfvars. Use this option more than once to include more than one variables file.]:file:_files -g "*.tfvars{,.json}"' + '*-var-file=[(foo) Load variable values from the given file, in addition to the default files terraform.tfvars and *.auto.tfvars. Use this option more than once to include more than one variables file.]:file:_files -W __chdir -g "*.tfvars{,.json}"' } (( ${+functions[_terraform_providers]} )) || _terraform_providers() { + _arguments \ + '-test-directory=[(path) Set the Terraform test directory, defaults to "tests".]:test_directory:_files -W __chdir -/' \ + '*::terraform providers command:_terraform_providers_commands' +} + +(( ${+functions[_terraform_providers_commands]} )) || _terraform_providers_commands() { local -a _providers_cmds _providers_cmds=( 'lock:Write out dependency locks for the configured providers' 'mirror:Save local copies of all required provider plugins' 'schema:Show schemas for the providers used in the configuration' ) - - if [[ "${CURRENT}" -lt 3 ]]; then - _arguments \ - '-test-directory=[(path) Set the Terraform test directory, defaults to "tests".]:test_directory:_files -/' \ - '*:: :->command' - + if (( CURRENT == 1 )); then _describe -t commands "terraform providers commands" _providers_cmds return fi local curcontext="${curcontext}" - cmd="${${_providers_cmds[(r)$words[2]:*]%%:*}}" + cmd="${${_providers_cmds[(r)$words[1]:*]%%:*}}" curcontext="${curcontext%:*:*}:terraform-providers-${cmd}:" if (( ${+functions[_terraform_providers_$cmd]} )); then @@ -257,7 +264,7 @@ compdef _terraform terraform (( ${+functions[_terraform_providers_lock]} )) || _terraform_providers_lock() { _arguments \ - '-fs-mirror=[(dir) Consult the given filesystem mirror directory instead of the origin registry for each of the given providers.]:fs_mirror:_files -/' \ + '-fs-mirror=[(dir) Consult the given filesystem mirror directory instead of the origin registry for each of the given providers.]:fs_mirror:_files -W __chdir -/' \ '-net-mirror=[(url) Consult the given network mirror (given as a base URL) instead of the origin registry for each of the given providers.]' \ '*-platform=[(os_arch) Choose a target platform to request package checksums for.]' \ '*:provider:' @@ -267,39 +274,43 @@ compdef _terraform terraform _arguments \ '*-platform=[(os_arch) Choose which target platform to build a mirror for.]' \ '::' \ - ':target_dir:_files -/' + ':target_dir:_files -W __chdir -/' } (( ${+functions[_terraform_providers_schema]} )) || _terraform_providers_schema() { _arguments \ - '-json[]' \ - '::' + '-json[]' } (( ${+functions[_terraform_refresh]} )) || _terraform_refresh() { _arguments \ - '-backup=[(path) Path to backup the existing state file before modifying. Defaults to the "-state-out" path with ".backup" extension. Set to "-" to disable backup.]::backupfile:_files -g "*.backup"' \ + '-backup=[(path) Path to backup the existing state file before modifying. Defaults to the "-state-out" path with ".backup" extension. Set to "-" to disable backup.]::backupfile:_files -W __chdir -g "*.backup"' \ '-compact-warnings[If Terraform produces any warnings that are not accompanied by errors, show them in a more compact form that includes only the summary messages.]' \ '-input=[(true) Ask for input for variables if not directly set.]:input:(true false)' \ '-lock=[(true) Don'\''t hold a state lock during the operation. This is dangerous if others might concurrently run commands against the same workspace.]:lock:(true false)' \ '-lock-timeout=[(0s) Duration to retry a state lock.]' \ '-no-color[If specified, output will not contain any color.]' \ '-parallelism=[(10) Limit the number of parallel resource operations.]' \ - '-state=[(path) Path to read and save state (unless state-out is specified). Defaults to "terraform.tfstate".]:statefile:_files -g "*.tfstate"' \ - '-state-out=[(path) Path to write state to that is different than "-state". This can be used to preserve the old state.]:statefile:_files -g "*.tfstate"' \ + '-state=[(path) Path to read and save state (unless state-out is specified). Defaults to "terraform.tfstate".]:statefile:_files -W __chdir -g "*.tfstate"' \ + '-state-out=[(path) Path to write state to that is different than "-state". This can be used to preserve the old state.]:statefile:_files -W __chdir -g "*.tfstate"' \ '*-target=[(resource) A Resource Address to target. Operation will be limited to this resource and its dependencies. This flag can be used multiple times.]:target:__terraform_state_resources' \ '*-var=[(for=bar) Set a variable in the Terraform configuration. This flag can be set multiple times.]' \ - '*-var-file=[(foo) Set variables in the Terraform configuration from a file. If "terraform.tfvars" or any ".auto.tfvars" files are present, they will be automatically loaded.]:file:_files -g "*.tfvars{,.json}"' + '*-var-file=[(foo) Set variables in the Terraform configuration from a file. If "terraform.tfvars" or any ".auto.tfvars" files are present, they will be automatically loaded.]:file:_files -W __chdir -g "*.tfvars{,.json}"' } (( ${+functions[_terraform_show]} )) || _terraform_show() { _arguments \ '-json[If specified, output the Terraform plan or state in a machine-readable form.]' \ '-no-color[If specified, output will not contain any color.]' \ - ':path:_files -g "*.tfstate"' + ':path:_files -W __chdir -g "*.tfstate"' } (( ${+functions[_terraform_state]} )) || _terraform_state() { + _arguments \ + '*::terraform state command:_terraform_state_commands' +} + +(( ${+functions[_terraform_state_commands]} )) || _terraform_state_commands() { local -a _state_cmds _state_cmds=( 'list:List resources in the state' @@ -310,13 +321,13 @@ compdef _terraform terraform 'rm:Remove instances from the state' 'show:Show a resource in the state' ) - if [[ "${CURRENT}" -lt 3 ]]; then + if (( CURRENT == 1 )); then _describe -t commands "terraform state commands" _state_cmds return fi local curcontext="${curcontext}" - cmd="${${_state_cmds[(r)$words[2]:*]%%:*}}" + cmd="${${_state_cmds[(r)$words[1]:*]%%:*}}" curcontext="${curcontext%:*:*}:terraform-state-${cmd}:" if (( ${+functions[_terraform_state_$cmd]} )); then @@ -328,7 +339,7 @@ compdef _terraform terraform (( ${+functions[_terraform_state_list]} )) || _terraform_state_list() { _arguments \ - '-state=[(statefile) Path to a Terraform state file to use to look up Terraform-managed resources. By default, Terraform will consult the state of the currently-selected workspace.]:statefile:_files -g "*.tfstate"' \ + '-state=[(statefile) Path to a Terraform state file to use to look up Terraform-managed resources. By default, Terraform will consult the state of the currently-selected workspace.]:statefile:_files -W __chdir -g "*.tfstate"' \ '-id=[(id) Filters the results to include only instances whose resource types have an attribute named id whose value equals the given id string.]' \ '*:address:__terraform_state_resources' } @@ -336,13 +347,13 @@ compdef _terraform terraform (( ${+functions[_terraform_state_mv]} )) || _terraform_state_mv() { _arguments \ '-dry-run[If set, prints out what would'\''ve been moved but doesn'\''t actually move anything.]' \ - '-backup=[(PATH) Path where Terraform should write the backup for the original state. This can"t be disabled. If not set, Terraform will write it to the same path as the statefile with a ".backup" extension.]:backupfile:_files -g "*.backup"' \ - '-backup-out=[(PATH) Path where Terraform should write the backup for the destination state. This can"t be disabled. If not set, Terraform will write it to the same path as the destination state file with a backup extension. This only needs to be specified if -state-out is set to a different path than -state.]:backupfile:_files -g "*.backup"' \ + '-backup=[(PATH) Path where Terraform should write the backup for the original state. This can"t be disabled. If not set, Terraform will write it to the same path as the statefile with a ".backup" extension.]:backupfile:_files -W __chdir -g "*.backup"' \ + '-backup-out=[(PATH) Path where Terraform should write the backup for the destination state. This can"t be disabled. If not set, Terraform will write it to the same path as the destination state file with a backup extension. This only needs to be specified if -state-out is set to a different path than -state.]:backupfile:_files -W __chdir -g "*.backup"' \ '-ignore-remote-version[A rare option used for the remote backend only. See the remote backend documentation for more information.]' \ '-lock=[(true) Don'\''t hold a state lock during the operation. This is dangerous if others might concurrently run commands against the same workspace.]:lock:(true false)' \ '-lock-timeout=[(0s) Duration to retry a state lock.]' \ - '-state=[(path) Path to the source state file. Defaults to the configured backend, or "terraform.tfstate"]:statefile:_files -g "*.tfstate"' \ - '-state-out=[(path) Path to the destination state file to write to. If this isn"t specified, the source state file will be used. This can be a new or existing path.]:statefile:_files -g "*.tfstate"' \ + '-state=[(path) Path to the source state file. Defaults to the configured backend, or "terraform.tfstate"]:statefile:_files -W __chdir -g "*.tfstate"' \ + '-state-out=[(path) Path to the destination state file to write to. If this isn"t specified, the source state file will be used. This can be a new or existing path.]:statefile:_files -W __chdir -g "*.tfstate"' \ '::' \ ':source:__terraform_state_resources' \ ':destination: ' @@ -360,10 +371,10 @@ compdef _terraform terraform (( ${+functions[_terraform_state_replace-provider]} )) || _terraform_state_replace-provider() { _arguments \ '-auto-approve[Skip interactive approval.]' \ - '-backup=[(PATH) Path where Terraform should write the backup for the state file. This can"t be disabled. If not set, Terraform will write it to the same path as the state file with a ".backup" extension.]:backupfile:_files -g "*.backup"' \ + '-backup=[(PATH) Path where Terraform should write the backup for the state file. This can"t be disabled. If not set, Terraform will write it to the same path as the state file with a ".backup" extension.]:backupfile:_files -W __chdir -g "*.backup"' \ '-lock=[(true) Don'\''t hold a state lock during the operation. This is dangerous if others might concurrently run commands against the same workspace.]:lock:(true false)' \ '-lock-timeout=[(0s) Duration to retry a state lock.]' \ - '-state=[(PATH) Path to the source state file. Defaults to the configured backend, or "terraform.tfstate"]:statefile:_files -g "*.tfstate"' \ + '-state=[(PATH) Path to the source state file. Defaults to the configured backend, or "terraform.tfstate"]:statefile:_files -W __chdir -g "*.tfstate"' \ '::' \ ':from_provider_fqn:' \ ':to_provider_fqn:' @@ -372,24 +383,24 @@ compdef _terraform terraform (( ${+functions[_terraform_state_rm]} )) || _terraform_state_rm() { _arguments \ '-dry-run[If set, prints out what would'\''ve been removed but doesn'\''t actually remove anything.]' \ - '-backup=[(PATH) Path where Terraform should write the backup for the original state.]::backupfile:_files -g "*.backup"' \ + '-backup=[(PATH) Path where Terraform should write the backup for the original state.]::backupfile:_files -W __chdir -g "*.backup"' \ '-ignore-remote-version[Continue even if remote and local Terraform versions are incompatible. This may result in an unusable workspace, and should be used with extreme caution.]' \ '-lock=[(true) Don'\''t hold a state lock during the operation. This is dangerous if others might concurrently run commands against the same workspace.]:lock:(true false)' \ '-lock-timeout=[(0s) Duration to retry a state lock.]' \ - '-state=[(PATH) Path to the state file to update. Defaults to the current workspace state.]:statefile:_files -g "*.tfstate"' \ + '-state=[(PATH) Path to the state file to update. Defaults to the current workspace state.]:statefile:_files -W __chdir -g "*.tfstate"' \ '*:address:__terraform_state_resources' } (( ${+functions[_terraform_state_show]} )) || _terraform_state_show() { _arguments \ - '-state=[(statefile) Path to a Terraform state file to use to look up Terraform-managed resources. By default it will use the state "terraform.tfstate" if it exists.]:statefile:_files -g "*.tfstate"' \ + '-state=[(statefile) Path to a Terraform state file to use to look up Terraform-managed resources. By default it will use the state "terraform.tfstate" if it exists.]:statefile:_files -W __chdir -g "*.tfstate"' \ "*:address:__terraform_state_resources" } (( ${+functions[__terraform_state_resources]} )) || __terraform_state_resources() { local resource local -a resources - terraform state list -state="${opt_args[-state]}" 2>/dev/null | while read -r resource; do + terraform -chdir="${__chdir}" state list -state="${opt_args[-state]}" 2>/dev/null | while read -r resource; do resources+=( "${resource}" ) done compadd "${@}" - "${resources[@]}" @@ -398,35 +409,35 @@ compdef _terraform terraform (( ${+functions[_terraform_taint]} )) || _terraform_taint() { _arguments \ '-allow-missing[If specified, the command will succeed (exit code 0) even if the resource is missing.]' \ - '-backup=[(path) Path to backup the existing state file before modifying. Defaults to the "-state-out" path with ".backup" extension. Set to "-" to disable backup.]:backupfile:_files -g "*.backup"' \ + '-backup=[(path) Path to backup the existing state file before modifying. Defaults to the "-state-out" path with ".backup" extension. Set to "-" to disable backup.]:backupfile:_files -W __chdir -g "*.backup"' \ '-ignore-remote-version[A rare option used for the remote backend only. See the remote backend documentation for more information.]' \ '-lock=[(true) Don'\''t hold a state lock during the operation. This is dangerous if others might concurrently run commands against the same workspace.]:lock:(true false)' \ '-lock-timeout=[(0s) Duration to retry a state lock.]' \ - '-state=[(path) Path to read and save state (unless state-out is specified). Defaults to "terraform.tfstate".]:statefile:_files -g "*.tfstate"' \ - '-state-out=[(path) Path to write updated state file. By default, the "-state" path will be used.]:statefile:_files -g "*.tfstate"' \ + '-state=[(path) Path to read and save state (unless state-out is specified). Defaults to "terraform.tfstate".]:statefile:_files -W __chdir -g "*.tfstate"' \ + '-state-out=[(path) Path to write updated state file. By default, the "-state" path will be used.]:statefile:_files -W __chdir -g "*.tfstate"' \ '*:address:__terraform_state_resources' } (( ${+functions[_terraform_test]} )) || _terraform_test() { _arguments \ '-cloud-run=[(source) If specified, Terraform will execute this test run remotely using Terraform Cloud. You must specify the source of a module registered in a private module registry as the argument to this flag. This allows Terraform to associate the cloud run with the correct Terraform Cloud module and organization.]' \ - '*-filter=[(testfile) If specified, Terraform will only execute the test files specified by this flag. You can use this option multiple times to execute more than one test file.]:testfile:_files -g "*.tftest.hcl"' \ + '*-filter=[(testfile) If specified, Terraform will only execute the test files specified by this flag. You can use this option multiple times to execute more than one test file.]:testfile:_files -W __chdir -g "*.tftest.hcl"' \ '-json[If specified, machine readable output will be printed in JSON format]' \ '-no-color[If specified, machine readable output will be printed in JSON format]' \ - '-test-directory=[(path) Set the Terraform test directory, defaults to "tests".]:test_directory:_files -/' \ + '-test-directory=[(path) Set the Terraform test directory, defaults to "tests".]:test_directory:_files -W __chdir -/' \ '*-var=[(for=bar) Set a value for one of the input variables in the root module of the configuration. Use this option more than once to set more than one variable.]' \ - '*-var-file=[(foo) Load variable values from the given file, in addition to the default files terraform.tfvars and *.auto.tfvars. Use this option more than once to include more than one variables file.]:file:_files -g "*.tfvars{,.json}"' \ + '*-var-file=[(foo) Load variable values from the given file, in addition to the default files terraform.tfvars and *.auto.tfvars. Use this option more than once to include more than one variables file.]:file:_files -W __chdir -g "*.tfvars{,.json}"' \ '-verbose[Print the plan or state for each test run block as it executes.]' \ } (( ${+functions[_terraform_untaint]} )) || _terraform_untaint() { _arguments \ '-allow-missing[If specified, the command will succeed (exit code 0) even if the resource is missing.]' \ - '-backup=[(path) Path to backup the existing state file before modifying. Defaults to the "-state-out" path with ".backup" extension. Set to "-" to disable backup.]:backupfile:_files -g "*.backup"' \ + '-backup=[(path) Path to backup the existing state file before modifying. Defaults to the "-state-out" path with ".backup" extension. Set to "-" to disable backup.]:backupfile:_files -W __chdir -g "*.backup"' \ '-lock=[(true) Don'\''t hold a state lock during the operation. This is dangerous if others might concurrently run commands against the same workspace.]:lock:(true false)' \ '-lock-timeout=[(0s) Duration to retry a state lock.]' \ - '-state=[(path) Path to read and save state (unless state-out is specified). Defaults to "terraform.tfstate".]:statefile:_files -g "*.tfstate"' \ - '-state-out=[(path) Path to write updated state file. By default, the "-state" path will be used.]:statefile:_files -g "*.tfstate"' \ + '-state=[(path) Path to read and save state (unless state-out is specified). Defaults to "terraform.tfstate".]:statefile:_files -W __chdir -g "*.tfstate"' \ + '-state-out=[(path) Path to write updated state file. By default, the "-state" path will be used.]:statefile:_files -W __chdir -g "*.tfstate"' \ ':name:__terraform_state_resources' } @@ -435,8 +446,8 @@ compdef _terraform terraform '-json[Produce output in a machine-readable JSON format, suitable for use in text editor integrations and other automated systems.]' \ '-no-color[If specified, output will not contain any color.]' \ '-no-tests[If specified, Terraform will not validate test files.]' \ - '-test-directory=[(path) Set the Terraform test directory, defaults to "tests".]:test_directory:_files -/' \ - ':dir:_files -/' + '-test-directory=[(path) Set the Terraform test directory, defaults to "tests".]:test_directory:_files -W __chdir -/' \ + ':dir:_files -W __chdir -/' } (( ${+functions[_terraform_version]} )) || _terraform_version() { @@ -446,6 +457,11 @@ compdef _terraform terraform } (( ${+functions[_terraform_workspace]} )) || _terraform_workspace() { + _arguments \ + '*::terraform workspace command:_terraform_workspace_commands' +} + +(( ${+functions[_terraform_workspace_commands]} )) || _terraform_workspace_commands() { local -a _workspace_cmds _workspace_cmds=( 'delete:Delete a workspace' @@ -454,13 +470,13 @@ compdef _terraform terraform 'select:Select a workspace' 'show:Show the name of the current workspace' ) - if [[ "${CURRENT}" -lt 3 ]]; then + if (( CURRENT == 1 )); then _describe -t commands "terraform workspace commands" _workspace_cmds return fi local curcontext="${curcontext}" - cmd="${${_workspace_cmds[(r)$words[2]:*]%%:*}}" + cmd="${${_workspace_cmds[(r)$words[1]:*]%%:*}}" curcontext="${curcontext%:*:*}:terraform-workspace-${cmd}:" if (( ${+functions[_terraform_workspace_$cmd]} )); then @@ -487,7 +503,7 @@ compdef _terraform terraform _arguments \ '-lock=[(true) Don'\''t hold a state lock during the operation. This is dangerous if others might concurrently run commands against the same workspace.]:lock:(true false)' \ '-lock-timeout=[(0s) Duration to retry a state lock.]' \ - '-state=[(path) Copy an existing state file into the new workspace.]:statefile:_files -g "*.tfstate"' \ + '-state=[(path) Copy an existing state file into the new workspace.]:statefile:_files -W __chdir -g "*.tfstate"' \ '::' \ ':name:' } @@ -506,7 +522,7 @@ compdef _terraform terraform (( ${+functions[__terraform_workspaces]} )) || __terraform_workspaces() { local workspace local -a workspaces - terraform workspace list | while read -r workspace; do + terraform -chdir="${__chdir}" workspace list | while read -r workspace; do if [[ -z "${workspace}" ]]; then continue fi @@ -517,7 +533,7 @@ compdef _terraform terraform _terraform() { _arguments \ - '-chdir=[(DIR) Switch to a different working directory before executing the given subcommand.]:chdir:_files -/' \ + '-chdir=[(DIR) Switch to a different working directory before executing the given subcommand.]:chdir:_files -W __chdir -/' \ '-help[Show this help output, or the help for a specified subcommand.]' \ '-version[An alias for the "version" subcommand.]' \ '*::terraform command:_terraform_commands' From da16258c5c261606d56836c0fce77188515a6c0e Mon Sep 17 00:00:00 2001 From: Maxime Brunet Date: Mon, 4 Mar 2024 07:28:00 +0000 Subject: [PATCH 527/672] fix(terraform): fix completion repeating flags with value (#12256) --- plugins/terraform/_terraform | 68 ++++++++++++++++++------------------ 1 file changed, 34 insertions(+), 34 deletions(-) diff --git a/plugins/terraform/_terraform b/plugins/terraform/_terraform index f72f3e552..157495814 100644 --- a/plugins/terraform/_terraform +++ b/plugins/terraform/_terraform @@ -54,25 +54,25 @@ compdef _terraform terraform '-compact-warnings[If Terraform produces any warnings that are not accompanied by errors, show them in a more compact form that includes only the summary messages.]' \ '-destroy[Destroy Terraform-managed infrastructure. The command "terraform destroy" is a convenience alias for this option.]' \ '-lock=[(true) Don'\''t hold a state lock during the operation. This is dangerous if others might concurrently run commands against the same workspace.]:lock:(true false)' \ - '-lock-timeout=[(0s) Duration to retry a state lock.]' \ + '-lock-timeout=[(0s) Duration to retry a state lock.]:lock_timeout:' \ '-input=[(true) Ask for input for variables if not directly set.]:input:(true false)' \ '-no-color[If specified, output won'\''t contain any color.]' \ - '-parallelism=[(10) Limit the number of parallel resource operations.]' \ + '-parallelism=[(10) Limit the number of parallel resource operations.]:parallelism:' \ '-refresh=[(true) Skip checking for external changes to remote objects while creating the plan. This can potentially make planning faster, but at the expense of possibly planning against a stale record of the remote system state.]:refresh:(true false)' \ '*-replace=[(resource) Force replacement of a particular resource instance using its resource address. If applying would'\''ve normally produced an update or no-op action for this instance, Terraform will replace it instead. You can use this option multiple times to replace more than one object.]:resource:__terraform_state_resources' \ '-state=[(terraform.tfstate) Path to read and save state (unless state-out is specified).]:statefile:_files -W __chdir -g "*.tfstate"' \ '-state-out=[(path) Path to write state to that is different than "-state". This can be used to preserve the old state.]:statefile:_files -W __chdir -g "*.tfstate"' \ '*-target=[(resource) Limit the operation to only the given module, resource, or resource instance and all of its dependencies. You can use this option multiple times to include more than one object. This is for exceptional use only.]:target:__terraform_state_resources' \ - '*-var=[(for=bar) Set a value for one of the input variables in the root module of the configuration. Use this option more than once to set more than one variable.]' \ + '*-var=[(for=bar) Set a value for one of the input variables in the root module of the configuration. Use this option more than once to set more than one variable.]:var:' \ '*-var-file=[(foo) Load variable values from the given file, in addition to the default files terraform.tfvars and *.auto.tfvars. Use this option more than once to include more than one variables file.]:file:_files -W __chdir -g "*.tfvars{,.json}"' \ ':plan:_files -W __chdir -' } (( ${+functions[_terraform_console]} )) || _terraform_console() { _arguments \ - '-state=[(terraform.tfstate) Legacy option for the local backend only. See the local backend'\''s documentation for more information.]' \ + '-state=[(terraform.tfstate) Legacy option for the local backend only. See the local backend'\''s documentation for more information.]:statefile:_files -W __chdir -g "*.tfstate"' \ '-plan[Create a new plan (as if running "terraform plan") and then evaluate expressions against its planned state, instead of evaluating against the current state. You can use this to inspect the effects of configuration changes that haven'\''t been applied yet.]' \ - '*-var=[(for=bar) Set a variable in the Terraform configuration. This flag can be set multiple times.]' \ + '*-var=[(for=bar) Set a variable in the Terraform configuration. This flag can be set multiple times.]:var:' \ '*-var-file=[(foo) Set variables in the Terraform configuration from a file. If "terraform.tfvars" or any ".auto.tfvars" files are present, they will be automatically loaded.]:file:_files -W __chdir -g "*.tfvars{,.json}"' } @@ -82,15 +82,15 @@ compdef _terraform terraform '-backup=[(path) Path to backup the existing state file before modifying. Defaults to the "-state-out" path with ".backup" extension. Set to "-" to disable backup.]:backupfile:_files -W __chdir -g "*.backup"' \ '-compact-warnings[If Terraform produces any warnings that are not accompanied by errors, show them in a more compact form that includes only the summary messages.]' \ '-lock=[(true) Don'\''t hold a state lock during the operation. This is dangerous if others might concurrently run commands against the same workspace.]:lock:(true false)' \ - '-lock-timeout=[(0s) Duration to retry a state lock.]' \ + '-lock-timeout=[(0s) Duration to retry a state lock.]:lock_timeout:' \ '-input=[(true) Ask for input for variables if not directly set.]:input:(true false)' \ '-no-color[If specified, output won'\''t contain any color.]' \ - '-parallelism=[(10) Limit the number of parallel resource operations.]' \ + '-parallelism=[(10) Limit the number of parallel resource operations.]:parallelism:' \ '-refresh=[(true) Update state prior to checking for differences. This has no effect if a plan file is given to apply.]:refresh:(true false)' \ '-state=[(terraform.tfstate) Path to read and save state (unless state-out is specified).]:statefile:_files -W __chdir -g "*.tfstate"' \ '-state-out=[(path) Path to write state to that is different than "-state". This can be used to preserve the old state.]:statefile:_files -W __chdir -g "*.tfstate"' \ '*-target=[(resource) Limit the operation to only the given module, resource, or resource instance and all of its dependencies. You can use this option multiple times to include more than one object. This is for exceptional use only.]:target:__terraform_state_resources' \ - '*-var=[(for=bar) Set a value for one of the input variables in the root module of the configuration. Use this option more than once to set more than one variable.]' \ + '*-var=[(for=bar) Set a value for one of the input variables in the root module of the configuration. Use this option more than once to set more than one variable.]:var:' \ '*-var-file=[(foo) Load variable values from the given file, in addition to the default files terraform.tfvars and *.auto.tfvars. Use this option more than once to include more than one variables file.]:file:_files -W __chdir -g "*.tfvars{,.json}"' } @@ -121,7 +121,7 @@ compdef _terraform terraform (( ${+functions[_terraform_graph]} )) || _terraform_graph() { _arguments \ '-draw-cycles[Highlight any cycles in the graph with colored edges. This helps when diagnosing cycle errors. This option is supported only when illustrating a real evaluation graph, selected using the -type=TYPE option.]' \ - '-module-depth=[(-1) (deprecated) In prior versions of Terraform, specified the depth of modules to show in the output.]' \ + '-module-depth=[(-1) (deprecated) In prior versions of Terraform, specified the depth of modules to show in the output.]:module_depth:' \ '-plan=[Render graph using the specified plan file instead of the configuration in the current directory. Implies -type=apply.]:plan:_files -W __chdir -' \ '-type=[(plan) Type of operation graph to output. Can be: plan, plan-refresh-only, plan-destroy, or apply. By default Terraform just summarizes the relationships between the resources in your configuration, without any particular operation in mind. Full operation graphs are more detailed but therefore often harder to read.]:type:(plan plan-refresh-only plan-destroy apply)' } @@ -132,11 +132,11 @@ compdef _terraform terraform '-config=[(path) Path to a directory of Terraform configuration files to use to configure the provider. Defaults to pwd. If no config files are present, they must be provided via the input prompts or env vars.]:config:_files -W __chdir -/' \ '-input=[(true) Disable interactive input prompts.]:input:(true false)' \ '-lock=[(true) Don'\''t hold a state lock during the operation. This is dangerous if others might concurrently run commands against the same workspace.]:lock:(true false)' \ - '-lock-timeout=[(0s) Duration to retry a state lock.]' \ + '-lock-timeout=[(0s) Duration to retry a state lock.]:lock_timeout:' \ '-no-color[If specified, output will contain no color.]' \ '-state=[(PATH) Path to the source state file. Defaults to the configured backend, or "terraform.tfstate"]:statefile:_files -W __chdir -g "*.tfstate"' \ '-state-out=[(PATH) Path to the destination state file to write to. If this is not specified, the source state file will be used. This can be a new or existing path.]:statefile:_files -W __chdir -g "*.tfstate"' \ - '*-var=[(for=bar) Set a variable in the Terraform configuration. This flag can be set multiple times. This is only useful with the "-config" flag.]' \ + '*-var=[(for=bar) Set a variable in the Terraform configuration. This flag can be set multiple times. This is only useful with the "-config" flag.]:var:' \ '*-var-file=[(foo) Set variables in the Terraform configuration from a file. If "terraform.tfvars" or any ".auto.tfvars" files are present, they will be automatically loaded.]:file:_files -W __chdir -g "*.tfvars{,.json}"' \ ':addr:' \ ':id:' @@ -151,7 +151,7 @@ compdef _terraform terraform '-get=[(true) Disable downloading modules for this configuration.]:get:(true false)' \ '-input=[(true) Disable interactive prompts. Note that some actions may require interactive prompts and will error if input is disabled.]:input:(true false)' \ '-lock=[(true) Don'\''t hold a state lock during backend migration. This is dangerous if others might concurrently run commands against the same workspace.]:lock:(true false)' \ - '-lock-timeout=[(0s) Duration to retry a state lock.]' \ + '-lock-timeout=[(0s) Duration to retry a state lock.]:lock_timeout:' \ '-no-color[If specified, output will contain no color.]' \ '-plugin-dir[Directory containing plugin binaries. This overrides all default search paths for plugins, and prevents the automatic installation of plugins. This flag can be used multiple times.]:plugin_dir:_files -W __chdir -/' \ '-reconfigure[Reconfigure the backend, ignoring any saved configuration.]' \ @@ -218,18 +218,18 @@ compdef _terraform terraform '-destroy[Select the "destroy" planning mode, which creates a plan to destroy all objects currently managed by this Terraform configuration instead of the usual behavior.]' \ '-detailed-exitcode[Return detailed exit codes when the command exits. This will change the meaning of exit codes to: 0 - Succeeded, diff is empty (no changes); 1 - Errored, 2 - Succeeded; there is a diff]' \ '-input=[(true) Ask for input for variables if not directly set.]:input:(true false)' \ - '-generate-config-out=[(path) (Experimental) If import blocks are present in configuration, instructs Terraform to generate HCL for any imported resources not already present. The configuration is written to a new file at PATH, which must not already exist. Terraform may still attempt to write configuration if the plan errors.]' \ + '-generate-config-out=[(path) (Experimental) If import blocks are present in configuration, instructs Terraform to generate HCL for any imported resources not already present. The configuration is written to a new file at PATH, which must not already exist. Terraform may still attempt to write configuration if the plan errors.]:generate_config_out:' \ '-lock=[(true) Don'\''t hold a state lock during the operation. This is dangerous if others might concurrently run commands against the same workspace.]:lock:(true false)' \ - '-lock-timeout=[(0s) Duration to retry a state lock.]' \ + '-lock-timeout=[(0s) Duration to retry a state lock.]:lock_timeout:' \ '-no-color[If specified, output will contain no color.]' \ - '-out=[(path) Write a plan file to the given path. This can be used as input to the "apply" command.]' \ - '-parallelism=[(10) Limit the number of concurrent operations.]' \ + '-out=[(path) Write a plan file to the given path. This can be used as input to the "apply" command.]:out:' \ + '-parallelism=[(10) Limit the number of concurrent operations.]:parallelism:' \ '-refresh=[(true) Skip checking for external changes to remote objects while creating the plan. This can potentially make planning faster, but at the expense of possibly planning against a stale record of the remote system state.]:refresh:(true false)' \ '-refresh-only[Select the "refresh only" planning mode, which checks whether remote objects still match the outcome of the most recent Terraform apply but does not propose any actions to undo any changes made outside of Terraform.]' \ '*-replace=[(resource) Force replacement of a particular resource instance using its resource address. If the plan would'\''ve normally produced an update or no-op action for this instance, Terraform will plan to replace it instead. You can use this option multiple times to replace more than one object.]:replace:__terraform_state_resources' \ '-state=[(statefile) Path to a Terraform state file to use to look up Terraform-managed resources. By default it will use the state "terraform.tfstate" if it exists.]:statefile:_files -W __chdir -g "*.tfstate"' \ '*-target=[(resource) Limit the planning operation to only the given module, resource, or resource instance and all of its dependencies. You can use this option multiple times to include more than one object. This is for exceptional use only.]:target:__terraform_state_resources' \ - '*-var=[(for=bar) Set a value for one of the input variables in the root module of the configuration. Use this option more than once to set more than one variable.]' \ + '*-var=[(for=bar) Set a value for one of the input variables in the root module of the configuration. Use this option more than once to set more than one variable.]:var:' \ '*-var-file=[(foo) Load variable values from the given file, in addition to the default files terraform.tfvars and *.auto.tfvars. Use this option more than once to include more than one variables file.]:file:_files -W __chdir -g "*.tfvars{,.json}"' } @@ -265,14 +265,14 @@ compdef _terraform terraform (( ${+functions[_terraform_providers_lock]} )) || _terraform_providers_lock() { _arguments \ '-fs-mirror=[(dir) Consult the given filesystem mirror directory instead of the origin registry for each of the given providers.]:fs_mirror:_files -W __chdir -/' \ - '-net-mirror=[(url) Consult the given network mirror (given as a base URL) instead of the origin registry for each of the given providers.]' \ - '*-platform=[(os_arch) Choose a target platform to request package checksums for.]' \ + '-net-mirror=[(url) Consult the given network mirror (given as a base URL) instead of the origin registry for each of the given providers.]:net_mirror:' \ + '*-platform=[(os_arch) Choose a target platform to request package checksums for.]:platform:' \ '*:provider:' } (( ${+functions[_terraform_providers_mirror]} )) || _terraform_providers_mirror() { _arguments \ - '*-platform=[(os_arch) Choose which target platform to build a mirror for.]' \ + '*-platform=[(os_arch) Choose which target platform to build a mirror for.]:platform:' \ '::' \ ':target_dir:_files -W __chdir -/' } @@ -288,13 +288,13 @@ compdef _terraform terraform '-compact-warnings[If Terraform produces any warnings that are not accompanied by errors, show them in a more compact form that includes only the summary messages.]' \ '-input=[(true) Ask for input for variables if not directly set.]:input:(true false)' \ '-lock=[(true) Don'\''t hold a state lock during the operation. This is dangerous if others might concurrently run commands against the same workspace.]:lock:(true false)' \ - '-lock-timeout=[(0s) Duration to retry a state lock.]' \ + '-lock-timeout=[(0s) Duration to retry a state lock.]:lock_timeout:' \ '-no-color[If specified, output will not contain any color.]' \ - '-parallelism=[(10) Limit the number of parallel resource operations.]' \ + '-parallelism=[(10) Limit the number of parallel resource operations.]:parallelism:' \ '-state=[(path) Path to read and save state (unless state-out is specified). Defaults to "terraform.tfstate".]:statefile:_files -W __chdir -g "*.tfstate"' \ '-state-out=[(path) Path to write state to that is different than "-state". This can be used to preserve the old state.]:statefile:_files -W __chdir -g "*.tfstate"' \ '*-target=[(resource) A Resource Address to target. Operation will be limited to this resource and its dependencies. This flag can be used multiple times.]:target:__terraform_state_resources' \ - '*-var=[(for=bar) Set a variable in the Terraform configuration. This flag can be set multiple times.]' \ + '*-var=[(for=bar) Set a variable in the Terraform configuration. This flag can be set multiple times.]:var:' \ '*-var-file=[(foo) Set variables in the Terraform configuration from a file. If "terraform.tfvars" or any ".auto.tfvars" files are present, they will be automatically loaded.]:file:_files -W __chdir -g "*.tfvars{,.json}"' } @@ -340,7 +340,7 @@ compdef _terraform terraform (( ${+functions[_terraform_state_list]} )) || _terraform_state_list() { _arguments \ '-state=[(statefile) Path to a Terraform state file to use to look up Terraform-managed resources. By default, Terraform will consult the state of the currently-selected workspace.]:statefile:_files -W __chdir -g "*.tfstate"' \ - '-id=[(id) Filters the results to include only instances whose resource types have an attribute named id whose value equals the given id string.]' \ + '-id=[(id) Filters the results to include only instances whose resource types have an attribute named id whose value equals the given id string.]:id:' \ '*:address:__terraform_state_resources' } @@ -351,7 +351,7 @@ compdef _terraform terraform '-backup-out=[(PATH) Path where Terraform should write the backup for the destination state. This can"t be disabled. If not set, Terraform will write it to the same path as the destination state file with a backup extension. This only needs to be specified if -state-out is set to a different path than -state.]:backupfile:_files -W __chdir -g "*.backup"' \ '-ignore-remote-version[A rare option used for the remote backend only. See the remote backend documentation for more information.]' \ '-lock=[(true) Don'\''t hold a state lock during the operation. This is dangerous if others might concurrently run commands against the same workspace.]:lock:(true false)' \ - '-lock-timeout=[(0s) Duration to retry a state lock.]' \ + '-lock-timeout=[(0s) Duration to retry a state lock.]:lock_timeout:' \ '-state=[(path) Path to the source state file. Defaults to the configured backend, or "terraform.tfstate"]:statefile:_files -W __chdir -g "*.tfstate"' \ '-state-out=[(path) Path to the destination state file to write to. If this isn"t specified, the source state file will be used. This can be a new or existing path.]:statefile:_files -W __chdir -g "*.tfstate"' \ '::' \ @@ -363,7 +363,7 @@ compdef _terraform terraform _arguments \ '-force[Write the state even if lineages don'\''t match or the remote serial is higher.]' \ '-lock=[(true) Don'\''t hold a state lock during the operation. This is dangerous if others might concurrently run commands against the same workspace.]:lock:(true false)' \ - '-lock-timeout=[(0s) Duration to retry a state lock.]' \ + '-lock-timeout=[(0s) Duration to retry a state lock.]:lock_timeout:' \ '::' \ ':destination:_files' } @@ -373,7 +373,7 @@ compdef _terraform terraform '-auto-approve[Skip interactive approval.]' \ '-backup=[(PATH) Path where Terraform should write the backup for the state file. This can"t be disabled. If not set, Terraform will write it to the same path as the state file with a ".backup" extension.]:backupfile:_files -W __chdir -g "*.backup"' \ '-lock=[(true) Don'\''t hold a state lock during the operation. This is dangerous if others might concurrently run commands against the same workspace.]:lock:(true false)' \ - '-lock-timeout=[(0s) Duration to retry a state lock.]' \ + '-lock-timeout=[(0s) Duration to retry a state lock.]:lock_timeout:' \ '-state=[(PATH) Path to the source state file. Defaults to the configured backend, or "terraform.tfstate"]:statefile:_files -W __chdir -g "*.tfstate"' \ '::' \ ':from_provider_fqn:' \ @@ -386,7 +386,7 @@ compdef _terraform terraform '-backup=[(PATH) Path where Terraform should write the backup for the original state.]::backupfile:_files -W __chdir -g "*.backup"' \ '-ignore-remote-version[Continue even if remote and local Terraform versions are incompatible. This may result in an unusable workspace, and should be used with extreme caution.]' \ '-lock=[(true) Don'\''t hold a state lock during the operation. This is dangerous if others might concurrently run commands against the same workspace.]:lock:(true false)' \ - '-lock-timeout=[(0s) Duration to retry a state lock.]' \ + '-lock-timeout=[(0s) Duration to retry a state lock.]:lock_timeout:' \ '-state=[(PATH) Path to the state file to update. Defaults to the current workspace state.]:statefile:_files -W __chdir -g "*.tfstate"' \ '*:address:__terraform_state_resources' } @@ -412,7 +412,7 @@ compdef _terraform terraform '-backup=[(path) Path to backup the existing state file before modifying. Defaults to the "-state-out" path with ".backup" extension. Set to "-" to disable backup.]:backupfile:_files -W __chdir -g "*.backup"' \ '-ignore-remote-version[A rare option used for the remote backend only. See the remote backend documentation for more information.]' \ '-lock=[(true) Don'\''t hold a state lock during the operation. This is dangerous if others might concurrently run commands against the same workspace.]:lock:(true false)' \ - '-lock-timeout=[(0s) Duration to retry a state lock.]' \ + '-lock-timeout=[(0s) Duration to retry a state lock.]:lock_timeout:' \ '-state=[(path) Path to read and save state (unless state-out is specified). Defaults to "terraform.tfstate".]:statefile:_files -W __chdir -g "*.tfstate"' \ '-state-out=[(path) Path to write updated state file. By default, the "-state" path will be used.]:statefile:_files -W __chdir -g "*.tfstate"' \ '*:address:__terraform_state_resources' @@ -420,12 +420,12 @@ compdef _terraform terraform (( ${+functions[_terraform_test]} )) || _terraform_test() { _arguments \ - '-cloud-run=[(source) If specified, Terraform will execute this test run remotely using Terraform Cloud. You must specify the source of a module registered in a private module registry as the argument to this flag. This allows Terraform to associate the cloud run with the correct Terraform Cloud module and organization.]' \ + '-cloud-run=[(source) If specified, Terraform will execute this test run remotely using Terraform Cloud. You must specify the source of a module registered in a private module registry as the argument to this flag. This allows Terraform to associate the cloud run with the correct Terraform Cloud module and organization.]:cloud_run:' \ '*-filter=[(testfile) If specified, Terraform will only execute the test files specified by this flag. You can use this option multiple times to execute more than one test file.]:testfile:_files -W __chdir -g "*.tftest.hcl"' \ '-json[If specified, machine readable output will be printed in JSON format]' \ '-no-color[If specified, machine readable output will be printed in JSON format]' \ '-test-directory=[(path) Set the Terraform test directory, defaults to "tests".]:test_directory:_files -W __chdir -/' \ - '*-var=[(for=bar) Set a value for one of the input variables in the root module of the configuration. Use this option more than once to set more than one variable.]' \ + '*-var=[(for=bar) Set a value for one of the input variables in the root module of the configuration. Use this option more than once to set more than one variable.]:var:' \ '*-var-file=[(foo) Load variable values from the given file, in addition to the default files terraform.tfvars and *.auto.tfvars. Use this option more than once to include more than one variables file.]:file:_files -W __chdir -g "*.tfvars{,.json}"' \ '-verbose[Print the plan or state for each test run block as it executes.]' \ } @@ -435,7 +435,7 @@ compdef _terraform terraform '-allow-missing[If specified, the command will succeed (exit code 0) even if the resource is missing.]' \ '-backup=[(path) Path to backup the existing state file before modifying. Defaults to the "-state-out" path with ".backup" extension. Set to "-" to disable backup.]:backupfile:_files -W __chdir -g "*.backup"' \ '-lock=[(true) Don'\''t hold a state lock during the operation. This is dangerous if others might concurrently run commands against the same workspace.]:lock:(true false)' \ - '-lock-timeout=[(0s) Duration to retry a state lock.]' \ + '-lock-timeout=[(0s) Duration to retry a state lock.]:lock_timeout:' \ '-state=[(path) Path to read and save state (unless state-out is specified). Defaults to "terraform.tfstate".]:statefile:_files -W __chdir -g "*.tfstate"' \ '-state-out=[(path) Path to write updated state file. By default, the "-state" path will be used.]:statefile:_files -W __chdir -g "*.tfstate"' \ ':name:__terraform_state_resources' @@ -490,7 +490,7 @@ compdef _terraform terraform _arguments \ '-force[Remove a workspace even if it is managing resources. Terraform can no longer track or manage the workspace'\''s infrastructure.]' \ '-lock=[(true) Don'\''t hold a state lock during the operation. This is dangerous if others might concurrently run commands against the same workspace.]:lock:(true false)' \ - '-lock-timeout=[(0s) Duration to retry a state lock.]' \ + '-lock-timeout=[(0s) Duration to retry a state lock.]:lock_timeout:' \ '::' \ ':name:__terraform_workspaces' } @@ -502,7 +502,7 @@ compdef _terraform terraform (( ${+functions[_terraform_workspace_new]} )) || _terraform_workspace_new() { _arguments \ '-lock=[(true) Don'\''t hold a state lock during the operation. This is dangerous if others might concurrently run commands against the same workspace.]:lock:(true false)' \ - '-lock-timeout=[(0s) Duration to retry a state lock.]' \ + '-lock-timeout=[(0s) Duration to retry a state lock.]:lock_timeout:' \ '-state=[(path) Copy an existing state file into the new workspace.]:statefile:_files -W __chdir -g "*.tfstate"' \ '::' \ ':name:' From 0ea0d14288d68aba026d47517009233846c7b409 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Mon, 4 Mar 2024 10:47:34 +0100 Subject: [PATCH 528/672] fix(nvm): remove zsh completion We rely on official bash completion now on. --- plugins/nvm/_nvm | 34 ---------------------------------- 1 file changed, 34 deletions(-) delete mode 100644 plugins/nvm/_nvm diff --git a/plugins/nvm/_nvm b/plugins/nvm/_nvm deleted file mode 100644 index e292a8d8c..000000000 --- a/plugins/nvm/_nvm +++ /dev/null @@ -1,34 +0,0 @@ -#compdef nvm -#autoload - -[[ -f "$NVM_DIR/nvm.sh" ]] || return 0 - -local -a _1st_arguments -_1st_arguments=( - 'help:show help' - '--version:print out the latest released version of nvm' - 'install:download and install a version in ' - 'install-latest-npm:download and install the latest npm version' - 'uninstall:uninstall a version' - 'use:modify PATH to use . Uses .nvmrc if available' - 'exec:run on . Uses .nvmrc if available' - 'run:run `node` on with as arguments. Uses .nvmrc if available' - 'current:list installed versions' - 'ls:list installed versions or versions matching a given description' - 'version:resolve the given description to a single local version' - 'version-remote:resolve the given description to a single remote version' - 'ls-remote:list remote versions available for install' - 'deactivate:undo effects of `nvm` on current shell' - 'alias:show or set aliases' - 'unalias:deletes an alias' - 'reinstall-packages:reinstall global `npm` packages contained in to current version' - 'unload:unload `nvm` from shell' - 'which:display path to installed node version. Uses .nvmrc if available' -) - -_arguments -C '*:: :->subcmds' && return 0 - -if (( CURRENT == 1 )); then - _describe -t commands "nvm subcommand" _1st_arguments - return -fi From 94aa49c0b96fed98d2751107301c16f32de13383 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Mon, 4 Mar 2024 11:02:37 +0100 Subject: [PATCH 529/672] feat(nvm)!: make `lazy` and `autoload` options compatible BREAKING CHANGE: Prior to this commit, if `lazy` and `autoload` options were enabled at the same time, `lazy` was getting overriden and only `autoload` was taken into account. Now they work together and `autoload` will be enabled after `nvm` has been lazy-loaded. Closes #11690 --- plugins/nvm/README.md | 3 +- plugins/nvm/nvm.plugin.zsh | 95 +++++++++++++++++++++----------------- 2 files changed, 54 insertions(+), 44 deletions(-) diff --git a/plugins/nvm/README.md b/plugins/nvm/README.md index b5ef221d3..e88ce0158 100644 --- a/plugins/nvm/README.md +++ b/plugins/nvm/README.md @@ -43,8 +43,7 @@ zstyle ':omz:plugins:nvm' lazy-cmd eslint prettier typescript ... #### `.nvmrc` autoload -Note: _this option cannot be used at the same time as `lazy`. `autoload` will override it and load `nvm` at -startup._ +Note: _if used at the same time as `lazy`, `autoload` will start working only after nvm has been lazy-loaded_ If set, the plugin will automatically load a node version when if finds a [`.nvmrc` file](https://github.com/nvm-sh/nvm#nvmrc) in the current working directory indicating which node diff --git a/plugins/nvm/nvm.plugin.zsh b/plugins/nvm/nvm.plugin.zsh index 94b666175..084b4846f 100644 --- a/plugins/nvm/nvm.plugin.zsh +++ b/plugins/nvm/nvm.plugin.zsh @@ -1,3 +1,7 @@ +# Don't try to load nvm if command already available +# Note: nvm is a function so we need to use `which` +which nvm &>/dev/null && return + # See https://github.com/nvm-sh/nvm#installation-and-update if [[ -z "$NVM_DIR" ]]; then if [[ -d "$HOME/.nvm" ]]; then @@ -12,39 +16,34 @@ if [[ -z "$NVM_DIR" ]]; then fi fi -# Don't try to load nvm if command already available -# Note: nvm is a function so we need to use `which` -which nvm &>/dev/null && return - if [[ -z "$NVM_DIR" ]] || [[ ! -f "$NVM_DIR/nvm.sh" ]]; then return fi -if zstyle -t ':omz:plugins:nvm' lazy && \ - ! zstyle -t ':omz:plugins:nvm' autoload; then - # Call nvm when first using nvm, node, npm, pnpm, yarn or other commands in lazy-cmd - zstyle -a ':omz:plugins:nvm' lazy-cmd nvm_lazy_cmd - nvm_lazy_cmd=(nvm node npm npx pnpm yarn $nvm_lazy_cmd) # default values - eval " - function $nvm_lazy_cmd { - for func in $nvm_lazy_cmd; do - if (( \$+functions[\$func] )); then - unfunction \$func - fi - done - # Load nvm if it exists in \$NVM_DIR - [[ -f \"\$NVM_DIR/nvm.sh\" ]] && source \"\$NVM_DIR/nvm.sh\" - \"\$0\" \"\$@\" - } - " - unset nvm_lazy_cmd -else - source "$NVM_DIR/nvm.sh" -fi +function _omz_load_nvm_completion { + local _nvm_completion + # Load nvm bash completion + for _nvm_completion in "$NVM_DIR/bash_completion" "$NVM_HOMEBREW/etc/bash_completion.d/nvm"; do + if [[ -f "$_nvm_completion" ]]; then + # Load bashcompinit + autoload -U +X bashcompinit && bashcompinit + # Bypass compinit call in nvm bash completion script. See: + # https://github.com/nvm-sh/nvm/blob/4436638/bash_completion#L86-L93 + ZSH_VERSION= source "$_nvm_completion" + break + fi + done + unfunction _omz_load_nvm_completion +} -# Autoload nvm when finding a .nvmrc file in the current directory -# Adapted from: https://github.com/nvm-sh/nvm#zsh -if zstyle -t ':omz:plugins:nvm' autoload; then +function _omz_setup_autoload { + if ! zstyle -t ':omz:plugins:nvm' autoload; then + unfunction _omz_setup_autoload + return + fi + + # Autoload nvm when finding a .nvmrc file in the current directory + # Adapted from: https://github.com/nvm-sh/nvm#zsh function load-nvmrc { local node_version="$(nvm version)" local nvmrc_path="$(nvm_find_nvmrc)" @@ -72,18 +71,30 @@ if zstyle -t ':omz:plugins:nvm' autoload; then add-zsh-hook chpwd load-nvmrc load-nvmrc + unfunction _omz_setup_autoload +} + +if zstyle -t ':omz:plugins:nvm' lazy; then + # Call nvm when first using nvm, node, npm, pnpm, yarn or other commands in lazy-cmd + zstyle -a ':omz:plugins:nvm' lazy-cmd nvm_lazy_cmd + nvm_lazy_cmd=(nvm node npm npx pnpm yarn $nvm_lazy_cmd) # default values + eval " + function $nvm_lazy_cmd { + for func in $nvm_lazy_cmd; do + if (( \$+functions[\$func] )); then + unfunction \$func + fi + done + # Load nvm if it exists in \$NVM_DIR + [[ -f \"\$NVM_DIR/nvm.sh\" ]] && source \"\$NVM_DIR/nvm.sh\" + _omz_load_nvm_completion + _omz_setup_autoload + \"\$0\" \"\$@\" + } + " + unset nvm_lazy_cmd +else + source "$NVM_DIR/nvm.sh" + _omz_load_nvm_completion + _omz_setup_autoload fi - -# Load nvm bash completion -for nvm_completion in "$NVM_DIR/bash_completion" "$NVM_HOMEBREW/etc/bash_completion.d/nvm"; do - if [[ -f "$nvm_completion" ]]; then - # Load bashcompinit - autoload -U +X bashcompinit && bashcompinit - # Bypass compinit call in nvm bash completion script. See: - # https://github.com/nvm-sh/nvm/blob/4436638/bash_completion#L86-L93 - ZSH_VERSION= source "$nvm_completion" - break - fi -done - -unset NVM_HOMEBREW nvm_completion From fd01fd66ce27c669e5ffaea94460a37423d1e134 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Mon, 4 Mar 2024 11:08:49 +0100 Subject: [PATCH 530/672] perf(nvm): don't call `nvm version` on every cd Now we only call `nvm version` in case we changed directory and we are not anymore in a `.nvmrc` directory. See https://github.com/nvm-sh/nvm/pull/2874 --- plugins/nvm/nvm.plugin.zsh | 7 ++----- 1 file changed, 2 insertions(+), 5 deletions(-) diff --git a/plugins/nvm/nvm.plugin.zsh b/plugins/nvm/nvm.plugin.zsh index 084b4846f..6a5afecfa 100644 --- a/plugins/nvm/nvm.plugin.zsh +++ b/plugins/nvm/nvm.plugin.zsh @@ -45,7 +45,6 @@ function _omz_setup_autoload { # Autoload nvm when finding a .nvmrc file in the current directory # Adapted from: https://github.com/nvm-sh/nvm#zsh function load-nvmrc { - local node_version="$(nvm version)" local nvmrc_path="$(nvm_find_nvmrc)" local nvm_silent="" zstyle -t ':omz:plugins:nvm' silent-autoload && nvm_silent="--silent" @@ -58,10 +57,8 @@ function _omz_setup_autoload { elif [[ "$nvmrc_node_version" != "$node_version" ]]; then nvm use $nvm_silent fi - elif [[ "$node_version" != "$(nvm version default)" ]]; then - if [[ -z $nvm_silent ]]; then - echo "Reverting to nvm default version" - fi + elif [[ -n "$(PWD=$OLDPWD nvm_find_nvmrc)" ]] && [[ "$(nvm version)" != "$(nvm version default)" ]]; then + [[ -z $nvm_silent ]] && echo "Reverting to nvm default version" nvm use default $nvm_silent fi From 2a71aa50170db6892abb3e173ba425c554744b37 Mon Sep 17 00:00:00 2001 From: Felipe Contreras Date: Thu, 7 Mar 2024 02:47:15 -0600 Subject: [PATCH 531/672] chore(gitfast): remove update script (#12262) Co-authored-by: Carlo Sala --- .github/dependencies.yml | 2 +- plugins/gitfast/README.md | 6 ------ plugins/gitfast/gitfast.plugin.zsh | 2 +- plugins/gitfast/update | 8 -------- 4 files changed, 2 insertions(+), 16 deletions(-) delete mode 100755 plugins/gitfast/update diff --git a/.github/dependencies.yml b/.github/dependencies.yml index 12beaecbb..d60ab2c92 100644 --- a/.github/dependencies.yml +++ b/.github/dependencies.yml @@ -2,7 +2,7 @@ dependencies: plugins/gitfast: repo: felipec/git-completion branch: master - version: tag:v2.0 + version: tag:v2.1 postcopy: | set -e rm -rf git-completion.plugin.zsh Makefile README.adoc t tools diff --git a/plugins/gitfast/README.md b/plugins/gitfast/README.md index fed4b120a..60b84a23c 100644 --- a/plugins/gitfast/README.md +++ b/plugins/gitfast/README.md @@ -7,9 +7,3 @@ To use it, add `gitfast` to the plugins array in your zshrc file: ```zsh plugins=(... gitfast) ``` - -## Aliases - -An earlier version of the plugin also loaded the git plugin. If you want to keep those -aliases enable the [git plugin](https://github.com/ohmyzsh/ohmyzsh/tree/master/plugins/git) -as well. diff --git a/plugins/gitfast/gitfast.plugin.zsh b/plugins/gitfast/gitfast.plugin.zsh index a6db0c6bd..c456eff7f 100644 --- a/plugins/gitfast/gitfast.plugin.zsh +++ b/plugins/gitfast/gitfast.plugin.zsh @@ -1,6 +1,6 @@ # Handle $0 according to the standard: # https://zdharma-continuum.github.io/Zsh-100-Commits-Club/Zsh-Plugin-Standard.html -0="${${ZERO:-${0:#$ZSH_ARGZERO}}:-${(%):-%N}}" +0="${ZERO:-${${0:#$ZSH_ARGZERO}:-${(%):-%N}}}" 0="${${(M)0:#/*}:-$PWD/$0}" source "${0:A:h}/git-prompt.sh" diff --git a/plugins/gitfast/update b/plugins/gitfast/update deleted file mode 100755 index feb13ff7e..000000000 --- a/plugins/gitfast/update +++ /dev/null @@ -1,8 +0,0 @@ -#!/bin/sh - -url="https://raw.githubusercontent.com/felipec/git-completion" -version="1.3.7" - -curl -s -o _git "${url}/v${version}/git-completion.zsh" && -curl -s -o git-completion.bash "${url}/v${version}/git-completion.bash" && -curl -s -o git-prompt.sh "${url}/v${version}/git-prompt.sh" From 4fca7ccb55eb4904f515806ffca51d27ee1cc670 Mon Sep 17 00:00:00 2001 From: Ross Williams Date: Thu, 7 Mar 2024 03:54:43 -0500 Subject: [PATCH 532/672] feat(tools): update `supports_hyperlinks` (#12258) Update to https://github.com/zkat/supports-hyperlinks/releases/tag/v3.0.0 --- tools/changelog.sh | 11 ++++++++--- tools/install.sh | 11 ++++++++--- tools/upgrade.sh | 11 ++++++++--- 3 files changed, 24 insertions(+), 9 deletions(-) diff --git a/tools/changelog.sh b/tools/changelog.sh index 3ad8fe786..c4b26079e 100755 --- a/tools/changelog.sh +++ b/tools/changelog.sh @@ -221,11 +221,16 @@ supports_hyperlinks() { # If $TERM_PROGRAM is set, these terminals support hyperlinks case "$TERM_PROGRAM" in - Hyper|iTerm.app|terminology|WezTerm) return 0 ;; + Hyper|iTerm.app|terminology|WezTerm|vscode) return 0 ;; esac - # kitty supports hyperlinks - if [ "$TERM" = xterm-kitty ]; then + # These termcap entries support hyperlinks + case "$TERM" in + xterm-kitty|alacritty|alacritty-direct) return 0 ;; + esac + + # xfce4-terminal supports hyperlinks + if [ "$COLORTERM" = "xfce4-terminal" ]; then return 0 fi diff --git a/tools/install.sh b/tools/install.sh index 508fc2f77..e3613a28b 100755 --- a/tools/install.sh +++ b/tools/install.sh @@ -166,11 +166,16 @@ supports_hyperlinks() { # If $TERM_PROGRAM is set, these terminals support hyperlinks case "$TERM_PROGRAM" in - Hyper|iTerm.app|terminology|WezTerm) return 0 ;; + Hyper|iTerm.app|terminology|WezTerm|vscode) return 0 ;; esac - # kitty supports hyperlinks - if [ "$TERM" = xterm-kitty ]; then + # These termcap entries support hyperlinks + case "$TERM" in + xterm-kitty|alacritty|alacritty-direct) return 0 ;; + esac + + # xfce4-terminal supports hyperlinks + if [ "$COLORTERM" = "xfce4-terminal" ]; then return 0 fi diff --git a/tools/upgrade.sh b/tools/upgrade.sh index f7a263d66..d7016aa44 100755 --- a/tools/upgrade.sh +++ b/tools/upgrade.sh @@ -90,11 +90,16 @@ supports_hyperlinks() { # If $TERM_PROGRAM is set, these terminals support hyperlinks case "$TERM_PROGRAM" in - Hyper|iTerm.app|terminology|WezTerm) return 0 ;; + Hyper|iTerm.app|terminology|WezTerm|vscode) return 0 ;; esac - # kitty supports hyperlinks - if [ "$TERM" = xterm-kitty ]; then + # These termcap entries support hyperlinks + case "$TERM" in + xterm-kitty|alacritty|alacritty-direct) return 0 ;; + esac + + # xfce4-terminal supports hyperlinks + if [ "$COLORTERM" = "xfce4-terminal" ]; then return 0 fi From 083cc2c8e8742bab8cce8c73a3e96f398e6b2da7 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Thu, 7 Mar 2024 14:39:05 +0100 Subject: [PATCH 533/672] feat(async)!: implement async prompt API and apply to git prompt (#12257) BREAKING CHANGE: the `git_prompt_info` prompt function has been reworked by default to use the new async prompt feature. If you're experiencing issues see #12257. Co-authored-by: Carlo Sala --- lib/async_prompt.zsh | 140 +++++++++++++++++++++++++++++++++++++++++++ lib/git.zsh | 22 ++++++- 2 files changed, 160 insertions(+), 2 deletions(-) create mode 100644 lib/async_prompt.zsh diff --git a/lib/async_prompt.zsh b/lib/async_prompt.zsh new file mode 100644 index 000000000..c6d03328b --- /dev/null +++ b/lib/async_prompt.zsh @@ -0,0 +1,140 @@ +# The async code is taken from +# https://github.com/zsh-users/zsh-autosuggestions/blob/master/src/async.zsh +# https://github.com/woefe/git-prompt.zsh/blob/master/git-prompt.zsh + +zmodload zsh/system + +# For now, async prompt function handlers are set up like so: +# First, define the async function handler and add the function name +# to the _omz_async_functions array: +# +# function _git_prompt_status_async { +# # Do some expensive operation that outputs to stdout +# } +# _omz_register_handler _git_prompt_status_async +# +# Then add a stub prompt function in `$PROMPT` or similar prompt variables, +# which will show the output of "$_OMZ_ASYNC_OUTPUT[handler_name]": +# +# function git_prompt_status { +# echo -n $_OMZ_ASYNC_OUTPUT[_git_prompt_status] +# } +# +# RPROMPT='$(git_prompt_status)' +# +# This API is subject to change and optimization. Rely on it at your own risk. + +function _omz_register_handler { + setopt localoptions noksharrays + typeset -ga _omz_async_functions + # we want to do nothing if there's no $1 function or we already set it up + if [[ -z "$1" ]] || (( ! ${+functions[$1]} )) \ + || (( ${_omz_async_functions[(Ie)$1]} )); then + return + fi + _omz_async_functions+=("$1") + # let's add the hook to async_request if it's not there yet + if (( ! ${precmd_functions[(Ie)_omz_async_request]} )) \ + && (( ${+functions[_omz_async_request]})); then + autoload -Uz add-zsh-hook + add-zsh-hook precmd _omz_async_request + fi +} + +# Set up async handlers and callbacks +function _omz_async_request { + typeset -gA _OMZ_ASYNC_FDS _OMZ_ASYNC_PIDS _OMZ_ASYNC_OUTPUT + + # executor runs a subshell for all async requests based on key + local handler + for handler in ${_omz_async_functions}; do + (( ${+functions[$handler]} )) || continue + + local fd=${_OMZ_ASYNC_FDS[$handler]:--1} + local pid=${_OMZ_ASYNC_PIDS[$handler]:--1} + + # If we've got a pending request, cancel it + if (( fd != -1 && pid != -1 )) && { true <&$fd } 2>/dev/null; then + # Close the file descriptor and remove the handler + exec {fd}<&- + zle -F $fd + + # Zsh will make a new process group for the child process only if job + # control is enabled (MONITOR option) + if [[ -o MONITOR ]]; then + # Send the signal to the process group to kill any processes that may + # have been forked by the async function handler + kill -TERM -$pid 2>/dev/null + else + # Kill just the child process since it wasn't placed in a new process + # group. If the async function handler forked any child processes they may + # be orphaned and left behind. + kill -TERM $pid 2>/dev/null + fi + fi + + # Define global variables to store the file descriptor, PID and output + _OMZ_ASYNC_FDS[$handler]=-1 + _OMZ_ASYNC_PIDS[$handler]=-1 + + # Fork a process to fetch the git status and open a pipe to read from it + exec {fd}< <( + # Tell parent process our PID + builtin echo ${sysparams[pid]} + # Store handler name for callback + builtin echo $handler + # Run the async function handler + $handler + ) + + # Save FD for handler + _OMZ_ASYNC_FDS[$handler]=$fd + + # There's a weird bug here where ^C stops working unless we force a fork + # See https://github.com/zsh-users/zsh-autosuggestions/issues/364 + command true + + # Save the PID from the handler child process + read pid <&$fd + _OMZ_ASYNC_PIDS[$handler]=$pid + + # When the fd is readable, call the response handler + zle -F "$fd" _omz_async_callback + done +} + +# Called when new data is ready to be read from the pipe +function _omz_async_callback() { + emulate -L zsh + + local fd=$1 # First arg will be fd ready for reading + local err=$2 # Second arg will be passed in case of error + + if [[ -z "$err" || "$err" == "hup" ]]; then + # Get handler name from first line + local handler + read handler <&$fd + + # Store old output which is supposed to be already printed + local old_output="${_OMZ_ASYNC_OUTPUT[$handler]}" + + # Read output from fd + _OMZ_ASYNC_OUTPUT[$handler]="$(cat <&$fd)" + + # Repaint prompt if output has changed + if [[ "$old_output" != "${_OMZ_ASYNC_OUTPUT[$handler]}" ]]; then + zle reset-prompt + zle -R + fi + + # Close the fd + exec {fd}<&- + fi + + # Always remove the handler + zle -F "$fd" + + # Unset global FD variable to prevent closing user created FDs in the precmd hook + _OMZ_ASYNC_FDS[$handler]=-1 + _OMZ_ASYNC_PIDS[$handler]=-1 +} diff --git a/lib/git.zsh b/lib/git.zsh index f049f73c2..6f4823458 100644 --- a/lib/git.zsh +++ b/lib/git.zsh @@ -9,14 +9,18 @@ function __git_prompt_git() { GIT_OPTIONAL_LOCKS=0 command git "$@" } -function git_prompt_info() { +function _omz_git_prompt_status() { # If we are on a folder not tracked by git, get out. # Otherwise, check for hide-info at global and local repository level if ! __git_prompt_git rev-parse --git-dir &> /dev/null \ - || [[ "$(__git_prompt_git config --get oh-my-zsh.hide-info 2>/dev/null)" == 1 ]]; then + || [[ "$(__git_prompt_git config --get oh-my-zsh.hide-info 2>/dev/null)" == 1 ]]; then return 0 fi + # Get either: + # - the current branch name + # - the tag name if we are on a tag + # - the short SHA of the current commit local ref ref=$(__git_prompt_git symbolic-ref --short HEAD 2> /dev/null) \ || ref=$(__git_prompt_git describe --tags --exact-match HEAD 2> /dev/null) \ @@ -33,6 +37,20 @@ function git_prompt_info() { echo "${ZSH_THEME_GIT_PROMPT_PREFIX}${ref:gs/%/%%}${upstream:gs/%/%%}$(parse_git_dirty)${ZSH_THEME_GIT_PROMPT_SUFFIX}" } +# Enable async prompt by default unless the setting is at false / no +if zstyle -T ':omz:alpha:lib:git' async-prompt; then + function git_prompt_info() { + _omz_register_handler _omz_git_prompt_status + if [[ -n "$_OMZ_ASYNC_OUTPUT[_omz_git_prompt_status]" ]]; then + echo -n "$_OMZ_ASYNC_OUTPUT[_omz_git_prompt_status]" + fi + } +else + function git_prompt_info() { + _omz_git_prompt_status + } +fi + # Checks if working tree is dirty function parse_git_dirty() { local STATUS From 32d4389aa6e896b27d9786d142a5c44163104056 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Thu, 7 Mar 2024 17:17:27 +0100 Subject: [PATCH 534/672] fix(git): disable temporarely async prompt --- lib/git.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/git.zsh b/lib/git.zsh index 6f4823458..8fe999095 100644 --- a/lib/git.zsh +++ b/lib/git.zsh @@ -38,7 +38,7 @@ function _omz_git_prompt_status() { } # Enable async prompt by default unless the setting is at false / no -if zstyle -T ':omz:alpha:lib:git' async-prompt; then +if zstyle -t ':omz:alpha:lib:git' async-prompt; then function git_prompt_info() { _omz_register_handler _omz_git_prompt_status if [[ -n "$_OMZ_ASYNC_OUTPUT[_omz_git_prompt_status]" ]]; then From 06753e8146332aa787857fc5cc41caa2b5f753f0 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Sat, 9 Mar 2024 18:22:35 +0100 Subject: [PATCH 535/672] fix(async): register the git prompt async handler correctly (#12267) This fix conditionally registers the git prompt async handler only if `git_prompt_info` is used anywhere in the prompt variables. This is done in the proper order, so that the async request is processed once the handler has been registered. This fix also passes the return value of the previous command to each of the async handlers, in case they are needed. --- lib/async_prompt.zsh | 12 +++++++++--- lib/git.zsh | 20 +++++++++++++++++++- 2 files changed, 28 insertions(+), 4 deletions(-) diff --git a/lib/async_prompt.zsh b/lib/async_prompt.zsh index c6d03328b..384e49d33 100644 --- a/lib/async_prompt.zsh +++ b/lib/async_prompt.zsh @@ -5,8 +5,8 @@ zmodload zsh/system # For now, async prompt function handlers are set up like so: -# First, define the async function handler and add the function name -# to the _omz_async_functions array: +# First, define the async function handler and register the handler +# with _omz_register_handler: # # function _git_prompt_status_async { # # Do some expensive operation that outputs to stdout @@ -17,7 +17,7 @@ zmodload zsh/system # which will show the output of "$_OMZ_ASYNC_OUTPUT[handler_name]": # # function git_prompt_status { -# echo -n $_OMZ_ASYNC_OUTPUT[_git_prompt_status] +# echo -n $_OMZ_ASYNC_OUTPUT[_git_prompt_status_async] # } # # RPROMPT='$(git_prompt_status)' @@ -43,6 +43,7 @@ function _omz_register_handler { # Set up async handlers and callbacks function _omz_async_request { + local -i ret=$? typeset -gA _OMZ_ASYNC_FDS _OMZ_ASYNC_PIDS _OMZ_ASYNC_OUTPUT # executor runs a subshell for all async requests based on key @@ -83,6 +84,8 @@ function _omz_async_request { builtin echo ${sysparams[pid]} # Store handler name for callback builtin echo $handler + # Set exit code for the handler if used + (exit $ret) # Run the async function handler $handler ) @@ -138,3 +141,6 @@ function _omz_async_callback() { _OMZ_ASYNC_FDS[$handler]=-1 _OMZ_ASYNC_PIDS[$handler]=-1 } + +autoload -Uz add-zsh-hook +add-zsh-hook precmd _omz_async_request diff --git a/lib/git.zsh b/lib/git.zsh index 8fe999095..96df5589d 100644 --- a/lib/git.zsh +++ b/lib/git.zsh @@ -40,11 +40,29 @@ function _omz_git_prompt_status() { # Enable async prompt by default unless the setting is at false / no if zstyle -t ':omz:alpha:lib:git' async-prompt; then function git_prompt_info() { - _omz_register_handler _omz_git_prompt_status if [[ -n "$_OMZ_ASYNC_OUTPUT[_omz_git_prompt_status]" ]]; then echo -n "$_OMZ_ASYNC_OUTPUT[_omz_git_prompt_status]" fi } + + # Conditionally register the async handler, only if it's needed in $PROMPT + # or any of the other prompt variables + function _defer_async_git_register() { + # Check if git_prompt_info is used in a prompt variable + case "${PS1}:${PS2}:${PS3}:${PS4}:${RPS1}:${RPS2}:${RPS3}:${RPS4}" in + *(\$\(git_prompt_info\)|\`git_prompt_info\`)*) + _omz_register_handler _omz_git_prompt_status + return + ;; + esac + + add-zsh-hook -d precmd _defer_async_git_register + unset -f _defer_async_git_register + } + + # Register the async handler first. This needs to be done before + # the async request prompt is run + precmd_functions=(_defer_async_git_register $precmd_functions) else function git_prompt_info() { _omz_git_prompt_status From 4fd2af0a82e2826317d9551ecd8d5f44553828d7 Mon Sep 17 00:00:00 2001 From: Misaka Date: Sun, 10 Mar 2024 10:16:16 +0800 Subject: [PATCH 536/672] feat(fzf): add default fzf_base for msys2 (#12274) --- plugins/fzf/fzf.plugin.zsh | 1 + 1 file changed, 1 insertion(+) diff --git a/plugins/fzf/fzf.plugin.zsh b/plugins/fzf/fzf.plugin.zsh index b253a23d2..7312e3d26 100644 --- a/plugins/fzf/fzf.plugin.zsh +++ b/plugins/fzf/fzf.plugin.zsh @@ -8,6 +8,7 @@ function fzf_setup_using_base_dir() { "${HOME}/.fzf" "${HOME}/.nix-profile/share/fzf" "${XDG_DATA_HOME:-$HOME/.local/share}/fzf" + "${MSYSTEM_PREFIX}/share/fzf" "/usr/local/opt/fzf" "/opt/homebrew/opt/fzf" "/usr/share/fzf" From 1cc41576d4d2ffe2f63bb893a40ef864dc7f2c98 Mon Sep 17 00:00:00 2001 From: webstar <814566123@qq.com> Date: Tue, 12 Mar 2024 10:43:08 +0800 Subject: [PATCH 537/672] docs(readme): add contributor list (#12236) --- README.md | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/README.md b/README.md index 98743432d..b3561a833 100644 --- a/README.md +++ b/README.md @@ -449,6 +449,10 @@ Oh My Zsh has a vibrant community of happy users and delightful contributors. Wi Thank you so much! + + + + ## Follow Us We're on social media: From 4ad09ab0b10adc90730476bd27f24f93d94728ad Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ing=2E=20Jan=20Kal=C3=A1b?= Date: Tue, 12 Mar 2024 18:23:08 +0100 Subject: [PATCH 538/672] feat(extract): prefer using `pbzip2` instead of `bunzip2` (#12280) --- plugins/extract/extract.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/extract/extract.plugin.zsh b/plugins/extract/extract.plugin.zsh index 88d8b0740..80ca50c50 100644 --- a/plugins/extract/extract.plugin.zsh +++ b/plugins/extract/extract.plugin.zsh @@ -70,7 +70,7 @@ EOF (*.tar.lz4) lz4 -c -d "$full_path" | tar xvf - ;; (*.tar.lrz) (( $+commands[lrzuntar] )) && lrzuntar "$full_path" ;; (*.gz) (( $+commands[pigz] )) && pigz -cdk "$full_path" > "${file:t:r}" || gunzip -ck "$full_path" > "${file:t:r}" ;; - (*.bz2) bunzip2 "$full_path" ;; + (*.bz2) (( $+commands[pbzip2] )) && pbzip2 -d "$full_path" || bunzip2 "$full_path" ;; (*.xz) unxz "$full_path" ;; (*.lrz) (( $+commands[lrunzip] )) && lrunzip "$full_path" ;; (*.lz4) lz4 -d "$full_path" ;; From 6780b19329501b66bc87274928f0a65cc7e5f473 Mon Sep 17 00:00:00 2001 From: guangwu Date: Thu, 14 Mar 2024 18:37:06 +0800 Subject: [PATCH 539/672] docs(pyenv): fix typo (#12283) --- plugins/pyenv/README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/pyenv/README.md b/plugins/pyenv/README.md index f1ca3d288..f18fc8cfb 100644 --- a/plugins/pyenv/README.md +++ b/plugins/pyenv/README.md @@ -10,7 +10,7 @@ To use it, add `pyenv` to the plugins array in your zshrc file: plugins=(... pyenv) ``` -If you receive a `Found pyenv, but it is badly configured.` error on startup, you may need to ensure that `pyenv` is initialized before the oh-my-zsh pyenv plugin is loaded. This can be achived by adding the following earlier in the `.zshrc` file than the `plugins=(...)` line: +If you receive a `Found pyenv, but it is badly configured.` error on startup, you may need to ensure that `pyenv` is initialized before the oh-my-zsh pyenv plugin is loaded. This can be achieved by adding the following earlier in the `.zshrc` file than the `plugins=(...)` line: ```zsh export PYENV_ROOT="$HOME/.pyenv" From c8ba08581dff43c18c1b0d9e7312ca32e6d97124 Mon Sep 17 00:00:00 2001 From: shuangcui Date: Fri, 15 Mar 2024 00:07:39 +0800 Subject: [PATCH 540/672] docs: fix typos (#12284) --- lib/cli.zsh | 2 +- plugins/catimg/README.md | 2 +- plugins/emacs/README.md | 2 +- plugins/emacs/emacs.plugin.zsh | 2 +- plugins/ipfs/_ipfs | 2 +- plugins/nomad/_nomad | 2 +- plugins/per-directory-history/per-directory-history.zsh | 2 +- plugins/ssh-agent/README.md | 2 +- 8 files changed, 8 insertions(+), 8 deletions(-) diff --git a/lib/cli.zsh b/lib/cli.zsh index 561c1b98b..aa36a6ab5 100644 --- a/lib/cli.zsh +++ b/lib/cli.zsh @@ -448,7 +448,7 @@ function _omz::plugin::load { if [[ ! -f "$base/_$plugin" && ! -f "$base/$plugin.plugin.zsh" ]]; then _omz::log warn "'$plugin' is not a valid plugin" continue - # It it is a valid plugin, add its directory to $fpath unless it is already there + # It is a valid plugin, add its directory to $fpath unless it is already there elif (( ! ${fpath[(Ie)$base]} )); then fpath=("$base" $fpath) fi diff --git a/plugins/catimg/README.md b/plugins/catimg/README.md index 8f2688050..68dc33c1f 100644 --- a/plugins/catimg/README.md +++ b/plugins/catimg/README.md @@ -1,6 +1,6 @@ # catimg -Plugin for displaying images on the terminal using the the `catimg.sh` script provided by [posva](https://github.com/posva/catimg) +Plugin for displaying images on the terminal using the `catimg.sh` script provided by [posva](https://github.com/posva/catimg) To use it, add `catimg` to the plugins array in your zshrc file: diff --git a/plugins/emacs/README.md b/plugins/emacs/README.md index 8ed4a1473..47c7644ab 100644 --- a/plugins/emacs/README.md +++ b/plugins/emacs/README.md @@ -27,4 +27,4 @@ The plugin uses a custom launcher (which we'll call here `$EMACS_LAUNCHER`) that | eeval | `$EMACS_LAUNCHER --eval` | Same as `M-x eval` but from outside Emacs | | eframe | `emacsclient --alternate-editor="" --create-frame` | Create new X frame | | efile | - | Print the path to the file open in the current buffer | -| ecd | - | Print the directory of the file open in the the current buffer | +| ecd | - | Print the directory of the file open in the current buffer | diff --git a/plugins/emacs/emacs.plugin.zsh b/plugins/emacs/emacs.plugin.zsh index 4747f035b..5aa621803 100644 --- a/plugins/emacs/emacs.plugin.zsh +++ b/plugins/emacs/emacs.plugin.zsh @@ -60,7 +60,7 @@ function efile { } # Write to standard output the directory of the file -# opened in the the current buffer +# opened in the current buffer function ecd { local file file="$(efile)" || return $? diff --git a/plugins/ipfs/_ipfs b/plugins/ipfs/_ipfs index 8771bc4ba..5b8b05b98 100644 --- a/plugins/ipfs/_ipfs +++ b/plugins/ipfs/_ipfs @@ -202,7 +202,7 @@ _ipfs_subcommand(){ _arguments \ '--resolve[Check if the given path can be resolved before publishing. Default: true.]' \ '(-t --lifetime)'{-t,--lifetime}'[Time duration that the record will be valid for. Default: 24h.]' \ - '--allow-offline[When offline, save the IPNS record to the the local datastore without broadcasting to the network instead of simply failing.]' \ + '--allow-offline[When offline, save the IPNS record to the local datastore without broadcasting to the network instead of simply failing.]' \ '--ttl[Time duration this record should be cached for. Uses the same syntax as the lifetime option. (caution: experimental).]' \ '(-k --key)'{-k,--key}"[Name of the key to be used or a valid PeerID, as listed by 'ipfs key list -l'. Default: self.]" \ '(-Q --quieter)'{-Q,--quieter}'[Write only final hash.]' \ diff --git a/plugins/nomad/_nomad b/plugins/nomad/_nomad index 1c935a02e..4c6cb2fcb 100644 --- a/plugins/nomad/_nomad +++ b/plugins/nomad/_nomad @@ -97,7 +97,7 @@ __run() { '-address=[(addr) The address of the Nomad server. Overrides the NOMAD_ADDR environment variable if set. Default = http://127.0.0.1:4646]' \ '-region=[(region) The region of the Nomad servers to forward commands to. Overrides the NOMAD_REGION environment variable if set. Defaults to the Agent s local region.]' \ '-no-color[Disables colored command output.]' \ - '-check-index[If set, the job is only registered or updated if the the passed job modify index matches the server side version. If a check-index value of zero is passed, the job is only registered if it does not yet exist. If a non-zero value is passed, it ensures that the job is being updated from a known state. The use of this flag is most common in conjunction with plan command.]' \ + '-check-index[If set, the job is only registered or updated if the passed job modify index matches the server side version. If a check-index value of zero is passed, the job is only registered if it does not yet exist. If a non-zero value is passed, it ensures that the job is being updated from a known state. The use of this flag is most common in conjunction with plan command.]' \ '-detach[Return immediately instead of entering monitor mode. After job submission, the evaluation ID will be printed to the screen, which can be used to examine the evaluation using the eval-status command.]' \ '-output[Output the JSON that would be submitted to the HTTP API without submitting the job.]' \ '-verbose[Show full information.]' diff --git a/plugins/per-directory-history/per-directory-history.zsh b/plugins/per-directory-history/per-directory-history.zsh index b33e0b5dd..926373ae0 100644 --- a/plugins/per-directory-history/per-directory-history.zsh +++ b/plugins/per-directory-history/per-directory-history.zsh @@ -21,7 +21,7 @@ #------------------------------------------------------------------------------- # # The idea/inspiration for a per directory history is from Stewart MacArthur[1] -# and Dieter[2], the implementation idea is from Bart Schaefer on the the zsh +# and Dieter[2], the implementation idea is from Bart Schaefer on the zsh # mailing list[3]. The implementation is by Jim Hester in September 2012. # # [1]: http://www.compbiome.com/2010/07/bash-per-directory-bash-history.html diff --git a/plugins/ssh-agent/README.md b/plugins/ssh-agent/README.md index 8c118e65b..0afa80cc8 100644 --- a/plugins/ssh-agent/README.md +++ b/plugins/ssh-agent/README.md @@ -90,7 +90,7 @@ use the `ssh-add-args` setting. You can pass multiple arguments separated by spa zstyle :omz:plugins:ssh-agent ssh-add-args -K -c -a /run/user/1000/ssh-auth ``` -These will then be passed the the `ssh-add` call as if written directly. The example +These will then be passed the `ssh-add` call as if written directly. The example above will turn into: ```zsh From fff9ab7619fc26341908f63b18341f113805967a Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Fri, 15 Mar 2024 19:49:24 +0700 Subject: [PATCH 541/672] feat(dependencies): enable gradle plugin --- .github/dependencies.yml | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/.github/dependencies.yml b/.github/dependencies.yml index d60ab2c92..add39f7f3 100644 --- a/.github/dependencies.yml +++ b/.github/dependencies.yml @@ -29,3 +29,10 @@ dependencies: postcopy: | set -e test -e dependencies/OMZ-README.md && cat dependencies/OMZ-README.md >> README.md + plugins/gradle: + repo: gradle/gradle-completion + branch: master + version: ea018400d86610d0f79f84debbb33c2d2ef5dbec + precopy: | + set -e + find . ! -name _gradle -delete From 8940fa29134e5b06bbe383e8f741dbe097244626 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Fri, 15 Mar 2024 19:53:43 +0700 Subject: [PATCH 542/672] fix(dependencies): copy gradle LICENSE --- .github/dependencies.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/dependencies.yml b/.github/dependencies.yml index add39f7f3..98b52ffa9 100644 --- a/.github/dependencies.yml +++ b/.github/dependencies.yml @@ -35,4 +35,4 @@ dependencies: version: ea018400d86610d0f79f84debbb33c2d2ef5dbec precopy: | set -e - find . ! -name _gradle -delete + find . ! -name _gradle ! -name LICENSE -delete From d0bddee6e3703e78f588d037078606d41a4d6237 Mon Sep 17 00:00:00 2001 From: "ohmyzsh[bot]" <54982679+ohmyzsh[bot]@users.noreply.github.com> Date: Fri, 15 Mar 2024 19:55:43 +0700 Subject: [PATCH 543/672] feat(gradle): update completion to version 25da917c (#12287) Co-authored-by: ohmyzsh[bot] <54982679+ohmyzsh[bot]@users.noreply.github.com> --- .github/dependencies.yml | 2 +- plugins/gradle/LICENSE | 19 +++++++++++++++++++ plugins/gradle/_gradle | 30 +++--------------------------- 3 files changed, 23 insertions(+), 28 deletions(-) create mode 100644 plugins/gradle/LICENSE diff --git a/.github/dependencies.yml b/.github/dependencies.yml index 98b52ffa9..f760ddcef 100644 --- a/.github/dependencies.yml +++ b/.github/dependencies.yml @@ -32,7 +32,7 @@ dependencies: plugins/gradle: repo: gradle/gradle-completion branch: master - version: ea018400d86610d0f79f84debbb33c2d2ef5dbec + version: 25da917cf5a88f3e58f05be3868a7b2748c8afe6 precopy: | set -e find . ! -name _gradle ! -name LICENSE -delete diff --git a/plugins/gradle/LICENSE b/plugins/gradle/LICENSE new file mode 100644 index 000000000..06edf4af2 --- /dev/null +++ b/plugins/gradle/LICENSE @@ -0,0 +1,19 @@ +Copyright (c) 2017 Eric Wendelin + +Permission is hereby granted, free of charge, to any person obtaining a copy of +this software and associated documentation files (the "Software"), to deal in +the Software without restriction, including without limitation the rights to +use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies +of the Software, and to permit persons to whom the Software is furnished to do +so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/plugins/gradle/_gradle b/plugins/gradle/_gradle index f8df928b4..ca13fd0b0 100644 --- a/plugins/gradle/_gradle +++ b/plugins/gradle/_gradle @@ -1,28 +1,4 @@ #compdef gradle gradlew gw -# THE LINE ABOVE MUST BE THE FIRST LINE OF THIS FILE IN ORDER FOR COMPLETION TO WORK - -# -# Taken from https://github.com/gradle/gradle-completion -# Copyright (c) 2017 Eric Wendelin -# -# Permission is hereby granted, free of charge, to any person obtaining a copy of -# this software and associated documentation files (the "Software"), to deal in -# the Software without restriction, including without limitation the rights to -# use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies -# of the Software, and to permit persons to whom the Software is furnished to do -# so, subject to the following conditions: -# -# The above copyright notice and this permission notice shall be included in all -# copies or substantial portions of the Software. -# -# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE -# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER -# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, -# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE -# SOFTWARE. -# Terms __gradle-set-project-root-dir() { local dir=`pwd` @@ -38,7 +14,7 @@ __gradle-set-project-root-dir() { } __gradle-init-cache-dir() { - cache_dir="$HOME/.gradle/completion" + cache_dir="${GRADLE_USER_HOME:-$HOME/.gradle}/completion" mkdir -p $cache_dir } @@ -98,7 +74,7 @@ __gradle-generate-script-cache() { zle -R "Generating Gradle build script cache" # Cache all Gradle scripts local -a gradle_build_scripts - gradle_build_scripts=( $(find $project_root_dir -type f -name "*.gradle" -o -name "*.gradle.kts" 2>/dev/null | egrep -v "$script_exclude_pattern") ) + gradle_build_scripts=( $(find $project_root_dir -type f -name "*.gradle" -o -name "*.gradle.kts" 2>/dev/null | grep -E -v "$script_exclude_pattern") ) printf "%s\n" "${gradle_build_scripts[@]}" >| $cache_dir/$cache_name fi } @@ -125,7 +101,7 @@ __gradle-generate-tasks-cache() { local gradle_all_tasks="" root_tasks="" subproject_tasks="" output_line local -a match for output_line in ${(f)"$(printf "%s\n" "${gradle_tasks_output[@]}")"}; do - if [[ $output_line =~ ^([[:lower:]][[:alnum:][:punct:]]*)([[:space:]]-[[:space:]]([[:print:]]*))? ]]; then + if [[ $output_line =~ ^([[:alpha:]][[:alnum:][:punct:]]*)([[:space:]]-[[:space:]]([[:print:]]*))? ]]; then local task_name="${match[1]}" local task_description="${match[3]}" # Completion for subproject tasks with ':' prefix From 0fed36688f9a60d8b1f2182f27de7fdc8a1e6b72 Mon Sep 17 00:00:00 2001 From: Colin Barnabas <1637663+colin-barnabas@users.noreply.github.com> Date: Fri, 15 Mar 2024 21:26:48 -0700 Subject: [PATCH 544/672] fix(docker-compose): completion regression (#12288) --- plugins/docker-compose/_docker-compose | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/docker-compose/_docker-compose b/plugins/docker-compose/_docker-compose index c6b733500..d0ebfe515 100644 --- a/plugins/docker-compose/_docker-compose +++ b/plugins/docker-compose/_docker-compose @@ -128,7 +128,7 @@ __docker-compose_subcommand() { '--resolve-image-digests[Pin image tags to digests.]' \ '--services[Print the service names, one per line.]' \ '--volumes[Print the volume names, one per line.]' \ - '--hash[Print the service config hash, one per line. Set "service1,service2" for a list of specified services.]' \ && ret=0 + '--hash[Print the service config hash, one per line. Set "service1,service2" for a list of specified services.]' && ret=0 ;; (create) _arguments \ From d157fc60c93fa59e757921b503e9594bd23b422c Mon Sep 17 00:00:00 2001 From: Ben Woodward Date: Thu, 21 Mar 2024 19:46:40 +0000 Subject: [PATCH 545/672] fix(mise): update environment when loading the plugin (#12294) --- plugins/mise/mise.plugin.zsh | 3 +++ 1 file changed, 3 insertions(+) diff --git a/plugins/mise/mise.plugin.zsh b/plugins/mise/mise.plugin.zsh index 1b4d3ae81..357174d91 100644 --- a/plugins/mise/mise.plugin.zsh +++ b/plugins/mise/mise.plugin.zsh @@ -11,6 +11,9 @@ fi # Load mise hooks eval "$($__mise activate zsh)" +# Hook mise into current environment +eval "$($__mise hook-env -s zsh)" + # If the completion file doesn't exist yet, we need to autoload it and # bind it to `mise`. Otherwise, compinit will have already done that. if [[ ! -f "$ZSH_CACHE_DIR/completions/_$__mise" ]]; then From 3e05befaeee60a0f8522f470292c75046b05ceb9 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Alexander=20Schl=C3=BCter?= Date: Mon, 25 Mar 2024 12:27:21 +0100 Subject: [PATCH 546/672] fix(ssh-agent): don't start new agent if screen/tmux symlink exists (#12297) --- plugins/ssh-agent/ssh-agent.plugin.zsh | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/plugins/ssh-agent/ssh-agent.plugin.zsh b/plugins/ssh-agent/ssh-agent.plugin.zsh index 49ad95a11..77c422ce1 100644 --- a/plugins/ssh-agent/ssh-agent.plugin.zsh +++ b/plugins/ssh-agent/ssh-agent.plugin.zsh @@ -98,8 +98,10 @@ function _add_identities() { # Add a nifty symlink for screen/tmux if agent forwarding is enabled if zstyle -t :omz:plugins:ssh-agent agent-forwarding \ - && [[ -n "$SSH_AUTH_SOCK" && ! -L "$SSH_AUTH_SOCK" ]]; then - ln -sf "$SSH_AUTH_SOCK" /tmp/ssh-agent-$USERNAME-screen + && [[ -n "$SSH_AUTH_SOCK" ]]; then + if [[ ! -L "$SSH_AUTH_SOCK" ]]; then + ln -sf "$SSH_AUTH_SOCK" /tmp/ssh-agent-$USERNAME-screen + fi else _start_agent fi From 7647c79bae1542b5f4dddc85b16058df7f83fc6c Mon Sep 17 00:00:00 2001 From: Jim Weller <31997291+jimweller@users.noreply.github.com> Date: Tue, 26 Mar 2024 01:48:14 -0700 Subject: [PATCH 547/672] feat(jira): add help/usage cmd (#12293) Co-authored-by: Carlo Sala --- plugins/jira/README.md | 5 ++++- plugins/jira/_jira | 1 + plugins/jira/jira.plugin.zsh | 17 +++++++++++++++++ 3 files changed, 22 insertions(+), 1 deletion(-) diff --git a/plugins/jira/README.md b/plugins/jira/README.md index d78ea15a4..b1d8a8bc6 100644 --- a/plugins/jira/README.md +++ b/plugins/jira/README.md @@ -16,18 +16,21 @@ This plugin supplies one command, `jira`, through which all its features are exp ## Commands +`jira help` or `jira usage` will print the below usage instructions + | Command | Description | | :------------ | :-------------------------------------------------------- | | `jira` | Performs the default action | | `jira new` | Opens a new Jira issue dialogue | | `jira ABC-123` | Opens an existing issue | | `jira ABC-123 m` | Opens an existing issue for adding a comment | -| `jira dashboard [rapid_view]` | # opens your JIRA dashboard | +| `jira dashboard [rapid_view]` | Opens your JIRA dashboard | | `jira mine` | Queries for your own issues | | `jira tempo` | Opens your JIRA Tempo | | `jira reported [username]` | Queries for issues reported by a user | | `jira assigned [username]` | Queries for issues assigned to a user | | `jira branch` | Opens an existing issue matching the current branch name | +| `jira help` | Prints usage instructions | ### Jira Branch usage notes diff --git a/plugins/jira/_jira b/plugins/jira/_jira index 0e37b7e9d..5f7dcd09d 100644 --- a/plugins/jira/_jira +++ b/plugins/jira/_jira @@ -11,6 +11,7 @@ _1st_arguments=( 'assigned:search for issues assigned to a user' 'branch:open the issue named after the git branch of the current directory' 'dumpconfig:display effective jira configuration' + 'help:print usage help to stdout' ) _arguments -C \ diff --git a/plugins/jira/jira.plugin.zsh b/plugins/jira/jira.plugin.zsh index b6ee9f100..9bcf4cc7b 100644 --- a/plugins/jira/jira.plugin.zsh +++ b/plugins/jira/jira.plugin.zsh @@ -2,6 +2,21 @@ # # See README.md for details +function _jira_usage() { +cat < Date: Tue, 26 Mar 2024 09:52:01 +0100 Subject: [PATCH 548/672] feat(terraform): add `tft` (`terraform test`) (#12299) --- plugins/terraform/README.md | 27 +++++++++++++------------- plugins/terraform/terraform.plugin.zsh | 1 + 2 files changed, 15 insertions(+), 13 deletions(-) diff --git a/plugins/terraform/README.md b/plugins/terraform/README.md index 135fd78ef..2b535517c 100644 --- a/plugins/terraform/README.md +++ b/plugins/terraform/README.md @@ -15,19 +15,20 @@ plugins=(... terraform) ## Aliases -| Alias | Command | -| ----- | -------------------- | -| `tf` | `terraform` | -| `tfa` | `terraform apply` | -| `tfc` | `terraform console` | -| `tfd` | `terraform destroy` | -| `tff` | `terraform fmt` | -| `tfi` | `terraform init` | -| `tfo` | `terraform output` | -| `tfp` | `terraform plan` | -| `tfv` | `terraform validate` | -| `tfs` | `terraform state` | -| `tfsh`| `terraform show` | +| Alias | Command | +| ------ | -------------------- | +| `tf` | `terraform` | +| `tfa` | `terraform apply` | +| `tfc` | `terraform console` | +| `tfd` | `terraform destroy` | +| `tff` | `terraform fmt` | +| `tfi` | `terraform init` | +| `tfo` | `terraform output` | +| `tfp` | `terraform plan` | +| `tfv` | `terraform validate` | +| `tfs` | `terraform state` | +| `tft` | `terraform test` | +| `tfsh` | `terraform show` | ## Prompt function diff --git a/plugins/terraform/terraform.plugin.zsh b/plugins/terraform/terraform.plugin.zsh index f66a8eac9..8ef392efd 100644 --- a/plugins/terraform/terraform.plugin.zsh +++ b/plugins/terraform/terraform.plugin.zsh @@ -25,4 +25,5 @@ alias tfo='terraform output' alias tfp='terraform plan' alias tfv='terraform validate' alias tfs='terraform state' +alias tft='terraform test' alias tfsh='terraform show' From a168efe73e467c7164ef9b49dea61e9aefd27a48 Mon Sep 17 00:00:00 2001 From: Zikoeng Xi Date: Tue, 26 Mar 2024 16:54:04 +0800 Subject: [PATCH 549/672] fix(poetry-env): activate only if env exists (#12301) --- plugins/poetry-env/poetry-env.plugin.zsh | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/plugins/poetry-env/poetry-env.plugin.zsh b/plugins/poetry-env/poetry-env.plugin.zsh index 86e5fad4e..97ca52492 100644 --- a/plugins/poetry-env/poetry-env.plugin.zsh +++ b/plugins/poetry-env/poetry-env.plugin.zsh @@ -14,10 +14,10 @@ _togglePoetryShell() { # activate the environment if pyproject.toml exists if [[ "$poetry_active" != 1 ]]; then if [[ -f "$PWD/pyproject.toml" ]]; then - if grep -q 'tool.poetry' "$PWD/pyproject.toml"; then + if grep -q 'tool.poetry' "$PWD/pyproject.toml" && venv_dir=$(poetry env info --path); then export poetry_active=1 export poetry_dir="$PWD" - source "$(poetry env info --path)/bin/activate" + source "${venv_dir}/bin/activate" fi fi fi From 1d09c6bb0a950756a65b02457842933e3aa493eb Mon Sep 17 00:00:00 2001 From: vladislav doster <10052309+vladdoster@users.noreply.github.com> Date: Tue, 26 Mar 2024 03:55:16 -0500 Subject: [PATCH 550/672] style: remove trailing whitespace (#12303) --- custom/example.zsh | 6 ++--- custom/themes/example.zsh-theme | 2 +- lib/compfix.zsh | 2 +- lib/diagnostics.zsh | 24 +++++++++---------- oh-my-zsh.sh | 2 +- plugins/ansible/README.md | 2 +- plugins/aws/aws.plugin.zsh | 2 +- plugins/branch/README.md | 2 +- plugins/chruby/chruby.plugin.zsh | 4 ++-- plugins/cloudfoundry/README.md | 2 +- plugins/coffee/README.md | 2 +- plugins/compleat/compleat.plugin.zsh | 4 ++-- plugins/copybuffer/copybuffer.plugin.zsh | 2 +- plugins/dash/README.md | 2 +- plugins/dotnet/dotnet.plugin.zsh | 2 +- plugins/emoji/emoji.plugin.zsh | 18 +++++++------- plugins/emotty/emotty.plugin.zsh | 2 +- plugins/encode64/README.md | 2 +- plugins/fancy-ctrl-z/README.md | 8 +++---- plugins/fastfile/README.md | 4 ++-- plugins/forklift/forklift.plugin.zsh | 4 ++-- plugins/fzf/fzf.plugin.zsh | 2 +- plugins/gnu-utils/gnu-utils.plugin.zsh | 4 ++-- plugins/grails/grails.plugin.zsh | 14 +++++------ plugins/history-substring-search/README.md | 8 +++---- plugins/ionic/ionic.plugin.zsh | 12 +++++----- plugins/iterm2/README.md | 2 +- plugins/iterm2/iterm2.plugin.zsh | 2 +- plugins/iterm2/iterm2_shell_integration.zsh | 4 ++-- plugins/jira/README.md | 2 +- plugins/juju/juju.plugin.zsh | 2 +- plugins/kn/kn.plugin.zsh | 2 +- plugins/macports/_port | 8 +++---- plugins/marked2/README.md | 2 +- plugins/marktext/README.md | 2 +- plugins/mongo-atlas/README.md | 2 +- plugins/n98-magerun/n98-magerun.plugin.zsh | 2 +- plugins/nmap/nmap.plugin.zsh | 2 +- plugins/nomad/_nomad | 2 +- plugins/npm/npm.plugin.zsh | 2 +- plugins/nvm/nvm.plugin.zsh | 2 +- plugins/otp/README.md | 2 +- plugins/pm2/_pm2 | 2 +- plugins/poetry-env/README.md | 2 +- plugins/ros/_ros | 2 +- plugins/sbt/sbt.plugin.zsh | 2 +- plugins/screen/screen.plugin.zsh | 2 +- plugins/singlechar/singlechar.plugin.zsh | 2 +- plugins/systemadmin/README.md | 2 +- plugins/thor/README.md | 2 +- plugins/ufw/README.md | 2 +- plugins/vagrant-prompt/README.md | 2 +- plugins/vi-mode/README.md | 2 +- plugins/vim-interaction/README.md | 2 +- .../vim-interaction.plugin.zsh | 2 +- .../virtualenvwrapper.plugin.zsh | 2 +- plugins/wd/README.md | 2 +- plugins/wd/_wd.sh | 2 +- plugins/z/MANUAL.md | 2 +- themes/Soliah.zsh-theme | 10 ++++---- themes/adben.zsh-theme | 2 +- themes/agnoster.zsh-theme | 2 +- themes/avit.zsh-theme | 2 +- themes/crunch.zsh-theme | 6 ++--- themes/eastwood.zsh-theme | 2 +- themes/emotty.zsh-theme | 4 ++-- themes/essembeh.zsh-theme | 4 ++-- themes/josh.zsh-theme | 8 +++---- themes/junkfood.zsh-theme | 4 ++-- themes/mlh.zsh-theme | 2 +- themes/mortalscumbag.zsh-theme | 2 +- themes/sonicradish.zsh-theme | 2 +- themes/wedisagree.zsh-theme | 14 +++++------ 73 files changed, 138 insertions(+), 138 deletions(-) diff --git a/custom/example.zsh b/custom/example.zsh index 21a8d8be7..c194f49d7 100644 --- a/custom/example.zsh +++ b/custom/example.zsh @@ -1,12 +1,12 @@ # Put files in this folder to add your own custom functionality. # See: https://github.com/ohmyzsh/ohmyzsh/wiki/Customization -# +# # Files in the custom/ directory will be: # - loaded automatically by the init script, in alphabetical order # - loaded last, after all built-ins in the lib/ directory, to override them # - ignored by git by default -# +# # Example: add custom/shortcuts.zsh for shortcuts to your local projects -# +# # brainstormr=~/Projects/development/planetargon/brainstormr # cd $brainstormr diff --git a/custom/themes/example.zsh-theme b/custom/themes/example.zsh-theme index 494d029e8..5551207f8 100644 --- a/custom/themes/example.zsh-theme +++ b/custom/themes/example.zsh-theme @@ -1,6 +1,6 @@ # Put your custom themes in this folder. # See: https://github.com/ohmyzsh/ohmyzsh/wiki/Customization#overriding-and-adding-themes -# +# # Example: PROMPT="%{$fg[red]%}%n%{$reset_color%}@%{$fg[blue]%}%m %{$fg[yellow]%}%~ %{$reset_color%}%% " diff --git a/lib/compfix.zsh b/lib/compfix.zsh index b09b283f2..2fe9d9e64 100644 --- a/lib/compfix.zsh +++ b/lib/compfix.zsh @@ -13,7 +13,7 @@ function handle_completion_insecurities() { # /usr/share/zsh/5.0.6 # # Since the ignorable first line is printed to stderr and thus not captured, - # stderr is squelched to prevent this output from leaking to the user. + # stderr is squelched to prevent this output from leaking to the user. local -aU insecure_dirs insecure_dirs=( ${(f@):-"$(compaudit 2>/dev/null)"} ) diff --git a/lib/diagnostics.zsh b/lib/diagnostics.zsh index eaeba7d23..d67e6fab4 100644 --- a/lib/diagnostics.zsh +++ b/lib/diagnostics.zsh @@ -30,7 +30,7 @@ # # This is written in a defensive style so it still works (and can detect) cases when # basic functionality like echo and which have been redefined. In particular, almost -# everything is invoked with "builtin" or "command", to work in the face of user +# everything is invoked with "builtin" or "command", to work in the face of user # redefinitions. # # OPTIONS @@ -59,7 +59,7 @@ function omz_diagnostic_dump() { emulate -L zsh builtin echo "Generating diagnostic dump; please be patient..." - + local thisfcn=omz_diagnostic_dump local -A opts local opt_verbose opt_noverbose opt_outfile @@ -90,7 +90,7 @@ function omz_diagnostic_dump() { builtin echo builtin echo Diagnostic dump file created at: "$outfile" builtin echo - builtin echo To share this with OMZ developers, post it as a gist on GitHub + builtin echo To share this with OMZ developers, post it as a gist on GitHub builtin echo at "https://gist.github.com" and share the link to the gist. builtin echo builtin echo "WARNING: This dump file contains all your zsh and omz configuration files," @@ -105,8 +105,8 @@ function _omz_diag_dump_one_big_text() { builtin echo oh-my-zsh diagnostic dump builtin echo builtin echo $outfile - builtin echo - + builtin echo + # Basic system and zsh information command date command uname -a @@ -151,7 +151,7 @@ function _omz_diag_dump_one_big_text() { # Core command definitions _omz_diag_dump_check_core_commands || return 1 - builtin echo + builtin echo # ZSH Process state builtin echo Process state: @@ -167,7 +167,7 @@ function _omz_diag_dump_one_big_text() { #TODO: Should this include `env` instead of or in addition to `export`? builtin echo Exported: builtin echo $(builtin export | command sed 's/=.*//') - builtin echo + builtin echo builtin echo Locale: command locale builtin echo @@ -181,7 +181,7 @@ function _omz_diag_dump_one_big_text() { builtin echo builtin echo 'compaudit output:' compaudit - builtin echo + builtin echo builtin echo '$fpath directories:' command ls -lad $fpath builtin echo @@ -224,7 +224,7 @@ function _omz_diag_dump_one_big_text() { local cfgfile cfgfiles # Some files for bash that zsh does not use are intentionally included # to help with diagnosing behavior differences between bash and zsh - cfgfiles=( /etc/zshenv /etc/zprofile /etc/zshrc /etc/zlogin /etc/zlogout + cfgfiles=( /etc/zshenv /etc/zprofile /etc/zshrc /etc/zlogin /etc/zlogout $zdotdir/.zshenv $zdotdir/.zprofile $zdotdir/.zshrc $zdotdir/.zlogin $zdotdir/.zlogout ~/.zsh.pre-oh-my-zsh /etc/bashrc /etc/profile ~/.bashrc ~/.profile ~/.bash_profile ~/.bash_logout ) @@ -258,8 +258,8 @@ function _omz_diag_dump_check_core_commands() { # (For back-compatibility, if any of these are newish, they should be removed, # or at least made conditional on the version of the current running zsh.) # "history" is also excluded because OMZ is known to redefine that - reserved_words=( do done esac then elif else fi for case if while function - repeat time until select coproc nocorrect foreach end '!' '[[' '{' '}' + reserved_words=( do done esac then elif else fi for case if while function + repeat time until select coproc nocorrect foreach end '!' '[[' '{' '}' ) builtins=( alias autoload bg bindkey break builtin bye cd chdir command comparguments compcall compctl compdescribe compfiles compgroups compquote comptags @@ -331,7 +331,7 @@ function _omz_diag_dump_os_specific_version() { case "$OSTYPE" in darwin*) osname=$(command sw_vers -productName) - osver=$(command sw_vers -productVersion) + osver=$(command sw_vers -productVersion) builtin echo "OS Version: $osname $osver build $(sw_vers -buildVersion)" ;; cygwin) diff --git a/oh-my-zsh.sh b/oh-my-zsh.sh index 137ca3b6f..2fb20298a 100644 --- a/oh-my-zsh.sh +++ b/oh-my-zsh.sh @@ -152,7 +152,7 @@ unset zcompdump_revision zcompdump_fpath zcompdump_refresh # zcompile the completion dump file if the .zwc is older or missing. if command mkdir "${ZSH_COMPDUMP}.lock" 2>/dev/null; then zrecompile -q -p "$ZSH_COMPDUMP" - command rm -rf "$ZSH_COMPDUMP.zwc.old" "${ZSH_COMPDUMP}.lock" + command rm -rf "$ZSH_COMPDUMP.zwc.old" "${ZSH_COMPDUMP}.lock" fi _omz_source() { diff --git a/plugins/ansible/README.md b/plugins/ansible/README.md index ce21e7075..dd0e1ce03 100644 --- a/plugins/ansible/README.md +++ b/plugins/ansible/README.md @@ -28,6 +28,6 @@ plugins=(... ansible) ## Maintainer -### [Deepankumar](https://github.com/deepan10) +### [Deepankumar](https://github.com/deepan10) [https://github.com/deepan10/oh-my-zsh/tree/features/ansible-plugin](https://github.com/deepan10/oh-my-zsh/tree/features/ansible-plugin) diff --git a/plugins/aws/aws.plugin.zsh b/plugins/aws/aws.plugin.zsh index 071dd1f0b..0c43031df 100644 --- a/plugins/aws/aws.plugin.zsh +++ b/plugins/aws/aws.plugin.zsh @@ -280,7 +280,7 @@ if [[ "$AWS_PROFILE_STATE_ENABLED" == true ]]; then test -s "${AWS_STATE_FILE}" || return aws_state=($(cat $AWS_STATE_FILE)) - + export AWS_DEFAULT_PROFILE="${aws_state[1]}" export AWS_PROFILE="$AWS_DEFAULT_PROFILE" export AWS_EB_PROFILE="$AWS_DEFAULT_PROFILE" diff --git a/plugins/branch/README.md b/plugins/branch/README.md index a15dd22df..2b6d12d29 100644 --- a/plugins/branch/README.md +++ b/plugins/branch/README.md @@ -39,7 +39,7 @@ index 2fd5f2cd..9d89a464 100644 PROMPT="%(?:%{$fg_bold[green]%}➜ :%{$fg_bold[red]%}➜ )" -PROMPT+=' %{$fg[cyan]%}%c%{$reset_color%} $(git_prompt_info)' +PROMPT+=' %{$fg[cyan]%}%c%{$reset_color%} $(branch_prompt_info)' - + ZSH_THEME_GIT_PROMPT_PREFIX="%{$fg_bold[blue]%}git:(%{$fg[red]%}" ZSH_THEME_GIT_PROMPT_SUFFIX="%{$reset_color%} " ``` diff --git a/plugins/chruby/chruby.plugin.zsh b/plugins/chruby/chruby.plugin.zsh index d7a28d4e2..1210897c4 100644 --- a/plugins/chruby/chruby.plugin.zsh +++ b/plugins/chruby/chruby.plugin.zsh @@ -2,7 +2,7 @@ _source-from-omz-settings() { local _chruby_path _chruby_auto - + zstyle -s :omz:plugins:chruby path _chruby_path || return 1 zstyle -s :omz:plugins:chruby auto _chruby_auto || return 1 @@ -23,7 +23,7 @@ _source-from-homebrew() { if [[ -h /usr/local/opt/chruby ]];then _brew_prefix="/usr/local/opt/chruby" else - # ok , it is not default prefix + # ok , it is not default prefix # this call to brew is expensive ( about 400 ms ), so at least let's make it only once _brew_prefix=$(brew --prefix chruby) fi diff --git a/plugins/cloudfoundry/README.md b/plugins/cloudfoundry/README.md index 89dd9d1ce..567a9056b 100644 --- a/plugins/cloudfoundry/README.md +++ b/plugins/cloudfoundry/README.md @@ -50,7 +50,7 @@ Alternatively, seek out the [online documentation][3]. And don't forget, there a ## Contributors -Contributed to `oh_my_zsh` by [benwilcock][2]. +Contributed to `oh_my_zsh` by [benwilcock][2]. [1]: https://docs.cloudfoundry.org/cf-cli/install-go-cli.html [2]: https://github.com/benwilcock diff --git a/plugins/coffee/README.md b/plugins/coffee/README.md index 2baade844..c2ab192b6 100644 --- a/plugins/coffee/README.md +++ b/plugins/coffee/README.md @@ -24,7 +24,7 @@ Also provides the following aliases: * **cfc:** Copies the compiled JS to your clipboard. Very useful when you want to run the code in a JS console. -* **cfp:** Compiles from your currently copied clipboard. Useful when you want +* **cfp:** Compiles from your currently copied clipboard. Useful when you want to compile large/multi-line snippets * **cfpc:** Paste coffeescript from clipboard, compile to JS, then copy the diff --git a/plugins/compleat/compleat.plugin.zsh b/plugins/compleat/compleat.plugin.zsh index 38f1b396a..7fbd2b953 100644 --- a/plugins/compleat/compleat.plugin.zsh +++ b/plugins/compleat/compleat.plugin.zsh @@ -7,7 +7,7 @@ if (( ${+commands[compleat]} )); then local prefix="${commands[compleat]:h:h}" - local setup="${prefix}/share/compleat-1.0/compleat_setup" + local setup="${prefix}/share/compleat-1.0/compleat_setup" if [[ -f "$setup" ]]; then if ! bashcompinit >/dev/null 2>&1; then @@ -15,6 +15,6 @@ if (( ${+commands[compleat]} )); then bashcompinit -i fi - source "$setup" + source "$setup" fi fi diff --git a/plugins/copybuffer/copybuffer.plugin.zsh b/plugins/copybuffer/copybuffer.plugin.zsh index e67f920f0..88bda32a0 100644 --- a/plugins/copybuffer/copybuffer.plugin.zsh +++ b/plugins/copybuffer/copybuffer.plugin.zsh @@ -1,4 +1,4 @@ -# copy the active line from the command line buffer +# copy the active line from the command line buffer # onto the system clipboard copybuffer () { diff --git a/plugins/dash/README.md b/plugins/dash/README.md index 0ca3e4e44..970c6541f 100644 --- a/plugins/dash/README.md +++ b/plugins/dash/README.md @@ -19,7 +19,7 @@ dash - Query for something in dash app: `dash query` ``` -dash golang +dash golang ``` - You can optionally provide a keyword: `dash [keyword:]query` diff --git a/plugins/dotnet/dotnet.plugin.zsh b/plugins/dotnet/dotnet.plugin.zsh index 40ee7efae..ed7c55024 100644 --- a/plugins/dotnet/dotnet.plugin.zsh +++ b/plugins/dotnet/dotnet.plugin.zsh @@ -11,7 +11,7 @@ _dotnet_completion() { compdef _dotnet_completion dotnet # Aliases bellow are here for backwards compatibility -# added by Shaun Tabone (https://github.com/xontab) +# added by Shaun Tabone (https://github.com/xontab) alias dn='dotnet new' alias dr='dotnet run' diff --git a/plugins/emoji/emoji.plugin.zsh b/plugins/emoji/emoji.plugin.zsh index f9e476ebf..f7be56cf7 100644 --- a/plugins/emoji/emoji.plugin.zsh +++ b/plugins/emoji/emoji.plugin.zsh @@ -24,7 +24,7 @@ unset _omz_emoji_plugin_dir # This is a combining character that can be placed after any other character to surround # it in a "keycap" symbol. -# The digits 0-9 are already in the emoji table as keycap_digit_, keycap_ten, etc. +# The digits 0-9 are already in the emoji table as keycap_digit_, keycap_ten, etc. # It's unclear whether this should be in the $emoji array, because those characters are all ones # which can be displayed on their own. @@ -63,9 +63,9 @@ function random_emoji() { [[ $list_size -eq 0 ]] && return 1 local random_index=$(( ( RANDOM % $list_size ) + 1 )) local name=${names[$random_index]} - if [[ "$group" == "flags" ]]; then + if [[ "$group" == "flags" ]]; then echo ${emoji_flags[$name]} - else + else echo ${emoji[$name]} fi } @@ -86,22 +86,22 @@ function display_emoji() { # terminals treat these emoji chars as single-width. local counter=1 for i in $names; do - if [[ "$group" == "flags" ]]; then + if [[ "$group" == "flags" ]]; then printf '%s ' "$emoji_flags[$i]" - else - printf '%s ' "$emoji[$i]" + else + printf '%s ' "$emoji[$i]" fi # New line every 20 emoji, to avoid weirdnesses if (($counter % 20 == 0)); then - printf "\n" + printf "\n" fi let counter=$counter+1 done print for i in $names; do - if [[ "$group" == "flags" ]]; then + if [[ "$group" == "flags" ]]; then echo "${emoji_flags[$i]} = $i" - else + else echo "${emoji[$i]} = $i" fi done diff --git a/plugins/emotty/emotty.plugin.zsh b/plugins/emotty/emotty.plugin.zsh index 661169a8b..b48d121dc 100644 --- a/plugins/emotty/emotty.plugin.zsh +++ b/plugins/emotty/emotty.plugin.zsh @@ -4,7 +4,7 @@ # AUTHOR: Alexis Hildebrandt (afh[at]surryhill.net) # VERSION: 1.0.0 # DEPENDS: emoji plugin -# +# # There are different sets of emoji characters available, to choose a different # set export emotty_set to the name of the set you would like to use, e.g.: # % export emotty_set=nature diff --git a/plugins/encode64/README.md b/plugins/encode64/README.md index 7cdf8c3f3..e3e25a742 100644 --- a/plugins/encode64/README.md +++ b/plugins/encode64/README.md @@ -40,7 +40,7 @@ plugins=(... encode64) ### Encoding a file -Encode a file's contents to base64 and save output to text file. +Encode a file's contents to base64 and save output to text file. **NOTE:** Takes provided file and saves encoded content as new file with `.txt` extension - From parameter diff --git a/plugins/fancy-ctrl-z/README.md b/plugins/fancy-ctrl-z/README.md index f1b1dfa5c..82a4fd75e 100644 --- a/plugins/fancy-ctrl-z/README.md +++ b/plugins/fancy-ctrl-z/README.md @@ -1,14 +1,14 @@ # Use Ctrl-Z to switch back to Vim -I frequently need to execute random commands in my shell. To achieve it I pause +I frequently need to execute random commands in my shell. To achieve it I pause Vim by pressing Ctrl-z, type command and press fg to switch back to Vim. -The fg part really hurts me. I just wanted to hit Ctrl-z once again to get back -to Vim. I could not find a solution, so I developed one on my own that +The fg part really hurts me. I just wanted to hit Ctrl-z once again to get back +to Vim. I could not find a solution, so I developed one on my own that works wonderfully with ZSH. Source: http://sheerun.net/2014/03/21/how-to-boost-your-vim-productivity/ -Credits: +Credits: - original idea by @sheerun - added to OMZ by @mbologna diff --git a/plugins/fastfile/README.md b/plugins/fastfile/README.md index 32f619ffd..7291fde38 100644 --- a/plugins/fastfile/README.md +++ b/plugins/fastfile/README.md @@ -71,13 +71,13 @@ them, add `=` to your zshrc file, before Oh My Zsh is sourced. For example: `fastfile_var_prefix='@'`. - `fastfile_var_prefix`: prefix for the global aliases created. Controls the prefix of the - created global aliases. + created global aliases. **Default:** `§` (section sign), easy to type in a german keyboard via the combination [`⇧ Shift`+`3`](https://en.wikipedia.org/wiki/German_keyboard_layout#/media/File:KB_Germany.svg), or using `⌥ Option`+`6` in macOS. - `fastfile_dir`: directory where the fastfile shortcuts are stored. Needs to end - with a trailing slash. + with a trailing slash. **Default:** `$HOME/.fastfile/`. ## Author diff --git a/plugins/forklift/forklift.plugin.zsh b/plugins/forklift/forklift.plugin.zsh index 85889481b..848aedabf 100644 --- a/plugins/forklift/forklift.plugin.zsh +++ b/plugins/forklift/forklift.plugin.zsh @@ -58,7 +58,7 @@ function fl { tell application forkLiftSetapp activate set forkLiftVersion to version - end tell + end tell else if forkLift3 is not null and application forkLift3 is running then tell application forkLift3 activate @@ -84,7 +84,7 @@ function fl { else if forkLift is not null then set appName to forkLift end if - + tell application appName activate set forkLiftVersion to version diff --git a/plugins/fzf/fzf.plugin.zsh b/plugins/fzf/fzf.plugin.zsh index 7312e3d26..9e372f498 100644 --- a/plugins/fzf/fzf.plugin.zsh +++ b/plugins/fzf/fzf.plugin.zsh @@ -62,7 +62,7 @@ function fzf_setup_using_base_dir() { function fzf_setup_using_debian() { if (( ! $+commands[apt] && ! $+commands[apt-get] )); then - # Not a debian based distro + # Not a debian based distro return 1 fi diff --git a/plugins/gnu-utils/gnu-utils.plugin.zsh b/plugins/gnu-utils/gnu-utils.plugin.zsh index 6023bf2b4..adc2bd3bb 100644 --- a/plugins/gnu-utils/gnu-utils.plugin.zsh +++ b/plugins/gnu-utils/gnu-utils.plugin.zsh @@ -14,7 +14,7 @@ __gnu_utils() { local -a gcmds local gcmd - # coreutils + # coreutils gcmds=('g[' 'gbase64' 'gbasename' 'gcat' 'gchcon' 'gchgrp' 'gchmod' 'gchown' 'gchroot' 'gcksum' 'gcomm' 'gcp' 'gcsplit' 'gcut' 'gdate' 'gdd' 'gdf' 'gdir' 'gdircolors' 'gdirname' 'gdu' 'gecho' 'genv' 'gexpand' @@ -41,7 +41,7 @@ __gnu_utils() { for gcmd in "${gcmds[@]}"; do # Do nothing if the command isn't found (( ${+commands[$gcmd]} )) || continue - + # This method allows for builtin commands to be primary but it's # lost if hash -r or rehash is executed, or if $PATH is updated. # Thus, a preexec hook is needed, which will only run if whoami diff --git a/plugins/grails/grails.plugin.zsh b/plugins/grails/grails.plugin.zsh index ddc257428..e5dceb530 100644 --- a/plugins/grails/grails.plugin.zsh +++ b/plugins/grails/grails.plugin.zsh @@ -7,7 +7,7 @@ _enumerateGrailsScripts() { then directories+=(plugins/*/scripts) fi - + # Enumerate all of the Groovy files files=() for dir in $directories; @@ -17,13 +17,13 @@ _enumerateGrailsScripts() { files+=($dir/[^_]*.groovy) fi done - + # Don't try to basename () if [ ${#files} -eq 0 ]; then return fi - + scripts=() for file in $files do @@ -42,19 +42,19 @@ _enumerateGrailsScripts() { done echo $scripts } - + _grails() { if (( CURRENT == 2 )); then scripts=( $(_enumerateGrailsScripts) ) - + if [ ${#scripts} -ne 0 ]; then _multi_parts / scripts return fi fi - + _files } - + compdef _grails grails diff --git a/plugins/history-substring-search/README.md b/plugins/history-substring-search/README.md index 71a389535..4be744c4c 100644 --- a/plugins/history-substring-search/README.md +++ b/plugins/history-substring-search/README.md @@ -57,13 +57,13 @@ Using [antigen](https://github.com/zsh-users/antigen): 1. Add the `antigen bundle` command just before `antigen apply`, like this: -``` +``` antigen bundle zsh-users/zsh-history-substring-search antigen apply ``` - + 2. Then, **after** `antigen apply`, add the key binding configurations, like this: - + ``` # zsh-history-substring-search configuration bindkey '^[[A' history-substring-search-up # or '\eOA' @@ -120,7 +120,7 @@ Usage bindkey "$terminfo[kcuu1]" history-substring-search-up bindkey "$terminfo[kcud1]" history-substring-search-down - Users have also observed that `[OA` and `[OB` are correct values, + Users have also observed that `[OA` and `[OB` are correct values, _even if_ these were not the observed values. If you are having trouble with the observed values, give these a try. diff --git a/plugins/ionic/ionic.plugin.zsh b/plugins/ionic/ionic.plugin.zsh index cf388af1b..e3913b549 100644 --- a/plugins/ionic/ionic.plugin.zsh +++ b/plugins/ionic/ionic.plugin.zsh @@ -3,13 +3,13 @@ alias ih="ionic --help" alias ist="ionic start" alias ii="ionic info" alias is="ionic serve" -alias icba="ionic cordova build android" -alias icbi="ionic cordova build ios" -alias icra="ionic cordova run android" -alias icri="ionic cordova run ios" -alias icrsa="ionic cordova resources android" +alias icba="ionic cordova build android" +alias icbi="ionic cordova build ios" +alias icra="ionic cordova run android" +alias icri="ionic cordova run ios" +alias icrsa="ionic cordova resources android" alias icrsi="ionic cordova resources ios" -alias icpaa="ionic cordova platform add android" +alias icpaa="ionic cordova platform add android" alias icpai="ionic cordova platform add ios" alias icpra="ionic cordova platform rm android" alias icpri="ionic cordova platform rm ios" diff --git a/plugins/iterm2/README.md b/plugins/iterm2/README.md index 3d11622df..86bd77f1d 100644 --- a/plugins/iterm2/README.md +++ b/plugins/iterm2/README.md @@ -9,7 +9,7 @@ plugins=(... iterm2) ``` Optionally, the plugin also applies the [Shell Integration Script for iTerm2](https://iterm2.com/documentation-shell-integration.html). -You can enable the integration with zstyle. It's important to add this line +You can enable the integration with zstyle. It's important to add this line before the line sourcing oh-my-zsh: ``` diff --git a/plugins/iterm2/iterm2.plugin.zsh b/plugins/iterm2/iterm2.plugin.zsh index d00232a30..03a63a70c 100644 --- a/plugins/iterm2/iterm2.plugin.zsh +++ b/plugins/iterm2/iterm2.plugin.zsh @@ -8,7 +8,7 @@ if [[ "$OSTYPE" == darwin* ]] && [[ -n "$ITERM_SESSION_ID" ]] ; then # maybe make it the default in the future and allow opting out? - if zstyle -t ':omz:plugins:iterm2' shell-integration; then + if zstyle -t ':omz:plugins:iterm2' shell-integration; then # Handle $0 according to the standard: # https://zdharma-continuum.github.io/Zsh-100-Commits-Club/Zsh-Plugin-Standard.html 0="${${ZERO:-${0:#$ZSH_ARGZERO}}:-${(%):-%N}}" diff --git a/plugins/iterm2/iterm2_shell_integration.zsh b/plugins/iterm2/iterm2_shell_integration.zsh index 7871ddded..281332e0d 100644 --- a/plugins/iterm2/iterm2_shell_integration.zsh +++ b/plugins/iterm2/iterm2_shell_integration.zsh @@ -2,12 +2,12 @@ # modify it under the terms of the GNU General Public License # as published by the Free Software Foundation; either version 2 # of the License, or (at your option) any later version. -# +# # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. -# +# # You should have received a copy of the GNU General Public License # along with this program; if not, write to the Free Software # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. diff --git a/plugins/jira/README.md b/plugins/jira/README.md index b1d8a8bc6..1c6930298 100644 --- a/plugins/jira/README.md +++ b/plugins/jira/README.md @@ -35,7 +35,7 @@ This plugin supplies one command, `jira`, through which all its features are exp ### Jira Branch usage notes -The branch name may have prefixes ending in "/": "feature/MP-1234", and also suffixes +The branch name may have prefixes ending in "/": "feature/MP-1234", and also suffixes starting with "_": "MP-1234_fix_dashboard". In both these cases, the issue opened will be "MP-1234" This is also checks if the prefix is in the name, and adds it if not, so: "MP-1234" opens the issue "MP-1234", diff --git a/plugins/juju/juju.plugin.zsh b/plugins/juju/juju.plugin.zsh index a82ebaf84..3c159da22 100644 --- a/plugins/juju/juju.plugin.zsh +++ b/plugins/juju/juju.plugin.zsh @@ -184,7 +184,7 @@ jmodel() { fi local model="$(yq e ".controllers.$(jcontroller).current-model" < ~/.local/share/juju/models.yaml | cut -d/ -f2)" - + if [[ -z "$model" ]]; then echo "--" return 1 diff --git a/plugins/kn/kn.plugin.zsh b/plugins/kn/kn.plugin.zsh index f60177dd9..483d1d68c 100644 --- a/plugins/kn/kn.plugin.zsh +++ b/plugins/kn/kn.plugin.zsh @@ -4,5 +4,5 @@ if [ $commands[kn] ]; then source <(kn completion zsh) - compdef _kn kn + compdef _kn kn fi diff --git a/plugins/macports/_port b/plugins/macports/_port index 897598a46..f40f6550b 100644 --- a/plugins/macports/_port +++ b/plugins/macports/_port @@ -1,6 +1,6 @@ #compdef port -local subcmds +local subcmds # we cache the list of ports # we shall use some cache policy to avoid problems with new ports @@ -31,8 +31,8 @@ subcmds=( 'file' 'help' 'info' -'install' -'installed' +'install' +'installed' 'list' 'livecheck' 'location' @@ -51,7 +51,7 @@ subcmds=( 'test' 'unarchive' 'uninstall' -'upgrade' +'upgrade' 'variants' 'version' ) diff --git a/plugins/marked2/README.md b/plugins/marked2/README.md index 101343abb..2f825bc4a 100644 --- a/plugins/marked2/README.md +++ b/plugins/marked2/README.md @@ -1,6 +1,6 @@ ## marked2 -Plugin for Marked 2, a previewer for Markdown files on Mac OS X +Plugin for Marked 2, a previewer for Markdown files on Mac OS X ### Requirements diff --git a/plugins/marktext/README.md b/plugins/marktext/README.md index 71d287451..254e4e7ac 100644 --- a/plugins/marktext/README.md +++ b/plugins/marktext/README.md @@ -1,6 +1,6 @@ ## marktext -Plugin for MarkText, a previewer for Markdown files on Mac OS X +Plugin for MarkText, a previewer for Markdown files on Mac OS X ### Requirements diff --git a/plugins/mongo-atlas/README.md b/plugins/mongo-atlas/README.md index ef1b5e0d2..94183c544 100644 --- a/plugins/mongo-atlas/README.md +++ b/plugins/mongo-atlas/README.md @@ -1,6 +1,6 @@ # MongoDB Atlas plugin -This plugin adds completion for [Atlas](https://www.mongodb.com/docs/atlas/cli/stable/) a command line interface built specifically for +This plugin adds completion for [Atlas](https://www.mongodb.com/docs/atlas/cli/stable/) a command line interface built specifically for MongoDB Atlas. To use it, add `mongo-atlas` to the plugins array in your zshrc file: diff --git a/plugins/n98-magerun/n98-magerun.plugin.zsh b/plugins/n98-magerun/n98-magerun.plugin.zsh index d79aee7eb..2744ad96e 100644 --- a/plugins/n98-magerun/n98-magerun.plugin.zsh +++ b/plugins/n98-magerun/n98-magerun.plugin.zsh @@ -1,6 +1,6 @@ # ------------------------------------------------------------------------------ # FILE: n98-magerun.plugin.zsh -# DESCRIPTION: oh-my-zsh n98-magerun plugin file. Adapted from composer plugin +# DESCRIPTION: oh-my-zsh n98-magerun plugin file. Adapted from composer plugin # AUTHOR: Andrew Dwyer (andrewrdwyer at gmail dot com) # AUTHOR: Jisse Reitsma (jisse at yireo dot com) # VERSION: 1.1.0 diff --git a/plugins/nmap/nmap.plugin.zsh b/plugins/nmap/nmap.plugin.zsh index 406870f00..f649dafc2 100644 --- a/plugins/nmap/nmap.plugin.zsh +++ b/plugins/nmap/nmap.plugin.zsh @@ -27,6 +27,6 @@ alias nmap_detect_versions="sudo nmap -sV -p1-65535 -O --osscan-guess -T4 -Pn" alias nmap_check_for_vulns="nmap --script=vuln" alias nmap_full_udp="sudo nmap -sS -sU -T4 -A -v -PE -PS22,25,80 -PA21,23,80,443,3389 " alias nmap_traceroute="sudo nmap -sP -PE -PS22,25,80 -PA21,23,80,3389 -PU -PO --traceroute " -alias nmap_full_with_scripts="sudo nmap -sS -sU -T4 -A -v -PE -PP -PS21,22,23,25,80,113,31339 -PA80,113,443,10042 -PO --script all " +alias nmap_full_with_scripts="sudo nmap -sS -sU -T4 -A -v -PE -PP -PS21,22,23,25,80,113,31339 -PA80,113,443,10042 -PO --script all " alias nmap_web_safe_osscan="sudo nmap -p 80,443 -O -v --osscan-guess --fuzzy " alias nmap_ping_scan="nmap -n -sP" diff --git a/plugins/nomad/_nomad b/plugins/nomad/_nomad index 4c6cb2fcb..87f80aa84 100644 --- a/plugins/nomad/_nomad +++ b/plugins/nomad/_nomad @@ -89,7 +89,7 @@ __plan() { '-address=[(addr) The address of the Nomad server. Overrides the NOMAD_ADDR environment variable if set. Default = http://127.0.0.1:4646]' \ '-region=[(region) The region of the Nomad servers to forward commands to. Overrides the NOMAD_REGION environment variable if set. Defaults to the Agent s local region.]' \ '-no-color[Disables colored command output.]' \ - '-diff[Determines whether the diff between the remote job and planned job is shown. Defaults to true.]' + '-diff[Determines whether the diff between the remote job and planned job is shown. Defaults to true.]' } __run() { diff --git a/plugins/npm/npm.plugin.zsh b/plugins/npm/npm.plugin.zsh index 23377b085..c333f76ed 100644 --- a/plugins/npm/npm.plugin.zsh +++ b/plugins/npm/npm.plugin.zsh @@ -58,7 +58,7 @@ alias npmt="npm test" # Run npm scripts alias npmR="npm run" -# Run npm publish +# Run npm publish alias npmP="npm publish" # Run npm init diff --git a/plugins/nvm/nvm.plugin.zsh b/plugins/nvm/nvm.plugin.zsh index 6a5afecfa..c2e8de94b 100644 --- a/plugins/nvm/nvm.plugin.zsh +++ b/plugins/nvm/nvm.plugin.zsh @@ -16,7 +16,7 @@ if [[ -z "$NVM_DIR" ]]; then fi fi -if [[ -z "$NVM_DIR" ]] || [[ ! -f "$NVM_DIR/nvm.sh" ]]; then +if [[ -z "$NVM_DIR" ]] || [[ ! -f "$NVM_DIR/nvm.sh" ]]; then return fi diff --git a/plugins/otp/README.md b/plugins/otp/README.md index 8331fd02b..52ad9525b 100644 --- a/plugins/otp/README.md +++ b/plugins/otp/README.md @@ -16,7 +16,7 @@ Provided aliases: email address). Then the OTP key needs to be pasted, followed by a CTRL+D character inserted on an empty line. -- `ot`: generates a MFA code based on the given key and copies it to the clipboard +- `ot`: generates a MFA code based on the given key and copies it to the clipboard (on Linux it relies on xsel, on MacOS X it uses pbcopy instead). The plugin uses `$HOME/.otp` to store its internal files. diff --git a/plugins/pm2/_pm2 b/plugins/pm2/_pm2 index faa6a3404..66320b810 100644 --- a/plugins/pm2/_pm2 +++ b/plugins/pm2/_pm2 @@ -79,7 +79,7 @@ _id_names() { local app_list app_list=`pm2 list -m` - local -a names ids + local -a names ids names=(`echo $app_list | grep '+---' | awk '{print $2}'`) ids=(`echo $app_list | grep 'pm2 id' | awk '{print $4}'`) diff --git a/plugins/poetry-env/README.md b/plugins/poetry-env/README.md index a7d16563e..bd99d2a91 100644 --- a/plugins/poetry-env/README.md +++ b/plugins/poetry-env/README.md @@ -1,6 +1,6 @@ # Poetry Environment Plugin -This plugin automatically changes poetry environment when you cd into or out of the project directory. +This plugin automatically changes poetry environment when you cd into or out of the project directory. Note: Script looks for pyproject.toml file to determine poetry if its a poetry environment To use it, add `poetry-env` to the plugins array in your zshrc file: diff --git a/plugins/ros/_ros b/plugins/ros/_ros index 6a04d3c8f..c73a7b353 100644 --- a/plugins/ros/_ros +++ b/plugins/ros/_ros @@ -18,7 +18,7 @@ _1st_arguments=( 'config:Get and set options' 'version:Show the roswell version information' "help:Use \"ros help [command]\" for more information about a command."$'\n\t\t'"Use \"ros help [topic]\" for more information about the topic." -) +) #local expl diff --git a/plugins/sbt/sbt.plugin.zsh b/plugins/sbt/sbt.plugin.zsh index 851302c68..1e977140b 100644 --- a/plugins/sbt/sbt.plugin.zsh +++ b/plugins/sbt/sbt.plugin.zsh @@ -4,7 +4,7 @@ # AUTHOR: Mirko Caserta (mirko.caserta@gmail.com) # VERSION: 1.0.2 # ------------------------------------------------------------------------------ - + # aliases - mnemonic: prefix is 'sb' alias sbc='sbt compile' alias sbcc='sbt clean compile' diff --git a/plugins/screen/screen.plugin.zsh b/plugins/screen/screen.plugin.zsh index c1db8ad92..26531c40b 100644 --- a/plugins/screen/screen.plugin.zsh +++ b/plugins/screen/screen.plugin.zsh @@ -8,7 +8,7 @@ if [[ "$TERM" == screen* ]]; then _GET_HOST='echo $HOST | sed "s/\..*//"' fi - # use the current user as the prefix of the current tab title + # use the current user as the prefix of the current tab title TAB_TITLE_PREFIX='"`'$_GET_HOST'`:`'$_GET_PATH' | sed "s:..*/::"`$PROMPT_CHAR"' # when at the shell prompt, show a truncated version of the current path (with # standard ~ replacement) as the rest of the title. diff --git a/plugins/singlechar/singlechar.plugin.zsh b/plugins/singlechar/singlechar.plugin.zsh index d4b0b6735..6d785d9e1 100644 --- a/plugins/singlechar/singlechar.plugin.zsh +++ b/plugins/singlechar/singlechar.plugin.zsh @@ -1,5 +1,5 @@ ########################### -# Settings +# Settings # These can be overwritten any time. # If they are not set yet, they will be diff --git a/plugins/systemadmin/README.md b/plugins/systemadmin/README.md index 3a9d9de66..bd6b08760 100644 --- a/plugins/systemadmin/README.md +++ b/plugins/systemadmin/README.md @@ -1,7 +1,7 @@ # Systemadmin plugin This plugin adds a series of aliases and functions which make a System Administrator's life easier. - + To use it, add `systemadmin` to the plugins array in your zshrc file: ```zsh diff --git a/plugins/thor/README.md b/plugins/thor/README.md index 09c705d9a..484c88b84 100644 --- a/plugins/thor/README.md +++ b/plugins/thor/README.md @@ -1,6 +1,6 @@ # Thor plugin -This plugin adds completion for [Thor](http://whatisthor.com/), +This plugin adds completion for [Thor](http://whatisthor.com/), a ruby toolkit for building powerful command-line interfaces. To use it, add `thor` to the plugins array in your zshrc file: diff --git a/plugins/ufw/README.md b/plugins/ufw/README.md index ac377cd17..ffcc6d6f7 100644 --- a/plugins/ufw/README.md +++ b/plugins/ufw/README.md @@ -10,7 +10,7 @@ plugins=(... ufw) Some of the commands include: -* `allow /` add an allow rule +* `allow /` add an allow rule * `default` set default policy * `delete /` delete RULE * `deny /` add deny rule diff --git a/plugins/vagrant-prompt/README.md b/plugins/vagrant-prompt/README.md index c5bc55d17..dd0ca363b 100644 --- a/plugins/vagrant-prompt/README.md +++ b/plugins/vagrant-prompt/README.md @@ -1,6 +1,6 @@ This plugin prompts the status of the Vagrant VMs. It supports single-host and multi-host configurations as well. -Look inside the source for documentation about custom variables. +Look inside the source for documentation about custom variables. Alberto Re diff --git a/plugins/vi-mode/README.md b/plugins/vi-mode/README.md index 84ba30105..6e781f296 100644 --- a/plugins/vi-mode/README.md +++ b/plugins/vi-mode/README.md @@ -55,7 +55,7 @@ INSERT_MODE_INDICATOR="%F{yellow}+%f" ### Adding mode indicators to your prompt -`Vi-mode` by default will add mode indicators to `RPROMPT` **unless** that is defined by +`Vi-mode` by default will add mode indicators to `RPROMPT` **unless** that is defined by a preceding plugin. If `PROMPT` or `RPROMPT` is not defined to your liking, you can add mode info manually. The `vi_mode_prompt_info` function is available to insert mode indicator information. diff --git a/plugins/vim-interaction/README.md b/plugins/vim-interaction/README.md index 681648018..c2b45f1d8 100644 --- a/plugins/vim-interaction/README.md +++ b/plugins/vim-interaction/README.md @@ -3,7 +3,7 @@ The plugin presents a function called `callvim` whose usage is: usage: callvim [-b cmd] [-a cmd] [file ... fileN] - + -b cmd Run this command in GVIM before editing the first file -a cmd Run this command in GVIM after editing the first file file The file to edit diff --git a/plugins/vim-interaction/vim-interaction.plugin.zsh b/plugins/vim-interaction/vim-interaction.plugin.zsh index b73f9b4da..a12b52bd5 100644 --- a/plugins/vim-interaction/vim-interaction.plugin.zsh +++ b/plugins/vim-interaction/vim-interaction.plugin.zsh @@ -2,7 +2,7 @@ # See README.md # # Derek Wyatt (derek@{myfirstnamemylastname}.org -# +# function callvim { if [[ $# == 0 ]]; then diff --git a/plugins/virtualenvwrapper/virtualenvwrapper.plugin.zsh b/plugins/virtualenvwrapper/virtualenvwrapper.plugin.zsh index e037241e4..1a3ae37b8 100644 --- a/plugins/virtualenvwrapper/virtualenvwrapper.plugin.zsh +++ b/plugins/virtualenvwrapper/virtualenvwrapper.plugin.zsh @@ -52,7 +52,7 @@ if [[ ! $DISABLE_VENV_CD -eq 1 ]]; then else ENV_NAME="" fi - + if [[ -n $CD_VIRTUAL_ENV && "$ENV_NAME" != "$CD_VIRTUAL_ENV" ]]; then # We've just left the repo, deactivate the environment # Note: this only happens if the virtualenv was activated automatically diff --git a/plugins/wd/README.md b/plugins/wd/README.md index 1d1980632..0ad74e805 100644 --- a/plugins/wd/README.md +++ b/plugins/wd/README.md @@ -153,7 +153,7 @@ wd .. wd ... ``` -This is a wrapper for the zsh's `dirs` function. +This is a wrapper for the zsh's `dirs` function. _You might need to add `setopt AUTO_PUSHD` to your `.zshrc` if you are not using [oh-my-zsh](https://github.com/ohmyzsh/ohmyzsh)._ * Remove warp point: diff --git a/plugins/wd/_wd.sh b/plugins/wd/_wd.sh index 8d5cf15a2..52ecb12e6 100644 --- a/plugins/wd/_wd.sh +++ b/plugins/wd/_wd.sh @@ -77,7 +77,7 @@ function _wd() { # complete sub directories from the warp point _path_files -W "(${points[$target]})" -/ && ret=0 fi - + # don't complete anything if warp point is not valid ;; esac diff --git a/plugins/z/MANUAL.md b/plugins/z/MANUAL.md index 67a207dbb..106d8c107 100644 --- a/plugins/z/MANUAL.md +++ b/plugins/z/MANUAL.md @@ -188,7 +188,7 @@ Add a backslash to the end of the last line add `'zsh-z'` to the list, e.g., Then relaunch `zsh`. ### For [zcomet](https://github.com/agkozak/zcomet) users - + Simply add zcomet load agkozak/zsh-z diff --git a/themes/Soliah.zsh-theme b/themes/Soliah.zsh-theme index c3dd6af89..e297fe9ca 100644 --- a/themes/Soliah.zsh-theme +++ b/themes/Soliah.zsh-theme @@ -5,10 +5,10 @@ ZSH_THEME_GIT_PROMPT_PREFIX="%{$fg[white]%}" ZSH_THEME_GIT_PROMPT_SUFFIX="%{$reset_color%})" # Text to display if the branch is dirty -ZSH_THEME_GIT_PROMPT_DIRTY="%{$fg[red]%}*%{$reset_color%}" +ZSH_THEME_GIT_PROMPT_DIRTY="%{$fg[red]%}*%{$reset_color%}" # Text to display if the branch is clean -ZSH_THEME_GIT_PROMPT_CLEAN="" +ZSH_THEME_GIT_PROMPT_CLEAN="" # Colors vary depending on time lapsed. ZSH_THEME_GIT_TIME_SINCE_COMMIT_SHORT="%{$fg[green]%}" @@ -36,7 +36,7 @@ function rvm_gemset() { GEMSET=`rvm gemset list | grep '=>' | cut -b4-` if [[ -n $GEMSET ]]; then echo "%{$fg[yellow]%}$GEMSET%{$reset_color%}|" - fi + fi fi } @@ -52,12 +52,12 @@ function git_time_since_commit() { # Totals MINUTES=$((seconds_since_last_commit / 60)) HOURS=$((seconds_since_last_commit/3600)) - + # Sub-hours and sub-minutes DAYS=$((seconds_since_last_commit / 86400)) SUB_HOURS=$((HOURS % 24)) SUB_MINUTES=$((MINUTES % 60)) - + if [[ -n $(git status -s 2> /dev/null) ]]; then if [ "$MINUTES" -gt 30 ]; then COLOR="$ZSH_THEME_GIT_TIME_SINCE_COMMIT_LONG" diff --git a/themes/adben.zsh-theme b/themes/adben.zsh-theme index c2fdbed23..cc097057f 100644 --- a/themes/adben.zsh-theme +++ b/themes/adben.zsh-theme @@ -79,7 +79,7 @@ ps1_command_tip() { command wget -qO- https://www.commandlinefu.com/commands/random/plaintext elif (( ${+commands[curl]} )); then command curl -fsL https://www.commandlinefu.com/commands/random/plaintext - fi + fi } | sed '1d;/^$/d' } diff --git a/themes/agnoster.zsh-theme b/themes/agnoster.zsh-theme index aa274a5bb..bd0405efb 100644 --- a/themes/agnoster.zsh-theme +++ b/themes/agnoster.zsh-theme @@ -111,7 +111,7 @@ prompt_git() { dirty=$(parse_git_dirty) ref=$(git symbolic-ref HEAD 2> /dev/null) || \ ref="◈ $(git describe --exact-match --tags HEAD 2> /dev/null)" || \ - ref="➦ $(git rev-parse --short HEAD 2> /dev/null)" + ref="➦ $(git rev-parse --short HEAD 2> /dev/null)" if [[ -n $dirty ]]; then prompt_segment yellow black else diff --git a/themes/avit.zsh-theme b/themes/avit.zsh-theme index 206274462..0e39d9077 100644 --- a/themes/avit.zsh-theme +++ b/themes/avit.zsh-theme @@ -15,7 +15,7 @@ __RPROMPT='$(vi_mode_prompt_info)%{$(echotc UP 1)%}$(_git_time_since_commit) $(g if [[ -z $RPROMPT ]]; then RPROMPT=$__RPROMPT else - RPROMPT="${RPROMPT} ${__RPROMPT}" + RPROMPT="${RPROMPT} ${__RPROMPT}" fi function _user_host() { diff --git a/themes/crunch.zsh-theme b/themes/crunch.zsh-theme index 8278661ab..d86ce1e4a 100644 --- a/themes/crunch.zsh-theme +++ b/themes/crunch.zsh-theme @@ -1,15 +1,15 @@ # CRUNCH - created from Steve Eley's cat waxing. # Initially hacked from the Dallas theme. Thanks, Dallas Reedy. # -# This theme assumes you do most of your oh-my-zsh'ed "colorful" work at a single machine, -# and eschews the standard space-consuming user and hostname info. Instead, only the +# This theme assumes you do most of your oh-my-zsh'ed "colorful" work at a single machine, +# and eschews the standard space-consuming user and hostname info. Instead, only the # things that vary in my own workflow are shown: # # * The time (not the date) # * The RVM version and gemset (omitting the 'ruby' name if it's MRI) # * The current directory # * The Git branch and its 'dirty' state -# +# # Colors are at the top so you can mess with those separately if you like. # For the most part I stuck with Dallas's. diff --git a/themes/eastwood.zsh-theme b/themes/eastwood.zsh-theme index 88134f8e6..31e24fa7f 100644 --- a/themes/eastwood.zsh-theme +++ b/themes/eastwood.zsh-theme @@ -1,5 +1,5 @@ # RVM settings -if [[ -s ~/.rvm/scripts/rvm ]] ; then +if [[ -s ~/.rvm/scripts/rvm ]] ; then RPS1="%{$fg[yellow]%}rvm:%{$reset_color%}%{$fg[red]%}\$(~/.rvm/bin/rvm-prompt)%{$reset_color%} $EPS1" else if which rbenv &> /dev/null; then diff --git a/themes/emotty.zsh-theme b/themes/emotty.zsh-theme index ba0840950..0fea7d916 100644 --- a/themes/emotty.zsh-theme +++ b/themes/emotty.zsh-theme @@ -11,7 +11,7 @@ # # There are pre-defined different emoji sets to choose from, e.g.: # emoji, stellar, floral, zodiac, love (see emotty plugin). -# +# # To choose a different emotty set than the default (emoji) # % export emotty_set=nature # @@ -95,7 +95,7 @@ zstyle ':vcs_info:*' stagedstr "${green}${vcs_staged_glyph}" # %(k|f) reset (back|fore)ground color zstyle ':vcs_info:*' max-exports 3 zstyle ':vcs_info:*' nvcsformats "${prompt_glyph}" '%3~' '' -zstyle ':vcs_info:*' formats "${yellow}%u%c%b${vcs_branch_glyph}%f" '%S|' "$FX[bold]%r$FX[no-bold]" +zstyle ':vcs_info:*' formats "${yellow}%u%c%b${vcs_branch_glyph}%f" '%S|' "$FX[bold]%r$FX[no-bold]" zstyle ':vcs_info:*' actionformats "${red}%K{white}%a${vcs_action_glyph}%k%f" '%S|' "$FX[bold]%r$FX[no-bold]" red_if_root="%(!.%F{red}.)" diff --git a/themes/essembeh.zsh-theme b/themes/essembeh.zsh-theme index 43d4093b1..50b3f7772 100644 --- a/themes/essembeh.zsh-theme +++ b/themes/essembeh.zsh-theme @@ -8,7 +8,7 @@ # - prefix to detect docker containers or chroot # - git plugin to display current branch and status -# git plugin +# git plugin ZSH_THEME_GIT_PROMPT_PREFIX="%{$fg[cyan]%}(" ZSH_THEME_GIT_PROMPT_SUFFIX=") %{$reset_color%}" ZSH_THEME_GIT_PROMPT_UNTRACKED="%%" @@ -35,7 +35,7 @@ if [[ -n "$SSH_CONNECTION" ]]; then ZSH_ESSEMBEH_PREFIX="%{$fg[yellow]%}[$(echo $SSH_CONNECTION | awk '{print $1}')]%{$reset_color%} " # use red color to highlight a remote connection ZSH_ESSEMBEH_COLOR="red" -elif [[ -r /etc/debian_chroot ]]; then +elif [[ -r /etc/debian_chroot ]]; then # prefix prompt in case of chroot ZSH_ESSEMBEH_PREFIX="%{$fg[yellow]%}[chroot:$(cat /etc/debian_chroot)]%{$reset_color%} " elif [[ -r /.dockerenv ]]; then diff --git a/themes/josh.zsh-theme b/themes/josh.zsh-theme index ea051c58e..df59280d7 100644 --- a/themes/josh.zsh-theme +++ b/themes/josh.zsh-theme @@ -15,7 +15,7 @@ function josh_prompt { branch_size=${#branch} ruby_size=${#ruby_version} user_machine_size=${#${(%):-%n@%m-}} - + if [[ ${#branch} -eq 0 ]] then (( ruby_size = ruby_size + 1 )) else @@ -24,15 +24,15 @@ function josh_prompt { (( branch_size = branch_size + 2 )) fi fi - + (( spare_width = ${spare_width} - (${user_machine_size} + ${path_size} + ${branch_size} + ${ruby_size}) )) while [ ${#prompt} -lt $spare_width ]; do prompt=" $prompt" done - + prompt="%{%F{green}%}$PWD$prompt%{%F{red}%}$(ruby_prompt_info)%{$reset_color%} $(git_current_branch)" - + echo $prompt } diff --git a/themes/junkfood.zsh-theme b/themes/junkfood.zsh-theme index 01fae4b95..e3b746c7a 100644 --- a/themes/junkfood.zsh-theme +++ b/themes/junkfood.zsh-theme @@ -3,10 +3,10 @@ # Grab the current date (%W) and time (%t): JUNKFOOD_TIME_="%{$fg_bold[red]%}#%{$fg_bold[white]%}( %{$fg_bold[yellow]%}%W%{$reset_color%}@%{$fg_bold[white]%}%t )( %{$reset_color%}" -# Grab the current machine name +# Grab the current machine name JUNKFOOD_MACHINE_="%{$fg_bold[blue]%}%m%{$fg[white]%} ):%{$reset_color%}" -# Grab the current username +# Grab the current username JUNKFOOD_CURRENT_USER_="%{$fg_bold[green]%}%n%{$reset_color%}" # Grab the current filepath, use shortcuts: ~/Desktop diff --git a/themes/mlh.zsh-theme b/themes/mlh.zsh-theme index c059bf850..94718f8f2 100644 --- a/themes/mlh.zsh-theme +++ b/themes/mlh.zsh-theme @@ -15,7 +15,7 @@ # To customize symbols (e.g MLH_AT_SYMBOL), simply set them as environment variables # for example in your ~/.zshrc file, like this: # MLH_AT_SYMBOL=" at " -# +# # Settings *must* be set before sourcing oh-my-zsh.sh the .zshrc file. # # To easily discover colors and their codes, type `spectrum_ls` in the terminal diff --git a/themes/mortalscumbag.zsh-theme b/themes/mortalscumbag.zsh-theme index 36301cb76..c9994c0f9 100644 --- a/themes/mortalscumbag.zsh-theme +++ b/themes/mortalscumbag.zsh-theme @@ -1,6 +1,6 @@ function my_git_prompt() { tester=$(git rev-parse --git-dir 2> /dev/null) || return - + INDEX=$(git status --porcelain 2> /dev/null) STATUS="" diff --git a/themes/sonicradish.zsh-theme b/themes/sonicradish.zsh-theme index 508611830..db6170969 100644 --- a/themes/sonicradish.zsh-theme +++ b/themes/sonicradish.zsh-theme @@ -1,4 +1,4 @@ -#!/usr/bin/env zsh +#!/usr/bin/env zsh #local return_code="%(?..%{$fg[red]%}%? ↵%{$reset_color%})" setopt promptsubst diff --git a/themes/wedisagree.zsh-theme b/themes/wedisagree.zsh-theme index e9e9d6ef8..358891992 100644 --- a/themes/wedisagree.zsh-theme +++ b/themes/wedisagree.zsh-theme @@ -5,9 +5,9 @@ # - Place that bundle in ~/Library/Application\ Support/SIMBL/Plugins (create that folder if it doesn't exist) # - Open Terminal preferences. Go to Settings -> Text -> More # - Change default colours to your liking. -# +# # Here are the colours from Textmate's Monokai theme: -# +# # Black: 0, 0, 0 # Red: 229, 34, 34 # Green: 166, 227, 45 @@ -28,7 +28,7 @@ PROMPT='%{$fg[magenta]%}[%c] %{$reset_color%}' RPROMPT='${time} %{$fg[magenta]%}$(git_prompt_info)%{$reset_color%}$(git_prompt_status)%{$reset_color%}$(git_prompt_ahead)%{$reset_color%}' # Add this at the start of RPROMPT to include rvm info showing ruby-version@gemset-name -# $(ruby_prompt_info) +# $(ruby_prompt_info) # local time, color coded by last return code time_enabled="%(?.%{$fg[green]%}.%{$fg[red]%})%*%{$reset_color%}" @@ -53,7 +53,7 @@ ZSH_THEME_RUBY_PROMPT_SUFFIX="%{$reset_color%}" # More symbols to choose from: # ☀ ✹ ☄ ♆ ♀ ♁ ♐ ♇ ♈ ♉ ♚ ♛ ♜ ♝ ♞ ♟ ♠ ♣ ⚢ ⚲ ⚳ ⚴ ⚥ ⚤ ⚦ ⚒ ⚑ ⚐ ♺ ♻ ♼ ☰ ☱ ☲ ☳ ☴ ☵ ☶ ☷ -# ✡ ✔ ✖ ✚ ✱ ✤ ✦ ❤ ➜ ➟ ➼ ✂ ✎ ✐ ⨀ ⨁ ⨂ ⨍ ⨎ ⨏ ⨷ ⩚ ⩛ ⩡ ⩱ ⩲ ⩵ ⩶ ⨠ +# ✡ ✔ ✖ ✚ ✱ ✤ ✦ ❤ ➜ ➟ ➼ ✂ ✎ ✐ ⨀ ⨁ ⨂ ⨍ ⨎ ⨏ ⨷ ⩚ ⩛ ⩡ ⩱ ⩲ ⩵ ⩶ ⨠ # ⬅ ⬆ ⬇ ⬈ ⬉ ⬊ ⬋ ⬒ ⬓ ⬔ ⬕ ⬖ ⬗ ⬘ ⬙ ⬟ ⬤ 〒 ǀ ǁ ǂ ĭ Ť Ŧ # Determine if we are using a gemset. @@ -61,7 +61,7 @@ function rvm_gemset() { GEMSET=`rvm gemset list | grep '=>' | cut -b4-` if [[ -n $GEMSET ]]; then echo "%{$fg[yellow]%}$GEMSET%{$reset_color%}|" - fi + fi } # Determine the time since last commit. If branch is clean, @@ -76,12 +76,12 @@ function git_time_since_commit() { # Totals MINUTES=$((seconds_since_last_commit / 60)) HOURS=$((seconds_since_last_commit/3600)) - + # Sub-hours and sub-minutes DAYS=$((seconds_since_last_commit / 86400)) SUB_HOURS=$((HOURS % 24)) SUB_MINUTES=$((MINUTES % 60)) - + if [[ -n $(git status -s 2> /dev/null) ]]; then if [ "$MINUTES" -gt 30 ]; then COLOR="$ZSH_THEME_GIT_TIME_SINCE_COMMIT_LONG" From 62a76353ab73532c2681c6b168623f7f1e7d96ae Mon Sep 17 00:00:00 2001 From: Masaru Iritani <25241373+masaru-iritani@users.noreply.github.com> Date: Sat, 30 Mar 2024 16:25:34 +0900 Subject: [PATCH 551/672] fix(starship): keep `ZSH_THEME` if not installed (#12309) --- plugins/starship/starship.plugin.zsh | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/plugins/starship/starship.plugin.zsh b/plugins/starship/starship.plugin.zsh index 8c5d9135e..fc415e64c 100644 --- a/plugins/starship/starship.plugin.zsh +++ b/plugins/starship/starship.plugin.zsh @@ -1,7 +1,7 @@ -# ignore oh-my-zsh theme -unset ZSH_THEME - if (( $+commands[starship] )); then + # ignore oh-my-zsh theme + unset ZSH_THEME + eval "$(starship init zsh)" else echo '[oh-my-zsh] starship not found, please install it from https://starship.rs' From 6dfa9507ce0eb0f4d386bd03268e33943ea55c0f Mon Sep 17 00:00:00 2001 From: Jason D'Amour Date: Sat, 30 Mar 2024 00:26:14 -0700 Subject: [PATCH 552/672] feat(gcloud): add homebrew installation path (#12308) --- plugins/gcloud/gcloud.plugin.zsh | 1 + 1 file changed, 1 insertion(+) diff --git a/plugins/gcloud/gcloud.plugin.zsh b/plugins/gcloud/gcloud.plugin.zsh index cf3d650ea..fa8f884a4 100644 --- a/plugins/gcloud/gcloud.plugin.zsh +++ b/plugins/gcloud/gcloud.plugin.zsh @@ -9,6 +9,7 @@ if [[ -z "${CLOUDSDK_HOME}" ]]; then "/usr/local/share/google-cloud-sdk" "/usr/local/Caskroom/google-cloud-sdk/latest/google-cloud-sdk" "/opt/homebrew/Caskroom/google-cloud-sdk/latest/google-cloud-sdk" + "/opt/homebrew/share/google-cloud-sdk" "/usr/share/google-cloud-sdk" "/snap/google-cloud-sdk/current" "/snap/google-cloud-cli/current" From 130002a79e8567befa409177990bb2724b8edefc Mon Sep 17 00:00:00 2001 From: Gregory Reshetniak Date: Wed, 3 Apr 2024 09:10:33 +0200 Subject: [PATCH 553/672] feat(httpie): complete https command (#12314) --- plugins/httpie/_httpie | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/httpie/_httpie b/plugins/httpie/_httpie index 11bc8e1f8..2c0db229f 100644 --- a/plugins/httpie/_httpie +++ b/plugins/httpie/_httpie @@ -1,4 +1,4 @@ -#compdef http +#compdef http https # ------------------------------------------------------------------------------ # Copyright (c) 2015 GitHub zsh-users - http://github.com/zsh-users # All rights reserved. From b43b84abc77850a3734c127c38afdd7cf7739dc6 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Lo=C3=AFc=20Yhuel?= Date: Wed, 3 Apr 2024 19:42:47 +0200 Subject: [PATCH 554/672] fix(async): avoid blocking the shell while waiting (#12304) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Co-authored-by: Marc Cornellà --- lib/async_prompt.zsh | 14 +++++--------- 1 file changed, 5 insertions(+), 9 deletions(-) diff --git a/lib/async_prompt.zsh b/lib/async_prompt.zsh index 384e49d33..ac95bcd73 100644 --- a/lib/async_prompt.zsh +++ b/lib/async_prompt.zsh @@ -82,10 +82,8 @@ function _omz_async_request { exec {fd}< <( # Tell parent process our PID builtin echo ${sysparams[pid]} - # Store handler name for callback - builtin echo $handler # Set exit code for the handler if used - (exit $ret) + () { return $ret } # Run the async function handler $handler ) @@ -98,8 +96,7 @@ function _omz_async_request { command true # Save the PID from the handler child process - read pid <&$fd - _OMZ_ASYNC_PIDS[$handler]=$pid + read -u $fd "_OMZ_ASYNC_PIDS[$handler]" # When the fd is readable, call the response handler zle -F "$fd" _omz_async_callback @@ -114,15 +111,14 @@ function _omz_async_callback() { local err=$2 # Second arg will be passed in case of error if [[ -z "$err" || "$err" == "hup" ]]; then - # Get handler name from first line - local handler - read handler <&$fd + # Get handler name from fd + local handler="${(k)_OMZ_ASYNC_FDS[(r)$fd]}" # Store old output which is supposed to be already printed local old_output="${_OMZ_ASYNC_OUTPUT[$handler]}" # Read output from fd - _OMZ_ASYNC_OUTPUT[$handler]="$(cat <&$fd)" + IFS= read -r -u $fd -d '' "_OMZ_ASYNC_OUTPUT[$handler]" # Repaint prompt if output has changed if [[ "$old_output" != "${_OMZ_ASYNC_OUTPUT[$handler]}" ]]; then From ec1afe9dd683c36e6384db25fc1e95acbb0cbc7a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Wed, 3 Apr 2024 19:55:46 +0200 Subject: [PATCH 555/672] feat(git)!: enable async git prompt (now for real) BREAKING CHANGE: the new async prompt feature will render prompt information asyncronously and degrade nicely when the calls take too long to finish, as the prompt will already be first drawn and interactive. This is enabled by default for the git prompt and themes that use it (`git_prompt_info`). If you find that it's not working for you, please open an issue if one is not already opened, and see https://github.com/ohmyzsh/ohmyzsh#disable-async-git-prompt for how to turn it off. --- README.md | 12 ++++++++++++ lib/git.zsh | 2 +- 2 files changed, 13 insertions(+), 1 deletion(-) diff --git a/README.md b/README.md index b3561a833..2ba374335 100644 --- a/README.md +++ b/README.md @@ -43,6 +43,7 @@ To learn more, visit [ohmyz.sh](https://ohmyz.sh), follow [@ohmyzsh](https://twi - [Custom Plugins And Themes](#custom-plugins-and-themes) - [Enable GNU ls In macOS And freeBSD Systems](#enable-gnu-ls-in-macos-and-freebsd-systems) - [Skip Aliases](#skip-aliases) + - [Disable async git prompt](#disable-async-git-prompt) - [Getting Updates](#getting-updates) - [Updates Verbosity](#updates-verbosity) - [Manual Updates](#manual-updates) @@ -361,6 +362,17 @@ Instead, you can now use the following: zstyle ':omz:lib:directories' aliases no ``` +### Disable async git prompt + +Async prompt functions are an experimental feature (included on April 3, 2024) that allows Oh My Zsh to render prompt information +asyncronously. This can improve prompt rendering performance, but it might not work well with some setups. We hope that's not an +issue, but if you're seeing problems with this new feature, you can turn it of by setting the following in your .zshrc file, +before Oh My Zsh is sourced: + +```sh +zstyle ':omz:alpha:lib:git' async-prompt no +``` + #### Notice > This feature is currently in a testing phase and it may be subject to change in the future. diff --git a/lib/git.zsh b/lib/git.zsh index 96df5589d..4d6681c5b 100644 --- a/lib/git.zsh +++ b/lib/git.zsh @@ -38,7 +38,7 @@ function _omz_git_prompt_status() { } # Enable async prompt by default unless the setting is at false / no -if zstyle -t ':omz:alpha:lib:git' async-prompt; then +if zstyle -T ':omz:alpha:lib:git' async-prompt; then function git_prompt_info() { if [[ -n "$_OMZ_ASYNC_OUTPUT[_omz_git_prompt_status]" ]]; then echo -n "$_OMZ_ASYNC_OUTPUT[_omz_git_prompt_status]" From 04007a0e5d0a458efff23da896cf70dc40df585d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Lo=C3=AFc=20Yhuel?= Date: Wed, 3 Apr 2024 21:32:16 +0200 Subject: [PATCH 556/672] feat(git): implement async completion for `git_prompt_status` (#12319) This is important for themes using it, since it is usually a little slower than git_prompt_info. Also two small fixes : - the handler for git_prompt_info was incorrectly named _omz_git_prompt_status - _defer_async_git_register was kept in precmd, there is no need to call it on each prompt --- lib/git.zsh | 20 +++++++++++++++++--- 1 file changed, 17 insertions(+), 3 deletions(-) diff --git a/lib/git.zsh b/lib/git.zsh index 4d6681c5b..76b3778db 100644 --- a/lib/git.zsh +++ b/lib/git.zsh @@ -9,7 +9,7 @@ function __git_prompt_git() { GIT_OPTIONAL_LOCKS=0 command git "$@" } -function _omz_git_prompt_status() { +function _omz_git_prompt_info() { # If we are on a folder not tracked by git, get out. # Otherwise, check for hide-info at global and local repository level if ! __git_prompt_git rev-parse --git-dir &> /dev/null \ @@ -40,6 +40,12 @@ function _omz_git_prompt_status() { # Enable async prompt by default unless the setting is at false / no if zstyle -T ':omz:alpha:lib:git' async-prompt; then function git_prompt_info() { + if [[ -n "$_OMZ_ASYNC_OUTPUT[_omz_git_prompt_info]" ]]; then + echo -n "$_OMZ_ASYNC_OUTPUT[_omz_git_prompt_info]" + fi + } + + function git_prompt_status() { if [[ -n "$_OMZ_ASYNC_OUTPUT[_omz_git_prompt_status]" ]]; then echo -n "$_OMZ_ASYNC_OUTPUT[_omz_git_prompt_status]" fi @@ -51,8 +57,13 @@ if zstyle -T ':omz:alpha:lib:git' async-prompt; then # Check if git_prompt_info is used in a prompt variable case "${PS1}:${PS2}:${PS3}:${PS4}:${RPS1}:${RPS2}:${RPS3}:${RPS4}" in *(\$\(git_prompt_info\)|\`git_prompt_info\`)*) + _omz_register_handler _omz_git_prompt_info + ;; + esac + + case "${PS1}:${PS2}:${PS3}:${PS4}:${RPS1}:${RPS2}:${RPS3}:${RPS4}" in + *(\$\(git_prompt_status\)|\`git_prompt_status\`)*) _omz_register_handler _omz_git_prompt_status - return ;; esac @@ -65,6 +76,9 @@ if zstyle -T ':omz:alpha:lib:git' async-prompt; then precmd_functions=(_defer_async_git_register $precmd_functions) else function git_prompt_info() { + _omz_git_prompt_info + } + function git_prompt_status() { _omz_git_prompt_status } fi @@ -197,7 +211,7 @@ function git_prompt_long_sha() { SHA=$(__git_prompt_git rev-parse HEAD 2> /dev/null) && echo "$ZSH_THEME_GIT_PROMPT_SHA_BEFORE$SHA$ZSH_THEME_GIT_PROMPT_SHA_AFTER" } -function git_prompt_status() { +function _omz_git_prompt_status() { [[ "$(__git_prompt_git config --get oh-my-zsh.hide-status 2>/dev/null)" = 1 ]] && return # Maps a git status prefix to an internal constant From 6d0362ef2f355a05cf945fae882ad1fa95428991 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Thu, 4 Apr 2024 10:08:28 +0200 Subject: [PATCH 557/672] fix(archlinux): make `upgrade` work with non-english Closes #12316 --- plugins/archlinux/archlinux.plugin.zsh | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/plugins/archlinux/archlinux.plugin.zsh b/plugins/archlinux/archlinux.plugin.zsh index fca6548c0..e20a31156 100644 --- a/plugins/archlinux/archlinux.plugin.zsh +++ b/plugins/archlinux/archlinux.plugin.zsh @@ -179,8 +179,8 @@ fi # Check Arch Linux PGP Keyring before System Upgrade to prevent failure. function upgrade() { echo ":: Checking Arch Linux PGP Keyring..." - local installedver="$(sudo pacman -Qi archlinux-keyring | grep -Po '(?<=Version : ).*')" - local currentver="$(sudo pacman -Si archlinux-keyring | grep -Po '(?<=Version : ).*')" + local installedver="$(LANG= sudo pacman -Qi archlinux-keyring | grep -Po '(?<=Version : ).*')" + local currentver="$(LANG= sudo pacman -Si archlinux-keyring | grep -Po '(?<=Version : ).*')" if [ $installedver != $currentver ]; then echo " Arch Linux PGP Keyring is out of date." echo " Updating before full system upgrade." From 114b58ed4e93faee352187779c7151f8580f24fe Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Thu, 4 Apr 2024 11:58:43 +0200 Subject: [PATCH 558/672] fix(git): disable locally `ksharrays` Fixes #12321 --- lib/git.zsh | 2 ++ 1 file changed, 2 insertions(+) diff --git a/lib/git.zsh b/lib/git.zsh index 76b3778db..23d11db2d 100644 --- a/lib/git.zsh +++ b/lib/git.zsh @@ -40,12 +40,14 @@ function _omz_git_prompt_info() { # Enable async prompt by default unless the setting is at false / no if zstyle -T ':omz:alpha:lib:git' async-prompt; then function git_prompt_info() { + setopt localoptions noksharrays if [[ -n "$_OMZ_ASYNC_OUTPUT[_omz_git_prompt_info]" ]]; then echo -n "$_OMZ_ASYNC_OUTPUT[_omz_git_prompt_info]" fi } function git_prompt_status() { + setopt localoptions noksharrays if [[ -n "$_OMZ_ASYNC_OUTPUT[_omz_git_prompt_status]" ]]; then echo -n "$_OMZ_ASYNC_OUTPUT[_omz_git_prompt_status]" fi From 9d529c41cc82580d0a947ce8bcf5ff7775585fe5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Lo=C3=AFc=20Yhuel?= Date: Thu, 4 Apr 2024 16:20:20 +0200 Subject: [PATCH 559/672] perf(async): avoid executing `true` if not required (#12318) The issue which required "command true" was fixed in zsh 5.8. --- lib/async_prompt.zsh | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/lib/async_prompt.zsh b/lib/async_prompt.zsh index ac95bcd73..a83c57f35 100644 --- a/lib/async_prompt.zsh +++ b/lib/async_prompt.zsh @@ -3,6 +3,7 @@ # https://github.com/woefe/git-prompt.zsh/blob/master/git-prompt.zsh zmodload zsh/system +autoload -Uz is-at-least # For now, async prompt function handlers are set up like so: # First, define the async function handler and register the handler @@ -93,7 +94,8 @@ function _omz_async_request { # There's a weird bug here where ^C stops working unless we force a fork # See https://github.com/zsh-users/zsh-autosuggestions/issues/364 - command true + # and https://github.com/zsh-users/zsh-autosuggestions/pull/612 + is-at-least 5.8 || command true # Save the PID from the handler child process read -u $fd "_OMZ_ASYNC_PIDS[$handler]" From 038931039030911852d456215d6f39385d5b7a6e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Fri, 5 Apr 2024 07:38:36 +0200 Subject: [PATCH 560/672] fix(lib/git): fix detection of function use in prompt RPS1 and RPROMPT are not equivalent, though they have the same effect. Added both to detect if `git_prompt_*` is used. Fixes #12325 --- lib/git.zsh | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/lib/git.zsh b/lib/git.zsh index 23d11db2d..c4265970b 100644 --- a/lib/git.zsh +++ b/lib/git.zsh @@ -57,13 +57,13 @@ if zstyle -T ':omz:alpha:lib:git' async-prompt; then # or any of the other prompt variables function _defer_async_git_register() { # Check if git_prompt_info is used in a prompt variable - case "${PS1}:${PS2}:${PS3}:${PS4}:${RPS1}:${RPS2}:${RPS3}:${RPS4}" in + case "${PS1}:${PS2}:${PS3}:${PS4}:${RPROMPT}:${RPS1}:${RPS2}:${RPS3}:${RPS4}" in *(\$\(git_prompt_info\)|\`git_prompt_info\`)*) _omz_register_handler _omz_git_prompt_info ;; esac - case "${PS1}:${PS2}:${PS3}:${PS4}:${RPS1}:${RPS2}:${RPS3}:${RPS4}" in + case "${PS1}:${PS2}:${PS3}:${PS4}:${RPROMPT}:${RPS1}:${RPS2}:${RPS3}:${RPS4}" in *(\$\(git_prompt_status\)|\`git_prompt_status\`)*) _omz_register_handler _omz_git_prompt_status ;; From d893dd9b83d518f2b2bd4b9a5b6a92ca0e4e33e2 Mon Sep 17 00:00:00 2001 From: Dee'Kej Date: Sat, 6 Apr 2024 19:12:05 +0200 Subject: [PATCH 561/672] fix(autojump): add macOS 'pkgsrc' installation location (#12329) --- plugins/autojump/autojump.plugin.zsh | 1 + 1 file changed, 1 insertion(+) diff --git a/plugins/autojump/autojump.plugin.zsh b/plugins/autojump/autojump.plugin.zsh index 84333a89f..5a52e3067 100644 --- a/plugins/autojump/autojump.plugin.zsh +++ b/plugins/autojump/autojump.plugin.zsh @@ -13,6 +13,7 @@ autojump_paths=( /opt/local/etc/profile.d/autojump.sh # macOS with MacPorts /usr/local/etc/profile.d/autojump.sh # macOS with Homebrew (default) /opt/homebrew/etc/profile.d/autojump.sh # macOS with Homebrew (default on M1 macs) + /opt/pkg/share/autojump/autojump.zsh # macOS with pkgsrc /etc/profiles/per-user/$USER/etc/profile.d/autojump.sh # macOS Nix, Home Manager and flakes ) From bf713e2c112ee1f0daf10deffa1215c982513f9b Mon Sep 17 00:00:00 2001 From: David Chin Date: Sun, 7 Apr 2024 01:23:19 +0800 Subject: [PATCH 562/672] Update README for git-prompt to clarify how to use (#10922) * Add note about need to customise theme. It may not be obvious that the theme needs to be customised. See: https://github.com/ohmyzsh/ohmyzsh/issues/9395 * Clarify type of theme customisation needed. --- plugins/git-prompt/README.md | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/plugins/git-prompt/README.md b/plugins/git-prompt/README.md index 05208d72f..8f42c6842 100644 --- a/plugins/git-prompt/README.md +++ b/plugins/git-prompt/README.md @@ -9,6 +9,10 @@ To use it, add `git-prompt` to the plugins array in your zshrc file: plugins=(... git-prompt) ``` +You may also need to [customize your theme](https://github.com/ohmyzsh/ohmyzsh/issues/9395#issuecomment-1027130429) +to change the way the prompt is built. See the +[OMZ wiki on customizing themes](https://github.com/ohmyzsh/ohmyzsh/wiki/Customization#overriding-and-adding-themes). + See the [original repository](https://github.com/olivierverdier/zsh-git-prompt). ## Requirements From a6ce40df49e0b219372517273c4edce1d34e49a2 Mon Sep 17 00:00:00 2001 From: Matheus Richard Date: Mon, 8 Apr 2024 12:48:57 -0300 Subject: [PATCH 563/672] feat(git): introduce `gwipe` alias (#12302) `gpristine` might be too much on several occasions, given that it removes all untracked files. This might not be ideal because it will delete important things like environment files and encryption keys. With that in mind, this commit introduces `gwipe` as a way to get a "clean slate" but still have your dev environment working. --- plugins/git/git.plugin.zsh | 1 + 1 file changed, 1 insertion(+) diff --git a/plugins/git/git.plugin.zsh b/plugins/git/git.plugin.zsh index 692a36a73..545ccc541 100644 --- a/plugins/git/git.plugin.zsh +++ b/plugins/git/git.plugin.zsh @@ -349,6 +349,7 @@ alias grhh='git reset --hard' alias grhk='git reset --keep' alias grhs='git reset --soft' alias gpristine='git reset --hard && git clean --force -dfx' +alias gwipe='git reset --hard && git clean --force -df' alias groh='git reset origin/$(git_current_branch) --hard' alias grs='git restore' alias grss='git restore --source' From 5bff59f78e607e77f2ed924c1e93ccc09a6ccb7e Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Mon, 8 Apr 2024 22:05:23 +0200 Subject: [PATCH 564/672] docs(git): add `gwipe` alias --- plugins/git/README.md | 1 + 1 file changed, 1 insertion(+) diff --git a/plugins/git/README.md b/plugins/git/README.md index 4acb0c858..181de37fc 100644 --- a/plugins/git/README.md +++ b/plugins/git/README.md @@ -166,6 +166,7 @@ plugins=(... git) | `grhk` | `git reset --keep` | | `grhs` | `git reset --soft` | | `gpristine` | `git reset --hard && git clean --force -dfx` | +| `gwipe` | `git reset --hard && git clean --force -df` | | `groh` | `git reset origin/$(git_current_branch) --hard` | | `grs` | `git restore` | | `grss` | `git restore --source` | From 982ea721bde90c1fca233419e2c5b6e90fd10225 Mon Sep 17 00:00:00 2001 From: Reza Askari Date: Tue, 9 Apr 2024 00:06:38 +0330 Subject: [PATCH 565/672] feat(laravel): add `artisan test` alias (`pats`) (#12310) --- plugins/laravel/README.md | 1 + plugins/laravel/laravel.plugin.zsh | 1 + 2 files changed, 2 insertions(+) diff --git a/plugins/laravel/README.md b/plugins/laravel/README.md index 95f590191..a831a86b6 100644 --- a/plugins/laravel/README.md +++ b/plugins/laravel/README.md @@ -10,6 +10,7 @@ plugins=(... laravel) |:-:|:-:| | `artisan` | `php artisan` | | `pas` | `php artisan serve` | +| `pats` | `php artisan test` | ## Database diff --git a/plugins/laravel/laravel.plugin.zsh b/plugins/laravel/laravel.plugin.zsh index a8382d3c9..319946f07 100644 --- a/plugins/laravel/laravel.plugin.zsh +++ b/plugins/laravel/laravel.plugin.zsh @@ -4,6 +4,7 @@ alias bob='php artisan bob::build' # Development alias pas='php artisan serve' +alias pats='php artisan test' # Database alias pam='php artisan migrate' From 3e2a5742cdb4deae4d7f10351d59c7f2933e3555 Mon Sep 17 00:00:00 2001 From: Soo Philip Jason Kim Date: Tue, 9 Apr 2024 05:40:15 +0900 Subject: [PATCH 566/672] feat(git): add alias `gmc` for `git merge --continue` (#12326) Co-authored-by: PJ Kim --- plugins/git/README.md | 1 + plugins/git/git.plugin.zsh | 1 + 2 files changed, 2 insertions(+) diff --git a/plugins/git/README.md b/plugins/git/README.md index 181de37fc..4c005ad2f 100644 --- a/plugins/git/README.md +++ b/plugins/git/README.md @@ -111,6 +111,7 @@ plugins=(... git) | `gfg` | `git ls-files \| grep` | | `gm` | `git merge` | | `gma` | `git merge --abort` | +| `gmc` | `git merge --continue` | | `gms` | `git merge --squash` | | `gmom` | `git merge origin/$(git_main_branch)` | | `gmum` | `git merge upstream/$(git_main_branch)` | diff --git a/plugins/git/git.plugin.zsh b/plugins/git/git.plugin.zsh index 545ccc541..146f4a512 100644 --- a/plugins/git/git.plugin.zsh +++ b/plugins/git/git.plugin.zsh @@ -252,6 +252,7 @@ alias gignored='git ls-files -v | grep "^[[:lower:]]"' alias gfg='git ls-files | grep' alias gm='git merge' alias gma='git merge --abort' +alias gmc='git merge --continue' alias gms="git merge --squash" alias gmom='git merge origin/$(git_main_branch)' alias gmum='git merge upstream/$(git_main_branch)' From a8f7f9f707ca5fb9ac7bedb088748b09db2fd3bd Mon Sep 17 00:00:00 2001 From: MoAlkhateeb <110918029+MoAlkhateeb@users.noreply.github.com> Date: Tue, 9 Apr 2024 09:07:57 +0300 Subject: [PATCH 567/672] fix(history)!: fix arg passing to `fc` for `history` command (#12338) BREAKING CHANGE: we have fixed a bug in the `history` wrapper for OMZ which means that running just history will now not show all the history since the 1st command, but only recent ones. To get the previous behavior, you can run `history 1` to get all the command history, or other commands such as `history -30` to get the last 30 commands. --- lib/history.zsh | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/lib/history.zsh b/lib/history.zsh index 794076904..c39c8c866 100644 --- a/lib/history.zsh +++ b/lib/history.zsh @@ -12,8 +12,8 @@ function omz_history { # if -l provided, run as if calling `fc' directly builtin fc "$@" else - # unless a number is provided, show all history events (starting from 1) - [[ ${@[-1]-} = *[0-9]* ]] && builtin fc -l "$@" || builtin fc -l "$@" 1 + # otherwise, run `fc -l` with a custom format + builtin fc -l "$@" fi } From ef402864830ba2e23720e3a6ee6f6b4f0e05d692 Mon Sep 17 00:00:00 2001 From: Taekin Kim Date: Tue, 9 Apr 2024 19:18:05 +0900 Subject: [PATCH 568/672] docs: fix typo (#12339) --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index 2ba374335..dea36fda7 100644 --- a/README.md +++ b/README.md @@ -366,7 +366,7 @@ zstyle ':omz:lib:directories' aliases no Async prompt functions are an experimental feature (included on April 3, 2024) that allows Oh My Zsh to render prompt information asyncronously. This can improve prompt rendering performance, but it might not work well with some setups. We hope that's not an -issue, but if you're seeing problems with this new feature, you can turn it of by setting the following in your .zshrc file, +issue, but if you're seeing problems with this new feature, you can turn it off by setting the following in your .zshrc file, before Oh My Zsh is sourced: ```sh From f85f501bcf3dc771c64f4b2ec7609fc542d4d031 Mon Sep 17 00:00:00 2001 From: Bartek Pacia Date: Tue, 9 Apr 2024 11:19:14 +0100 Subject: [PATCH 569/672] feat(macos): `ofd` now opens any directory (#12337) Co-authored-by: Carlo Sala --- plugins/macos/README.md | 2 +- plugins/macos/macos.plugin.zsh | 11 +++++++++-- 2 files changed, 10 insertions(+), 3 deletions(-) diff --git a/plugins/macos/README.md b/plugins/macos/README.md index 1cb9b395d..2c52ec8a7 100644 --- a/plugins/macos/README.md +++ b/plugins/macos/README.md @@ -17,7 +17,7 @@ Original author: [Sorin Ionescu](https://github.com/sorin-ionescu) | `tab` | Open the current directory in a new tab | | `split_tab` | Split the current terminal tab horizontally | | `vsplit_tab` | Split the current terminal tab vertically | -| `ofd` | Open the current directory in a Finder window | +| `ofd` | Open passed directories (or $PWD by default) in Finder | | `pfd` | Return the path of the frontmost Finder window | | `pfs` | Return the current Finder selection | | `cdf` | `cd` to the current Finder directory | diff --git a/plugins/macos/macos.plugin.zsh b/plugins/macos/macos.plugin.zsh index a4347005e..2702a1901 100644 --- a/plugins/macos/macos.plugin.zsh +++ b/plugins/macos/macos.plugin.zsh @@ -3,8 +3,15 @@ 0="${${ZERO:-${0:#$ZSH_ARGZERO}}:-${(%):-%N}}" 0="${${(M)0:#/*}:-$PWD/$0}" -# Open the current directory in a Finder window -alias ofd='open_command $PWD' +# Open in Finder the directories passed as arguments, or the current directory if +# no directories are passed +function ofd { + if (( ! $# )); then + open_command $PWD + else + open_command $@ + fi +} # Show/hide hidden files in the Finder alias showfiles="defaults write com.apple.finder AppleShowAllFiles -bool true && killall Finder" From 605d76616aa47b2e5abe25eb26c4c9c1554f93d5 Mon Sep 17 00:00:00 2001 From: MoAlkhateeb <110918029+MoAlkhateeb@users.noreply.github.com> Date: Tue, 9 Apr 2024 19:09:26 +0300 Subject: [PATCH 570/672] fix(history): revert to old behavior when no args passed (#12341) * Fixed a bug in *omz_history* where it would automatically create a file when run with the -p flag * Reverted old history behaviour while fixing parsing bug --- lib/history.zsh | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/lib/history.zsh b/lib/history.zsh index c39c8c866..56dda2462 100644 --- a/lib/history.zsh +++ b/lib/history.zsh @@ -3,7 +3,10 @@ function omz_history { local clear list zparseopts -E c=clear l=list - if [[ -n "$clear" ]]; then + if [[ $# -eq 0 ]]; then + # if no arguments provided, show full history starting from 1 + builtin fc -l 1 + elif [[ -n "$clear" ]]; then # if -c provided, clobber the history file echo -n >| "$HISTFILE" fc -p "$HISTFILE" From 53c4c4671a931d9f7a3b39fe9131c6f84fe27ca5 Mon Sep 17 00:00:00 2001 From: Ruize Tang <1466040111@qq.com> Date: Wed, 10 Apr 2024 21:39:19 +0800 Subject: [PATCH 571/672] fix(shell-proxy): support ssh-proxy using http proxy in cygwin (#12340) --- plugins/shell-proxy/ssh-proxy.py | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/plugins/shell-proxy/ssh-proxy.py b/plugins/shell-proxy/ssh-proxy.py index a498c84bc..4b692f9e4 100755 --- a/plugins/shell-proxy/ssh-proxy.py +++ b/plugins/shell-proxy/ssh-proxy.py @@ -22,7 +22,8 @@ if parsed.scheme not in proxy_protocols: def make_argv(): yield "nc" - if sys.platform == 'linux': + if sys.platform in {'linux', 'cygwin'}: + # caveats: the built-in netcat of most linux distributions and cygwin support proxy type # caveats: macOS built-in netcat command not supported proxy-type yield "-X" # --proxy-type # Supported protocols are 4 (SOCKS v4), 5 (SOCKS v5) and connect (HTTP proxy). From 6e9d57d5abdb33b0c22f8979dc529c1a046d7aa3 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?jo=C3=A9l=20hawkins=20torres?= Date: Thu, 11 Apr 2024 10:27:29 -0700 Subject: [PATCH 572/672] fix(yarn): use `builtin cd` in completion (#12347) --- plugins/yarn/_yarn | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/plugins/yarn/_yarn b/plugins/yarn/_yarn index f15756ff4..9ffe5660c 100644 --- a/plugins/yarn/_yarn +++ b/plugins/yarn/_yarn @@ -86,7 +86,7 @@ _global_commands=( ) _yarn_find_package_json() { - local dir=$(cd "$1" && pwd) + local dir=$(builtin cd "$1" && pwd) while true do @@ -109,7 +109,7 @@ _yarn_commands_scripts() { if [[ -n $opt_args[--cwd] ]]; then packageJson=$(_yarn_find_package_json $opt_args[--cwd]) - binaries=($(cd $opt_args[--cwd] && echo node_modules/.bin/*(x:t))) + binaries=($(builtin cd $opt_args[--cwd] && echo node_modules/.bin/*(x:t))) else packageJson=$(_yarn_find_package_json $pwd) binaries=($(echo node_modules/.bin/*(x:t))) @@ -130,9 +130,9 @@ _yarn_scripts() { if [[ -n $_yarn_run_cwd ]]; then packageJson=$(_yarn_find_package_json $_yarn_run_cwd) if [[ -d "${_yarn_run_cwd}/node_modules" ]]; then - binaries=($(cd $_yarn_run_cwd && echo node_modules/.bin/*(x:t))) + binaries=($(builtin cd $_yarn_run_cwd && echo node_modules/.bin/*(x:t))) else - binaries=($(cd $_yarn_run_cwd && yarn bin | perl -wln -e 'm{^[^:]+: (\S+)$} and print $1')) + binaries=($(builtin cd $_yarn_run_cwd && yarn bin | perl -wln -e 'm{^[^:]+: (\S+)$} and print $1')) fi else packageJson=$(_yarn_find_package_json $pwd) From 31f2025e0fa963788655fe197e0179c47588b175 Mon Sep 17 00:00:00 2001 From: Kate Sullivan <75387802+katesullivan@users.noreply.github.com> Date: Fri, 12 Apr 2024 02:24:54 -0500 Subject: [PATCH 573/672] feat(poetry-env): support changing between two venv dirs (#12346) Co-authored-by: Carlo Sala --- plugins/poetry-env/poetry-env.plugin.zsh | 38 ++++++++++++------------ 1 file changed, 19 insertions(+), 19 deletions(-) diff --git a/plugins/poetry-env/poetry-env.plugin.zsh b/plugins/poetry-env/poetry-env.plugin.zsh index 97ca52492..f98c177b4 100644 --- a/plugins/poetry-env/poetry-env.plugin.zsh +++ b/plugins/poetry-env/poetry-env.plugin.zsh @@ -1,27 +1,27 @@ -# Automatic poetry environment activation/deactivation _togglePoetryShell() { - # deactivate environment if pyproject.toml doesn't exist and not in a subdir - if [[ ! -f "$PWD/pyproject.toml" ]] ; then - if [[ "$poetry_active" == 1 ]]; then - if [[ "$PWD" != "$poetry_dir"* ]]; then - export poetry_active=0 - deactivate - return - fi - fi + # Determine if currently in a Poetry-managed directory + local in_poetry_dir=0 + if [[ -f "$PWD/pyproject.toml" ]] && grep -q 'tool.poetry' "$PWD/pyproject.toml"; then + in_poetry_dir=1 fi - # activate the environment if pyproject.toml exists - if [[ "$poetry_active" != 1 ]]; then - if [[ -f "$PWD/pyproject.toml" ]]; then - if grep -q 'tool.poetry' "$PWD/pyproject.toml" && venv_dir=$(poetry env info --path); then - export poetry_active=1 - export poetry_dir="$PWD" - source "${venv_dir}/bin/activate" - fi + # Deactivate the current environment if moving out of a Poetry directory or into a different Poetry directory + if [[ $poetry_active -eq 1 ]] && { [[ $in_poetry_dir -eq 0 ]] || [[ "$PWD" != "$poetry_dir"* ]]; }; then + export poetry_active=0 + unset poetry_dir + deactivate + fi + + # Activate the environment if in a Poetry directory and no environment is currently active + if [[ $in_poetry_dir -eq 1 ]] && [[ $poetry_active -ne 1 ]]; then + venv_dir=$(poetry env info --path 2>/dev/null) + if [[ -n "$venv_dir" ]]; then + export poetry_active=1 + export poetry_dir="$PWD" + source "${venv_dir}/bin/activate" fi fi } autoload -U add-zsh-hook add-zsh-hook chpwd _togglePoetryShell -_togglePoetryShell +_togglePoetryShell # Initial call to check the current directory at shell startup From b26000d1685fa61bddddea42e2a606b2a0d64e25 Mon Sep 17 00:00:00 2001 From: Jhon Pedroza Date: Tue, 16 Apr 2024 02:52:12 -0500 Subject: [PATCH 574/672] feat(tmux): sessions named as current dir (#12351) --- plugins/tmux/README.md | 1 + plugins/tmux/tmux.plugin.zsh | 24 ++++++++++++++++++++---- 2 files changed, 21 insertions(+), 4 deletions(-) diff --git a/plugins/tmux/README.md b/plugins/tmux/README.md index 50f8b2c2f..09952a9f5 100644 --- a/plugins/tmux/README.md +++ b/plugins/tmux/README.md @@ -37,6 +37,7 @@ The plugin also supports the following: | `ZSH_TMUX_AUTOQUIT` | Automatically closes terminal once tmux exits (default: `ZSH_TMUX_AUTOSTART`) | | `ZSH_TMUX_CONFIG` | Set the configuration path (default: `$HOME/.tmux.conf`, `$XDG_CONFIG_HOME/tmux/tmux.conf`) | | `ZSH_TMUX_DEFAULT_SESSION_NAME` | Set tmux default session name when autostart is enabled | +| `ZSH_TMUX_AUTONAME_SESSION` | Automatically name new sessions based on the basename of `$PWD` (default: `false`) | | `ZSH_TMUX_DETACHED` | Set the detached mode (default: `false`) | | `ZSH_TMUX_FIXTERM` | Sets `$TERM` to 256-color term or not based on current terminal support | | `ZSH_TMUX_FIXTERM_WITHOUT_256COLOR` | `$TERM` to use for non 256-color terminals (default: `tmux` if available, `screen` otherwise) | diff --git a/plugins/tmux/tmux.plugin.zsh b/plugins/tmux/tmux.plugin.zsh index 791592d8f..f65598358 100644 --- a/plugins/tmux/tmux.plugin.zsh +++ b/plugins/tmux/tmux.plugin.zsh @@ -13,6 +13,8 @@ fi : ${ZSH_TMUX_AUTOCONNECT:=true} # Automatically close the terminal when tmux exits : ${ZSH_TMUX_AUTOQUIT:=$ZSH_TMUX_AUTOSTART} +# Automatically name the new session based on the basename of PWD +: ${ZSH_TMUX_AUTONAME_SESSION:=false} # Set term to screen or screen-256color based on current terminal support : ${ZSH_TMUX_DETACHED:=false} # Set detached mode @@ -102,9 +104,22 @@ function _zsh_tmux_plugin_run() { local _detached="" [[ "$ZSH_TMUX_DETACHED" == "true" ]] && _detached="-d" + + local session_name + if [[ "$ZSH_TMUX_AUTONAME_SESSION" == "true" ]]; then + # Name the session after the basename of the current directory + session_name=${PWD##*/} + # If the current directory is the home directory, name it 'HOME' + [[ "$PWD" == "$HOME" ]] && session_name="HOME" + # If the current directory is the root directory, name it 'ROOT' + [[ "$PWD" == "/" ]] && session_name="ROOT" + else + session_name="$ZSH_TMUX_DEFAULT_SESSION_NAME" + fi + # Try to connect to an existing session. - if [[ -n "$ZSH_TMUX_DEFAULT_SESSION_NAME" ]]; then - [[ "$ZSH_TMUX_AUTOCONNECT" == "true" ]] && $tmux_cmd attach $_detached -t $ZSH_TMUX_DEFAULT_SESSION_NAME + if [[ -n "$session_name" ]]; then + [[ "$ZSH_TMUX_AUTOCONNECT" == "true" ]] && $tmux_cmd attach $_detached -t "$session_name" else [[ "$ZSH_TMUX_AUTOCONNECT" == "true" ]] && $tmux_cmd attach $_detached fi @@ -116,8 +131,9 @@ function _zsh_tmux_plugin_run() { elif [[ -e "$ZSH_TMUX_CONFIG" ]]; then tmux_cmd+=(-f "$ZSH_TMUX_CONFIG") fi - if [[ -n "$ZSH_TMUX_DEFAULT_SESSION_NAME" ]]; then - $tmux_cmd new-session -s $ZSH_TMUX_DEFAULT_SESSION_NAME + + if [[ -n "$session_name" ]]; then + $tmux_cmd new-session -s "$session_name" else $tmux_cmd new-session fi From efa8de0b52dda6b51bded60c0b26b6dce2dfa354 Mon Sep 17 00:00:00 2001 From: Martin Hans Date: Tue, 16 Apr 2024 19:38:58 +0200 Subject: [PATCH 575/672] fix(history): fix edge cases introduced in #12341 (#12357) --- lib/history.zsh | 12 +++++------- 1 file changed, 5 insertions(+), 7 deletions(-) diff --git a/lib/history.zsh b/lib/history.zsh index 56dda2462..ec89bc15e 100644 --- a/lib/history.zsh +++ b/lib/history.zsh @@ -1,22 +1,20 @@ ## History wrapper function omz_history { - local clear list - zparseopts -E c=clear l=list + # parse arguments and remove from $@ + local clear list stamp + zparseopts -E -D c=clear l=list f=stamp E=stamp i=stamp if [[ $# -eq 0 ]]; then # if no arguments provided, show full history starting from 1 - builtin fc -l 1 + builtin fc $stamp -l 1 elif [[ -n "$clear" ]]; then # if -c provided, clobber the history file echo -n >| "$HISTFILE" fc -p "$HISTFILE" echo >&2 History file deleted. - elif [[ -n "$list" ]]; then - # if -l provided, run as if calling `fc' directly - builtin fc "$@" else # otherwise, run `fc -l` with a custom format - builtin fc -l "$@" + builtin fc $stamp -l "$@" fi } From 7ef3f49f97ff34db3785b1cea444eb4972b1937b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Tue, 16 Apr 2024 20:04:25 +0200 Subject: [PATCH 576/672] fix(agnoster): prevent accidental alias use --- themes/agnoster.zsh-theme | 38 +++++++++++++++++++------------------- 1 file changed, 19 insertions(+), 19 deletions(-) diff --git a/themes/agnoster.zsh-theme b/themes/agnoster.zsh-theme index bd0405efb..c2a542163 100644 --- a/themes/agnoster.zsh-theme +++ b/themes/agnoster.zsh-theme @@ -96,7 +96,7 @@ prompt_context() { # Git: branch/detached head, dirty status prompt_git() { (( $+commands[git] )) || return - if [[ "$(git config --get oh-my-zsh.hide-status 2>/dev/null)" = 1 ]]; then + if [[ "$(command git config --get oh-my-zsh.hide-status 2>/dev/null)" = 1 ]]; then return fi local PL_BRANCH_CHAR @@ -106,12 +106,12 @@ prompt_git() { } local ref dirty mode repo_path - if [[ "$(git rev-parse --is-inside-work-tree 2>/dev/null)" = "true" ]]; then - repo_path=$(git rev-parse --git-dir 2>/dev/null) + if [[ "$(command git rev-parse --is-inside-work-tree 2>/dev/null)" = "true" ]]; then + repo_path=$(command git rev-parse --git-dir 2>/dev/null) dirty=$(parse_git_dirty) - ref=$(git symbolic-ref HEAD 2> /dev/null) || \ - ref="◈ $(git describe --exact-match --tags HEAD 2> /dev/null)" || \ - ref="➦ $(git rev-parse --short HEAD 2> /dev/null)" + ref=$(command git symbolic-ref HEAD 2> /dev/null) || \ + ref="◈ $(command git describe --exact-match --tags HEAD 2> /dev/null)" || \ + ref="➦ $(command git rev-parse --short HEAD 2> /dev/null)" if [[ -n $dirty ]]; then prompt_segment yellow black else @@ -119,8 +119,8 @@ prompt_git() { fi local ahead behind - ahead=$(git log --oneline @{upstream}.. 2>/dev/null) - behind=$(git log --oneline ..@{upstream} 2>/dev/null) + ahead=$(command git log --oneline @{upstream}.. 2>/dev/null) + behind=$(command git log --oneline ..@{upstream} 2>/dev/null) if [[ -n "$ahead" ]] && [[ -n "$behind" ]]; then PL_BRANCH_CHAR=$'\u21c5' elif [[ -n "$ahead" ]]; then @@ -163,10 +163,10 @@ prompt_bzr() { done local bzr_status status_mod status_all revision - if bzr_status=$(bzr status 2>&1); then + if bzr_status=$(command bzr status 2>&1); then status_mod=$(echo -n "$bzr_status" | head -n1 | grep "modified" | wc -m) status_all=$(echo -n "$bzr_status" | head -n1 | wc -m) - revision=${$(bzr log -r-1 --log-format line | cut -d: -f1):gs/%/%%} + revision=${$(command bzr log -r-1 --log-format line | cut -d: -f1):gs/%/%%} if [[ $status_mod -gt 0 ]] ; then prompt_segment yellow black "bzr@$revision ✚" else @@ -182,13 +182,13 @@ prompt_bzr() { prompt_hg() { (( $+commands[hg] )) || return local rev st branch - if $(hg id >/dev/null 2>&1); then - if $(hg prompt >/dev/null 2>&1); then - if [[ $(hg prompt "{status|unknown}") = "?" ]]; then + if $(command hg id >/dev/null 2>&1); then + if $(command hg prompt >/dev/null 2>&1); then + if [[ $(command hg prompt "{status|unknown}") = "?" ]]; then # if files are not added prompt_segment red white st='±' - elif [[ -n $(hg prompt "{status|modified}") ]]; then + elif [[ -n $(command hg prompt "{status|modified}") ]]; then # if any modification prompt_segment yellow black st='±' @@ -196,15 +196,15 @@ prompt_hg() { # if working copy is clean prompt_segment green $CURRENT_FG fi - echo -n ${$(hg prompt "☿ {rev}@{branch}"):gs/%/%%} $st + echo -n ${$(command hg prompt "☿ {rev}@{branch}"):gs/%/%%} $st else st="" - rev=$(hg id -n 2>/dev/null | sed 's/[^-0-9]//g') - branch=$(hg id -b 2>/dev/null) - if `hg st | grep -q "^\?"`; then + rev=$(command hg id -n 2>/dev/null | sed 's/[^-0-9]//g') + branch=$(command hg id -b 2>/dev/null) + if command hg st | command grep -q "^\?"; then prompt_segment red black st='±' - elif `hg st | grep -q "^[MA]"`; then + elif command hg st | command grep -q "^[MA]"; then prompt_segment yellow black st='±' else From 1ed8d4b55530888bfa723e7dc6226a798260bdc8 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Wed, 17 Apr 2024 20:21:18 +0200 Subject: [PATCH 577/672] fix(git): turn off async prompt by default on zsh < 5.0.6 (#12331) See https://github.com/ohmyzsh/ohmyzsh/issues/12331#issuecomment-2059460268 --- lib/git.zsh | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/lib/git.zsh b/lib/git.zsh index c4265970b..277c0b3e8 100644 --- a/lib/git.zsh +++ b/lib/git.zsh @@ -1,3 +1,5 @@ +autoload -Uz is-at-least + # The git prompt's git commands are read-only and should not interfere with # other processes. This environment variable is equivalent to running with `git # --no-optional-locks`, but falls back gracefully for older versions of git. @@ -37,8 +39,10 @@ function _omz_git_prompt_info() { echo "${ZSH_THEME_GIT_PROMPT_PREFIX}${ref:gs/%/%%}${upstream:gs/%/%%}$(parse_git_dirty)${ZSH_THEME_GIT_PROMPT_SUFFIX}" } -# Enable async prompt by default unless the setting is at false / no -if zstyle -T ':omz:alpha:lib:git' async-prompt; then +# Use async version if setting is enabled, or undefined but zsh version is at least 5.0.6 +# https://github.com/ohmyzsh/ohmyzsh/issues/12331#issuecomment-2059460268 +if zstyle -t ':omz:alpha:lib:git' async-prompt \ + || { is-at-least 5.0.6 && zstyle -T ':omz:alpha:lib:git' async-prompt }; then function git_prompt_info() { setopt localoptions noksharrays if [[ -n "$_OMZ_ASYNC_OUTPUT[_omz_git_prompt_info]" ]]; then From eafa78217d836115a99f80bddfcd0a8901a15f77 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Thu, 18 Apr 2024 07:12:32 +0200 Subject: [PATCH 578/672] fix(history): fix `history -c` (#12362) Fixes #12362 --- lib/history.zsh | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/lib/history.zsh b/lib/history.zsh index ec89bc15e..aace78aa1 100644 --- a/lib/history.zsh +++ b/lib/history.zsh @@ -4,14 +4,14 @@ function omz_history { local clear list stamp zparseopts -E -D c=clear l=list f=stamp E=stamp i=stamp - if [[ $# -eq 0 ]]; then - # if no arguments provided, show full history starting from 1 - builtin fc $stamp -l 1 - elif [[ -n "$clear" ]]; then + if [[ -n "$clear" ]]; then # if -c provided, clobber the history file echo -n >| "$HISTFILE" fc -p "$HISTFILE" echo >&2 History file deleted. + elif [[ $# -eq 0 ]]; then + # if no arguments provided, show full history starting from 1 + builtin fc $stamp -l 1 else # otherwise, run `fc -l` with a custom format builtin fc $stamp -l "$@" From c262ffbb68e6dfc30b619e6ce6bdbd00f27b8a71 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Thu, 18 Apr 2024 07:16:42 +0200 Subject: [PATCH 579/672] fix(update): define `$ZSH` if undefined (#12273) Fixes #12273 Fixes https://github.com/topgrade-rs/topgrade/issues/519 --- tools/upgrade.sh | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/tools/upgrade.sh b/tools/upgrade.sh index d7016aa44..5eb90ab41 100755 --- a/tools/upgrade.sh +++ b/tools/upgrade.sh @@ -10,9 +10,14 @@ fi # Protect against unwanted sourcing case "$ZSH_EVAL_CONTEXT" in - *:file) echo "error: this file should not be sourced" && return ;; + *:file) echo "error: this file should not be sourced" && return 1 ;; esac +# Define "$ZSH" if not defined -- in theory this should be `export`ed by the calling script +if [[ -z "$ZSH" ]]; then + ZSH="${0:a:h:h}" +fi + cd "$ZSH" verbose_mode="default" From 56cfcb44e7ff730c10c5a00b58f38c33c984c52e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Thu, 18 Apr 2024 07:33:13 +0200 Subject: [PATCH 580/672] fix(updater): abort update if `$ZSH` is not a git repository Fixes #12298 --- lib/cli.zsh | 12 +++++++++++- tools/check_for_upgrade.sh | 10 ++++++---- 2 files changed, 17 insertions(+), 5 deletions(-) diff --git a/lib/cli.zsh b/lib/cli.zsh index aa36a6ab5..4a8d4d127 100644 --- a/lib/cli.zsh +++ b/lib/cli.zsh @@ -773,7 +773,17 @@ function _omz::theme::use { } function _omz::update { - local last_commit=$(builtin cd -q "$ZSH"; git rev-parse HEAD) + # Check if git command is available + (( $+commands[git] )) || { + _omz::log error "git is not installed. Aborting..." + return 1 + } + + local last_commit=$(builtin cd -q "$ZSH"; git rev-parse HEAD 2>/dev/null) + [[ $? -eq 0 ]] || { + _omz::log error "\`$ZSH\` is not a git directory. Aborting..." + return 1 + } # Run update script zstyle -s ':omz:update' verbose verbose_mode || verbose_mode=default diff --git a/tools/check_for_upgrade.sh b/tools/check_for_upgrade.sh index 1cc193bde..a5d2112f6 100644 --- a/tools/check_for_upgrade.sh +++ b/tools/check_for_upgrade.sh @@ -20,14 +20,16 @@ zstyle -s ':omz:update' mode update_mode || { } # Cancel update if: -# - the automatic update is disabled. -# - the current user doesn't have write permissions nor owns the $ZSH directory. +# - the automatic update is disabled +# - the current user doesn't have write permissions nor owns the $ZSH directory # - is not run from a tty -# - git is unavailable on the system. +# - git is unavailable on the system +# - $ZSH is not a git repository if [[ "$update_mode" = disabled ]] \ || [[ ! -w "$ZSH" || ! -O "$ZSH" ]] \ || [[ ! -t 1 ]] \ - || ! command git --version 2>&1 >/dev/null; then + || ! command git --version 2>&1 >/dev/null + || (builtin cd -q "$ZSH"; ! command git rev-parse --is-inside-work-tree &>/dev/null); then unset update_mode return fi From 80a651a6dfafc40630b47ad2f173d326844d6925 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Thu, 18 Apr 2024 07:48:33 +0200 Subject: [PATCH 581/672] chore(updater): small typo --- tools/check_for_upgrade.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tools/check_for_upgrade.sh b/tools/check_for_upgrade.sh index a5d2112f6..1ecab5c0b 100644 --- a/tools/check_for_upgrade.sh +++ b/tools/check_for_upgrade.sh @@ -28,7 +28,7 @@ zstyle -s ':omz:update' mode update_mode || { if [[ "$update_mode" = disabled ]] \ || [[ ! -w "$ZSH" || ! -O "$ZSH" ]] \ || [[ ! -t 1 ]] \ - || ! command git --version 2>&1 >/dev/null + || ! command git --version 2>&1 >/dev/null \ || (builtin cd -q "$ZSH"; ! command git rev-parse --is-inside-work-tree &>/dev/null); then unset update_mode return From d17ca487a4357923d8b8681b9e40c2bb2d2fadea Mon Sep 17 00:00:00 2001 From: Martin Hans Date: Thu, 18 Apr 2024 10:49:34 +0200 Subject: [PATCH 582/672] fix(history): add `t` option to history wrapper (#12365) The `t` option takes a strftime format specification as argument. This fixes cases in which $HIST_STAMPS is set to a value other than `mm/dd/yyyy|dd.mm.yyyy|yyyy-mm-dd`. --- lib/history.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/history.zsh b/lib/history.zsh index aace78aa1..a8431fd5a 100644 --- a/lib/history.zsh +++ b/lib/history.zsh @@ -2,7 +2,7 @@ function omz_history { # parse arguments and remove from $@ local clear list stamp - zparseopts -E -D c=clear l=list f=stamp E=stamp i=stamp + zparseopts -E -D c=clear l=list f=stamp E=stamp i=stamp t:=stamp if [[ -n "$clear" ]]; then # if -c provided, clobber the history file From 1b5503a3eefeb3e248bbc07a2f4e4b7591924307 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Fri, 19 Apr 2024 21:57:46 +0200 Subject: [PATCH 583/672] feat(fzf): support fzf setup for 0.48.0 and older (#12367) Fixes #12355 --- plugins/fzf/fzf.plugin.zsh | 12 +++++++++++- 1 file changed, 11 insertions(+), 1 deletion(-) diff --git a/plugins/fzf/fzf.plugin.zsh b/plugins/fzf/fzf.plugin.zsh index 9e372f498..ac4370596 100644 --- a/plugins/fzf/fzf.plugin.zsh +++ b/plugins/fzf/fzf.plugin.zsh @@ -1,3 +1,12 @@ +function fzf_setup_using_fzf() { + (( ${+commands[fzf]} )) || return 1 + + local fzf_ver=${$(fzf --version)[1]} + is-at-least 0.48.0 $fzf_ver || return 1 + + eval "$(fzf --zsh)" +} + function fzf_setup_using_base_dir() { local fzf_base fzf_shell fzfdirs dir @@ -217,7 +226,8 @@ Please add `export FZF_BASE=/path/to/fzf/install/dir` to your .zshrc EOF } -fzf_setup_using_openbsd \ +fzf_setup_using_fzf \ + || fzf_setup_using_openbsd \ || fzf_setup_using_debian \ || fzf_setup_using_opensuse \ || fzf_setup_using_cygwin \ From f78c6b90fc18e2d0bb119ff549207463ce1d57a5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Tue, 16 Apr 2024 18:07:10 +0200 Subject: [PATCH 584/672] fix(async): fix crash on zsh < 5.0.6 (#12358) --- lib/async_prompt.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/async_prompt.zsh b/lib/async_prompt.zsh index a83c57f35..db48446e7 100644 --- a/lib/async_prompt.zsh +++ b/lib/async_prompt.zsh @@ -124,7 +124,7 @@ function _omz_async_callback() { # Repaint prompt if output has changed if [[ "$old_output" != "${_OMZ_ASYNC_OUTPUT[$handler]}" ]]; then - zle reset-prompt + zle .reset-prompt zle -R fi From 0c80a063c3ad9513b83589d377c501a8d85d63a6 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Fri, 19 Apr 2024 18:47:21 +0200 Subject: [PATCH 585/672] chore(async): reenable async prompt by default on zsh < 5.0.6 (#12358) Fixes #12331 --- lib/git.zsh | 16 ++++++---------- 1 file changed, 6 insertions(+), 10 deletions(-) diff --git a/lib/git.zsh b/lib/git.zsh index 277c0b3e8..b257d01a4 100644 --- a/lib/git.zsh +++ b/lib/git.zsh @@ -39,21 +39,17 @@ function _omz_git_prompt_info() { echo "${ZSH_THEME_GIT_PROMPT_PREFIX}${ref:gs/%/%%}${upstream:gs/%/%%}$(parse_git_dirty)${ZSH_THEME_GIT_PROMPT_SUFFIX}" } -# Use async version if setting is enabled, or undefined but zsh version is at least 5.0.6 -# https://github.com/ohmyzsh/ohmyzsh/issues/12331#issuecomment-2059460268 -if zstyle -t ':omz:alpha:lib:git' async-prompt \ - || { is-at-least 5.0.6 && zstyle -T ':omz:alpha:lib:git' async-prompt }; then +# Use async version if setting is enabled or undefined +if zstyle -T ':omz:alpha:lib:git' async-prompt; then function git_prompt_info() { - setopt localoptions noksharrays - if [[ -n "$_OMZ_ASYNC_OUTPUT[_omz_git_prompt_info]" ]]; then - echo -n "$_OMZ_ASYNC_OUTPUT[_omz_git_prompt_info]" + if [[ -n "${_OMZ_ASYNC_OUTPUT[_omz_git_prompt_info]}" ]]; then + echo -n "${_OMZ_ASYNC_OUTPUT[_omz_git_prompt_info]}" fi } function git_prompt_status() { - setopt localoptions noksharrays - if [[ -n "$_OMZ_ASYNC_OUTPUT[_omz_git_prompt_status]" ]]; then - echo -n "$_OMZ_ASYNC_OUTPUT[_omz_git_prompt_status]" + if [[ -n "${_OMZ_ASYNC_OUTPUT[_omz_git_prompt_status]}" ]]; then + echo -n "${_OMZ_ASYNC_OUTPUT[_omz_git_prompt_status]}" fi } From 67581c53c6458566e174620361e84b364b9034d2 Mon Sep 17 00:00:00 2001 From: Zikoeng Xi Date: Tue, 23 Apr 2024 03:37:17 +0800 Subject: [PATCH 586/672] fix(ssh-agent): add identity only if identity exists (#12371) --- plugins/ssh-agent/ssh-agent.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/ssh-agent/ssh-agent.plugin.zsh b/plugins/ssh-agent/ssh-agent.plugin.zsh index 77c422ce1..1da54d4dd 100644 --- a/plugins/ssh-agent/ssh-agent.plugin.zsh +++ b/plugins/ssh-agent/ssh-agent.plugin.zsh @@ -62,7 +62,7 @@ function _add_identities() { # if id is an absolute path, make file equal to id [[ "$id" = /* ]] && file="$id" || file="$HOME/.ssh/$id" # check for filename match, otherwise try for signature match - if [[ ${loaded_ids[(I)$file]} -le 0 ]]; then + if [[ -f $file && ${loaded_ids[(I)$file]} -le 0 ]]; then sig="$(ssh-keygen -lf "$file" | awk '{print $2}')" [[ ${loaded_sigs[(I)$sig]} -le 0 ]] && not_loaded+=("$file") fi From ee69c14beb24c652707b2f6b2a9db0fa8b238d05 Mon Sep 17 00:00:00 2001 From: John Matczak <50644033+cidrmill@users.noreply.github.com> Date: Tue, 23 Apr 2024 01:54:00 -0700 Subject: [PATCH 587/672] feat(fishy): add color to username (#12369) --- themes/fishy.zsh-theme | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/themes/fishy.zsh-theme b/themes/fishy.zsh-theme index 2b8d559e5..3b975c8f4 100644 --- a/themes/fishy.zsh-theme +++ b/themes/fishy.zsh-theme @@ -16,7 +16,8 @@ _fishy_collapsed_wd() { } local user_color='green'; [ $UID -eq 0 ] && user_color='red' -PROMPT='%n@%m %{$fg[$user_color]%}$(_fishy_collapsed_wd)%{$reset_color%}%(!.#.>) ' +local host_color='white'; [ -n "$SSH_CLIENT" ] || [ -n "$SSH_TTY" ] && host_color='yellow' +PROMPT='%{$fg[$user_color]%}%n%{$reset_color%}@%{$fg[$host_color]%}%m %{$fg[$user_color]%}$(_fishy_collapsed_wd)%{$reset_color%}%(!.#.>) ' PROMPT2='%{$fg[red]%}\ %{$reset_color%}' local return_status="%{$fg_bold[red]%}%(?..%?)%{$reset_color%}" From 5d2d35cd1741af19553007fe0cc5324744fc58fa Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Tue, 23 Apr 2024 16:21:21 +0200 Subject: [PATCH 588/672] fix(poetry-env): do not deactivate in a subdir Closes #12377 --- plugins/poetry-env/poetry-env.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/poetry-env/poetry-env.plugin.zsh b/plugins/poetry-env/poetry-env.plugin.zsh index f98c177b4..be46717d8 100644 --- a/plugins/poetry-env/poetry-env.plugin.zsh +++ b/plugins/poetry-env/poetry-env.plugin.zsh @@ -6,7 +6,7 @@ _togglePoetryShell() { fi # Deactivate the current environment if moving out of a Poetry directory or into a different Poetry directory - if [[ $poetry_active -eq 1 ]] && { [[ $in_poetry_dir -eq 0 ]] || [[ "$PWD" != "$poetry_dir"* ]]; }; then + if [[ $poetry_active -eq 1 ]] && { [[ $in_poetry_dir -eq 0 ]] && [[ "$PWD" != "$poetry_dir"* ]]; }; then export poetry_active=0 unset poetry_dir deactivate From 803e1a784cd520f101d126b47deea3297e6a82fc Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Thu, 25 Apr 2024 08:04:18 +0200 Subject: [PATCH 589/672] fix(copybuffer): prevent `which` alias usage (#12379) --- plugins/copybuffer/copybuffer.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/copybuffer/copybuffer.plugin.zsh b/plugins/copybuffer/copybuffer.plugin.zsh index 88bda32a0..e636d9730 100644 --- a/plugins/copybuffer/copybuffer.plugin.zsh +++ b/plugins/copybuffer/copybuffer.plugin.zsh @@ -2,7 +2,7 @@ # onto the system clipboard copybuffer () { - if which clipcopy &>/dev/null; then + if builtin which clipcopy &>/dev/null; then printf "%s" "$BUFFER" | clipcopy else zle -M "clipcopy not found. Please make sure you have Oh My Zsh installed correctly." From 21963f4f678e69fb3154a1d43a33d531a5b3566d Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Tue, 30 Apr 2024 12:56:02 +0200 Subject: [PATCH 590/672] fix(fzf): support old `fzf` versions Closes #12387 --- plugins/fzf/fzf.plugin.zsh | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/plugins/fzf/fzf.plugin.zsh b/plugins/fzf/fzf.plugin.zsh index ac4370596..3d29f1762 100644 --- a/plugins/fzf/fzf.plugin.zsh +++ b/plugins/fzf/fzf.plugin.zsh @@ -1,8 +1,10 @@ function fzf_setup_using_fzf() { (( ${+commands[fzf]} )) || return 1 - local fzf_ver=${$(fzf --version)[1]} - is-at-least 0.48.0 $fzf_ver || return 1 + # we remove "fzf " prefix, this fixes really old fzf versions behaviour + # see https://github.com/ohmyzsh/ohmyzsh/issues/12387 + local fzf_ver=${"$(fzf --version)"#fzf } + is-at-least 0.48.0 ${${(s: :)fzf_ver}[1]} || return 1 eval "$(fzf --zsh)" } From 8581ecd462ab2714936398c54433ed1deddb2926 Mon Sep 17 00:00:00 2001 From: Antoine Date: Wed, 1 May 2024 11:04:12 +0200 Subject: [PATCH 591/672] feat(autojump): add `nix-darwin` install path (#12389) --- plugins/autojump/autojump.plugin.zsh | 1 + 1 file changed, 1 insertion(+) diff --git a/plugins/autojump/autojump.plugin.zsh b/plugins/autojump/autojump.plugin.zsh index 5a52e3067..e385a2de8 100644 --- a/plugins/autojump/autojump.plugin.zsh +++ b/plugins/autojump/autojump.plugin.zsh @@ -15,6 +15,7 @@ autojump_paths=( /opt/homebrew/etc/profile.d/autojump.sh # macOS with Homebrew (default on M1 macs) /opt/pkg/share/autojump/autojump.zsh # macOS with pkgsrc /etc/profiles/per-user/$USER/etc/profile.d/autojump.sh # macOS Nix, Home Manager and flakes + /nix/var/nix/gcroots/current-system/sw/share/zsh/site-functions/autojump.zsh # macOS Nix, nix-darwin ) for file in $autojump_paths; do From 529f77a344de5fd53ea2235547cefd5d15d02723 Mon Sep 17 00:00:00 2001 From: stefan Date: Thu, 2 May 2024 15:11:18 +0200 Subject: [PATCH 592/672] feat(termsupport): support `alacritty*` TERM (#12392) Closes #12391 --- lib/termsupport.zsh | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/lib/termsupport.zsh b/lib/termsupport.zsh index d170ffcbf..087bae9bb 100644 --- a/lib/termsupport.zsh +++ b/lib/termsupport.zsh @@ -17,7 +17,7 @@ function title { : ${2=$1} case "$TERM" in - cygwin|xterm*|putty*|rxvt*|konsole*|ansi|mlterm*|alacritty|st*|foot*|contour*) + cygwin|xterm*|putty*|rxvt*|konsole*|ansi|mlterm*|alacritty*|st*|foot*|contour*) print -Pn "\e]2;${2:q}\a" # set window name print -Pn "\e]1;${1:q}\a" # set tab name ;; @@ -129,7 +129,7 @@ fi # Don't define the function if we're in an unsupported terminal case "$TERM" in # all of these either process OSC 7 correctly or ignore entirely - xterm*|putty*|rxvt*|konsole*|mlterm*|alacritty|screen*|tmux*) ;; + xterm*|putty*|rxvt*|konsole*|mlterm*|alacritty*|screen*|tmux*) ;; contour*|foot*) ;; *) # Terminal.app and iTerm2 process OSC 7 correctly From 668ca3a32dae5ff5d164fc3be565f1e2ece248db Mon Sep 17 00:00:00 2001 From: Shai Coleman Date: Fri, 3 May 2024 20:43:53 +0100 Subject: [PATCH 593/672] fix(extract): `zst` now extracts as expected (#12395) --- plugins/extract/extract.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/extract/extract.plugin.zsh b/plugins/extract/extract.plugin.zsh index 80ca50c50..1c7599195 100644 --- a/plugins/extract/extract.plugin.zsh +++ b/plugins/extract/extract.plugin.zsh @@ -87,7 +87,7 @@ EOF builtin cd -q control; extract ../control.tar.* builtin cd -q ../data; extract ../data.tar.* builtin cd -q ..; command rm *.tar.* debian-binary ;; - (*.zst) unzstd "$full_path" ;; + (*.zst) unzstd --stdout "$full_path" > "${file:t:r}" ;; (*.cab|*.exe) cabextract "$full_path" ;; (*.cpio|*.obscpio) cpio -idmvF "$full_path" ;; (*.zpaq) zpaq x "$full_path" ;; From 22bbc233e90f18ad7a02625c66d1867a5486fcbb Mon Sep 17 00:00:00 2001 From: Michael Gonzo Date: Tue, 7 May 2024 21:30:23 +0200 Subject: [PATCH 594/672] feat(python): autovenv keeps activated on subdirs (#12396) Co-authored-by: Carlo Sala --- plugins/python/README.md | 7 ++++--- plugins/python/python.plugin.zsh | 19 ++++++++++++++----- 2 files changed, 18 insertions(+), 8 deletions(-) diff --git a/plugins/python/README.md b/plugins/python/README.md index c99697b22..b990a26b9 100644 --- a/plugins/python/README.md +++ b/plugins/python/README.md @@ -32,8 +32,9 @@ virtual environments: `venv`) in the current directory. - `auto_vrun`: Automatically activate the venv virtual environment when entering a directory containing - `/bin/activate`, and automatically deactivate it when navigating out of it (including - subdirectories!). + `/bin/activate`, and automatically deactivate it when navigating out of it (keeps venv activated + in subdirectories). - To enable the feature, set `export PYTHON_AUTO_VRUN=true` before sourcing oh-my-zsh. - - The default virtual environment name is `venv`. To use a different name, set + - Plugin activates first virtual environment in lexicographic order whose name begins with ``. + The default virtual environment name is `venv`. To use a different name, set `export PYTHON_VENV_NAME=`. For example: `export PYTHON_VENV_NAME=".venv"` diff --git a/plugins/python/python.plugin.zsh b/plugins/python/python.plugin.zsh index f6ea85027..7256aa04f 100644 --- a/plugins/python/python.plugin.zsh +++ b/plugins/python/python.plugin.zsh @@ -86,11 +86,20 @@ function mkv() { if [[ "$PYTHON_AUTO_VRUN" == "true" ]]; then # Automatically activate venv when changing dir - auto_vrun() { - if [[ -f "${PYTHON_VENV_NAME}/bin/activate" ]]; then - source "${PYTHON_VENV_NAME}/bin/activate" > /dev/null 2>&1 - else - (( $+functions[deactivate] )) && deactivate > /dev/null 2>&1 + function auto_vrun() { + # deactivate if we're on a different dir than VIRTUAL_ENV states + # we don't deactivate subdirectories! + if (( $+functions[deactivate] )) && [[ $PWD != ${VIRTUAL_ENV:h}* ]]; then + deactivate > /dev/null 2>&1 + fi + + if [[ $PWD != ${VIRTUAL_ENV:h} ]]; then + for _file in "${PYTHON_VENV_NAME}"*/bin/activate(N.); do + # make sure we're not in a venv already + (( $+functions[deactivate] )) && deactivate > /dev/null 2>&1 + source $_file > /dev/null 2>&1 + break + done fi } add-zsh-hook chpwd auto_vrun From 8c5f64cc2f0e75399a1e906e39713ed25b65ece1 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Mon, 6 May 2024 09:49:21 +0200 Subject: [PATCH 595/672] feat(nvm): add `corepack` to `lazy_cmd` --- plugins/nvm/README.md | 6 +++--- plugins/nvm/nvm.plugin.zsh | 4 ++-- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/plugins/nvm/README.md b/plugins/nvm/README.md index e88ce0158..eb1e236ee 100644 --- a/plugins/nvm/README.md +++ b/plugins/nvm/README.md @@ -26,9 +26,9 @@ These settings should go in your zshrc file, before Oh My Zsh is sourced: #### Lazy startup This option will help you to defer nvm's load until you use it to speed-up your zsh startup. This will source -nvm script only when using it, and will create a function for `node`, `npm`, `npx`, `pnpm`, `yarn`, and the -command(s) specified by `lazy-cmd` option, so when you call either of them, nvm will be loaded and run with -default version. To enable it, you can add this snippet to your zshrc, before Oh My Zsh is sourced: +nvm script only when using it, and will create a function for `node`, `npm`, `npx`, `pnpm`, `yarn`, `corepack` +and the command(s) specified by `lazy-cmd` option, so when you call either of them, nvm will be loaded and run +with default version. To enable it, you can add this snippet to your zshrc, before Oh My Zsh is sourced: ```zsh zstyle ':omz:plugins:nvm' lazy yes diff --git a/plugins/nvm/nvm.plugin.zsh b/plugins/nvm/nvm.plugin.zsh index c2e8de94b..95c94030a 100644 --- a/plugins/nvm/nvm.plugin.zsh +++ b/plugins/nvm/nvm.plugin.zsh @@ -72,9 +72,9 @@ function _omz_setup_autoload { } if zstyle -t ':omz:plugins:nvm' lazy; then - # Call nvm when first using nvm, node, npm, pnpm, yarn or other commands in lazy-cmd + # Call nvm when first using nvm, node, npm, pnpm, yarn, corepack or other commands in lazy-cmd zstyle -a ':omz:plugins:nvm' lazy-cmd nvm_lazy_cmd - nvm_lazy_cmd=(nvm node npm npx pnpm yarn $nvm_lazy_cmd) # default values + nvm_lazy_cmd=(nvm node npm npx pnpm yarn corepack $nvm_lazy_cmd) # default values eval " function $nvm_lazy_cmd { for func in $nvm_lazy_cmd; do From b0561d28b5a3efbbcca4700626fa32e62c23959b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Wed, 8 May 2024 22:20:42 +0200 Subject: [PATCH 596/672] fix(cli): fix edge cases in `omz plugin disable` command (#12401) Also introduces tests, which will be refactored into the proper place when a test system is finally designed. Fixes #12400 --- lib/cli.zsh | 14 +++- lib/tests/cli.test.zsh | 169 +++++++++++++++++++++++++++++++++++++++++ 2 files changed, 180 insertions(+), 3 deletions(-) create mode 100644 lib/tests/cli.test.zsh diff --git a/lib/cli.zsh b/lib/cli.zsh index 4a8d4d127..383b0cfb0 100644 --- a/lib/cli.zsh +++ b/lib/cli.zsh @@ -241,10 +241,18 @@ function _omz::plugin::disable { # Remove plugins substitution awk script local awk_subst_plugins="\ - gsub(/[ \t]+(${(j:|:)dis_plugins})/, \"\") # with spaces before - gsub(/(${(j:|:)dis_plugins})[ \t]+/, \"\") # with spaces after - gsub(/\((${(j:|:)dis_plugins})\)/, \"\") # without spaces (only plugin) + gsub(/[ \t]+(${(j:|:)dis_plugins})[ \t]+/, \" \") # with spaces before or after + gsub(/[ \t]+(${(j:|:)dis_plugins})$/, \"\") # with spaces before and EOL + gsub(/^(${(j:|:)dis_plugins})[ \t]+/, \"\") # with BOL and spaces after + + gsub(/\((${(j:|:)dis_plugins})[ \t]+/, \"(\") # with parenthesis before and spaces after + gsub(/[ \t]+(${(j:|:)dis_plugins})\)/, \")\") # with spaces before or parenthesis after + gsub(/\((${(j:|:)dis_plugins})\)/, \"()\") # with only parentheses + + gsub(/^(${(j:|:)dis_plugins})\)/, \")\") # with BOL and closing parenthesis + gsub(/\((${(j:|:)dis_plugins})$/, \"(\") # with opening parenthesis and EOL " + # Disable plugins awk script local awk_script=" # if plugins=() is in oneline form, substitute disabled plugins and go to next line diff --git a/lib/tests/cli.test.zsh b/lib/tests/cli.test.zsh new file mode 100644 index 000000000..9ee5cd219 --- /dev/null +++ b/lib/tests/cli.test.zsh @@ -0,0 +1,169 @@ +#!/usr/bin/zsh -df + +run_awk() { + local -a dis_plugins=(${=1}) + local input_text="$2" + + (( ! DEBUG )) || set -xv + + local awk_subst_plugins="\ + gsub(/[ \t]+(${(j:|:)dis_plugins})[ \t]+/, \" \") # with spaces before or after + gsub(/[ \t]+(${(j:|:)dis_plugins})$/, \"\") # with spaces before and EOL + gsub(/^(${(j:|:)dis_plugins})[ \t]+/, \"\") # with BOL and spaces after + + gsub(/\((${(j:|:)dis_plugins})[ \t]+/, \"(\") # with parenthesis before and spaces after + gsub(/[ \t]+(${(j:|:)dis_plugins})\)/, \")\") # with spaces before or parenthesis after + gsub(/\((${(j:|:)dis_plugins})\)/, \"()\") # with only parentheses + + gsub(/^(${(j:|:)dis_plugins})\)/, \")\") # with BOL and closing parenthesis + gsub(/\((${(j:|:)dis_plugins})$/, \"(\") # with opening parenthesis and EOL + " + # Disable plugins awk script + local awk_script=" + # if plugins=() is in oneline form, substitute disabled plugins and go to next line + /^[ \t]*plugins=\([^#]+\).*\$/ { + $awk_subst_plugins + print \$0 + next + } + + # if plugins=() is in multiline form, enable multi flag and disable plugins if they're there + /^[ \t]*plugins=\(/ { + multi=1 + $awk_subst_plugins + print \$0 + next + } + + # if multi flag is enabled and we find a valid closing parenthesis, remove plugins and disable multi flag + multi == 1 && /^[^#]*\)/ { + multi=0 + $awk_subst_plugins + print \$0 + next + } + + multi == 1 && length(\$0) > 0 { + $awk_subst_plugins + if (length(\$0) > 0) print \$0 + next + } + + { print \$0 } + " + + command awk "$awk_script" <<< "$input_text" + + (( ! DEBUG )) || set +xv +} + +# runs awk against stdin, checks if the resulting file is not empty and then checks if the file has valid zsh syntax +run_awk_and_test() { + local description="$1" + local plugins_to_disable="$2" + local input_text="$3" + local expected_output="$4" + + local tmpfile==(:) + + { + print -u2 "Test: $description" + DEBUG=0 run_awk "$plugins_to_disable" "$input_text" >| $tmpfile + + if [[ ! -s "$tmpfile" ]]; then + print -u2 "\e[31mError\e[0m: output file empty" + return 1 + fi + + if ! zsh -n $tmpfile; then + print -u2 "\e[31mError\e[0m: zsh syntax error" + diff -u $tmpfile <(echo "$expected_output") + return 1 + fi + + if ! diff -u --color=always $tmpfile <(echo "$expected_output"); then + if (( DEBUG )); then + print -u2 "" + DEBUG=1 run_awk "$plugins_to_disable" "$input_text" + print -u2 "" + fi + print -u2 "\e[31mError\e[0m: output file does not match expected output" + return 1 + fi + + print -u2 "\e[32mSuccess\e[0m" + } always { + print -u2 "" + command rm -f "$tmpfile" + } +} + +# These tests are for the `omz plugin disable` command +run_awk_and_test \ + "it should delete a single plugin in oneline format" \ + "git" \ + "plugins=(git)" \ + "plugins=()" + +run_awk_and_test \ + "it should delete a single plugin in multiline format" \ + "github" \ +"plugins=( + github +)" \ +"plugins=( +)" + +run_awk_and_test \ + "it should delete multiple plugins in oneline format" \ + "github git z" \ + "plugins=(github git z)" \ + "plugins=()" + +run_awk_and_test \ + "it should delete multiple plugins in multiline format" \ + "github git z" \ +"plugins=( + github + git + z +)" \ +"plugins=( +)" + +run_awk_and_test \ + "it should delete a single plugin among multiple in oneline format" \ + "git" \ + "plugins=(github git z)" \ + "plugins=(github z)" + +run_awk_and_test \ + "it should delete a single plugin among multiple in multiline format" \ + "git" \ +"plugins=( + github + git + z +)" \ +"plugins=( + github + z +)" + +run_awk_and_test \ + "it should delete multiple plugins in mixed format" \ + "git z" \ +"plugins=(github +git z)" \ +"plugins=(github +)" + +run_awk_and_test \ + "it should delete multiple plugins in mixed format 2" \ + "github z" \ +"plugins=(github + git +z)" \ +"plugins=( + git +)" From 5947c3c3c91d04fa0bff45866938027b85b56c6e Mon Sep 17 00:00:00 2001 From: Atk Date: Thu, 9 May 2024 15:57:30 +0100 Subject: [PATCH 597/672] feat(dependencies): add `wd` (#12405) Co-authored-by: Carlo Sala --- .github/dependencies.yml | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/.github/dependencies.yml b/.github/dependencies.yml index f760ddcef..a105f440d 100644 --- a/.github/dependencies.yml +++ b/.github/dependencies.yml @@ -36,3 +36,11 @@ dependencies: precopy: | set -e find . ! -name _gradle ! -name LICENSE -delete + plugins/wd: + repo: mfaerevaag/wd + branch: master + version: tag:v0.6.0 + precopy: | + set -e + rm -r test + rm install.sh tty.gif wd.1 From b1af78d64d81ade60d74f301c877d6a6394a12ab Mon Sep 17 00:00:00 2001 From: Kiran Koirala Date: Fri, 10 May 2024 13:12:47 +0545 Subject: [PATCH 598/672] fix(nvm): use `nvm version` when needed (#12409) --- plugins/nvm/nvm.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/nvm/nvm.plugin.zsh b/plugins/nvm/nvm.plugin.zsh index 95c94030a..8ca82fe83 100644 --- a/plugins/nvm/nvm.plugin.zsh +++ b/plugins/nvm/nvm.plugin.zsh @@ -54,7 +54,7 @@ function _omz_setup_autoload { if [[ "$nvmrc_node_version" = "N/A" ]]; then nvm install - elif [[ "$nvmrc_node_version" != "$node_version" ]]; then + elif [[ "$nvmrc_node_version" != "$(nvm version)" ]]; then nvm use $nvm_silent fi elif [[ -n "$(PWD=$OLDPWD nvm_find_nvmrc)" ]] && [[ "$(nvm version)" != "$(nvm version default)" ]]; then From 9af7ebcf36c20e1490a50fa5bab6319275859c17 Mon Sep 17 00:00:00 2001 From: Kiran Koirala Date: Fri, 10 May 2024 15:53:35 +0545 Subject: [PATCH 599/672] fix(nvm): use `command cat` to avoid alias (#12410) --- plugins/nvm/nvm.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/nvm/nvm.plugin.zsh b/plugins/nvm/nvm.plugin.zsh index 8ca82fe83..f36182eda 100644 --- a/plugins/nvm/nvm.plugin.zsh +++ b/plugins/nvm/nvm.plugin.zsh @@ -50,7 +50,7 @@ function _omz_setup_autoload { zstyle -t ':omz:plugins:nvm' silent-autoload && nvm_silent="--silent" if [[ -n "$nvmrc_path" ]]; then - local nvmrc_node_version=$(nvm version $(cat "$nvmrc_path" | tr -dc '[:print:]')) + local nvmrc_node_version=$(nvm version $(command cat "$nvmrc_path" | tr -dc '[:print:]')) if [[ "$nvmrc_node_version" = "N/A" ]]; then nvm install From d2cf10c29f2ebcbdbcc70ed3569aa3333d70d00d Mon Sep 17 00:00:00 2001 From: Ilya <68309482+Str1kez@users.noreply.github.com> Date: Fri, 10 May 2024 20:16:45 +0300 Subject: [PATCH 600/672] feat(procs): add completions plugin (#12406) --- plugins/procs/README.md | 9 +++++++++ plugins/procs/procs.plugin.zsh | 13 +++++++++++++ 2 files changed, 22 insertions(+) create mode 100644 plugins/procs/README.md create mode 100644 plugins/procs/procs.plugin.zsh 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..332985bf9 --- /dev/null +++ b/plugins/procs/procs.plugin.zsh @@ -0,0 +1,13 @@ +if (( ! $+commands[procs] )); then + return +fi + +# If the completion file doesn't exist yet, we need to autoload it and +# bind it to `minikube`. 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 + +procs --gen-completion-out zsh >| "$ZSH_CACHE_DIR/completions/_procs" &| From 0fabd5f22f4e0378b09c92607789fdb17cab3c20 Mon Sep 17 00:00:00 2001 From: Francesco Ilario Date: Fri, 10 May 2024 19:17:18 +0200 Subject: [PATCH 601/672] fix(git): add checked-out branch support to `gbg*` (#12397) --- plugins/git/README.md | 4 ++-- plugins/git/git.plugin.zsh | 4 ++-- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/plugins/git/README.md b/plugins/git/README.md index 4c005ad2f..4022f8c62 100644 --- a/plugins/git/README.md +++ b/plugins/git/README.md @@ -41,8 +41,8 @@ plugins=(... git) | `gba` | `git branch --all` | | `gbd` | `git branch --delete` | | `gbD` | `git branch --delete --force` | -| `gbgd` | `LANG=C git branch --no-color -vv \| grep ": gone\]" \| awk '"'"'{print $1}'"'"' \| xargs git branch -d` | -| `gbgD` | `LANG=C git branch --no-color -vv \| grep ": gone\]" \| awk '"'"'{print $1}'"'"' \| xargs git branch -D` | +| `gbgd` | `LANG=C git branch --no-color -vv \| grep ": gone\]" \| cut -c 3- \| awk '"'"'{print $1}'"'"' \| xargs git branch -d` | +| `gbgD` | `LANG=C git branch --no-color -vv \| grep ": gone\]" \| cut -c 3- \| awk '"'"'{print $1}'"'"' \| xargs git branch -D` | | `gbm` | `git branch --move` | | `gbnm` | `git branch --no-merged` | | `gbr` | `git branch --remote` | diff --git a/plugins/git/git.plugin.zsh b/plugins/git/git.plugin.zsh index 146f4a512..c48e365b5 100644 --- a/plugins/git/git.plugin.zsh +++ b/plugins/git/git.plugin.zsh @@ -147,8 +147,8 @@ function gbds() { done } -alias gbgd='LANG=C git branch --no-color -vv | grep ": gone\]" | awk '"'"'{print $1}'"'"' | xargs git branch -d' -alias gbgD='LANG=C git branch --no-color -vv | grep ": gone\]" | awk '"'"'{print $1}'"'"' | xargs git branch -D' +alias gbgd='LANG=C git branch --no-color -vv | grep ": gone\]" | cut -c 3- | awk '"'"'{print $1}'"'"' | xargs git branch -d' +alias gbgD='LANG=C git branch --no-color -vv | grep ": gone\]" | cut -c 3- | awk '"'"'{print $1}'"'"' | xargs git branch -D' alias gbm='git branch --move' alias gbnm='git branch --no-merged' alias gbr='git branch --remote' From d91f4e83efc5759a3347a2e1ae919ce0a6dda07f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Sun, 12 May 2024 09:44:11 +0200 Subject: [PATCH 602/672] fix(fzf): fix missing `is-at-least` error in setup (#12412) Fixes #12412 --- plugins/fzf/fzf.plugin.zsh | 2 ++ 1 file changed, 2 insertions(+) diff --git a/plugins/fzf/fzf.plugin.zsh b/plugins/fzf/fzf.plugin.zsh index 3d29f1762..48fea4f63 100644 --- a/plugins/fzf/fzf.plugin.zsh +++ b/plugins/fzf/fzf.plugin.zsh @@ -4,6 +4,8 @@ function fzf_setup_using_fzf() { # we remove "fzf " prefix, this fixes really old fzf versions behaviour # see https://github.com/ohmyzsh/ohmyzsh/issues/12387 local fzf_ver=${"$(fzf --version)"#fzf } + + autoload -Uz is-at-least is-at-least 0.48.0 ${${(s: :)fzf_ver}[1]} || return 1 eval "$(fzf --zsh)" From 83110e8ce16cd3c6bd85e7f96a920d114f598df1 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Thu, 9 May 2024 17:19:43 +0200 Subject: [PATCH 603/672] chore(dependencies): update requirements.txt --- .github/workflows/dependencies/requirements.txt | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/.github/workflows/dependencies/requirements.txt b/.github/workflows/dependencies/requirements.txt index 3c4c149ea..0ef3e54ca 100644 --- a/.github/workflows/dependencies/requirements.txt +++ b/.github/workflows/dependencies/requirements.txt @@ -1,2 +1,6 @@ -PyYAML~=6.0.1 -requests~=2.31.0 +certifi==2024.2.2 +charset-normalizer==3.3.2 +idna==3.7 +PyYAML==6.0.1 +requests==2.31.0 +urllib3==2.2.1 From 13c8a10e39d60c078193d403b253270cdc4abc80 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Thu, 9 May 2024 17:20:09 +0200 Subject: [PATCH 604/672] style(dependencies): run `ruff` formatter --- .editorconfig | 3 + .github/workflows/dependencies/updater.py | 704 ++++++++++++---------- 2 files changed, 378 insertions(+), 329 deletions(-) diff --git a/.editorconfig b/.editorconfig index b5321de59..b349bcc42 100644 --- a/.editorconfig +++ b/.editorconfig @@ -6,3 +6,6 @@ insert_final_newline = true charset = utf-8 indent_size = 2 indent_style = space + +[*.py] +indent_size = 4 diff --git a/.github/workflows/dependencies/updater.py b/.github/workflows/dependencies/updater.py index f54d316f9..765cb26fe 100644 --- a/.github/workflows/dependencies/updater.py +++ b/.github/workflows/dependencies/updater.py @@ -1,12 +1,14 @@ import os +import shutil import subprocess import sys -import requests -import shutil -import yaml +import timeit from copy import deepcopy from typing import Optional, TypedDict +import requests +import yaml + # Get TMP_DIR variable from environment TMP_DIR = os.path.join(os.environ.get("TMP_DIR", "/tmp"), "ohmyzsh") # Relative path to dependencies.yml file @@ -14,28 +16,29 @@ DEPS_YAML_FILE = ".github/dependencies.yml" # Dry run flag DRY_RUN = os.environ.get("DRY_RUN", "0") == "1" -import timeit + class CodeTimer: - def __init__(self, name=None): - self.name = " '" + name + "'" if name else '' + def __init__(self, name=None): + self.name = " '" + name + "'" if name else "" - def __enter__(self): - self.start = timeit.default_timer() + def __enter__(self): + self.start = timeit.default_timer() - def __exit__(self, exc_type, exc_value, traceback): - self.took = (timeit.default_timer() - self.start) * 1000.0 - print('Code block' + self.name + ' took: ' + str(self.took) + ' ms') + def __exit__(self, exc_type, exc_value, traceback): + self.took = (timeit.default_timer() - self.start) * 1000.0 + print("Code block" + self.name + " took: " + str(self.took) + " ms") ### YAML representation def str_presenter(dumper, data): - """ - Configures yaml for dumping multiline strings - Ref: https://stackoverflow.com/a/33300001 - """ - if len(data.splitlines()) > 1: # check for multiline string - return dumper.represent_scalar('tag:yaml.org,2002:str', data, style='|') - return dumper.represent_scalar('tag:yaml.org,2002:str', data) + """ + Configures yaml for dumping multiline strings + Ref: https://stackoverflow.com/a/33300001 + """ + if len(data.splitlines()) > 1: # check for multiline string + return dumper.represent_scalar("tag:yaml.org,2002:str", data, style="|") + return dumper.represent_scalar("tag:yaml.org,2002:str", data) + yaml.add_representer(str, str_presenter) yaml.representer.SafeRepresenter.add_representer(str, str_presenter) @@ -43,408 +46,451 @@ yaml.representer.SafeRepresenter.add_representer(str, str_presenter) # Types class DependencyDict(TypedDict): - repo: str - branch: str - version: str - precopy: Optional[str] - postcopy: Optional[str] + repo: str + branch: str + version: str + precopy: Optional[str] + postcopy: Optional[str] + class DependencyYAML(TypedDict): - dependencies: dict[str, DependencyDict] + dependencies: dict[str, DependencyDict] + class UpdateStatus(TypedDict): - has_updates: bool - version: Optional[str] - compare_url: Optional[str] - head_ref: Optional[str] - head_url: Optional[str] + has_updates: bool + version: Optional[str] + compare_url: Optional[str] + head_ref: Optional[str] + head_url: Optional[str] class CommandRunner: - class Exception(Exception): - def __init__(self, message, returncode, stage, stdout, stderr): - super().__init__(message) - self.returncode = returncode - self.stage = stage - self.stdout = stdout - self.stderr = stderr + class Exception(Exception): + def __init__(self, message, returncode, stage, stdout, stderr): + super().__init__(message) + self.returncode = returncode + self.stage = stage + self.stdout = stdout + self.stderr = stderr - @staticmethod - def run_or_fail(command: list[str], stage: str, *args, **kwargs): - if DRY_RUN and command[0] == "gh": - command.insert(0, "echo") + @staticmethod + def run_or_fail(command: list[str], stage: str, *args, **kwargs): + if DRY_RUN and command[0] == "gh": + command.insert(0, "echo") - result = subprocess.run(command, *args, capture_output=True, **kwargs) + result = subprocess.run(command, *args, capture_output=True, **kwargs) - if result.returncode != 0: - raise CommandRunner.Exception( - f"{stage} command failed with exit code {result.returncode}", returncode=result.returncode, - stage=stage, - stdout=result.stdout.decode("utf-8"), - stderr=result.stderr.decode("utf-8") - ) + if result.returncode != 0: + raise CommandRunner.Exception( + f"{stage} command failed with exit code {result.returncode}", + returncode=result.returncode, + stage=stage, + stdout=result.stdout.decode("utf-8"), + stderr=result.stderr.decode("utf-8"), + ) - return result + return result class DependencyStore: - store: DependencyYAML = { - "dependencies": {} - } + store: DependencyYAML = {"dependencies": {}} - @staticmethod - def set(data: DependencyYAML): - DependencyStore.store = data + @staticmethod + def set(data: DependencyYAML): + DependencyStore.store = data - @staticmethod - def update_dependency_version(path: str, version: str) -> DependencyYAML: - with CodeTimer(f"store deepcopy: {path}"): - store_copy = deepcopy(DependencyStore.store) + @staticmethod + def update_dependency_version(path: str, version: str) -> DependencyYAML: + with CodeTimer(f"store deepcopy: {path}"): + store_copy = deepcopy(DependencyStore.store) - dependency = store_copy["dependencies"].get(path, {}) - dependency["version"] = version - store_copy["dependencies"][path] = dependency + dependency = store_copy["dependencies"].get(path, {}) + dependency["version"] = version + store_copy["dependencies"][path] = dependency - return store_copy + return store_copy - @staticmethod - def write_store(file: str, data: DependencyYAML): - with open(file, "w") as yaml_file: - yaml.safe_dump(data, yaml_file, sort_keys=False) + @staticmethod + def write_store(file: str, data: DependencyYAML): + with open(file, "w") as yaml_file: + yaml.safe_dump(data, yaml_file, sort_keys=False) class Dependency: - def __init__(self, path: str, values: DependencyDict): - self.path = path - self.values = values + def __init__(self, path: str, values: DependencyDict): + self.path = path + self.values = values - self.name: str = "" - self.desc: str = "" - self.kind: str = "" + self.name: str = "" + self.desc: str = "" + self.kind: str = "" - match path.split("/"): - case ["plugins", name]: - self.name = name - self.kind = "plugin" - self.desc = f"{name} plugin" - case ["themes", name]: - self.name = name.replace(".zsh-theme", "") - self.kind = "theme" - self.desc = f"{self.name} theme" - case _: - self.name = self.desc = path + match path.split("/"): + case ["plugins", name]: + self.name = name + self.kind = "plugin" + self.desc = f"{name} plugin" + case ["themes", name]: + self.name = name.replace(".zsh-theme", "") + self.kind = "theme" + self.desc = f"{self.name} theme" + case _: + self.name = self.desc = path - def __str__(self): - output: str = "" - for key in DependencyDict.__dict__['__annotations__'].keys(): - if key not in self.values: - output += f"{key}: None\n" - continue + def __str__(self): + output: str = "" + for key in DependencyDict.__dict__["__annotations__"].keys(): + if key not in self.values: + output += f"{key}: None\n" + continue - value = self.values[key] - if "\n" not in value: - output += f"{key}: {value}\n" - else: - output += f"{key}:\n " - output += value.replace("\n", "\n ", value.count("\n") - 1) - return output + value = self.values[key] + if "\n" not in value: + output += f"{key}: {value}\n" + else: + output += f"{key}:\n " + output += value.replace("\n", "\n ", value.count("\n") - 1) + return output - def update_or_notify(self): - # Print dependency settings - print(f"Processing {self.desc}...", file=sys.stderr) - print(self, file=sys.stderr) + def update_or_notify(self): + # Print dependency settings + print(f"Processing {self.desc}...", file=sys.stderr) + print(self, file=sys.stderr) - # Check for updates - repo = self.values["repo"] - remote_branch = self.values["branch"] - version = self.values["version"] - is_tag = version.startswith("tag:") - - try: - with CodeTimer(f"update check: {repo}"): - if is_tag: - status = GitHub.check_newer_tag(repo, version.replace("tag:", "")) - else: - status = GitHub.check_updates(repo, remote_branch, version) - - if status["has_updates"]: - short_sha = status["head_ref"][:8] - new_version = status["version"] if is_tag else short_sha + # Check for updates + repo = self.values["repo"] + remote_branch = self.values["branch"] + version = self.values["version"] + is_tag = version.startswith("tag:") try: - # Create new branch - branch = Git.create_branch(self.path, new_version) + with CodeTimer(f"update check: {repo}"): + if is_tag: + status = GitHub.check_newer_tag(repo, version.replace("tag:", "")) + else: + status = GitHub.check_updates(repo, remote_branch, version) - # Update dependencies.yml file - self.__update_yaml(f"tag:{new_version}" if is_tag else status["version"]) + if status["has_updates"]: + short_sha = status["head_ref"][:8] + new_version = status["version"] if is_tag else short_sha - # Update dependency files - self.__apply_upstream_changes() + try: + # Create new branch + branch = Git.create_branch(self.path, new_version) - # Add all changes and commit - Git.add_and_commit(self.name, short_sha) + # Update dependencies.yml file + self.__update_yaml( + f"tag:{new_version}" if is_tag else status["version"] + ) - # Push changes to remote - Git.push(branch) + # Update dependency files + self.__apply_upstream_changes() - # Create GitHub PR - GitHub.create_pr( - branch, - f"feat({self.name}): update to version {new_version}", - f"""## Description + # Add all changes and commit + Git.add_and_commit(self.name, short_sha) + + # Push changes to remote + Git.push(branch) + + # Create GitHub PR + GitHub.create_pr( + branch, + f"feat({self.name}): update to version {new_version}", + f"""## Description Update for **{self.desc}**: update to version [{new_version}]({status['head_url']}). Check out the [list of changes]({status['compare_url']}). -""" - ) +""", + ) - # Clean up repository - Git.clean_repo() - except (CommandRunner.Exception, shutil.Error) as e: - # Handle exception on automatic update - match type(e): - case CommandRunner.Exception: - # Print error message - print(f"Error running {e.stage} command: {e.returncode}", file=sys.stderr) - print(e.stderr, file=sys.stderr) - case shutil.Error: - print(f"Error copying files: {e}", file=sys.stderr) + # Clean up repository + Git.clean_repo() + except (CommandRunner.Exception, shutil.Error) as e: + # Handle exception on automatic update + match type(e): + case CommandRunner.Exception: + # Print error message + print( + f"Error running {e.stage} command: {e.returncode}", + file=sys.stderr, + ) + print(e.stderr, file=sys.stderr) + case shutil.Error: + print(f"Error copying files: {e}", file=sys.stderr) - try: - Git.clean_repo() - except CommandRunner.Exception as e: - print(f"Error reverting repository to clean state: {e}", file=sys.stderr) - sys.exit(1) + try: + Git.clean_repo() + except CommandRunner.Exception as e: + print( + f"Error reverting repository to clean state: {e}", + file=sys.stderr, + ) + sys.exit(1) - # Create a GitHub issue to notify maintainer - title = f"{self.path}: update to {new_version}" - body = ( - f"""## Description + # Create a GitHub issue to notify maintainer + title = f"{self.path}: update to {new_version}" + body = f"""## Description There is a new version of `{self.name}` {self.kind} available. New version: [{new_version}]({status['head_url']}) Check out the [list of changes]({status['compare_url']}). """ - ) - print(f"Creating GitHub issue", file=sys.stderr) - print(f"{title}\n\n{body}", file=sys.stderr) - GitHub.create_issue(title, body) - except Exception as e: - print(e, file=sys.stderr) + print("Creating GitHub issue", file=sys.stderr) + print(f"{title}\n\n{body}", file=sys.stderr) + GitHub.create_issue(title, body) + except Exception as e: + print(e, file=sys.stderr) - def __update_yaml(self, new_version: str) -> None: - dep_yaml = DependencyStore.update_dependency_version(self.path, new_version) - DependencyStore.write_store(DEPS_YAML_FILE, dep_yaml) + def __update_yaml(self, new_version: str) -> None: + dep_yaml = DependencyStore.update_dependency_version(self.path, new_version) + DependencyStore.write_store(DEPS_YAML_FILE, dep_yaml) - def __apply_upstream_changes(self) -> None: - # Patterns to ignore in copying files from upstream repo - GLOBAL_IGNORE = [ - ".git", - ".github", - ".gitignore" - ] + def __apply_upstream_changes(self) -> None: + # Patterns to ignore in copying files from upstream repo + GLOBAL_IGNORE = [".git", ".github", ".gitignore"] - path = os.path.abspath(self.path) - precopy = self.values.get("precopy") - postcopy = self.values.get("postcopy") + path = os.path.abspath(self.path) + precopy = self.values.get("precopy") + postcopy = self.values.get("postcopy") - repo = self.values["repo"] - branch = self.values["branch"] - remote_url = f"https://github.com/{repo}.git" - repo_dir = os.path.join(TMP_DIR, repo) + repo = self.values["repo"] + branch = self.values["branch"] + remote_url = f"https://github.com/{repo}.git" + repo_dir = os.path.join(TMP_DIR, repo) - # Clone repository - Git.clone(remote_url, branch, repo_dir, reclone=True) + # Clone repository + Git.clone(remote_url, branch, repo_dir, reclone=True) - # Run precopy on tmp repo - if precopy is not None: - print("Running precopy script:", end="\n ", file=sys.stderr) - print(precopy.replace("\n", "\n ", precopy.count("\n") - 1), file=sys.stderr) - CommandRunner.run_or_fail(["bash", "-c", precopy], cwd=repo_dir, stage="Precopy") + # Run precopy on tmp repo + if precopy is not None: + print("Running precopy script:", end="\n ", file=sys.stderr) + print( + precopy.replace("\n", "\n ", precopy.count("\n") - 1), file=sys.stderr + ) + CommandRunner.run_or_fail( + ["bash", "-c", precopy], cwd=repo_dir, stage="Precopy" + ) - # Copy files from upstream repo - print(f"Copying files from {repo_dir} to {path}", file=sys.stderr) - shutil.copytree(repo_dir, path, dirs_exist_ok=True, ignore=shutil.ignore_patterns(*GLOBAL_IGNORE)) + # Copy files from upstream repo + print(f"Copying files from {repo_dir} to {path}", file=sys.stderr) + shutil.copytree( + repo_dir, + path, + dirs_exist_ok=True, + ignore=shutil.ignore_patterns(*GLOBAL_IGNORE), + ) - # Run postcopy on our repository - if postcopy is not None: - print("Running postcopy script:", end="\n ", file=sys.stderr) - print(postcopy.replace("\n", "\n ", postcopy.count("\n") - 1), file=sys.stderr) - CommandRunner.run_or_fail(["bash", "-c", postcopy], cwd=path, stage="Postcopy") + # Run postcopy on our repository + if postcopy is not None: + print("Running postcopy script:", end="\n ", file=sys.stderr) + print( + postcopy.replace("\n", "\n ", postcopy.count("\n") - 1), + file=sys.stderr, + ) + CommandRunner.run_or_fail( + ["bash", "-c", postcopy], cwd=path, stage="Postcopy" + ) class Git: - default_branch = "master" + default_branch = "master" - @staticmethod - def clone(remote_url: str, branch: str, repo_dir: str, reclone=False): - # If repo needs to be fresh - if reclone and os.path.exists(repo_dir): - shutil.rmtree(repo_dir) + @staticmethod + def clone(remote_url: str, branch: str, repo_dir: str, reclone=False): + # If repo needs to be fresh + if reclone and os.path.exists(repo_dir): + shutil.rmtree(repo_dir) - # Clone repo in tmp directory and checkout branch - if not os.path.exists(repo_dir): - print(f"Cloning {remote_url} to {repo_dir} and checking out {branch}", file=sys.stderr) - CommandRunner.run_or_fail(["git", "clone", "--depth=1", "-b", branch, remote_url, repo_dir], stage="Clone") + # Clone repo in tmp directory and checkout branch + if not os.path.exists(repo_dir): + print( + f"Cloning {remote_url} to {repo_dir} and checking out {branch}", + file=sys.stderr, + ) + CommandRunner.run_or_fail( + ["git", "clone", "--depth=1", "-b", branch, remote_url, repo_dir], + stage="Clone", + ) - @staticmethod - def create_branch(path: str, version: str): - # Get current branch name - result = CommandRunner.run_or_fail(["git", "rev-parse", "--abbrev-ref", "HEAD"], stage="GetDefaultBranch") - Git.default_branch = result.stdout.decode("utf-8").strip() + @staticmethod + def create_branch(path: str, version: str): + # Get current branch name + result = CommandRunner.run_or_fail( + ["git", "rev-parse", "--abbrev-ref", "HEAD"], stage="GetDefaultBranch" + ) + Git.default_branch = result.stdout.decode("utf-8").strip() - # Create new branch and return created branch name - branch_name = f"update/{path}/{version}" - CommandRunner.run_or_fail(["git", "checkout", "-b", branch_name], stage="CreateBranch") - return branch_name + # Create new branch and return created branch name + branch_name = f"update/{path}/{version}" + CommandRunner.run_or_fail( + ["git", "checkout", "-b", branch_name], stage="CreateBranch" + ) + return branch_name - @staticmethod - def add_and_commit(scope: str, version: str): - user_name = os.environ.get("GIT_APP_NAME") - user_email = os.environ.get("GIT_APP_EMAIL") + @staticmethod + def add_and_commit(scope: str, version: str): + user_name = os.environ.get("GIT_APP_NAME") + user_email = os.environ.get("GIT_APP_EMAIL") - # Add all files to git staging - CommandRunner.run_or_fail(["git", "add", "-A", "-v"], stage="AddFiles") + # Add all files to git staging + CommandRunner.run_or_fail(["git", "add", "-A", "-v"], stage="AddFiles") - # Reset environment and git config - clean_env = os.environ.copy() - clean_env["LANG"]="C.UTF-8" - clean_env["GIT_CONFIG_GLOBAL"]="/dev/null" - clean_env["GIT_CONFIG_NOSYSTEM"]="1" + # Reset environment and git config + clean_env = os.environ.copy() + clean_env["LANG"] = "C.UTF-8" + clean_env["GIT_CONFIG_GLOBAL"] = "/dev/null" + clean_env["GIT_CONFIG_NOSYSTEM"] = "1" - # Commit with settings above - CommandRunner.run_or_fail([ - "git", - "-c", f"user.name={user_name}", - "-c", f"user.email={user_email}", - "commit", - "-m", f"feat({scope}): update to {version}" - ], stage="CreateCommit", env=clean_env) + # Commit with settings above + CommandRunner.run_or_fail( + [ + "git", + "-c", + f"user.name={user_name}", + "-c", + f"user.email={user_email}", + "commit", + "-m", + f"feat({scope}): update to {version}", + ], + stage="CreateCommit", + env=clean_env, + ) - @staticmethod - def push(branch: str): - CommandRunner.run_or_fail(["git", "push", "-u", "origin", branch], stage="PushBranch") + @staticmethod + def push(branch: str): + CommandRunner.run_or_fail( + ["git", "push", "-u", "origin", branch], stage="PushBranch" + ) - @staticmethod - def clean_repo(): - CommandRunner.run_or_fail(["git", "reset", "--hard", "HEAD"], stage="ResetRepository") - CommandRunner.run_or_fail(["git", "checkout", Git.default_branch], stage="CheckoutDefaultBranch") + @staticmethod + def clean_repo(): + CommandRunner.run_or_fail( + ["git", "reset", "--hard", "HEAD"], stage="ResetRepository" + ) + CommandRunner.run_or_fail( + ["git", "checkout", Git.default_branch], stage="CheckoutDefaultBranch" + ) class GitHub: - @staticmethod - def check_newer_tag(repo, current_tag) -> UpdateStatus: - # GET /repos/:owner/:repo/git/refs/tags - url = f"https://api.github.com/repos/{repo}/git/refs/tags" + @staticmethod + def check_newer_tag(repo, current_tag) -> UpdateStatus: + # GET /repos/:owner/:repo/git/refs/tags + url = f"https://api.github.com/repos/{repo}/git/refs/tags" - # Send a GET request to the GitHub API - response = requests.get(url) + # Send a GET request to the GitHub API + response = requests.get(url) - # If the request was successful - if response.status_code == 200: - # Parse the JSON response - data = response.json() + # If the request was successful + if response.status_code == 200: + # Parse the JSON response + data = response.json() - if len(data) == 0: - return { - "has_updates": False, - } + if len(data) == 0: + return { + "has_updates": False, + } - latest_ref = data[-1] - latest_tag = latest_ref["ref"].replace("refs/tags/", "") + latest_ref = data[-1] + latest_tag = latest_ref["ref"].replace("refs/tags/", "") - if latest_tag == current_tag: - return { - "has_updates": False, - } + if latest_tag == current_tag: + return { + "has_updates": False, + } - return { - "has_updates": True, - "version": latest_tag, - "compare_url": f"https://github.com/{repo}/compare/{current_tag}...{latest_tag}", - "head_ref": latest_ref["object"]["sha"], - "head_url": f"https://github.com/{repo}/releases/tag/{latest_tag}", - } - else: - # If the request was not successful, raise an exception - raise Exception(f"GitHub API request failed with status code {response.status_code}: {response.json()}") + return { + "has_updates": True, + "version": latest_tag, + "compare_url": f"https://github.com/{repo}/compare/{current_tag}...{latest_tag}", + "head_ref": latest_ref["object"]["sha"], + "head_url": f"https://github.com/{repo}/releases/tag/{latest_tag}", + } + else: + # If the request was not successful, raise an exception + raise Exception( + f"GitHub API request failed with status code {response.status_code}: {response.json()}" + ) - @staticmethod - def check_updates(repo, branch, version) -> UpdateStatus: - # TODO: add support for semver updating (based on tags) - # Check if upstream github repo has a new version - # GitHub API URL for comparing two commits - url = f"https://api.github.com/repos/{repo}/compare/{version}...{branch}" + @staticmethod + def check_updates(repo, branch, version) -> UpdateStatus: + # TODO: add support for semver updating (based on tags) + # Check if upstream github repo has a new version + # GitHub API URL for comparing two commits + url = f"https://api.github.com/repos/{repo}/compare/{version}...{branch}" - # Send a GET request to the GitHub API - response = requests.get(url) + # Send a GET request to the GitHub API + response = requests.get(url) - # If the request was successful - if response.status_code == 200: - # Parse the JSON response - data = response.json() + # If the request was successful + if response.status_code == 200: + # Parse the JSON response + data = response.json() - # If the base is behind the head, there is a newer version - has_updates = data["status"] != "identical" + # If the base is behind the head, there is a newer version + has_updates = data["status"] != "identical" - if not has_updates: - return { - "has_updates": False, - } + if not has_updates: + return { + "has_updates": False, + } - return { - "has_updates": data["status"] != "identical", - "version": data["commits"][-1]["sha"], - "compare_url": data["permalink_url"], - "head_ref": data["commits"][-1]["sha"], - "head_url": data["commits"][-1]["html_url"] - } - else: - # If the request was not successful, raise an exception - raise Exception(f"GitHub API request failed with status code {response.status_code}: {response.json()}") + return { + "has_updates": data["status"] != "identical", + "version": data["commits"][-1]["sha"], + "compare_url": data["permalink_url"], + "head_ref": data["commits"][-1]["sha"], + "head_url": data["commits"][-1]["html_url"], + } + else: + # If the request was not successful, raise an exception + raise Exception( + f"GitHub API request failed with status code {response.status_code}: {response.json()}" + ) - @staticmethod - def create_issue(title: str, body: str) -> None: - cmd = [ - "gh", - "issue", - "create", - "-t", title, - "-b", body - ] - CommandRunner.run_or_fail(cmd, stage="CreateIssue") + @staticmethod + def create_issue(title: str, body: str) -> None: + cmd = ["gh", "issue", "create", "-t", title, "-b", body] + CommandRunner.run_or_fail(cmd, stage="CreateIssue") - @staticmethod - def create_pr(branch: str, title: str, body: str) -> None: - cmd = [ - "gh", - "pr", - "create", - "-B", Git.default_branch, - "-H", branch, - "-t", title, - "-b", body - ] - CommandRunner.run_or_fail(cmd, stage="CreatePullRequest") + @staticmethod + def create_pr(branch: str, title: str, body: str) -> None: + cmd = [ + "gh", + "pr", + "create", + "-B", + Git.default_branch, + "-H", + branch, + "-t", + title, + "-b", + body, + ] + CommandRunner.run_or_fail(cmd, stage="CreatePullRequest") def main(): - # Load the YAML file - with open(DEPS_YAML_FILE, "r") as yaml_file: - data: DependencyYAML = yaml.safe_load(yaml_file) + # Load the YAML file + with open(DEPS_YAML_FILE, "r") as yaml_file: + data: DependencyYAML = yaml.safe_load(yaml_file) - if "dependencies" not in data: - raise Exception(f"dependencies.yml not properly formatted") + if "dependencies" not in data: + raise Exception("dependencies.yml not properly formatted") - # Cache YAML version - DependencyStore.set(data) + # Cache YAML version + DependencyStore.set(data) + + dependencies = data["dependencies"] + for path in dependencies: + dependency = Dependency(path, dependencies[path]) + dependency.update_or_notify() - dependencies = data["dependencies"] - for path in dependencies: - dependency = Dependency(path, dependencies[path]) - dependency.update_or_notify() if __name__ == "__main__": - main() + main() From a258eb4547e610899162526f754ce1bf88027112 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Thu, 9 May 2024 18:27:01 +0200 Subject: [PATCH 605/672] fix(dependencies): improve typing --- .github/workflows/dependencies/updater.py | 36 +++++++++++++---------- 1 file changed, 21 insertions(+), 15 deletions(-) diff --git a/.github/workflows/dependencies/updater.py b/.github/workflows/dependencies/updater.py index 765cb26fe..9754cdf83 100644 --- a/.github/workflows/dependencies/updater.py +++ b/.github/workflows/dependencies/updater.py @@ -4,7 +4,7 @@ import subprocess import sys import timeit from copy import deepcopy -from typing import Optional, TypedDict +from typing import Literal, NotRequired, TypedDict import requests import yaml @@ -49,20 +49,24 @@ class DependencyDict(TypedDict): repo: str branch: str version: str - precopy: Optional[str] - postcopy: Optional[str] + precopy: NotRequired[str] + postcopy: NotRequired[str] class DependencyYAML(TypedDict): dependencies: dict[str, DependencyDict] -class UpdateStatus(TypedDict): - has_updates: bool - version: Optional[str] - compare_url: Optional[str] - head_ref: Optional[str] - head_url: Optional[str] +class UpdateStatusFalse(TypedDict): + has_updates: Literal[False] + + +class UpdateStatusTrue(TypedDict): + has_updates: Literal[True] + version: str + compare_url: str + head_ref: str + head_url: str class CommandRunner: @@ -105,7 +109,9 @@ class DependencyStore: with CodeTimer(f"store deepcopy: {path}"): store_copy = deepcopy(DependencyStore.store) - dependency = store_copy["dependencies"].get(path, {}) + dependency = store_copy["dependencies"].get(path) + if dependency is None: + raise ValueError(f"Dependency {path} {version} not found") dependency["version"] = version store_copy["dependencies"][path] = dependency @@ -171,7 +177,7 @@ class Dependency: else: status = GitHub.check_updates(repo, remote_branch, version) - if status["has_updates"]: + if status["has_updates"] is True: short_sha = status["head_ref"][:8] new_version = status["version"] if is_tag else short_sha @@ -212,10 +218,10 @@ Check out the [list of changes]({status['compare_url']}). case CommandRunner.Exception: # Print error message print( - f"Error running {e.stage} command: {e.returncode}", + f"Error running {e.stage} command: {e.returncode}", # pyright: ignore[reportAttributeAccessIssue] file=sys.stderr, ) - print(e.stderr, file=sys.stderr) + print(e.stderr, file=sys.stderr) # pyright: ignore[reportAttributeAccessIssue] case shutil.Error: print(f"Error copying files: {e}", file=sys.stderr) @@ -378,7 +384,7 @@ class Git: class GitHub: @staticmethod - def check_newer_tag(repo, current_tag) -> UpdateStatus: + def check_newer_tag(repo, current_tag) -> UpdateStatusFalse | UpdateStatusTrue: # GET /repos/:owner/:repo/git/refs/tags url = f"https://api.github.com/repos/{repo}/git/refs/tags" @@ -417,7 +423,7 @@ class GitHub: ) @staticmethod - def check_updates(repo, branch, version) -> UpdateStatus: + def check_updates(repo, branch, version) -> UpdateStatusFalse | UpdateStatusTrue: # TODO: add support for semver updating (based on tags) # Check if upstream github repo has a new version # GitHub API URL for comparing two commits From 423b9a8ded10b0d4a81d6134c4045d0b7e077eb5 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Thu, 9 May 2024 19:20:11 +0200 Subject: [PATCH 606/672] feat(dependencies): add support for semver tags --- .../workflows/dependencies/requirements.txt | 1 + .github/workflows/dependencies/updater.py | 62 +++++++++++++++++-- 2 files changed, 57 insertions(+), 6 deletions(-) diff --git a/.github/workflows/dependencies/requirements.txt b/.github/workflows/dependencies/requirements.txt index 0ef3e54ca..7e840a74c 100644 --- a/.github/workflows/dependencies/requirements.txt +++ b/.github/workflows/dependencies/requirements.txt @@ -3,4 +3,5 @@ charset-normalizer==3.3.2 idna==3.7 PyYAML==6.0.1 requests==2.31.0 +semver==3.0.2 urllib3==2.2.1 diff --git a/.github/workflows/dependencies/updater.py b/.github/workflows/dependencies/updater.py index 9754cdf83..7e8e92ca9 100644 --- a/.github/workflows/dependencies/updater.py +++ b/.github/workflows/dependencies/updater.py @@ -1,13 +1,15 @@ import os +import re import shutil import subprocess import sys import timeit from copy import deepcopy -from typing import Literal, NotRequired, TypedDict +from typing import Literal, NotRequired, Optional, TypedDict import requests import yaml +from semver import Version # Get TMP_DIR variable from environment TMP_DIR = os.path.join(os.environ.get("TMP_DIR", "/tmp"), "ohmyzsh") @@ -16,6 +18,35 @@ DEPS_YAML_FILE = ".github/dependencies.yml" # Dry run flag DRY_RUN = os.environ.get("DRY_RUN", "0") == "1" +# utils for tag comparison +BASEVERSION = re.compile( + r"""[vV]? + (?P(0|[1-9])\d*) + (\. + (?P(0|[1-9])\d*) + (\. + (?P(0|[1-9])\d*) + )? + )? + """, + re.VERBOSE, +) + + +def coerce(version: str) -> Optional[Version]: + match = BASEVERSION.search(version) + if not match: + return None + + # BASEVERSION looks for `MAJOR.minor.patch` in the string given + # it fills with None if any of them is missing (for example `2.1`) + ver = { + key: 0 if value is None else value for key, value in match.groupdict().items() + } + # Version takes `major`, `minor`, `patch` arguments + ver = Version(**ver) # pyright: ignore[reportArgumentType] + return ver + class CodeTimer: def __init__(self, name=None): @@ -390,6 +421,11 @@ class GitHub: # Send a GET request to the GitHub API response = requests.get(url) + current_version = coerce(current_tag) + if current_version is None: + raise ValueError( + f"Stored {current_version} from {repo} does not follow semver" + ) # If the request was successful if response.status_code == 200: @@ -401,10 +437,27 @@ class GitHub: "has_updates": False, } - latest_ref = data[-1] + latest_ref = None + latest_version: Optional[Version] = None + for ref in data: + # we find the tag since GitHub returns it as plain git ref + tag_version = coerce(ref["ref"].replace("refs/tags/", "")) + if tag_version is None: + # we skip every tag that is not semver-complaint + continue + if latest_version is None or tag_version.compare(latest_version) > 0: + # if we have a "greater" semver version, set it as latest + latest_version = tag_version + latest_ref = ref + + # raise if no valid semver tag is found + if latest_ref is None or latest_version is None: + raise ValueError(f"No tags following semver found in {repo}") + + # we get the tag since GitHub returns it as plain git ref latest_tag = latest_ref["ref"].replace("refs/tags/", "") - if latest_tag == current_tag: + if latest_version.compare(current_version) <= 0: return { "has_updates": False, } @@ -424,9 +477,6 @@ class GitHub: @staticmethod def check_updates(repo, branch, version) -> UpdateStatusFalse | UpdateStatusTrue: - # TODO: add support for semver updating (based on tags) - # Check if upstream github repo has a new version - # GitHub API URL for comparing two commits url = f"https://api.github.com/repos/{repo}/compare/{version}...{branch}" # Send a GET request to the GitHub API From eb2ff84a2c8ae45b90d36e367c6bd6bc01f8464d Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Thu, 9 May 2024 19:52:50 +0200 Subject: [PATCH 607/672] fix(dependencies): avoid creating PR if it's already there --- .github/workflows/dependencies/updater.py | 42 +++++++++++++++++++---- 1 file changed, 36 insertions(+), 6 deletions(-) diff --git a/.github/workflows/dependencies/updater.py b/.github/workflows/dependencies/updater.py index 7e8e92ca9..6fa32e378 100644 --- a/.github/workflows/dependencies/updater.py +++ b/.github/workflows/dependencies/updater.py @@ -1,3 +1,4 @@ +import json import os import re import shutil @@ -213,8 +214,10 @@ class Dependency: new_version = status["version"] if is_tag else short_sha try: + branch_name = f"update/{self.path}/{new_version}" + # Create new branch - branch = Git.create_branch(self.path, new_version) + branch = Git.checkout_or_create_branch(branch_name) # Update dependencies.yml file self.__update_yaml( @@ -353,7 +356,7 @@ class Git: ) @staticmethod - def create_branch(path: str, version: str): + def checkout_or_create_branch(branch_name: str): # Get current branch name result = CommandRunner.run_or_fail( ["git", "rev-parse", "--abbrev-ref", "HEAD"], stage="GetDefaultBranch" @@ -361,10 +364,16 @@ class Git: Git.default_branch = result.stdout.decode("utf-8").strip() # Create new branch and return created branch name - branch_name = f"update/{path}/{version}" - CommandRunner.run_or_fail( - ["git", "checkout", "-b", branch_name], stage="CreateBranch" - ) + try: + # try to checkout already existing branch + CommandRunner.run_or_fail( + ["git", "checkout", branch_name], stage="CreateBranch" + ) + except CommandRunner.Exception: + # otherwise create new branch + CommandRunner.run_or_fail( + ["git", "checkout", "-b", branch_name], stage="CreateBranch" + ) return branch_name @staticmethod @@ -515,6 +524,27 @@ class GitHub: @staticmethod def create_pr(branch: str, title: str, body: str) -> None: + # first of all let's check if PR is already open + check_cmd = [ + "gh", + "pr", + "list", + "--state", + "open", + "--head", + branch, + "--json", + "title", + ] + # returncode is 0 also if no PRs are found + output = json.loads( + CommandRunner.run_or_fail(check_cmd, stage="CheckPullRequestOpen") + .stdout.decode("utf-8") + .strip() + ) + # we have PR in this case! + if len(output) > 0: + return cmd = [ "gh", "pr", From eff648aab021df0407dcd86126d2ab9db950d0f2 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Thu, 9 May 2024 17:41:59 +0200 Subject: [PATCH 608/672] ci(dependencies): use `setup-python` and enable cron-based jobs --- .github/workflows/dependencies.yml | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/.github/workflows/dependencies.yml b/.github/workflows/dependencies.yml index 2e2217e1c..fce666e4c 100644 --- a/.github/workflows/dependencies.yml +++ b/.github/workflows/dependencies.yml @@ -1,8 +1,8 @@ name: Update dependencies on: workflow_dispatch: {} - # schedule: - # - cron: '34 3 * * */8' + schedule: + - cron: '34 3 * * */8' jobs: check: @@ -18,6 +18,11 @@ jobs: with: app_id: ${{ secrets.OHMYZSH_APP_ID }} private_key: ${{ secrets.OHMYZSH_APP_PRIVATE_KEY }} + - name: Setup Python + uses: actions/setup-python@v5 + with: + python-version: "3.12" + cache: "pip" - name: Process dependencies env: GH_TOKEN: ${{ steps.generate_token.outputs.token }} From 1d31ff603706007e69aefe2c9ca198658e35b5dc Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Sun, 12 May 2024 12:30:22 +0200 Subject: [PATCH 609/672] ci(dependencies): fetch all branches --- .github/workflows/dependencies.yml | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/.github/workflows/dependencies.yml b/.github/workflows/dependencies.yml index fce666e4c..6bc8dc74d 100644 --- a/.github/workflows/dependencies.yml +++ b/.github/workflows/dependencies.yml @@ -2,7 +2,7 @@ name: Update dependencies on: workflow_dispatch: {} schedule: - - cron: '34 3 * * */8' + - cron: "34 3 * * */8" jobs: check: @@ -12,6 +12,8 @@ jobs: steps: - name: Checkout uses: actions/checkout@v4 + with: + fetch-depth: 0 - name: Authenticate as @ohmyzsh id: generate_token uses: ohmyzsh/github-app-token@v2 From 0493eab8ce02c4988a16cbe27ad61a20ed8a89df Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Sun, 12 May 2024 12:40:45 +0200 Subject: [PATCH 610/672] fix(dependencies): check if repo is clean before committing --- .github/workflows/dependencies/updater.py | 36 +++++++++++++---------- 1 file changed, 21 insertions(+), 15 deletions(-) diff --git a/.github/workflows/dependencies/updater.py b/.github/workflows/dependencies/updater.py index 6fa32e378..4533b7aeb 100644 --- a/.github/workflows/dependencies/updater.py +++ b/.github/workflows/dependencies/updater.py @@ -390,21 +390,27 @@ class Git: clean_env["GIT_CONFIG_GLOBAL"] = "/dev/null" clean_env["GIT_CONFIG_NOSYSTEM"] = "1" - # Commit with settings above - CommandRunner.run_or_fail( - [ - "git", - "-c", - f"user.name={user_name}", - "-c", - f"user.email={user_email}", - "commit", - "-m", - f"feat({scope}): update to {version}", - ], - stage="CreateCommit", - env=clean_env, - ) + # check if repo is clean (clean => no error, no commit) + try: + CommandRunner.run_or_fail( + ["git", "diff", "--exit-code"], stage="CheckRepoClean", env=clean_env + ) + except CommandRunner.Exception: + # Commit with settings above + CommandRunner.run_or_fail( + [ + "git", + "-c", + f"user.name={user_name}", + "-c", + f"user.email={user_email}", + "commit", + "-m", + f"feat({scope}): update to {version}", + ], + stage="CreateCommit", + env=clean_env, + ) @staticmethod def push(branch: str): From b1c5315a5fbc33624525e434ddbaec3bb30030e2 Mon Sep 17 00:00:00 2001 From: "ohmyzsh[bot]" <54982679+ohmyzsh[bot]@users.noreply.github.com> Date: Sun, 12 May 2024 12:42:59 +0200 Subject: [PATCH 611/672] feat(wd): update to version v0.6.1 (#12413) Co-authored-by: ohmyzsh[bot] <54982679+ohmyzsh[bot]@users.noreply.github.com> --- .github/dependencies.yml | 2 +- plugins/wd/README.md | 28 +++++++++++++++++++++++++++- plugins/wd/wd.plugin.zsh | 7 ++++++- plugins/wd/wd.sh | 37 +++++++++++++++++++++++++++++-------- 4 files changed, 63 insertions(+), 11 deletions(-) mode change 100644 => 100755 plugins/wd/wd.sh diff --git a/.github/dependencies.yml b/.github/dependencies.yml index a105f440d..6ae97ad4e 100644 --- a/.github/dependencies.yml +++ b/.github/dependencies.yml @@ -39,7 +39,7 @@ dependencies: plugins/wd: repo: mfaerevaag/wd branch: master - version: tag:v0.6.0 + version: tag:v0.6.1 precopy: | set -e rm -r test diff --git a/plugins/wd/README.md b/plugins/wd/README.md index 0ad74e805..0c71c0565 100644 --- a/plugins/wd/README.md +++ b/plugins/wd/README.md @@ -57,6 +57,24 @@ wd() { } ``` +### [Home Manager](https://github.com/nix-community/home-manager) + +Add the following to your `home.nix` then run `home-manager switch`: + +```nix +programs.zsh.plugins = [ + { + name = "wd"; + src = pkgs.fetchFromGitHub { + owner = "mfaerevaag"; + repo = "wd"; + rev = "v0.5.2"; + sha256 = "sha256-4yJ1qhqhNULbQmt6Z9G22gURfDLe30uV1ascbzqgdhg="; + }; + } +]; +``` + ### [zplug](https://github.com/zplug/zplug) ```zsh @@ -119,6 +137,14 @@ Also, you may have to force a rebuild of `zcompdump` by running: rm -f ~/.zcompdump; compinit ``` +## Browse + +If you want to make use of the `fzf`-powered browse feature to fuzzy search through all your warp points, set up a keybind in your `.zshrc`: + +```zsh +bindkey '^G' wd_browse +``` + ## Usage * Add warp point to current working directory: @@ -153,7 +179,7 @@ wd .. wd ... ``` -This is a wrapper for the zsh's `dirs` function. +This is a wrapper for the zsh's `dirs` function. _You might need to add `setopt AUTO_PUSHD` to your `.zshrc` if you are not using [oh-my-zsh](https://github.com/ohmyzsh/ohmyzsh)._ * Remove warp point: diff --git a/plugins/wd/wd.plugin.zsh b/plugins/wd/wd.plugin.zsh index ca2ca7c65..9e0c7ff13 100644 --- a/plugins/wd/wd.plugin.zsh +++ b/plugins/wd/wd.plugin.zsh @@ -8,8 +8,13 @@ # @github.com/mfaerevaag/wd # Handle $0 according to the standard: -# https://zdharma-continuum.github.io/Zsh-100-Commits-Club/Zsh-Plugin-Standard.html +# # https://zdharma-continuum.github.io/Zsh-100-Commits-Club/Zsh-Plugin-Standard.html 0="${${ZERO:-${0:#$ZSH_ARGZERO}}:-${(%):-%N}}" 0="${${(M)0:#/*}:-$PWD/$0}" eval "wd() { source '${0:A:h}/wd.sh' }" +wd > /dev/null +# Register the function as a Zsh widget +zle -N wd_browse +# Bind the widget to a key combination +bindkey '^G' wd_browse diff --git a/plugins/wd/wd.sh b/plugins/wd/wd.sh old mode 100644 new mode 100755 index 840e92d61..c4f422cbf --- a/plugins/wd/wd.sh +++ b/plugins/wd/wd.sh @@ -8,7 +8,7 @@ # @github.com/mfaerevaag/wd # version -readonly WD_VERSION=0.5.0 +readonly WD_VERSION=0.6.1 # colors readonly WD_BLUE="\033[96m" @@ -57,12 +57,11 @@ wd_print_msg() { if [[ -z $wd_quiet_mode ]] then - local color=$1 - local msg=$2 + local color="${1:-$WD_BLUE}" # Default to blue if no color is provided + local msg="$2" - if [[ $color == "" || $msg == "" ]] - then - print " ${WD_RED}*${WD_NOC} Could not print message. Sorry!" + if [[ -z "$msg" ]]; then + print "${WD_RED}*${WD_NOC} Could not print message. Sorry!" else print " ${color}*${WD_NOC} ${msg}" fi @@ -230,6 +229,20 @@ wd_remove() done } +wd_browse() { + if ! command -v fzf >/dev/null; then + echo "This functionality requires fzf. Please install fzf first." + return 1 + fi + local entries=("${(@f)$(sed "s:${HOME}:~:g" "$WD_CONFIG" | awk -F ':' '{print $1 " -> " $2}')}") + local selected_entry=$(printf '%s\n' "${entries[@]}" | fzf --height 40% --reverse) + if [[ -n $selected_entry ]]; then + local selected_point="${selected_entry%% ->*}" + selected_point=$(echo "$selected_point" | xargs) + wd $selected_point + fi +} + wd_list_all() { wd_print_msg "$WD_BLUE" "All warp points:" @@ -396,7 +409,9 @@ fi # disable extendedglob for the complete wd execution time setopt | grep -q extendedglob wd_extglob_is_set=$? -(( ! $wd_extglob_is_set )) && setopt noextendedglob +if (( wd_extglob_is_set == 0 )); then + setopt noextendedglob +fi # load warp points typeset -A points @@ -436,6 +451,10 @@ else wd_add "$2" "$wd_force_mode" break ;; + "-b"|"browse") + wd_browse + break + ;; "-e"|"export") wd_export_static_named_directories break @@ -484,7 +503,9 @@ fi # if not, next time warp will pick up variables from this run # remember, there's no sub shell -(( ! $wd_extglob_is_set )) && setopt extendedglob +if (( wd_extglob_is_set == 0 )); then + setopt extendedglob +fi unset wd_extglob_is_set unset wd_warp From a8a747e18abe41b26de0b892e888ad5c386abc3f Mon Sep 17 00:00:00 2001 From: Juho Kuisma Date: Wed, 15 May 2024 20:14:11 +0300 Subject: [PATCH 612/672] feat(fzf): add support for Fedora package (#12421) --- plugins/fzf/fzf.plugin.zsh | 22 ++++++++++++++++++++++ 1 file changed, 22 insertions(+) diff --git a/plugins/fzf/fzf.plugin.zsh b/plugins/fzf/fzf.plugin.zsh index 48fea4f63..e244b4cfb 100644 --- a/plugins/fzf/fzf.plugin.zsh +++ b/plugins/fzf/fzf.plugin.zsh @@ -148,6 +148,27 @@ function fzf_setup_using_opensuse() { return 0 } +function fzf_setup_using_fedora() { + (( $+commands[fzf] )) || return 1 + + local completions="/usr/share/zsh/site-functions/fzf" + local key_bindings="/usr/share/fzf/shell/key-bindings.zsh" + + if [[ ! -f "$completions" || ! -f "$key_bindings" ]]; then + return 1 + fi + + if [[ -o interactive && "$DISABLE_FZF_AUTO_COMPLETION" != "true" ]]; then + source "$completions" 2>/dev/null + fi + + if [[ "$DISABLE_FZF_KEY_BINDINGS" != "true" ]]; then + source "$key_bindings" 2>/dev/null + fi + + return 0 +} + function fzf_setup_using_openbsd() { # openBSD installs fzf in /usr/local/bin/fzf if [[ "$OSTYPE" != openbsd* ]] || (( ! $+commands[fzf] )); then @@ -234,6 +255,7 @@ fzf_setup_using_fzf \ || fzf_setup_using_openbsd \ || fzf_setup_using_debian \ || fzf_setup_using_opensuse \ + || fzf_setup_using_fedora \ || fzf_setup_using_cygwin \ || fzf_setup_using_macports \ || fzf_setup_using_base_dir \ From fb91ca27a2d65b834e98a3986cfee73ad82ea412 Mon Sep 17 00:00:00 2001 From: Fritz Reichwald Date: Wed, 15 May 2024 19:27:21 +0200 Subject: [PATCH 613/672] feat(amuse): add whitespace before virtualenv (#12423) --- themes/amuse.zsh-theme | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/themes/amuse.zsh-theme b/themes/amuse.zsh-theme index d787fdaa4..cddbcd40d 100644 --- a/themes/amuse.zsh-theme +++ b/themes/amuse.zsh-theme @@ -17,7 +17,7 @@ $ ' RPROMPT='$(ruby_prompt_info)' VIRTUAL_ENV_DISABLE_PROMPT=0 -ZSH_THEME_VIRTUAL_ENV_PROMPT_PREFIX=" %{$fg[green]%}🐍" +ZSH_THEME_VIRTUAL_ENV_PROMPT_PREFIX=" %{$fg[green]%}🐍 " ZSH_THEME_VIRTUAL_ENV_PROMPT_SUFFIX="%{$reset_color%}" ZSH_THEME_VIRTUALENV_PREFIX=$ZSH_THEME_VIRTUAL_ENV_PROMPT_PREFIX ZSH_THEME_VIRTUALENV_SUFFIX=$ZSH_THEME_VIRTUAL_ENV_PROMPT_SUFFIX From a779d6563ffb2f0093b4b74c8d5ff0982fa3e930 Mon Sep 17 00:00:00 2001 From: Alessandro Miliucci Date: Thu, 16 May 2024 22:13:36 +0200 Subject: [PATCH 614/672] chore(template): propose add `.local/bin` to PATH (#12417) --- templates/zshrc.zsh-template | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/templates/zshrc.zsh-template b/templates/zshrc.zsh-template index 7e1c7997c..a73d60799 100644 --- a/templates/zshrc.zsh-template +++ b/templates/zshrc.zsh-template @@ -1,5 +1,5 @@ # If you come from bash you might have to change your $PATH. -# export PATH=$HOME/bin:/usr/local/bin:$PATH +# export PATH=$HOME/bin:$HOME/.local/bin:/usr/local/bin:$PATH # Path to your oh-my-zsh installation. export ZSH=$HOME/.oh-my-zsh From 309129f651eeeca62c3a3b7f6817f0ac601db9f0 Mon Sep 17 00:00:00 2001 From: Daniel Ochoja <37149152+Ochoja@users.noreply.github.com> Date: Tue, 21 May 2024 19:36:07 +0100 Subject: [PATCH 615/672] feat(agnoster): add `anaconda` env information (#12434) --- themes/agnoster.zsh-theme | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/themes/agnoster.zsh-theme b/themes/agnoster.zsh-theme index c2a542163..767a4ed50 100644 --- a/themes/agnoster.zsh-theme +++ b/themes/agnoster.zsh-theme @@ -227,6 +227,14 @@ prompt_virtualenv() { fi } +# Conda Virtualenv +promp_conda_virtualenv() { + if [[ -n $CONDA_PROMPT_MODIFIER ]]; then + prompt_segment black default ${CONDA_PROMPT_MODIFIER:1:-2} + fi +} + + # Status: # - was there an error # - am I root @@ -266,6 +274,7 @@ build_prompt() { prompt_bzr prompt_hg prompt_end + promp_conda_virtualenv } PROMPT='%{%f%b%k%}$(build_prompt) ' From 0621944db50aec931850806644b673e39b650163 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Tue, 21 May 2024 20:43:26 +0200 Subject: [PATCH 616/672] fix(dependencies): only open PR if there are changes --- .github/workflows/dependencies/updater.py | 78 +++++++++++++---------- 1 file changed, 44 insertions(+), 34 deletions(-) diff --git a/.github/workflows/dependencies/updater.py b/.github/workflows/dependencies/updater.py index 4533b7aeb..e64d69939 100644 --- a/.github/workflows/dependencies/updater.py +++ b/.github/workflows/dependencies/updater.py @@ -228,21 +228,22 @@ class Dependency: self.__apply_upstream_changes() # Add all changes and commit - Git.add_and_commit(self.name, short_sha) + has_new_commit = Git.add_and_commit(self.name, short_sha) - # Push changes to remote - Git.push(branch) + if has_new_commit: + # Push changes to remote + Git.push(branch) - # Create GitHub PR - GitHub.create_pr( - branch, - f"feat({self.name}): update to version {new_version}", - f"""## Description + # Create GitHub PR + GitHub.create_pr( + branch, + f"feat({self.name}): update to version {new_version}", + f"""## Description -Update for **{self.desc}**: update to version [{new_version}]({status['head_url']}). -Check out the [list of changes]({status['compare_url']}). -""", - ) + Update for **{self.desc}**: update to version [{new_version}]({status['head_url']}). + Check out the [list of changes]({status['compare_url']}). + """, + ) # Clean up repository Git.clean_repo() @@ -377,7 +378,21 @@ class Git: return branch_name @staticmethod - def add_and_commit(scope: str, version: str): + def add_and_commit(scope: str, version: str) -> bool: + """ + Returns `True` if there were changes and were indeed commited. + Returns `False` if the repo was clean and no changes were commited. + """ + # check if repo is clean (clean => no error, no commit) + try: + CommandRunner.run_or_fail( + ["git", "diff", "--exit-code"], stage="CheckRepoClean" + ) + return False + except CommandRunner.Exception: + # if it's other kind of error just throw! + pass + user_name = os.environ.get("GIT_APP_NAME") user_email = os.environ.get("GIT_APP_EMAIL") @@ -390,27 +405,22 @@ class Git: clean_env["GIT_CONFIG_GLOBAL"] = "/dev/null" clean_env["GIT_CONFIG_NOSYSTEM"] = "1" - # check if repo is clean (clean => no error, no commit) - try: - CommandRunner.run_or_fail( - ["git", "diff", "--exit-code"], stage="CheckRepoClean", env=clean_env - ) - except CommandRunner.Exception: - # Commit with settings above - CommandRunner.run_or_fail( - [ - "git", - "-c", - f"user.name={user_name}", - "-c", - f"user.email={user_email}", - "commit", - "-m", - f"feat({scope}): update to {version}", - ], - stage="CreateCommit", - env=clean_env, - ) + # Commit with settings above + CommandRunner.run_or_fail( + [ + "git", + "-c", + f"user.name={user_name}", + "-c", + f"user.email={user_email}", + "commit", + "-m", + f"feat({scope}): update to {version}", + ], + stage="CreateCommit", + env=clean_env, + ) + return True @staticmethod def push(branch: str): From 04b66b230857fb9bc28af5e7590b09ff79f888fa Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Tue, 21 May 2024 20:46:54 +0200 Subject: [PATCH 617/672] chore(dependencies): PR wording --- .github/workflows/dependencies/updater.py | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/.github/workflows/dependencies/updater.py b/.github/workflows/dependencies/updater.py index e64d69939..f85c9eda7 100644 --- a/.github/workflows/dependencies/updater.py +++ b/.github/workflows/dependencies/updater.py @@ -240,9 +240,9 @@ class Dependency: f"feat({self.name}): update to version {new_version}", f"""## Description - Update for **{self.desc}**: update to version [{new_version}]({status['head_url']}). - Check out the [list of changes]({status['compare_url']}). - """, +Update for **{self.desc}**: update to version [{new_version}]({status['head_url']}). +Check out the [list of changes]({status['compare_url']}). +""", ) # Clean up repository From f6b3fc84d192274f245a7322c3994767c5e68691 Mon Sep 17 00:00:00 2001 From: "ohmyzsh[bot]" <54982679+ohmyzsh[bot]@users.noreply.github.com> Date: Tue, 21 May 2024 20:48:54 +0200 Subject: [PATCH 618/672] feat(wd): update to version v0.7.0 (#12436) Co-authored-by: ohmyzsh[bot] <54982679+ohmyzsh[bot]@users.noreply.github.com> --- .github/dependencies.yml | 2 +- plugins/wd/README.md | 15 ++++++- plugins/wd/_wd.sh | 4 ++ plugins/wd/wd.plugin.zsh | 9 +++-- plugins/wd/wd.sh | 87 ++++++++++++++++++++++++++++++++-------- 5 files changed, 95 insertions(+), 22 deletions(-) diff --git a/.github/dependencies.yml b/.github/dependencies.yml index 6ae97ad4e..d3b269361 100644 --- a/.github/dependencies.yml +++ b/.github/dependencies.yml @@ -39,7 +39,7 @@ dependencies: plugins/wd: repo: mfaerevaag/wd branch: master - version: tag:v0.6.1 + version: tag:v0.7.0 precopy: | set -e rm -r test diff --git a/plugins/wd/README.md b/plugins/wd/README.md index 0c71c0565..bf19031f8 100644 --- a/plugins/wd/README.md +++ b/plugins/wd/README.md @@ -142,7 +142,7 @@ rm -f ~/.zcompdump; compinit If you want to make use of the `fzf`-powered browse feature to fuzzy search through all your warp points, set up a keybind in your `.zshrc`: ```zsh -bindkey '^G' wd_browse +bindkey ${FZF_WD_BINDKEY:-'^B'} fuzzy_wd_widget ``` ## Usage @@ -158,6 +158,19 @@ If a warp point with the same name exists, use `wd add foo --force` to overwrite **Note:** a warp point cannot contain colons, or consist of only spaces and dots. The first will conflict in how `wd` stores the warp points, and the second will conflict with other features, as below. +* Add warp point to any directory with default name: + +```zsh +wd addcd /foo/ bar +``` + +* Add warp point to any directory with a custom name: + +```zsh +wd addcd /foo/ +``` + + You can omit point name to automatically use the current directory's name instead. * From any directory, warp to `foo` with: diff --git a/plugins/wd/_wd.sh b/plugins/wd/_wd.sh index 52ecb12e6..46b032f78 100644 --- a/plugins/wd/_wd.sh +++ b/plugins/wd/_wd.sh @@ -31,6 +31,7 @@ function _wd() { commands=( 'add:Adds the current working directory to your warp points' + 'addcd:Adds a directory to your warp points' 'add!:Overwrites existing warp point' 'export:Export warp points as static named directories' 'rm:Removes the given warp point' @@ -63,6 +64,9 @@ function _wd() { add) _message 'Write the name of your warp point' && ret=0 ;; + addcd) + _message 'Write the name of your path' && ret=0 + ;; show) _describe -t points "Warp points" warp_points && ret=0 ;; diff --git a/plugins/wd/wd.plugin.zsh b/plugins/wd/wd.plugin.zsh index 9e0c7ff13..9910cb968 100644 --- a/plugins/wd/wd.plugin.zsh +++ b/plugins/wd/wd.plugin.zsh @@ -14,7 +14,8 @@ eval "wd() { source '${0:A:h}/wd.sh' }" wd > /dev/null -# Register the function as a Zsh widget -zle -N wd_browse -# Bind the widget to a key combination -bindkey '^G' wd_browse +zle -N wd_browse_widget +zle -N wd_restore_buffer +autoload -Uz add-zle-hook-widget +add-zle-hook-widget line-init wd_restore_buffer +bindkey ${FZF_WD_BINDKEY:-'^B'} wd_browse_widget diff --git a/plugins/wd/wd.sh b/plugins/wd/wd.sh index c4f422cbf..160ab3be3 100755 --- a/plugins/wd/wd.sh +++ b/plugins/wd/wd.sh @@ -8,7 +8,7 @@ # @github.com/mfaerevaag/wd # version -readonly WD_VERSION=0.6.1 +readonly WD_VERSION=0.7.0 # colors readonly WD_BLUE="\033[96m" @@ -59,7 +59,7 @@ wd_print_msg() then local color="${1:-$WD_BLUE}" # Default to blue if no color is provided local msg="$2" - + if [[ -z "$msg" ]]; then print "${WD_RED}*${WD_NOC} Could not print message. Sorry!" else @@ -74,18 +74,20 @@ wd_print_usage() Usage: wd [command] [point] Commands: - Warps to the directory specified by the warp point - Warps to the directory specified by the warp point with path appended - add Adds the current working directory to your warp points - add Adds the current working directory to your warp points with current directory's name - rm Removes the given warp point - rm Removes the given warp point with current directory's name - show Print path to given warp point - show Print warp points to current directory - list Print all stored warp points - ls Show files from given warp point (ls) - path Show the path to given warp point (pwd) - clean Remove points warping to nonexistent directories (will prompt unless --force is used) + Warps to the directory specified by the warp point + Warps to the directory specified by the warp point with path appended + add Adds the current working directory to your warp points + add Adds the current working directory to your warp points with current directory's name + addcd Adds a path to your warp points with the directory's name + addcd Adds a path to your warp points with a custom name + rm Removes the given warp point + rm Removes the given warp point with current directory's name + show Print path to given warp point + show Print warp points to current directory + list Print all stored warp points + ls Show files from given warp point (ls) + path Show the path to given warp point (pwd) + clean Remove points warping to nonexistent directories (will prompt unless --force is used) -v | --version Print version -d | --debug Exit after execution with exit codes (for testing) @@ -203,6 +205,28 @@ wd_add() fi } +wd_addcd() { + local folder="$1" + local point=$2 + local force=$3 + local currentdir=$PWD + + if [[ -z "$folder" ]]; then + wd_exit_fail "You must specify a path" + return + fi + + if [[ ! -d "$folder" ]]; then + wd_exit_fail "The directory does not exist" + return + fi + + cd "$folder" || return + wd_add "$point" "$force" + cd "$currentdir" || return +} + + wd_remove() { local point_list=$1 @@ -235,7 +259,15 @@ wd_browse() { return 1 fi local entries=("${(@f)$(sed "s:${HOME}:~:g" "$WD_CONFIG" | awk -F ':' '{print $1 " -> " $2}')}") - local selected_entry=$(printf '%s\n' "${entries[@]}" | fzf --height 40% --reverse) + local script_path="${${(%):-%x}:h}" + local wd_remove_output=$(mktemp "${TMPDIR:-/tmp}/wd.XXXXXXXXXX") + local entries_with_headers=("All warp points:" "Press enter to select. Press delete to remove" "${entries[@]}") + local fzf_bind="delete:execute(echo {} | awk -F ' -> ' '{print \$1}' | xargs -I {} "$script_path/wd.sh" rm {} > "$wd_remove_output")+abort" + local fzf_command=$(printf '%s\n' "${entries_with_headers[@]}" | fzf --height 100% --reverse --header-lines=2 --bind="$fzf_bind") + if [[ -e $wd_remove_output ]]; then + cat "$wd_remove_output" + rm "$wd_remove_output" + fi if [[ -n $selected_entry ]]; then local selected_point="${selected_entry%% ->*}" selected_point=$(echo "$selected_point" | xargs) @@ -243,6 +275,24 @@ wd_browse() { fi } +wd_browse_widget() { + if [[ -e $WD_CONFIG ]]; then + wd_browse + saved_buffer=$BUFFER + saved_cursor=$CURSOR + BUFFER= + zle redisplay + zle accept-line + fi +} + +wd_restore_buffer() { + BUFFER=$saved_buffer + CURSOR=$saved_cursor + saved_buffer= + saved_cursor=1 +} + wd_list_all() { wd_print_msg "$WD_BLUE" "All warp points:" @@ -371,7 +421,7 @@ wd_export_static_named_directories() { fi } -local WD_CONFIG=${WD_CONFIG:-$HOME/.warprc} +WD_CONFIG=${WD_CONFIG:-$HOME/.warprc} local WD_QUIET=0 local WD_EXIT_CODE=0 local WD_DEBUG=0 @@ -455,6 +505,10 @@ else wd_browse break ;; + "-c"|"--addcd"|"addcd") + wd_addcd "$2" "$3" "$wd_force_mode" + break + ;; "-e"|"export") wd_export_static_named_directories break @@ -510,6 +564,7 @@ fi unset wd_extglob_is_set unset wd_warp unset wd_add +unset wd_addcd unset wd_remove unset wd_show unset wd_list_all From dfb436b54a10c84156a548dded0506d474050a43 Mon Sep 17 00:00:00 2001 From: danielwerg <35052399+danielwerg@users.noreply.github.com> Date: Tue, 21 May 2024 21:58:43 +0300 Subject: [PATCH 619/672] feat(tldr): add tldr plugin (#12429) --- plugins/tldr/README.md | 15 +++++++++++++++ plugins/tldr/tldr.plugin.zsh | 19 +++++++++++++++++++ 2 files changed, 34 insertions(+) create mode 100644 plugins/tldr/README.md create mode 100644 plugins/tldr/tldr.plugin.zsh diff --git a/plugins/tldr/README.md b/plugins/tldr/README.md new file mode 100644 index 000000000..fb91d9d1f --- /dev/null +++ b/plugins/tldr/README.md @@ -0,0 +1,15 @@ +# tldr plugin + +This plugin adds a shortcut to insert tldr before the previous command. +Heavily inspired from [Man plugin](https://github.com/ohmyzsh/ohmyzsh/tree/master/plugins/man). + +To use it, add `tldr` to the plugins array in your zshrc file: + +```zsh +plugins=(... tldr) +``` + +# Keyboard Shortcuts +| Shortcut | Description | +|------------------------------------|----------------------------------------------------------------------------| +| Esc + tldr | add tldr before the previous command to see the tldr page for this command | diff --git a/plugins/tldr/tldr.plugin.zsh b/plugins/tldr/tldr.plugin.zsh new file mode 100644 index 000000000..9f3de5f0c --- /dev/null +++ b/plugins/tldr/tldr.plugin.zsh @@ -0,0 +1,19 @@ +tldr-command-line() { + # if there is no command typed, use the last command + [[ -z "$BUFFER" ]] && zle up-history + + # if typed command begins with tldr, do nothing + [[ "$BUFFER" = tldr\ * ]] && return + + # get command and possible subcommand + # http://zsh.sourceforge.net/Doc/Release/Expansion.html#Parameter-Expansion-Flags + local -a args + args=(${${(Az)BUFFER}[1]} ${${(Az)BUFFER}[2]}) + + BUFFER="tldr ${args[1]}" +} + +zle -N tldr-command-line +# Defined shortcut keys: [Esc]tldr +bindkey "\e"tldr tldr-command-line + From bbfb9853591312c180a0c417226e4ef899d4cf3a Mon Sep 17 00:00:00 2001 From: robinverduijn Date: Tue, 21 May 2024 22:39:12 -0700 Subject: [PATCH 620/672] chore(agnoster): typo (#12437) --- themes/agnoster.zsh-theme | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/themes/agnoster.zsh-theme b/themes/agnoster.zsh-theme index 767a4ed50..4445ad4a4 100644 --- a/themes/agnoster.zsh-theme +++ b/themes/agnoster.zsh-theme @@ -228,7 +228,7 @@ prompt_virtualenv() { } # Conda Virtualenv -promp_conda_virtualenv() { +prompt_conda_virtualenv() { if [[ -n $CONDA_PROMPT_MODIFIER ]]; then prompt_segment black default ${CONDA_PROMPT_MODIFIER:1:-2} fi @@ -274,7 +274,7 @@ build_prompt() { prompt_bzr prompt_hg prompt_end - promp_conda_virtualenv + prompt_conda_virtualenv } PROMPT='%{%f%b%k%}$(build_prompt) ' From c77a01dbe28acaa13e53c7dc78d6b798f3f42fc2 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Wed, 22 May 2024 09:15:11 +0200 Subject: [PATCH 621/672] Revert "feat(agnoster): add `anaconda` env information (#12434)" This reverts commit 309129f651eeeca62c3a3b7f6817f0ac601db9f0. --- themes/agnoster.zsh-theme | 9 --------- 1 file changed, 9 deletions(-) diff --git a/themes/agnoster.zsh-theme b/themes/agnoster.zsh-theme index 4445ad4a4..c2a542163 100644 --- a/themes/agnoster.zsh-theme +++ b/themes/agnoster.zsh-theme @@ -227,14 +227,6 @@ prompt_virtualenv() { fi } -# Conda Virtualenv -prompt_conda_virtualenv() { - if [[ -n $CONDA_PROMPT_MODIFIER ]]; then - prompt_segment black default ${CONDA_PROMPT_MODIFIER:1:-2} - fi -} - - # Status: # - was there an error # - am I root @@ -274,7 +266,6 @@ build_prompt() { prompt_bzr prompt_hg prompt_end - prompt_conda_virtualenv } PROMPT='%{%f%b%k%}$(build_prompt) ' From 41d2029dec256b9ef3869cb83699d88b94eb3c1d Mon Sep 17 00:00:00 2001 From: Rizky Ilham Pratama Date: Wed, 22 May 2024 15:17:06 +0800 Subject: [PATCH 622/672] feat(laravel): add aliases laravel 11 (#12354) --- plugins/laravel/README.md | 4 ++++ plugins/laravel/laravel.plugin.zsh | 4 ++++ 2 files changed, 8 insertions(+) diff --git a/plugins/laravel/README.md b/plugins/laravel/README.md index a831a86b6..21eb89373 100644 --- a/plugins/laravel/README.md +++ b/plugins/laravel/README.md @@ -36,6 +36,10 @@ plugins=(... laravel) | `pamj` | `php artisan make:job` | | `paml` | `php artisan make:listener` | | `pamn` | `php artisan make:notification` | +| `pamcl` | `php artisan make:class` | +| `pamen` | `php artisan make:enum` | +| `pami` | `php artisan make:interface` | +| `pamtr` | `php artisan make:trait` | ## Clears diff --git a/plugins/laravel/laravel.plugin.zsh b/plugins/laravel/laravel.plugin.zsh index 319946f07..86ae27299 100644 --- a/plugins/laravel/laravel.plugin.zsh +++ b/plugins/laravel/laravel.plugin.zsh @@ -25,6 +25,10 @@ alias pamj='php artisan make:job' alias paml='php artisan make:listener' alias pamn='php artisan make:notification' alias pampp='php artisan make:provider' +alias pamcl='php artisan make:class' +alias pamen='php artisan make:enum' +alias pami='php artisan make:interface' +alias pamtr='php artisan make:trait' # Clears From 203369b0f9ec284e06b73f555a14fa5f02be5a0a Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Wed, 22 May 2024 15:36:03 +0200 Subject: [PATCH 623/672] ci(dependencies): run on sunday CET morning --- .github/workflows/dependencies.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/dependencies.yml b/.github/workflows/dependencies.yml index 6bc8dc74d..6c7387089 100644 --- a/.github/workflows/dependencies.yml +++ b/.github/workflows/dependencies.yml @@ -2,7 +2,7 @@ name: Update dependencies on: workflow_dispatch: {} schedule: - - cron: "34 3 * * */8" + - cron: "0 6 * * 0" jobs: check: From 1b29fd3a460e43d4a7581d6a6a7e5a1877a39068 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jes=C3=BAs=20Miguel=20Benito=20Calzada?= Date: Thu, 23 May 2024 12:51:02 +0200 Subject: [PATCH 624/672] feat(git): support `stable` in `git_main_branch` (#12447) --- plugins/git/git.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/git/git.plugin.zsh b/plugins/git/git.plugin.zsh index c48e365b5..1e65a7acc 100644 --- a/plugins/git/git.plugin.zsh +++ b/plugins/git/git.plugin.zsh @@ -35,7 +35,7 @@ function git_develop_branch() { function git_main_branch() { command git rev-parse --git-dir &>/dev/null || return local ref - for ref in refs/{heads,remotes/{origin,upstream}}/{main,trunk,mainline,default,master}; do + for ref in refs/{heads,remotes/{origin,upstream}}/{main,trunk,mainline,default,stable,master}; do if command git show-ref -q --verify $ref; then echo ${ref:t} return 0 From 5e59d21e5465ec0694441f41ff0acf1ddf4de187 Mon Sep 17 00:00:00 2001 From: theredcmdcraft <57496807+theredcmdcraft@users.noreply.github.com> Date: Sun, 26 May 2024 21:53:03 +0200 Subject: [PATCH 625/672] Add Support for Tabby Terminal in Macos Plugin (#12451) * Added Support for Tabby in Macos-Plugin * Update README.md Added Supported Terminal List * chore(macos): Update README to link to terminals Linking to the supported terminals, moving reference to the original author to the Acknowledgements section --------- Co-authored-by: Robby Russell --- plugins/macos/README.md | 10 ++++++++-- plugins/macos/macos.plugin.zsh | 19 +++++++++++++++++++ 2 files changed, 27 insertions(+), 2 deletions(-) diff --git a/plugins/macos/README.md b/plugins/macos/README.md index 2c52ec8a7..8245e211f 100644 --- a/plugins/macos/README.md +++ b/plugins/macos/README.md @@ -8,7 +8,11 @@ To start using it, add the `macos` plugin to your plugins array in `~/.zshrc`: plugins=(... macos) ``` -Original author: [Sorin Ionescu](https://github.com/sorin-ionescu) +## Supported Terminals +- [iTerm](https://iterm.sourceforge.net/) +- [iTerm2](https://iterm2.com/) +- [Hyper](https://hyper.is/) +- [Tabby](https://tabby.sh/) ## Commands @@ -37,7 +41,9 @@ Original author: [Sorin Ionescu](https://github.com/sorin-ionescu) ## Acknowledgements -This application makes use of the following third party scripts: +Original author: [Sorin Ionescu](https://github.com/sorin-ionescu) + +This application makes use of the following third-party scripts: [shpotify](https://github.com/hnarayanan/shpotify) diff --git a/plugins/macos/macos.plugin.zsh b/plugins/macos/macos.plugin.zsh index 2702a1901..b951a289f 100644 --- a/plugins/macos/macos.plugin.zsh +++ b/plugins/macos/macos.plugin.zsh @@ -79,6 +79,13 @@ EOF key code 36 #(presses enter) end tell EOF + + elif [[ "$the_app" == 'Tabby' ]]; then + osascript >/dev/null <&2 return 1 @@ -126,6 +133,12 @@ EOF delay 1 keystroke "${command} \n" end tell +EOF + elif [[ "$the_app" == 'Tabby' ]]; then + osascript >/dev/null <&2 @@ -175,6 +188,12 @@ EOF delay 1 keystroke "${command} \n" end tell +EOF + elif [[ "$the_app" == 'Tabby' ]]; then + osascript >/dev/null <&2 From 071b8f8921cb2bbb1fcabbf3d271e77af0b12a7d Mon Sep 17 00:00:00 2001 From: Ian Chesal Date: Tue, 28 May 2024 17:40:30 -0400 Subject: [PATCH 626/672] feat(kitty): add plugin for the kitty terminal (#10994) * A plugin for the Kitty terminal Provides a handful of useful aliases for anyone working in a Kitty terminal. In particular, the kssh command is handy for ensuring that terminfo is set correctly on remote hosts when you ssh to them. * Guard kitty configuration We should only load these aliases into a terminal that's identifying itself as an xterm-kitty terminal. They're not useful in any other situation. --- plugins/kitty/README.md | 23 +++++++++++++++++++++++ plugins/kitty/kitty.plugin.zsh | 16 ++++++++++++++++ 2 files changed, 39 insertions(+) create mode 100644 plugins/kitty/README.md create mode 100644 plugins/kitty/kitty.plugin.zsh diff --git a/plugins/kitty/README.md b/plugins/kitty/README.md new file mode 100644 index 000000000..ec9e375de --- /dev/null +++ b/plugins/kitty/README.md @@ -0,0 +1,23 @@ +# Kitty plugin + +This plugin adds a few aliases and functions that are useful for users of the [Kitty](https://sw.kovidgoyal.net/kitty/) terminal. + +To use it, add _kitty_ to the plugins array of your zshrc file: +``` +plugins=(... kitty) +``` + +## Plugin commands + +* `kssh` + Runs a kitten ssh session that ensures your terminfo settings are copied + correctly to the remote hose. +* `kssh-slow` + A slower form of `kssh` that should always work. Use this if `kssh` fails + to set terminfo correctly for you on the remote host. +* `kitty-theme` + Browse and change the theme of your Kitty terminal. + +## Contributors + +- [Ian Chesal](https://github.com/ianchesal) diff --git a/plugins/kitty/kitty.plugin.zsh b/plugins/kitty/kitty.plugin.zsh new file mode 100644 index 000000000..1094236a7 --- /dev/null +++ b/plugins/kitty/kitty.plugin.zsh @@ -0,0 +1,16 @@ +##################################################### +# Kitty plugin for oh-my-zsh # +##################################################### + +if [[ "$TERM" == 'xterm-kitty' ]]; then + ## kssh + # Use this when your terminfo isn't recognized on remote hosts. + # See: https://sw.kovidgoyal.net/kitty/faq/#i-get-errors-about-the-terminal-being-unknown-or-opening-the-terminal-failing-when-sshing-into-a-different-computer + alias kssh="kitty +kitten ssh" + compdef kssh='ssh' + # Use this if kssh fails + alias kssh-slow="infocmp -a xterm-kitty | ssh myserver tic -x -o \~/.terminfo /dev/stdin" + + # Change the colour theme + alias kitty-theme="kitty +kitten themes" +fi From a4424dfefd68e4d23badb2f86087184f9e06fab4 Mon Sep 17 00:00:00 2001 From: Lukas Grimm Date: Thu, 30 May 2024 17:05:50 +0200 Subject: [PATCH 627/672] fix(pass): completion for multiple repositories (#12464) --- plugins/pass/_pass | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/plugins/pass/_pass b/plugins/pass/_pass index d911e122f..c66d99318 100644 --- a/plugins/pass/_pass +++ b/plugins/pass/_pass @@ -20,6 +20,8 @@ _pass () { local cmd + local rootcontext + rootcontext=$curcontext if (( CURRENT > 2)); then cmd=${words[2]} # Set the context for the subcommand. @@ -123,8 +125,9 @@ _pass_cmd_show () { _pass_complete_entries_helper () { local IFS=$'\n' local prefix - zstyle -s ":completion:${curcontext}:" prefix prefix || prefix="${PASSWORD_STORE_DIR:-$HOME/.password-store}" - _values -C 'passwords' ${$(find -L "$prefix" \( -name .git -o -name .gpg-id \) -prune -o $@ -print 2>/dev/null | sed -e "s#${prefix}/\{0,1\}##" -e 's#\.gpg##' -e 's#\\#\\\\#g' -e 's#:#\\:#g' | sort):-""} + zstyle -s ":completion:${rootcontext}:" prefix prefix || +prefix="${PASSWORD_STORE_DIR:-$HOME/.password-store}" + _values -C 'passwords' ${$(find -L "$prefix" \( -name .git -o -name .gpg-id \) -prune -o $@ -print 2>/dev/null | sed -e "s#${prefix}/\{0,1\}##" -e 's#\.gpg##' -e 's#\\#\\\\#g' -e 's#:#\\:#g' | sort):-""} } _pass_complete_entries_with_subdirs () { From 2c08d2b8423d6fc38d4d6e3be3aaebc3522b1555 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Thu, 30 May 2024 20:21:17 +0200 Subject: [PATCH 628/672] fix(kubectl): load completion properly in functions Closes #12427 --- plugins/kubectl/kubectl.plugin.zsh | 16 +++++++--------- 1 file changed, 7 insertions(+), 9 deletions(-) diff --git a/plugins/kubectl/kubectl.plugin.zsh b/plugins/kubectl/kubectl.plugin.zsh index 0dd4e691a..a96e409c6 100644 --- a/plugins/kubectl/kubectl.plugin.zsh +++ b/plugins/kubectl/kubectl.plugin.zsh @@ -180,13 +180,11 @@ alias kej='kubectl edit job' alias kdj='kubectl describe job' alias kdelj='kubectl delete job' -# Only run if the user actually has kubectl installed -if (( ${+_comps[kubectl]} )); then - function kj() { kubectl "$@" -o json | jq; } - function kjx() { kubectl "$@" -o json | fx; } - function ky() { kubectl "$@" -o yaml | yh; } - - compdef kj=kubectl - compdef kjx=kubectl - compdef ky=kubectl +function kj() { kubectl "$@" -o json | jq; } +function kjx() { kubectl "$@" -o json | fx; } +function ky() { kubectl "$@" -o yaml | yh; } +if (( ${+functions[compdef]} )); then + compdef _kubectl kj + compdef _kubectl kjx + compdef _kubectl ky fi From 189774c5d0d989ab45c0765f646803926e08e013 Mon Sep 17 00:00:00 2001 From: Jeroen Claassens Date: Thu, 30 May 2024 20:31:39 +0200 Subject: [PATCH 629/672] feat(yarn)!: add optional support for yarn berry (#12374) BREAKING CHANGE: some `yarn` aliases changed . Please see README for further information. Co-authored-by: Carlo Sala --- plugins/yarn/README.md | 96 +++++++++++++++++++++--------------- plugins/yarn/yarn.plugin.zsh | 36 +++++++++++--- 2 files changed, 84 insertions(+), 48 deletions(-) diff --git a/plugins/yarn/README.md b/plugins/yarn/README.md index 5c7c7f323..f1d089b1f 100644 --- a/plugins/yarn/README.md +++ b/plugins/yarn/README.md @@ -1,7 +1,7 @@ # Yarn plugin -This plugin adds completion for the [Yarn package manager](https://yarnpkg.com/en/), -as well as some aliases for common Yarn commands. +This plugin adds completion for the [Yarn package manager](https://yarnpkg.com/en/), as well as some aliases +for common Yarn commands. To use it, add `yarn` to the plugins array in your zshrc file: @@ -11,48 +11,64 @@ plugins=(... yarn) ## Global scripts directory -It also adds `yarn` global scripts dir (commonly `~/.yarn/bin`) to the `$PATH`. -To disable this feature, set the following style in your `.zshrc`: +It also adds `yarn` global scripts dir (commonly `~/.yarn/bin`) to the `$PATH`. To disable this feature, set +the following style in your `.zshrc`: ```zsh zstyle ':omz:plugins:yarn' global-path no ``` +## Yarn Berry + +If you are using Yarn berry (a.k.a. Yarn version 2 or higher) as your global Yarn version you should configure +this plugin to configure its aliases accordingly, set the following style in your `.zshrc`: + +```zsh +zstyle ':omz:plugins:yarn' berry yes +``` + ## Aliases -| Alias | Command | Description | -| ----- | ----------------------------------------- | ----------------------------------------------------------------------------- | -| y | `yarn` | The Yarn command | -| ya | `yarn add` | Install a package in dependencies (`package.json`) | -| yad | `yarn add --dev` | Install a package in devDependencies (`package.json`) | -| yap | `yarn add --peer` | Install a package in peerDependencies (`package.json`) | -| yb | `yarn build` | Run the build script defined in `package.json` | -| ycc | `yarn cache clean` | Clean yarn's global cache of packages | -| yd | `yarn dev` | Run the dev script defined in `package.json` | -| yf | `yarn format` | Run the dev script defined in `package.json` | -| yga | `yarn global add` | Install packages globally on your operating system | -| ygls | `yarn global list` | Lists global installed packages | -| ygrm | `yarn global remove` | Remove global installed packages from your OS | -| ygu | `yarn global upgrade` | Upgrade packages installed globally to their latest version | -| yh | `yarn help` | Show help for a yarn command | -| yi | `yarn init` | Interactively creates or updates a package.json file | -| yin | `yarn install` | Install dependencies defined in `package.json` | -| yln | `yarn lint` | Run the lint script defined in `package.json` | -| ylnf | `yarn lint --fix` | Run the lint script defined in `package.json`to automatically fix problems | -| yls | `yarn list` | List installed packages | -| yout | `yarn outdated` | Check for outdated package dependencies | -| yp | `yarn pack` | Create a compressed gzip archive of package dependencies | -| yrm | `yarn remove` | Remove installed packages | -| yrun | `yarn run` | Run a defined package script | -| ys | `yarn serve` | Start the dev server | -| yst | `yarn start` | Run the start script defined in `package.json` | -| yt | `yarn test` | Run the test script defined in `package.json` | -| ytc | `yarn test --coverage` | Run the test script defined in `package.json` with coverage | -| yuc | `yarn global upgrade && yarn cache clean` | Upgrade global packages and clean yarn's global cache | -| yui | `yarn upgrade-interactive` | Prompt for which outdated packages to upgrade | -| yuil | `yarn upgrade-interactive --latest` | Prompt for which outdated packages to upgrade to the latest available version | -| yup | `yarn upgrade` | Upgrade packages to their latest version | -| yv | `yarn version` | Update the version of your package | -| yw | `yarn workspace` | Run a command within a single workspace. | -| yws | `yarn workspaces` | Run a command within all defined workspaces. | -| yy | `yarn why` | Show why a package has been installed, detailing which other packages depend on it | +- Aliases marked with `*` are only available when using Yarn v1 (non-berry) +- Aliases marked with `b` are only available when using Yarn berry + +| Alias | Command | Description | +| ------------------ | ----------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------- | +| y | `yarn` | The Yarn command | +| ya | `yarn add` | Install a package in dependencies (`package.json`) | +| yad | `yarn add --dev` | Install a package in devDependencies (`package.json`) | +| yap | `yarn add --peer` | Install a package in peerDependencies (`package.json`) | +| yb | `yarn build` | Run the build script defined in `package.json` | +| ycc | `yarn cache clean` | Clean yarn's global cache of packages | +| yd | `yarn dev` | Run the dev script defined in `package.json` | +| yf | `yarn format` | Run the dev script defined in `package.json` | +| yh | `yarn help` | Show help for a yarn command | +| yi | `yarn init` | Interactively creates or updates a package.json file | +| yin | `yarn install` | Install dependencies defined in `package.json` | +| yln | `yarn lint` | Run the lint script defined in `package.json` | +| ylnf | `yarn lint --fix` | Run the lint script defined in `package.json`to automatically fix problems | +| yp | `yarn pack` | Create a compressed gzip archive of package dependencies | +| yrm | `yarn remove` | Remove installed packages | +| yrun | `yarn run` | Run a defined package script | +| ys | `yarn serve` | Start the dev server | +| yst | `yarn start` | Run the start script defined in `package.json` | +| yt | `yarn test` | Run the test script defined in `package.json` | +| ytc | `yarn test --coverage` | Run the test script defined in `package.json` with coverage | +| yui | `yarn upgrade-interactive` | Prompt for which outdated packages to upgrade | +| yuil | `yarn upgrade-interactive --latest` (or see `yui` when using [yarn berry](#yarn-berry)) | Prompt for which outdated packages to upgrade to the latest available version | +| yii | `yarn install --frozen-lockfile` (or `yarn install --immutable` when using [yarn berry](#yarn-berry)) | Install dependencies and abort if the lockfile was to be modified | +| yifl | `yii` | Install dependencies and abort if the lockfile was to be modified | +| yup | `yarn upgrade` | Upgrade packages to their latest version | +| yv | `yarn version` | Update the version of your package | +| yw | `yarn workspace` | Run a command within a single workspace. | +| yws | `yarn workspaces` | Run a command within all defined workspaces. | +| yy | `yarn why` | Show why a package has been installed, detailing which other packages depend on it | +| yga`*` | `yarn global add` | Install packages globally on your operating system | +| ygls`*` | `yarn global list` | Lists global installed packages | +| ygrm`*` | `yarn global remove` | Remove global installed packages from your OS | +| ygu`*` | `yarn global upgrade` | Upgrade packages installed globally to their latest version | +| yls`*` | `yarn list` | List installed packages | +| yout`*` | `yarn outdated` | Check for outdated package dependencies | +| yuca`*` | `yarn global upgrade && yarn cache clean` | Upgrade global packages and clean yarn's global cache | +| ydlx`b` | `yarn dlx` | Run a package in a temporary environment. | +| yn`b` | `yarn node` | Run node with the hook already setup. | diff --git a/plugins/yarn/yarn.plugin.zsh b/plugins/yarn/yarn.plugin.zsh index 157044d71..b7d64770d 100644 --- a/plugins/yarn/yarn.plugin.zsh +++ b/plugins/yarn/yarn.plugin.zsh @@ -18,17 +18,11 @@ alias yb="yarn build" alias ycc="yarn cache clean" alias yd="yarn dev" alias yf="yarn format" -alias yga="yarn global add" -alias ygls="yarn global list" -alias ygrm="yarn global remove" -alias ygu="yarn global upgrade" alias yh="yarn help" alias yi="yarn init" alias yin="yarn install" alias yln="yarn lint" alias ylnf="yarn lint --fix" -alias yls="yarn list" -alias yout="yarn outdated" alias yp="yarn pack" alias yrm="yarn remove" alias yrun="yarn run" @@ -36,11 +30,37 @@ alias ys="yarn serve" alias yst="yarn start" alias yt="yarn test" alias ytc="yarn test --coverage" -alias yuc="yarn global upgrade && yarn cache clean" alias yui="yarn upgrade-interactive" -alias yuil="yarn upgrade-interactive --latest" alias yup="yarn upgrade" alias yv="yarn version" alias yw="yarn workspace" alias yws="yarn workspaces" alias yy="yarn why" + +# Commands that are specific to the yarn version being used +if zstyle -t ':omz:plugins:yarn' berry; then + # aliases that differ + alias yuil='yui' # --latest flag was removed in yarn berry + alias yii='yarn install --immutable' + alias yifl='yarn install --immutable' + + # unique aliases + alias ydlx="yarn dlx" + alias yn="yarn node" +else + # aliases that differ + alias yuil='yarn upgrade-interactive --latest' + alias yii='yarn install --frozen-lockfile' + alias yifl='yarn install --frozen-lockfile' + + # unique aliases + alias yga="yarn global add" + alias ygls="yarn global list" + alias ygrm="yarn global remove" + alias ygu="yarn global upgrade" + alias yls="yarn list" + alias yout="yarn outdated" + alias yuca="yarn global upgrade && yarn cache clean" +fi + +unset is_yarn_berry From e0c6cb147030350c8e27dbdeda6e8a4d367d1e66 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Fri, 31 May 2024 08:55:53 +0200 Subject: [PATCH 630/672] chore(yarn): remove unneeded line --- plugins/yarn/yarn.plugin.zsh | 2 -- 1 file changed, 2 deletions(-) diff --git a/plugins/yarn/yarn.plugin.zsh b/plugins/yarn/yarn.plugin.zsh index b7d64770d..5dd329698 100644 --- a/plugins/yarn/yarn.plugin.zsh +++ b/plugins/yarn/yarn.plugin.zsh @@ -62,5 +62,3 @@ else alias yout="yarn outdated" alias yuca="yarn global upgrade && yarn cache clean" fi - -unset is_yarn_berry From 56afe7b3685be8a1ddef25a742016dc76c0a5f8f Mon Sep 17 00:00:00 2001 From: MoetaYuko Date: Mon, 3 Jun 2024 18:53:27 +0800 Subject: [PATCH 631/672] fix(tmux): add completion for alias functions (#12468) --- plugins/tmux/tmux.plugin.zsh | 13 +++++++++++++ 1 file changed, 13 insertions(+) diff --git a/plugins/tmux/tmux.plugin.zsh b/plugins/tmux/tmux.plugin.zsh index f65598358..399de1ccc 100644 --- a/plugins/tmux/tmux.plugin.zsh +++ b/plugins/tmux/tmux.plugin.zsh @@ -57,6 +57,19 @@ function _build_tmux_alias { tmux $2 $3 \"\$@\" fi }" + + local f s + f="_omz_tmux_alias_${1}" + s=(${(z)2}) + + eval "function ${f}() { + shift words; + words=(tmux ${@:2} \$words); + ((CURRENT+=${#s[@]}+1)) + _tmux + }" + + compdef "$f" "$1" } alias tksv='tmux kill-server' From 695c7456d1a84697e9b86e11e839d5178cae743a Mon Sep 17 00:00:00 2001 From: Albert <87888006+MustCodeAl@users.noreply.github.com> Date: Mon, 3 Jun 2024 05:59:01 -0500 Subject: [PATCH 632/672] docs(stripe): fix typo (#12470) --- plugins/stripe/README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/stripe/README.md b/plugins/stripe/README.md index 9f0f32bc2..7e7944d63 100644 --- a/plugins/stripe/README.md +++ b/plugins/stripe/README.md @@ -1,4 +1,4 @@ -# Struoe +# Stripe This plugin provides completion for the [Stripe CLI](https://stripe.com/docs/stripe-cli). From 228d44d55d812725c3c0c26655b28c72eddb4ba6 Mon Sep 17 00:00:00 2001 From: EraPartner <152506497+EraPartner@users.noreply.github.com> Date: Tue, 4 Jun 2024 13:54:42 +0000 Subject: [PATCH 633/672] feat(eza): add icons option (#12469) Co-authored-by: Computer --- plugins/eza/README.md | 10 ++++++++++ plugins/eza/eza.plugin.zsh | 3 +++ 2 files changed, 13 insertions(+) diff --git a/plugins/eza/README.md b/plugins/eza/README.md index 5de935c2c..6fc113eba 100644 --- a/plugins/eza/README.md +++ b/plugins/eza/README.md @@ -55,6 +55,16 @@ If `yes` (default), always add `-g` flag to show the group ownership. Default: `yes` +### `icons` + +```zsh +zstyle ':omz:plugins:eza' 'icons' yes|no +``` + +If `yes`, sets the `--icons` option of `eza`, adding icons for files and folders. + +Default: `no` + ### `size-prefix` ```zsh diff --git a/plugins/eza/eza.plugin.zsh b/plugins/eza/eza.plugin.zsh index 6d7f720bd..79f5a0f71 100644 --- a/plugins/eza/eza.plugin.zsh +++ b/plugins/eza/eza.plugin.zsh @@ -31,6 +31,9 @@ function _configure_eza() { if zstyle -t ':omz:plugins:eza' 'git-status'; then _EZA_TAIL+=("--git") fi + if zstyle -t ':omz:plugins:eza' 'icons'; then + _EZA_TAIL+=("--icons") + fi zstyle -s ':omz:plugins:eza' 'time-style' _val if [[ $_val ]]; then _EZA_TAIL+=("--time-style='$_val'") From e53edd712f28170a0843ce1d2a61efe335484ad4 Mon Sep 17 00:00:00 2001 From: David LJ Date: Tue, 4 Jun 2024 15:55:08 +0200 Subject: [PATCH 634/672] fix(bgnotify): use terminal-notifier args properly (#12467) --- plugins/bgnotify/bgnotify.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/bgnotify/bgnotify.plugin.zsh b/plugins/bgnotify/bgnotify.plugin.zsh index 0e3f2c640..7de6f9a91 100644 --- a/plugins/bgnotify/bgnotify.plugin.zsh +++ b/plugins/bgnotify/bgnotify.plugin.zsh @@ -117,7 +117,7 @@ function bgnotify { local icon="$3" if (( ${+commands[terminal-notifier]} )); then # macOS local term_id=$(bgnotify_programid) - terminal-notifier -message "$message" -title "$title" ${=icon:+-appIcon "$icon"} ${=term_id:+-activate "$term_id" -sender "$term_id"} &>/dev/null + terminal-notifier -message "$message" -title "$title" ${=icon:+-appIcon "$icon"} ${=term_id:+-activate "$term_id"} &>/dev/null elif (( ${+commands[growlnotify]} )); then # macOS growl growlnotify -m "$title" "$message" elif (( ${+commands[notify-send]} )); then From de2e3d9cd3840a1052132d502868aca263debc26 Mon Sep 17 00:00:00 2001 From: "K.B.Dharun Krishna" Date: Tue, 4 Jun 2024 19:26:34 +0530 Subject: [PATCH 635/672] docs: reword alternative installer mirror (#12474) --- README.md | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/README.md b/README.md index dea36fda7..2d873c514 100644 --- a/README.md +++ b/README.md @@ -89,7 +89,7 @@ Oh My Zsh is installed by running one of the following commands in your terminal | **wget** | `sh -c "$(wget -O- https://raw.githubusercontent.com/ohmyzsh/ohmyzsh/master/tools/install.sh)"` | | **fetch** | `sh -c "$(fetch -o - https://raw.githubusercontent.com/ohmyzsh/ohmyzsh/master/tools/install.sh)"` | -Alternatively, the installer is also mirrored outside GitHub. Using this URL instead may be required if you're in a country like India or China, that blocks `raw.githubusercontent.com`: +Alternatively, the installer is also mirrored outside GitHub. Using this URL instead may be required if you're in a country like China or India (for certain ISPs), that blocks `raw.githubusercontent.com`: | Method | Command | | :-------- | :------------------------------------------------------------------------------------------------ | @@ -235,7 +235,7 @@ If you're in China, India, or another country that blocks `raw.githubusercontent #### Installing From A Forked Repository -The install script also accepts these variables to allow installation of a different repository: +The install script also accepts these variables to allow the installation of a different repository: - `REPO` (default: `ohmyzsh/ohmyzsh`): this takes the form of `owner/repository`. If you set this variable, the installer will look for a repository at `https://github.com/{owner}/{repository}`. @@ -309,7 +309,7 @@ If you would like to override the functionality of a plugin distributed with Oh -The default behaviour in Oh My Zsh is to use BSD `ls` in macOS and freeBSD systems. If GNU `ls` is installed +The default behaviour in Oh My Zsh is to use BSD `ls` in macOS and FreeBSD systems. If GNU `ls` is installed (as `gls` command), you can choose to use it instead. To do it, you can use zstyle-based config before sourcing `oh-my-zsh.sh`: @@ -342,7 +342,7 @@ zstyle ':omz:plugins:*' aliases no zstyle ':omz:plugins:git' aliases no ``` -You can combine these in other ways taking into account that more specific scopes takes precedence: +You can combine these in other ways taking into account that more specific scopes take precedence: ```sh # Skip all plugin aliases, except for the git plugin @@ -365,7 +365,7 @@ zstyle ':omz:lib:directories' aliases no ### Disable async git prompt Async prompt functions are an experimental feature (included on April 3, 2024) that allows Oh My Zsh to render prompt information -asyncronously. This can improve prompt rendering performance, but it might not work well with some setups. We hope that's not an +asynchronously. This can improve prompt rendering performance, but it might not work well with some setups. We hope that's not an issue, but if you're seeing problems with this new feature, you can turn it off by setting the following in your .zshrc file, before Oh My Zsh is sourced: From efdfe2f29ac57a9de76391b4e5548edab6a43241 Mon Sep 17 00:00:00 2001 From: "K.B.Dharun Krishna" Date: Tue, 4 Jun 2024 19:27:08 +0530 Subject: [PATCH 636/672] feat(golang): add alias for `go mod tidy` (#12473) --- plugins/golang/README.md | 1 + plugins/golang/golang.plugin.zsh | 1 + 2 files changed, 2 insertions(+) diff --git a/plugins/golang/README.md b/plugins/golang/README.md index 128cc7fbb..80f8cf3b5 100644 --- a/plugins/golang/README.md +++ b/plugins/golang/README.md @@ -25,6 +25,7 @@ plugins=(... golang) | goi | `go install` | Compiles and installs packages to $GOPATH | | gol | `go list` | Lists Go packages | | gom | `go mod` | Access to operations on modules | +| gomt | `go mod tidy` | Tidies up the go.mod file | | gopa | `cd $GOPATH` | Takes you to `$GOPATH` | | gopb | `cd $GOPATH/bin` | Takes you to `$GOPATH/bin` | | gops | `cd $GOPATH/src` | Takes you to `$GOPATH/src` | diff --git a/plugins/golang/golang.plugin.zsh b/plugins/golang/golang.plugin.zsh index 45ccd3a1c..dc4d91845 100644 --- a/plugins/golang/golang.plugin.zsh +++ b/plugins/golang/golang.plugin.zsh @@ -22,6 +22,7 @@ alias goga='go get ./...' alias goi='go install' alias gol='go list' alias gom='go mod' +alias gomt='go mod tidy' alias gopa='cd $GOPATH' alias gopb='cd $GOPATH/bin' alias gops='cd $GOPATH/src' From e898de066473eb725d582a10483d9a2570d221f8 Mon Sep 17 00:00:00 2001 From: Martin Bjeldbak Madsen Date: Sat, 8 Jun 2024 18:47:51 +1000 Subject: [PATCH 637/672] fix(eza): icons tab completion (#12483) --- plugins/eza/eza.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/eza/eza.plugin.zsh b/plugins/eza/eza.plugin.zsh index 79f5a0f71..e95b14749 100644 --- a/plugins/eza/eza.plugin.zsh +++ b/plugins/eza/eza.plugin.zsh @@ -32,7 +32,7 @@ function _configure_eza() { _EZA_TAIL+=("--git") fi if zstyle -t ':omz:plugins:eza' 'icons'; then - _EZA_TAIL+=("--icons") + _EZA_TAIL+=("--icons=auto") fi zstyle -s ':omz:plugins:eza' 'time-style' _val if [[ $_val ]]; then From 4e8099175ef2559f00e8ab5954adccd940a8fd4a Mon Sep 17 00:00:00 2001 From: vincent Date: Sat, 8 Jun 2024 16:48:33 +0800 Subject: [PATCH 638/672] feat(extract): add support for multi-part 7z (#12484) --- plugins/extract/extract.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/extract/extract.plugin.zsh b/plugins/extract/extract.plugin.zsh index 1c7599195..e2b3111d5 100644 --- a/plugins/extract/extract.plugin.zsh +++ b/plugins/extract/extract.plugin.zsh @@ -80,7 +80,7 @@ EOF (*.rar) unrar x -ad "$full_path" ;; (*.rpm) rpm2cpio "$full_path" | cpio --quiet -id ;; - (*.7z) 7za x "$full_path" ;; + (*.7z | *.7z.[0-9]*) 7za x "$full_path" ;; (*.deb) command mkdir -p "control" "data" ar vx "$full_path" > /dev/null From 8510847ff38a142850e4a065dc3cf09555260ff7 Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Sat, 8 Jun 2024 13:32:27 +0200 Subject: [PATCH 639/672] fix(bundler): add completion for `bundler` bin as well Closes #12482 --- plugins/bundler/_bundler | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/bundler/_bundler b/plugins/bundler/_bundler index 51678dd7c..6613cc68a 100644 --- a/plugins/bundler/_bundler +++ b/plugins/bundler/_bundler @@ -1,4 +1,4 @@ -#compdef bundle +#compdef bundle bundler local curcontext="$curcontext" state line _gems _opts ret=1 From cedbb9e22846eb4b1fff0c47c3c4dbafb73601f0 Mon Sep 17 00:00:00 2001 From: "ohmyzsh[bot]" <54982679+ohmyzsh[bot]@users.noreply.github.com> Date: Sun, 9 Jun 2024 08:43:02 +0200 Subject: [PATCH 640/672] feat(history-substring-search): update to 87ce96b1 (#12486) Co-authored-by: ohmyzsh[bot] <54982679+ohmyzsh[bot]@users.noreply.github.com> --- .github/dependencies.yml | 2 +- plugins/history-substring-search/README.md | 8 ++++---- .../history-substring-search/history-substring-search.zsh | 4 ++-- 3 files changed, 7 insertions(+), 7 deletions(-) diff --git a/.github/dependencies.yml b/.github/dependencies.yml index d3b269361..ce28e34c9 100644 --- a/.github/dependencies.yml +++ b/.github/dependencies.yml @@ -21,7 +21,7 @@ dependencies: plugins/history-substring-search: repo: zsh-users/zsh-history-substring-search branch: master - version: 8dd05bfcc12b0cd1ee9ea64be725b3d9f713cf64 + version: 87ce96b1862928d84b1afe7c173316614b30e301 precopy: | set -e rm -f zsh-history-substring-search.plugin.zsh diff --git a/plugins/history-substring-search/README.md b/plugins/history-substring-search/README.md index 4be744c4c..71a389535 100644 --- a/plugins/history-substring-search/README.md +++ b/plugins/history-substring-search/README.md @@ -57,13 +57,13 @@ Using [antigen](https://github.com/zsh-users/antigen): 1. Add the `antigen bundle` command just before `antigen apply`, like this: -``` +``` antigen bundle zsh-users/zsh-history-substring-search antigen apply ``` - + 2. Then, **after** `antigen apply`, add the key binding configurations, like this: - + ``` # zsh-history-substring-search configuration bindkey '^[[A' history-substring-search-up # or '\eOA' @@ -120,7 +120,7 @@ Usage bindkey "$terminfo[kcuu1]" history-substring-search-up bindkey "$terminfo[kcud1]" history-substring-search-down - Users have also observed that `[OA` and `[OB` are correct values, + Users have also observed that `[OA` and `[OB` are correct values, _even if_ these were not the observed values. If you are having trouble with the observed values, give these a try. diff --git a/plugins/history-substring-search/history-substring-search.zsh b/plugins/history-substring-search/history-substring-search.zsh index 471cc9ad1..2137b7950 100644 --- a/plugins/history-substring-search/history-substring-search.zsh +++ b/plugins/history-substring-search/history-substring-search.zsh @@ -406,7 +406,7 @@ _history-substring-search-end() { # For debugging purposes: # zle -R "mn: "$_history_substring_search_match_index" m#: "${#_history_substring_search_matches} - # read -k -t 200 && zle -U $REPLY + # read -k -t 200 && zle -U -- "$REPLY" # # When this function returns, z-sy-h runs its line-pre-redraw hook. It has no @@ -421,7 +421,7 @@ _history-substring-search-end() { # before removing search highlight and exiting. This ensures no highlights # are left lingering after search is finished. # - read -k -t ${HISTORY_SUBSTRING_SEARCH_HIGHLIGHT_TIMEOUT:-1} && zle -U $REPLY + read -k -t ${HISTORY_SUBSTRING_SEARCH_HIGHLIGHT_TIMEOUT:-1} && zle -U -- "$REPLY" region_highlight=( "${(@)region_highlight:#*${highlight_memo}*}" ) fi From 5a5d5eb85b245e0c6bc561134fdb0fd0bf9bbe10 Mon Sep 17 00:00:00 2001 From: Michal Szymanski <55950820+misiektoja@users.noreply.github.com> Date: Tue, 11 Jun 2024 01:25:53 +0200 Subject: [PATCH 641/672] feat(forklift): add support for ForkLift 4 (#12490) (#12491) --- plugins/forklift/forklift.plugin.zsh | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/plugins/forklift/forklift.plugin.zsh b/plugins/forklift/forklift.plugin.zsh index 848aedabf..4bc74958d 100644 --- a/plugins/forklift/forklift.plugin.zsh +++ b/plugins/forklift/forklift.plugin.zsh @@ -2,6 +2,7 @@ # Author: Adam Strzelecki nanoant.com, modified by Bodo Tasche bitboxer.de # Updated to support ForkLift 2 and ForkLift 3 by Johan Kaving # Updated to support ForkLift from Setapp by Paul Rudkin +# Updated to support ForkLift 4 by Michal Szymanski (misiektoja) # # Usage: # fl [] @@ -110,6 +111,11 @@ function fl { tell pop over of list of group of splitter group of splitter group of topWindow set value of text field 1 to "$PWD" end tell + else if forkLiftVersion starts with "4" then + tell pop over of list of group of splitter group of splitter group of topWindow + keystroke "$PWD" + delay 0.1 + end tell else tell sheet 1 of topWindow set value of text field 1 to "$PWD" From 37f5203abe6b0f603172d86530f0e65029f4ac9c Mon Sep 17 00:00:00 2001 From: nitrocode <7775707+nitrocode@users.noreply.github.com> Date: Tue, 11 Jun 2024 04:59:57 +0530 Subject: [PATCH 642/672] feat(terraform): add workspace aliases (#12171) * feat(terraform): add workspace aliases * chore: rm aliases in separate pending pr * docs: show tfiu alias in readme --------- Co-authored-by: Robby Russell --- plugins/terraform/README.md | 29 +++++++++++++------------- plugins/terraform/terraform.plugin.zsh | 1 + 2 files changed, 16 insertions(+), 14 deletions(-) diff --git a/plugins/terraform/README.md b/plugins/terraform/README.md index 2b535517c..b5158b4e9 100644 --- a/plugins/terraform/README.md +++ b/plugins/terraform/README.md @@ -15,20 +15,21 @@ plugins=(... terraform) ## Aliases -| Alias | Command | -| ------ | -------------------- | -| `tf` | `terraform` | -| `tfa` | `terraform apply` | -| `tfc` | `terraform console` | -| `tfd` | `terraform destroy` | -| `tff` | `terraform fmt` | -| `tfi` | `terraform init` | -| `tfo` | `terraform output` | -| `tfp` | `terraform plan` | -| `tfv` | `terraform validate` | -| `tfs` | `terraform state` | -| `tft` | `terraform test` | -| `tfsh` | `terraform show` | +| Alias | Command | +| ------ | ------------------------- | +| `tf` | `terraform` | +| `tfa` | `terraform apply` | +| `tfc` | `terraform console` | +| `tfd` | `terraform destroy` | +| `tff` | `terraform fmt` | +| `tfi` | `terraform init` | +| `tfiu` | `terraform init -upgrade` | +| `tfo` | `terraform output` | +| `tfp` | `terraform plan` | +| `tfv` | `terraform validate` | +| `tfs` | `terraform state` | +| `tft` | `terraform test` | +| `tfsh` | `terraform show` | ## Prompt function diff --git a/plugins/terraform/terraform.plugin.zsh b/plugins/terraform/terraform.plugin.zsh index 8ef392efd..71a58b939 100644 --- a/plugins/terraform/terraform.plugin.zsh +++ b/plugins/terraform/terraform.plugin.zsh @@ -21,6 +21,7 @@ alias tfc='terraform console' alias tfd='terraform destroy' alias tff='terraform fmt' alias tfi='terraform init' +alias tfiu='terraform init -upgrade' alias tfo='terraform output' alias tfp='terraform plan' alias tfv='terraform validate' From a4304dd7e5826a2aeabb910a3966158897d55271 Mon Sep 17 00:00:00 2001 From: Sergey Karpuk Date: Tue, 11 Jun 2024 02:31:26 +0300 Subject: [PATCH 643/672] feat(docker): add aliases for `docker ps` and `docker ps -a` (#12488) --- plugins/docker/README.md | 2 ++ plugins/docker/docker.plugin.zsh | 2 ++ 2 files changed, 4 insertions(+) diff --git a/plugins/docker/README.md b/plugins/docker/README.md index 0ab2e41fb..72ebbcb1e 100644 --- a/plugins/docker/README.md +++ b/plugins/docker/README.md @@ -61,6 +61,8 @@ zstyle ':omz:plugins:docker' legacy-completion yes | dnls | `docker network ls` | List all networks the engine daemon knows about, including those spanning multiple hosts | | dnrm | `docker network rm` | Remove one or more networks | | dpo | `docker container port` | List port mappings or a specific mapping for the container | +| dps | `docker ps` | List all the running docker containers | +| dpsa | `docker ps -a` | List all running and stopped containers | | dpu | `docker pull` | Pull an image or a repository from a registry | | dr | `docker container run` | Create a new container and start it using the specified command | | drit | `docker container run -it` | Create a new container and start it in an interactive shell | diff --git a/plugins/docker/docker.plugin.zsh b/plugins/docker/docker.plugin.zsh index b429ae211..56dbc6b80 100644 --- a/plugins/docker/docker.plugin.zsh +++ b/plugins/docker/docker.plugin.zsh @@ -16,6 +16,8 @@ alias dni='docker network inspect' alias dnls='docker network ls' alias dnrm='docker network rm' alias dpo='docker container port' +alias dps='docker ps' +alias dpsa='docker ps -a' alias dpu='docker pull' alias dr='docker container run' alias drit='docker container run -it' From 6ffdf8e008bb1bb052afdb56684917075424a056 Mon Sep 17 00:00:00 2001 From: Marco Eidinger Date: Mon, 10 Jun 2024 16:40:03 -0700 Subject: [PATCH 644/672] feat(swiftpm): update completion for Swift 5.9 (#12044) --- plugins/swiftpm/README.md | 2 +- plugins/swiftpm/_swift | 258 +++++++++++++++++--------------------- 2 files changed, 114 insertions(+), 146 deletions(-) diff --git a/plugins/swiftpm/README.md b/plugins/swiftpm/README.md index 223a607c1..e5b4752e4 100644 --- a/plugins/swiftpm/README.md +++ b/plugins/swiftpm/README.md @@ -2,7 +2,7 @@ ## Description -This plugin provides a few utilities that make you faster on your daily work with the [Swift Package Manager](https://github.com/apple/swift-package-manager), as well as autocompletion for Swift 5.7. +This plugin provides a few utilities that make you faster on your daily work with the [Swift Package Manager](https://github.com/apple/swift-package-manager), as well as autocompletion for Swift 5.9. To start using it, add the `swiftpm` plugin to your `plugins` array in `~/.zshrc`: diff --git a/plugins/swiftpm/_swift b/plugins/swiftpm/_swift index 51c9fffa0..f9a603f58 100644 --- a/plugins/swiftpm/_swift +++ b/plugins/swiftpm/_swift @@ -57,6 +57,8 @@ _swift_run() { '--config-path[Specify the shared configuration directory path]:config-path:_files -/' '--security-path[Specify the shared security directory path]:security-path:_files -/' '--scratch-path[Specify a custom scratch directory path (default .build)]:scratch-path:_files -/' + '--pkg-config-path[Specify alternative path to search for pkg-config `.pc` files. Use the option multiple times to + specify more than one path.]:pkg-config-path:_files -/' '--enable-dependency-cache[Use a shared cache when fetching dependencies]' '--disable-dependency-cache[Use a shared cache when fetching dependencies]' '--enable-build-manifest-caching' @@ -64,13 +66,18 @@ _swift_run() { '--manifest-cache[Caching mode of Package.swift manifests (shared: shared cache, local: package'"'"'s build directory, none: disabled]:manifest-cache:' '(--verbose -v)'{--verbose,-v}'[Increase verbosity to include informational output]' '(--very-verbose --vv)'{--very-verbose,--vv}'[Increase verbosity to include debug output]' + '(--quiet -q)'{--quiet,-q}'[Decrease verbosity to only include error output.]' '--disable-sandbox[Disable using the sandbox when executing subprocesses]' - '--enable-netrc[Load credentials from a .netrc file]' - '--disable-netrc[Load credentials from a .netrc file]' - '--netrc-file[Specify the .netrc file path.]:netrc-file:_files' + '--netrc[Use netrc file even in cases where other credential stores are preferred]' + '--enable-netrc[Load credentials from a netrc file]' + '--disable-netrc[Load credentials from a netrc file]' + '--netrc-file[Specify the netrc file path]:netrc-file:_files' '--enable-keychain[Search credentials in macOS keychain]' '--disable-keychain[Search credentials in macOS keychain]' '--resolver-fingerprint-checking:resolver-fingerprint-checking:' + '--resolver-signing-entity-checking:resolver-signing-entity-checking:' + '--enable-signature-validation[Validate signature of a signed package release downloaded from registry]' + '--disable-signature-validation[Validate signature of a signed package release downloaded from registry]' '--enable-prefetching' '--disable-prefetching' '(--force-resolved-versions --disable-automatic-resolution --only-use-versions-from-resolved-file)'{--force-resolved-versions,--disable-automatic-resolution,--only-use-versions-from-resolved-file}'[Only use versions from the Package.resolved file and fail resolution if it is out-of-date]' @@ -78,6 +85,7 @@ _swift_run() { '--disable-scm-to-registry-transformation[disable source control to registry transformation]' '--use-registry-identity-for-scm[look up source control dependencies in the registry and use their registry identity when possible to help deduplicate across the two origins]' '--replace-scm-with-registry[look up source control dependencies in the registry and use the registry to retrieve them instead of source control when possible]' + '--default-registry-url[Default registry URL to use, instead of the registries.json configuration file]:default-registry-url:' '(--configuration -c)'{--configuration,-c}'[Build with configuration]:configuration:(debug release)' '-Xcc[Pass flag through to all C compiler invocations]:Xcc:' '-Xswiftc[Pass flag through to all Swift compiler invocations]:Xswiftc:' @@ -86,7 +94,7 @@ _swift_run() { '--triple:triple:' '--sdk:sdk:_files -/' '--toolchain:toolchain:_files -/' - '--sanitize[Turn on runtime checks for erroneous behavior, possible values: address, thread, undefined, scudo]:sanitize:' + '--sanitize[Turn on runtime checks for erroneous behavior, possible values: address, thread, undefined, scudo]:sanitize:(address thread undefined scudo)' '--auto-index-store[Enable or disable indexing-while-building feature]' '--enable-index-store[Enable or disable indexing-while-building feature]' '--disable-index-store[Enable or disable indexing-while-building feature]' @@ -94,8 +102,8 @@ _swift_run() { '(--jobs -j)'{--jobs,-j}'[The number of jobs to spawn in parallel during the build process]:jobs:' '--emit-swift-module-separately' '--use-integrated-swift-driver' + '--explicit-target-dependency-import-check:explicit-target-dependency-import-check:' '--experimental-explicit-module-build' - '--print-manifest-job-graph[Write the command graph for the build manifest as a graphviz file]' '--build-system:build-system:(native xcode)' '--enable-dead-strip[Disable/enable dead code stripping by the linker]' '--disable-dead-strip[Disable/enable dead code stripping by the linker]' @@ -125,6 +133,8 @@ _swift_build() { '--config-path[Specify the shared configuration directory path]:config-path:_files -/' '--security-path[Specify the shared security directory path]:security-path:_files -/' '--scratch-path[Specify a custom scratch directory path (default .build)]:scratch-path:_files -/' + '--pkg-config-path[Specify alternative path to search for pkg-config `.pc` files. Use the option multiple times to + specify more than one path.]:pkg-config-path:_files -/' '--enable-dependency-cache[Use a shared cache when fetching dependencies]' '--disable-dependency-cache[Use a shared cache when fetching dependencies]' '--enable-build-manifest-caching' @@ -132,13 +142,18 @@ _swift_build() { '--manifest-cache[Caching mode of Package.swift manifests (shared: shared cache, local: package'"'"'s build directory, none: disabled]:manifest-cache:' '(--verbose -v)'{--verbose,-v}'[Increase verbosity to include informational output]' '(--very-verbose --vv)'{--very-verbose,--vv}'[Increase verbosity to include debug output]' + '(--quiet -q)'{--quiet,-q}'[Decrease verbosity to only include error output.]' '--disable-sandbox[Disable using the sandbox when executing subprocesses]' - '--enable-netrc[Load credentials from a .netrc file]' - '--disable-netrc[Load credentials from a .netrc file]' - '--netrc-file[Specify the .netrc file path.]:netrc-file:_files' + '--netrc[Use netrc file even in cases where other credential stores are preferred]' + '--enable-netrc[Load credentials from a netrc file]' + '--disable-netrc[Load credentials from a netrc file]' + '--netrc-file[Specify the netrc file path]:netrc-file:_files' '--enable-keychain[Search credentials in macOS keychain]' '--disable-keychain[Search credentials in macOS keychain]' '--resolver-fingerprint-checking:resolver-fingerprint-checking:' + '--resolver-signing-entity-checking:resolver-signing-entity-checking:' + '--enable-signature-validation[Validate signature of a signed package release downloaded from registry]' + '--disable-signature-validation[Validate signature of a signed package release downloaded from registry]' '--enable-prefetching' '--disable-prefetching' '(--force-resolved-versions --disable-automatic-resolution --only-use-versions-from-resolved-file)'{--force-resolved-versions,--disable-automatic-resolution,--only-use-versions-from-resolved-file}'[Only use versions from the Package.resolved file and fail resolution if it is out-of-date]' @@ -146,6 +161,7 @@ _swift_build() { '--disable-scm-to-registry-transformation[disable source control to registry transformation]' '--use-registry-identity-for-scm[look up source control dependencies in the registry and use their registry identity when possible to help deduplicate across the two origins]' '--replace-scm-with-registry[look up source control dependencies in the registry and use the registry to retrieve them instead of source control when possible]' + '--default-registry-url[Default registry URL to use, instead of the registries.json configuration file]:default-registry-url:' '(--configuration -c)'{--configuration,-c}'[Build with configuration]:configuration:(debug release)' '-Xcc[Pass flag through to all C compiler invocations]:Xcc:' '-Xswiftc[Pass flag through to all Swift compiler invocations]:Xswiftc:' @@ -154,7 +170,7 @@ _swift_build() { '--triple:triple:' '--sdk:sdk:_files -/' '--toolchain:toolchain:_files -/' - '--sanitize[Turn on runtime checks for erroneous behavior, possible values: address, thread, undefined, scudo]:sanitize:' + '--sanitize[Turn on runtime checks for erroneous behavior, possible values: address, thread, undefined, scudo]:sanitize:(address thread undefined scudo)' '--auto-index-store[Enable or disable indexing-while-building feature]' '--enable-index-store[Enable or disable indexing-while-building feature]' '--disable-index-store[Enable or disable indexing-while-building feature]' @@ -162,8 +178,8 @@ _swift_build() { '(--jobs -j)'{--jobs,-j}'[The number of jobs to spawn in parallel during the build process]:jobs:' '--emit-swift-module-separately' '--use-integrated-swift-driver' + '--explicit-target-dependency-import-check:explicit-target-dependency-import-check:' '--experimental-explicit-module-build' - '--print-manifest-job-graph[Write the command graph for the build manifest as a graphviz file]' '--build-system:build-system:(native xcode)' '--enable-dead-strip[Disable/enable dead code stripping by the linker]' '--disable-dead-strip[Disable/enable dead code stripping by the linker]' @@ -171,6 +187,7 @@ _swift_build() { '--no-static-swift-stdlib[Link Swift stdlib statically]' '--build-tests[Build both source and test targets]' '--show-bin-path[Print the binary output path]' + '--print-manifest-job-graph[Write the command graph for the build manifest as a graphviz file]' '--target[Build the specified target]:target:' '--product[Build the specified product]:product:' '--version[Show the version.]' @@ -190,6 +207,8 @@ _swift_test() { '--config-path[Specify the shared configuration directory path]:config-path:_files -/' '--security-path[Specify the shared security directory path]:security-path:_files -/' '--scratch-path[Specify a custom scratch directory path (default .build)]:scratch-path:_files -/' + '--pkg-config-path[Specify alternative path to search for pkg-config `.pc` files. Use the option multiple times to + specify more than one path.]:pkg-config-path:_files -/' '--enable-dependency-cache[Use a shared cache when fetching dependencies]' '--disable-dependency-cache[Use a shared cache when fetching dependencies]' '--enable-build-manifest-caching' @@ -197,13 +216,18 @@ _swift_test() { '--manifest-cache[Caching mode of Package.swift manifests (shared: shared cache, local: package'"'"'s build directory, none: disabled]:manifest-cache:' '(--verbose -v)'{--verbose,-v}'[Increase verbosity to include informational output]' '(--very-verbose --vv)'{--very-verbose,--vv}'[Increase verbosity to include debug output]' + '(--quiet -q)'{--quiet,-q}'[Decrease verbosity to only include error output.]' '--disable-sandbox[Disable using the sandbox when executing subprocesses]' - '--enable-netrc[Load credentials from a .netrc file]' - '--disable-netrc[Load credentials from a .netrc file]' - '--netrc-file[Specify the .netrc file path.]:netrc-file:_files' + '--netrc[Use netrc file even in cases where other credential stores are preferred]' + '--enable-netrc[Load credentials from a netrc file]' + '--disable-netrc[Load credentials from a netrc file]' + '--netrc-file[Specify the netrc file path]:netrc-file:_files' '--enable-keychain[Search credentials in macOS keychain]' '--disable-keychain[Search credentials in macOS keychain]' '--resolver-fingerprint-checking:resolver-fingerprint-checking:' + '--resolver-signing-entity-checking:resolver-signing-entity-checking:' + '--enable-signature-validation[Validate signature of a signed package release downloaded from registry]' + '--disable-signature-validation[Validate signature of a signed package release downloaded from registry]' '--enable-prefetching' '--disable-prefetching' '(--force-resolved-versions --disable-automatic-resolution --only-use-versions-from-resolved-file)'{--force-resolved-versions,--disable-automatic-resolution,--only-use-versions-from-resolved-file}'[Only use versions from the Package.resolved file and fail resolution if it is out-of-date]' @@ -211,6 +235,7 @@ _swift_test() { '--disable-scm-to-registry-transformation[disable source control to registry transformation]' '--use-registry-identity-for-scm[look up source control dependencies in the registry and use their registry identity when possible to help deduplicate across the two origins]' '--replace-scm-with-registry[look up source control dependencies in the registry and use the registry to retrieve them instead of source control when possible]' + '--default-registry-url[Default registry URL to use, instead of the registries.json configuration file]:default-registry-url:' '(--configuration -c)'{--configuration,-c}'[Build with configuration]:configuration:(debug release)' '-Xcc[Pass flag through to all C compiler invocations]:Xcc:' '-Xswiftc[Pass flag through to all Swift compiler invocations]:Xswiftc:' @@ -219,7 +244,7 @@ _swift_test() { '--triple:triple:' '--sdk:sdk:_files -/' '--toolchain:toolchain:_files -/' - '--sanitize[Turn on runtime checks for erroneous behavior, possible values: address, thread, undefined, scudo]:sanitize:' + '--sanitize[Turn on runtime checks for erroneous behavior, possible values: address, thread, undefined, scudo]:sanitize:(address thread undefined scudo)' '--auto-index-store[Enable or disable indexing-while-building feature]' '--enable-index-store[Enable or disable indexing-while-building feature]' '--disable-index-store[Enable or disable indexing-while-building feature]' @@ -227,29 +252,77 @@ _swift_test() { '(--jobs -j)'{--jobs,-j}'[The number of jobs to spawn in parallel during the build process]:jobs:' '--emit-swift-module-separately' '--use-integrated-swift-driver' + '--explicit-target-dependency-import-check:explicit-target-dependency-import-check:' '--experimental-explicit-module-build' - '--print-manifest-job-graph[Write the command graph for the build manifest as a graphviz file]' '--build-system:build-system:(native xcode)' '--enable-dead-strip[Disable/enable dead code stripping by the linker]' '--disable-dead-strip[Disable/enable dead code stripping by the linker]' '--static-swift-stdlib[Link Swift stdlib statically]' '--no-static-swift-stdlib[Link Swift stdlib statically]' '--skip-build[Skip building the test target]' + '--test-product[Test the specified product.]:test-product:' '--parallel[Run the tests in parallel.]' '--num-workers[Number of tests to execute in parallel.]:num-workers:' '(--list-tests -l)'{--list-tests,-l}'[Lists test methods in specifier format]' - '--show-codecov-path[Print the path of the exported code coverage JSON file]' + '(--show-codecov-path --show-code-coverage-path --show-coverage-path)'{--show-codecov-path,--show-code-coverage-path,--show-coverage-path}'[Print the path of the exported code coverage JSON file]' '(-s --specifier)'{-s,--specifier}':specifier:' '--filter[Run test cases matching regular expression, Format: . or ./]:filter:' '--skip[Skip test cases matching regular expression, Example: --skip PerformanceTests]:skip:' '--xunit-output[Path where the xUnit xml file should be generated.]:xunit-output:_files -/' - '--test-product[Test the specified product.]:test-product:' '--enable-testable-imports[Enable or disable testable imports. Enabled by default.]' '--disable-testable-imports[Enable or disable testable imports. Enabled by default.]' '--enable-code-coverage[Enable code coverage]' '--disable-code-coverage[Enable code coverage]' '--version[Show the version.]' '(-help -h --help)'{-help,-h,--help}'[Show help information.]' + '(-): :->command' + '(-)*:: :->arg' + ) + _arguments -w -s -S $args[@] && ret=0 + case $state in + (command) + local subcommands + subcommands=( + 'list:Lists test methods in specifier format' + 'generate-linuxmain:Generate LinuxMain.swift (deprecated)' + ) + _describe "subcommand" subcommands + ;; + (arg) + case ${words[1]} in + (list) + _swift_test_list + ;; + (generate-linuxmain) + _swift_test_generate-linuxmain + ;; + esac + ;; + esac + + return ret +} + +_swift_test_list() { + integer ret=1 + local -a args + args+=( + '--skip-build[Skip building the test target]' + '--test-product[Test the specified product.]:test-product:' + '--version[Show the version.]' + '(-help -h --help)'{-help,-h,--help}'[Show help information.]' + ) + _arguments -w -s -S $args[@] && ret=0 + + return ret +} + +_swift_test_generate-linuxmain() { + integer ret=1 + local -a args + args+=( + '--version[Show the version.]' + '(-help -h --help)'{-help,-h,--help}'[Show help information.]' ) _arguments -w -s -S $args[@] && ret=0 @@ -265,6 +338,8 @@ _swift_package() { '--config-path[Specify the shared configuration directory path]:config-path:_files -/' '--security-path[Specify the shared security directory path]:security-path:_files -/' '--scratch-path[Specify a custom scratch directory path (default .build)]:scratch-path:_files -/' + '--pkg-config-path[Specify alternative path to search for pkg-config `.pc` files. Use the option multiple times to + specify more than one path.]:pkg-config-path:_files -/' '--enable-dependency-cache[Use a shared cache when fetching dependencies]' '--disable-dependency-cache[Use a shared cache when fetching dependencies]' '--enable-build-manifest-caching' @@ -272,13 +347,18 @@ _swift_package() { '--manifest-cache[Caching mode of Package.swift manifests (shared: shared cache, local: package'"'"'s build directory, none: disabled]:manifest-cache:' '(--verbose -v)'{--verbose,-v}'[Increase verbosity to include informational output]' '(--very-verbose --vv)'{--very-verbose,--vv}'[Increase verbosity to include debug output]' + '(--quiet -q)'{--quiet,-q}'[Decrease verbosity to only include error output.]' '--disable-sandbox[Disable using the sandbox when executing subprocesses]' - '--enable-netrc[Load credentials from a .netrc file]' - '--disable-netrc[Load credentials from a .netrc file]' - '--netrc-file[Specify the .netrc file path.]:netrc-file:_files' + '--netrc[Use netrc file even in cases where other credential stores are preferred]' + '--enable-netrc[Load credentials from a netrc file]' + '--disable-netrc[Load credentials from a netrc file]' + '--netrc-file[Specify the netrc file path]:netrc-file:_files' '--enable-keychain[Search credentials in macOS keychain]' '--disable-keychain[Search credentials in macOS keychain]' '--resolver-fingerprint-checking:resolver-fingerprint-checking:' + '--resolver-signing-entity-checking:resolver-signing-entity-checking:' + '--enable-signature-validation[Validate signature of a signed package release downloaded from registry]' + '--disable-signature-validation[Validate signature of a signed package release downloaded from registry]' '--enable-prefetching' '--disable-prefetching' '(--force-resolved-versions --disable-automatic-resolution --only-use-versions-from-resolved-file)'{--force-resolved-versions,--disable-automatic-resolution,--only-use-versions-from-resolved-file}'[Only use versions from the Package.resolved file and fail resolution if it is out-of-date]' @@ -286,6 +366,7 @@ _swift_package() { '--disable-scm-to-registry-transformation[disable source control to registry transformation]' '--use-registry-identity-for-scm[look up source control dependencies in the registry and use their registry identity when possible to help deduplicate across the two origins]' '--replace-scm-with-registry[look up source control dependencies in the registry and use the registry to retrieve them instead of source control when possible]' + '--default-registry-url[Default registry URL to use, instead of the registries.json configuration file]:default-registry-url:' '(--configuration -c)'{--configuration,-c}'[Build with configuration]:configuration:(debug release)' '-Xcc[Pass flag through to all C compiler invocations]:Xcc:' '-Xswiftc[Pass flag through to all Swift compiler invocations]:Xswiftc:' @@ -294,7 +375,7 @@ _swift_package() { '--triple:triple:' '--sdk:sdk:_files -/' '--toolchain:toolchain:_files -/' - '--sanitize[Turn on runtime checks for erroneous behavior, possible values: address, thread, undefined, scudo]:sanitize:' + '--sanitize[Turn on runtime checks for erroneous behavior, possible values: address, thread, undefined, scudo]:sanitize:(address thread undefined scudo)' '--auto-index-store[Enable or disable indexing-while-building feature]' '--enable-index-store[Enable or disable indexing-while-building feature]' '--disable-index-store[Enable or disable indexing-while-building feature]' @@ -302,8 +383,8 @@ _swift_package() { '(--jobs -j)'{--jobs,-j}'[The number of jobs to spawn in parallel during the build process]:jobs:' '--emit-swift-module-separately' '--use-integrated-swift-driver' + '--explicit-target-dependency-import-check:explicit-target-dependency-import-check:' '--experimental-explicit-module-build' - '--print-manifest-job-graph[Write the command graph for the build manifest as a graphviz file]' '--build-system:build-system:(native xcode)' '--enable-dead-strip[Disable/enable dead code stripping by the linker]' '--disable-dead-strip[Disable/enable dead code stripping by the linker]' @@ -325,25 +406,19 @@ _swift_package() { 'update:Update package dependencies' 'describe:Describe the current package' 'init:Initialize a new package' - '_format:' 'diagnose-api-breaking-changes:Diagnose API-breaking changes to Swift modules in a package' - 'experimental-api-diff:Deprecated - use `swift package diagnose-api-breaking-changes` instead' 'dump-symbol-graph:Dump Symbol Graph' - 'dump-pif:' 'dump-package:Print parsed Package.swift as JSON' 'edit:Put a package in editable mode' 'unedit:Remove a package from editable mode' 'config:Manipulate configuration of the package' 'resolve:Resolve package dependencies' - 'fetch:' 'show-dependencies:Print the resolved dependency graph' 'tools-version:Manipulate tools version of the current package' - 'generate-xcodeproj:Generates an Xcode project. This command will be deprecated soon.' 'compute-checksum:Compute the checksum for a binary artifact.' 'archive-source:Create a source archive for the package' 'completion-tool:Completion tool (for shell completions)' 'plugin:Invoke a command plugin or perform other actions on command plugins' - 'default-command:' ) _describe "subcommand" subcommands ;; @@ -367,21 +442,12 @@ _swift_package() { (init) _swift_package_init ;; - (_format) - _swift_package__format - ;; (diagnose-api-breaking-changes) _swift_package_diagnose-api-breaking-changes ;; - (experimental-api-diff) - _swift_package_experimental-api-diff - ;; (dump-symbol-graph) _swift_package_dump-symbol-graph ;; - (dump-pif) - _swift_package_dump-pif - ;; (dump-package) _swift_package_dump-package ;; @@ -397,18 +463,12 @@ _swift_package() { (resolve) _swift_package_resolve ;; - (fetch) - _swift_package_fetch - ;; (show-dependencies) _swift_package_show-dependencies ;; (tools-version) _swift_package_tools-version ;; - (generate-xcodeproj) - _swift_package_generate-xcodeproj - ;; (compute-checksum) _swift_package_compute-checksum ;; @@ -421,9 +481,6 @@ _swift_package() { (plugin) _swift_package_plugin ;; - (default-command) - _swift_package_default-command - ;; esac ;; esac @@ -498,7 +555,7 @@ _swift_package_init() { integer ret=1 local -a args args+=( - '--type[Package type: empty | library | executable | system-module | manifest]:type:' + '--type[Package type:]:type:' '--name[Provide custom package name]:name:' '--version[Show the version.]' '(-help -h --help)'{-help,-h,--help}'[Show help information.]' @@ -508,19 +565,6 @@ _swift_package_init() { return ret } -_swift_package__format() { - integer ret=1 - local -a args - args+=( - ':swift-format-flags:' - '--version[Show the version.]' - '(-help -h --help)'{-help,-h,--help}'[Show help information.]' - ) - _arguments -w -s -S $args[@] && ret=0 - - return ret -} - _swift_package_diagnose-api-breaking-changes() { integer ret=1 local -a args @@ -539,19 +583,6 @@ _swift_package_diagnose-api-breaking-changes() { return ret } -_swift_package_experimental-api-diff() { - integer ret=1 - local -a args - args+=( - ':args:' - '--version[Show the version.]' - '(-help -h --help)'{-help,-h,--help}'[Show help information.]' - ) - _arguments -w -s -S $args[@] && ret=0 - - return ret -} - _swift_package_dump-symbol-graph() { integer ret=1 local -a args @@ -561,19 +592,8 @@ _swift_package_dump-symbol-graph() { '--minimum-access-level[Include symbols with this access level or more. Possible values: private | fileprivate | internal | public | open]:minimum-access-level:(private fileprivate internal public open)' '--skip-inherited-docs[Skip emitting doc comments for members inherited through classes or default implementations.]' '--include-spi-symbols[Add symbols with SPI information to the symbol graph.]' - '--version[Show the version.]' - '(-help -h --help)'{-help,-h,--help}'[Show help information.]' - ) - _arguments -w -s -S $args[@] && ret=0 - - return ret -} - -_swift_package_dump-pif() { - integer ret=1 - local -a args - args+=( - '--preserve-structure[Preserve the internal structure of PIF]' + '--emit-extension-block-symbols[Emit extension block symbols for extensions to external types or directly associate members and conformances with the extended nominal.]' + '--omit-extension-block-symbols[Emit extension block symbols for extensions to external types or directly associate members and conformances with the extended nominal.]' '--version[Show the version.]' '(-help -h --help)'{-help,-h,--help}'[Show help information.]' ) @@ -614,7 +634,7 @@ _swift_package_unedit() { integer ret=1 local -a args args+=( - '--force[Unedit the package even if it has uncommitted and unpushed changes]' + '--force[Unedit the package even if it has uncommited and unpushed changes]' ':package-name:' '--version[Show the version.]' '(-help -h --help)'{-help,-h,--help}'[Show help information.]' @@ -666,9 +686,8 @@ _swift_package_config_set-mirror() { integer ret=1 local -a args args+=( - '--package-url[The package dependency url]:package-url:' - '--original-url[The original url]:original-url:' - '--mirror-url[The mirror url]:mirror-url:' + '--original[The original url or identity]:original:' + '--mirror[The mirror url or identity]:mirror:' '--version[Show the version.]' '(-help -h --help)'{-help,-h,--help}'[Show help information.]' ) @@ -681,9 +700,8 @@ _swift_package_config_unset-mirror() { integer ret=1 local -a args args+=( - '--package-url[The package dependency url]:package-url:' - '--original-url[The original url]:original-url:' - '--mirror-url[The mirror url]:mirror-url:' + '--original[The original url or identity]:original:' + '--mirror[The mirror url or identity]:mirror:' '--version[Show the version.]' '(-help -h --help)'{-help,-h,--help}'[Show help information.]' ) @@ -696,8 +714,7 @@ _swift_package_config_get-mirror() { integer ret=1 local -a args args+=( - '--package-url[The package dependency url]:package-url:' - '--original-url[The original url]:original-url:' + '--original[The original url or identity]:original:' '--version[Show the version.]' '(-help -h --help)'{-help,-h,--help}'[Show help information.]' ) @@ -722,22 +739,6 @@ _swift_package_resolve() { return ret } -_swift_package_fetch() { - integer ret=1 - local -a args - args+=( - '--version[The version to resolve at]:version:' - '--branch[The branch to resolve at]:branch:' - '--revision[The revision to resolve at]:revision:' - ':package-name:' - '--version[Show the version.]' - '(-help -h --help)'{-help,-h,--help}'[Show help information.]' - ) - _arguments -w -s -S $args[@] && ret=0 - - return ret -} - _swift_package_show-dependencies() { integer ret=1 local -a args @@ -766,25 +767,6 @@ _swift_package_tools-version() { return ret } -_swift_package_generate-xcodeproj() { - integer ret=1 - local -a args - args+=( - '--xcconfig-overrides[Path to xcconfig file]:xcconfig-overrides:_files' - '--output[Path where the Xcode project should be generated]:output:_files -/' - '--legacy-scheme-generator[Use the legacy scheme generator]' - '--watch[Watch for changes to the Package manifest to regenerate the Xcode project]' - '--skip-extra-files[Do not add file references for extra files to the generated Xcode project]' - '--enable-code-coverage[Enable code coverage]' - '--disable-code-coverage[Enable code coverage]' - '--version[Show the version.]' - '(-help -h --help)'{-help,-h,--help}'[Show help information.]' - ) - _arguments -w -s -S $args[@] && ret=0 - - return ret -} - _swift_package_compute-checksum() { integer ret=1 local -a args @@ -831,6 +813,7 @@ _swift_package_plugin() { '--list[List the available command plugins]' '--allow-writing-to-package-directory[Allow the plugin to write to the package directory]' '--allow-writing-to-directory[Allow the plugin to write to an additional directory]:allow-writing-to-directory:' + '--allow-network-connections:allow-network-connections:(none local all docker unixDomainSocket)' ':command:' ':arguments:' '--version[Show the version.]' @@ -841,21 +824,6 @@ _swift_package_plugin() { return ret } -_swift_package_default-command() { - integer ret=1 - local -a args - args+=( - '--allow-writing-to-package-directory[Allow the plugin to write to the package directory]' - '--allow-writing-to-directory[Allow the plugin to write to an additional directory]:allow-writing-to-directory:' - ':remaining:' - '--version[Show the version.]' - '(-help -h --help)'{-help,-h,--help}'[Show help information.]' - ) - _arguments -w -s -S $args[@] && ret=0 - - return ret -} - _swift_help() { integer ret=1 local -a args From b7e05f136640678539f90e0fa32475bd12c8d930 Mon Sep 17 00:00:00 2001 From: baltic-tea <97766478+baltic-tea@users.noreply.github.com> Date: Tue, 11 Jun 2024 02:45:09 +0300 Subject: [PATCH 645/672] feat(poetry): add aliases (#11858) --- plugins/poetry/README.md | 33 ++++++++++++++++++++++++++++++++ plugins/poetry/poetry.plugin.zsh | 28 +++++++++++++++++++++++++++ 2 files changed, 61 insertions(+) diff --git a/plugins/poetry/README.md b/plugins/poetry/README.md index 51780cbed..7b7905a41 100644 --- a/plugins/poetry/README.md +++ b/plugins/poetry/README.md @@ -7,3 +7,36 @@ To use it, add `poetry` to the plugins array in your zshrc file: ```zsh plugins=(... poetry) ``` + +## Aliases + +| Alias | Command | Description +|:----- |--------------------------------------------------- |:--------------------------------------------------------------------------------------- | +| pad | `poetry add` | Add packages to `pyproject.toml` and install them | +| pbld | `poetry build` | Build the source and wheels archives | +| pch | `poetry check` | Validate the content of the `pyproject.toml` and its consistency with the `poetry.lock` | +| pcmd | `poetry list` | Display all the available Poetry commands | +| pconf | `poetry config --list` | Allow you to edit poetry config settings and repositories | +| pexp | `poetry export --without-hashes > requirements.txt | Export the lock file to `requirements.txt` | +| pin | `poetry init` | Create a `pyproject.toml` interactively | +| pinst | `poetry install` | Read the `pyproject.toml`, resolve the dependencies, and install them | +| plck | `poetry lock` | Lock the dependencies in `pyproject.toml` without installing | +| pnew | `poetry new` | Create a directory structure suitable for most Python projects | +| ppath | `poetry env info --path` | Get the path of the currently activated virtualenv` | +| pplug | `poetry self show plugins` | List all the installed Poetry plugins | +| ppub | `poetry publish` | Publish the builded (`poetry build` command) package to the remote repository | +| prm | `poetry remove` | Remove packages from `pyproject.toml` and uninstall them | +| prun | `poetry run` | Executes the given command inside the project’s virtualenv | +| psad | `poetry self add` | Add the Poetry plugin and install dependencies to make it work | +| psh | `poetry shell` | Spawns a shell within the virtual environment. If one doesn’t exist, it will be created | +| pshw | `poetry show` | List all the available dependencies | +| pslt | `poetry show --latest` | List lastest version of the dependencies | +| psup | `poetry self update` | Update Poetry to the latest version (default) or to the specified version | +| psync | `poetry install --sync` | Synchronize your environment with the `poetry.lock` | +| ptree | `poetry show --tree` | List the dependencies as tree | +| pup | `poetry update` | Get the latest versions of the dependencies and to update the `poetry.lock` | +| pvinf | `poetry env info` | Get basic information about the currently activated virtualenv | +| pvoff | `poetry config virtualenvs.create false` | Disable automatic virtualenv creation | +| pvrm | `poetry env remove` | Delete existing virtualenvs | +| pvrma | `poetry env remove --all` | Delete all existing virtualenvs | +| pvu | `poetry env use` | Switch between existing virtualenvs | diff --git a/plugins/poetry/poetry.plugin.zsh b/plugins/poetry/poetry.plugin.zsh index cebcb46c4..fe6a0f7ed 100644 --- a/plugins/poetry/poetry.plugin.zsh +++ b/plugins/poetry/poetry.plugin.zsh @@ -1,3 +1,31 @@ +alias pad='poetry add' +alias pbld='poetry build' +alias pch='poetry check' +alias pcmd='poetry list' +alias pconf='poetry config --list' +alias pexp='poetry export --without-hashes > requirements.txt' +alias pin='poetry init' +alias pinst='poetry install' +alias plck='poetry lock' +alias pnew='poetry new' +alias ppath='poetry env info --path' +alias pplug='poetry self show plugins' +alias ppub='poetry publish' +alias prm='poetry remove' +alias prun='poetry run' +alias psad='poetry self add' +alias psh='poetry shell' +alias pshw='poetry show' +alias pslt='poetry show --latest' +alias psup='poetry self update' +alias psync='poetry install --sync' +alias ptree='poetry show --tree' +alias pup='poetry update' +alias pvinf='poetry env info' +alias pvoff='poetry config virtualenvs.create false' +alias pvrm='poetry env remove' +alias pvu='poetry env use' + # Return immediately if poetry is not found if (( ! $+commands[poetry] )); then return From 166b9dcfdc32c5ce3a2060c0c221e2df0b49fa37 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Malte=20Schl=C3=BCter?= Date: Tue, 11 Jun 2024 01:46:33 +0200 Subject: [PATCH 646/672] Add plugin for native autocompletion from Symfony 6 (#11999) --- plugins/symfony6/README.md | 9 +++ plugins/symfony6/symfony6.plugin.zsh | 82 ++++++++++++++++++++++++++++ 2 files changed, 91 insertions(+) create mode 100644 plugins/symfony6/README.md create mode 100644 plugins/symfony6/symfony6.plugin.zsh diff --git a/plugins/symfony6/README.md b/plugins/symfony6/README.md new file mode 100644 index 000000000..54611bcee --- /dev/null +++ b/plugins/symfony6/README.md @@ -0,0 +1,9 @@ +# Symfony + +This plugin provides native completion for [Symfony](https://symfony.com/), but requires at least Symfony 6.2. + +To use it add `symfony6` to the plugins array in your zshrc file. + +```bash +plugins=(... symfony6) +``` diff --git a/plugins/symfony6/symfony6.plugin.zsh b/plugins/symfony6/symfony6.plugin.zsh new file mode 100644 index 000000000..ed7dbe60e --- /dev/null +++ b/plugins/symfony6/symfony6.plugin.zsh @@ -0,0 +1,82 @@ +#compdef console + +# This file is part of the Symfony package. +# +# (c) Fabien Potencier +# +# For the full copyright and license information, please view +# https://symfony.com/doc/current/contributing/code/license.html + +# +# zsh completions for console +# +# References: +# - https://github.com/spf13/cobra/blob/master/zsh_completions.go +# - https://github.com/symfony/symfony/blob/5.4/src/Symfony/Component/Console/Resources/completion.bash +# +_sf_console() { + local lastParam flagPrefix requestComp out comp + local -a completions + + # The user could have moved the cursor backwards on the command-line. + # We need to trigger completion from the $CURRENT location, so we need + # to truncate the command-line ($words) up to the $CURRENT location. + # (We cannot use $CURSOR as its value does not work when a command is an alias.) + words=("${=words[1,CURRENT]}") lastParam=${words[-1]} + + # For zsh, when completing a flag with an = (e.g., console -n=) + # completions must be prefixed with the flag + setopt local_options BASH_REMATCH + if [[ "${lastParam}" =~ '-.*=' ]]; then + # We are dealing with a flag with an = + flagPrefix="-P ${BASH_REMATCH}" + fi + + # Prepare the command to obtain completions + requestComp="${words[0]} ${words[1]} _complete --no-interaction -szsh -a1 -c$((CURRENT-1))" i="" + for w in ${words[@]}; do + w=$(printf -- '%b' "$w") + # remove quotes from typed values + quote="${w:0:1}" + if [ "$quote" = \' ]; then + w="${w%\'}" + w="${w#\'}" + elif [ "$quote" = \" ]; then + w="${w%\"}" + w="${w#\"}" + fi + # empty values are ignored + if [ ! -z "$w" ]; then + i="${i}-i${w} " + fi + done + + # Ensure at least 1 input + if [ "${i}" = "" ]; then + requestComp="${requestComp} -i\" \"" + else + requestComp="${requestComp} ${i}" + fi + + # Use eval to handle any environment variables and such + out=$(eval ${requestComp} 2>/dev/null) + + while IFS='\n' read -r comp; do + if [ -n "$comp" ]; then + # If requested, completions are returned with a description. + # The description is preceded by a TAB character. + # For zsh's _describe, we need to use a : instead of a TAB. + # We first need to escape any : as part of the completion itself. + comp=${comp//:/\\:} + local tab=$(printf '\t') + comp=${comp//$tab/:} + completions+=${comp} + fi + done < <(printf "%s\n" "${out[@]}") + + # Let inbuilt _describe handle completions + eval _describe "completions" completions $flagPrefix + return $? +} + +compdef _sf_console console From 83014bd9458b870c93fd18642484b305d7e5340b Mon Sep 17 00:00:00 2001 From: Robby Russell Date: Mon, 10 Jun 2024 16:47:55 -0700 Subject: [PATCH 647/672] Revert "Add plugin for native autocompletion from Symfony 6 (#11999)" (#12493) This reverts commit 166b9dcfdc32c5ce3a2060c0c221e2df0b49fa37. --- plugins/symfony6/README.md | 9 --- plugins/symfony6/symfony6.plugin.zsh | 82 ---------------------------- 2 files changed, 91 deletions(-) delete mode 100644 plugins/symfony6/README.md delete mode 100644 plugins/symfony6/symfony6.plugin.zsh diff --git a/plugins/symfony6/README.md b/plugins/symfony6/README.md deleted file mode 100644 index 54611bcee..000000000 --- a/plugins/symfony6/README.md +++ /dev/null @@ -1,9 +0,0 @@ -# Symfony - -This plugin provides native completion for [Symfony](https://symfony.com/), but requires at least Symfony 6.2. - -To use it add `symfony6` to the plugins array in your zshrc file. - -```bash -plugins=(... symfony6) -``` diff --git a/plugins/symfony6/symfony6.plugin.zsh b/plugins/symfony6/symfony6.plugin.zsh deleted file mode 100644 index ed7dbe60e..000000000 --- a/plugins/symfony6/symfony6.plugin.zsh +++ /dev/null @@ -1,82 +0,0 @@ -#compdef console - -# This file is part of the Symfony package. -# -# (c) Fabien Potencier -# -# For the full copyright and license information, please view -# https://symfony.com/doc/current/contributing/code/license.html - -# -# zsh completions for console -# -# References: -# - https://github.com/spf13/cobra/blob/master/zsh_completions.go -# - https://github.com/symfony/symfony/blob/5.4/src/Symfony/Component/Console/Resources/completion.bash -# -_sf_console() { - local lastParam flagPrefix requestComp out comp - local -a completions - - # The user could have moved the cursor backwards on the command-line. - # We need to trigger completion from the $CURRENT location, so we need - # to truncate the command-line ($words) up to the $CURRENT location. - # (We cannot use $CURSOR as its value does not work when a command is an alias.) - words=("${=words[1,CURRENT]}") lastParam=${words[-1]} - - # For zsh, when completing a flag with an = (e.g., console -n=) - # completions must be prefixed with the flag - setopt local_options BASH_REMATCH - if [[ "${lastParam}" =~ '-.*=' ]]; then - # We are dealing with a flag with an = - flagPrefix="-P ${BASH_REMATCH}" - fi - - # Prepare the command to obtain completions - requestComp="${words[0]} ${words[1]} _complete --no-interaction -szsh -a1 -c$((CURRENT-1))" i="" - for w in ${words[@]}; do - w=$(printf -- '%b' "$w") - # remove quotes from typed values - quote="${w:0:1}" - if [ "$quote" = \' ]; then - w="${w%\'}" - w="${w#\'}" - elif [ "$quote" = \" ]; then - w="${w%\"}" - w="${w#\"}" - fi - # empty values are ignored - if [ ! -z "$w" ]; then - i="${i}-i${w} " - fi - done - - # Ensure at least 1 input - if [ "${i}" = "" ]; then - requestComp="${requestComp} -i\" \"" - else - requestComp="${requestComp} ${i}" - fi - - # Use eval to handle any environment variables and such - out=$(eval ${requestComp} 2>/dev/null) - - while IFS='\n' read -r comp; do - if [ -n "$comp" ]; then - # If requested, completions are returned with a description. - # The description is preceded by a TAB character. - # For zsh's _describe, we need to use a : instead of a TAB. - # We first need to escape any : as part of the completion itself. - comp=${comp//:/\\:} - local tab=$(printf '\t') - comp=${comp//$tab/:} - completions+=${comp} - fi - done < <(printf "%s\n" "${out[@]}") - - # Let inbuilt _describe handle completions - eval _describe "completions" completions $flagPrefix - return $? -} - -compdef _sf_console console From 4295aed17b4b1180b7e42bd7debd7685686c1307 Mon Sep 17 00:00:00 2001 From: Robby Russell Date: Mon, 10 Jun 2024 16:49:59 -0700 Subject: [PATCH 648/672] feat(symfony6): Add plugin for native autocompletion from Symfony 6 This reverts commit 83014bd9458b870c93fd18642484b305d7e5340b. --- plugins/symfony6/README.md | 9 +++ plugins/symfony6/symfony6.plugin.zsh | 82 ++++++++++++++++++++++++++++ 2 files changed, 91 insertions(+) create mode 100644 plugins/symfony6/README.md create mode 100644 plugins/symfony6/symfony6.plugin.zsh diff --git a/plugins/symfony6/README.md b/plugins/symfony6/README.md new file mode 100644 index 000000000..54611bcee --- /dev/null +++ b/plugins/symfony6/README.md @@ -0,0 +1,9 @@ +# Symfony + +This plugin provides native completion for [Symfony](https://symfony.com/), but requires at least Symfony 6.2. + +To use it add `symfony6` to the plugins array in your zshrc file. + +```bash +plugins=(... symfony6) +``` diff --git a/plugins/symfony6/symfony6.plugin.zsh b/plugins/symfony6/symfony6.plugin.zsh new file mode 100644 index 000000000..ed7dbe60e --- /dev/null +++ b/plugins/symfony6/symfony6.plugin.zsh @@ -0,0 +1,82 @@ +#compdef console + +# This file is part of the Symfony package. +# +# (c) Fabien Potencier +# +# For the full copyright and license information, please view +# https://symfony.com/doc/current/contributing/code/license.html + +# +# zsh completions for console +# +# References: +# - https://github.com/spf13/cobra/blob/master/zsh_completions.go +# - https://github.com/symfony/symfony/blob/5.4/src/Symfony/Component/Console/Resources/completion.bash +# +_sf_console() { + local lastParam flagPrefix requestComp out comp + local -a completions + + # The user could have moved the cursor backwards on the command-line. + # We need to trigger completion from the $CURRENT location, so we need + # to truncate the command-line ($words) up to the $CURRENT location. + # (We cannot use $CURSOR as its value does not work when a command is an alias.) + words=("${=words[1,CURRENT]}") lastParam=${words[-1]} + + # For zsh, when completing a flag with an = (e.g., console -n=) + # completions must be prefixed with the flag + setopt local_options BASH_REMATCH + if [[ "${lastParam}" =~ '-.*=' ]]; then + # We are dealing with a flag with an = + flagPrefix="-P ${BASH_REMATCH}" + fi + + # Prepare the command to obtain completions + requestComp="${words[0]} ${words[1]} _complete --no-interaction -szsh -a1 -c$((CURRENT-1))" i="" + for w in ${words[@]}; do + w=$(printf -- '%b' "$w") + # remove quotes from typed values + quote="${w:0:1}" + if [ "$quote" = \' ]; then + w="${w%\'}" + w="${w#\'}" + elif [ "$quote" = \" ]; then + w="${w%\"}" + w="${w#\"}" + fi + # empty values are ignored + if [ ! -z "$w" ]; then + i="${i}-i${w} " + fi + done + + # Ensure at least 1 input + if [ "${i}" = "" ]; then + requestComp="${requestComp} -i\" \"" + else + requestComp="${requestComp} ${i}" + fi + + # Use eval to handle any environment variables and such + out=$(eval ${requestComp} 2>/dev/null) + + while IFS='\n' read -r comp; do + if [ -n "$comp" ]; then + # If requested, completions are returned with a description. + # The description is preceded by a TAB character. + # For zsh's _describe, we need to use a : instead of a TAB. + # We first need to escape any : as part of the completion itself. + comp=${comp//:/\\:} + local tab=$(printf '\t') + comp=${comp//$tab/:} + completions+=${comp} + fi + done < <(printf "%s\n" "${out[@]}") + + # Let inbuilt _describe handle completions + eval _describe "completions" completions $flagPrefix + return $? +} + +compdef _sf_console console From 59e8e028e179fc126d46254900946953072048e7 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Wed, 12 Jun 2024 10:32:30 +0200 Subject: [PATCH 649/672] fix(lib/git): turn off async prompt for zsh < 5.0.6 We removed this mitigation in 0c80a063 because of an assumption that the issue had been fixed, but it looks like zsh < 5.0.6 has other issues (see #12360), so we need to disable it for real. Fixes #12360 --- lib/git.zsh | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/lib/git.zsh b/lib/git.zsh index b257d01a4..db6c9174c 100644 --- a/lib/git.zsh +++ b/lib/git.zsh @@ -39,8 +39,13 @@ function _omz_git_prompt_info() { echo "${ZSH_THEME_GIT_PROMPT_PREFIX}${ref:gs/%/%%}${upstream:gs/%/%%}$(parse_git_dirty)${ZSH_THEME_GIT_PROMPT_SUFFIX}" } -# Use async version if setting is enabled or undefined -if zstyle -T ':omz:alpha:lib:git' async-prompt; then +# Use async version if setting is enabled, or unset but zsh version is at least 5.0.6. +# This avoids async prompt issues caused by previous zsh versions: +# - https://github.com/ohmyzsh/ohmyzsh/issues/12331 +# - https://github.com/ohmyzsh/ohmyzsh/issues/12360 +# TODO(2024-06-12): @mcornella remove workaround when CentOS 7 reaches EOL +if zstyle -t ':omz:alpha:lib:git' async-prompt \ + || { is-at-least 5.0.6 && zstyle -T ':omz:alpha:lib:git' async-prompt }; then function git_prompt_info() { if [[ -n "${_OMZ_ASYNC_OUTPUT[_omz_git_prompt_info]}" ]]; then echo -n "${_OMZ_ASYNC_OUTPUT[_omz_git_prompt_info]}" From 35a6725970167278254ab11a996bf04d2186b009 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Wed, 12 Jun 2024 11:04:05 +0200 Subject: [PATCH 650/672] fix(history): add warning before deleting command history in `history -c` (#12472) --- lib/history.zsh | 14 +++++++++++--- 1 file changed, 11 insertions(+), 3 deletions(-) diff --git a/lib/history.zsh b/lib/history.zsh index a8431fd5a..b13e1807f 100644 --- a/lib/history.zsh +++ b/lib/history.zsh @@ -1,14 +1,22 @@ ## History wrapper function omz_history { # parse arguments and remove from $@ - local clear list stamp + local clear list stamp REPLY zparseopts -E -D c=clear l=list f=stamp E=stamp i=stamp t:=stamp if [[ -n "$clear" ]]; then # if -c provided, clobber the history file - echo -n >| "$HISTFILE" + + # confirm action before deleting history + print -nu2 "This action will irreversibly delete your command history. Are you sure? [y/N] " + builtin read -k1 + [[ "$REPLY" = $'\n' ]] || print -u2 + [[ "$REPLY" != ([nN]|$'\n') ]] || return 0 + + print -nu2 >| "$HISTFILE" fc -p "$HISTFILE" - echo >&2 History file deleted. + + print -u2 History file deleted. elif [[ $# -eq 0 ]]; then # if no arguments provided, show full history starting from 1 builtin fc $stamp -l 1 From fee61a7c4731a1835dfc13f4e6ddc8482d5f1d01 Mon Sep 17 00:00:00 2001 From: Manuel Faux Date: Wed, 12 Jun 2024 12:19:48 +0200 Subject: [PATCH 651/672] fix(screen): Prevent title being overwritten (#4633) lib/termsupport.zsh creates titles for screen which take precedence over titles set by the screen plugin. Unsetting the title() function within the screen plugin prevent this "race-condition". --- plugins/screen/screen.plugin.zsh | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/plugins/screen/screen.plugin.zsh b/plugins/screen/screen.plugin.zsh index 26531c40b..375d8750a 100644 --- a/plugins/screen/screen.plugin.zsh +++ b/plugins/screen/screen.plugin.zsh @@ -1,6 +1,10 @@ # if using GNU screen, let the zsh tell screen what the title and hardstatus # of the tab window should be. if [[ "$TERM" == screen* ]]; then + # Unset title() function defined in lib/termsupport.zsh to prevent + # overwriting our screen titles + title(){} + if [[ $_GET_PATH == '' ]]; then _GET_PATH='echo $PWD | sed "s/^\/Users\//~/;s/^\/home\//~/;s/^~$USERNAME/~/"' fi From 6754b7e67b71511c8c06b75be6d4d06a386acbda Mon Sep 17 00:00:00 2001 From: Mayu Laierlence Date: Wed, 12 Jun 2024 12:28:13 +0200 Subject: [PATCH 652/672] feat(init): add custom functions and completions to `$fpath` (#5644) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Closes #5644 Co-authored-by: Marc Cornellà --- oh-my-zsh.sh | 2 +- .../history-substring-search.plugin.zsh | 1 - 2 files changed, 1 insertion(+), 2 deletions(-) diff --git a/oh-my-zsh.sh b/oh-my-zsh.sh index 2fb20298a..9660f93c9 100644 --- a/oh-my-zsh.sh +++ b/oh-my-zsh.sh @@ -71,7 +71,7 @@ source "$ZSH/tools/check_for_upgrade.sh" # Initializes Oh My Zsh # add a function path -fpath=("$ZSH/functions" "$ZSH/completions" $fpath) +fpath=($ZSH/{functions,completions} $ZSH_CUSTOM/{functions,completions} $fpath) # Load all stock functions (from $fpath files) called below. autoload -U compaudit compinit zrecompile diff --git a/plugins/history-substring-search/history-substring-search.plugin.zsh b/plugins/history-substring-search/history-substring-search.plugin.zsh index 63f0bdd42..077105ea3 100644 --- a/plugins/history-substring-search/history-substring-search.plugin.zsh +++ b/plugins/history-substring-search/history-substring-search.plugin.zsh @@ -16,4 +16,3 @@ if [[ -n "$terminfo[kcud1]" ]]; then bindkey -M emacs "$terminfo[kcud1]" history-substring-search-down bindkey -M viins "$terminfo[kcud1]" history-substring-search-down fi - From 11e84bf4f783100c162f2273d72fccc22eb2756d Mon Sep 17 00:00:00 2001 From: Gabriel Charland <76267249+gcharland1@users.noreply.github.com> Date: Wed, 12 Jun 2024 12:52:54 -0400 Subject: [PATCH 653/672] feat(shrink-path): allow for showing `N` last-full elements (#12481) This commit allows specifying a number of last segments to be fully shown, either via `-l N` or with `zstyle`. --- plugins/shrink-path/shrink-path.plugin.zsh | 25 +++++++++++++++++----- 1 file changed, 20 insertions(+), 5 deletions(-) diff --git a/plugins/shrink-path/shrink-path.plugin.zsh b/plugins/shrink-path/shrink-path.plugin.zsh index 373fd5b05..1739f9234 100644 --- a/plugins/shrink-path/shrink-path.plugin.zsh +++ b/plugins/shrink-path/shrink-path.plugin.zsh @@ -56,7 +56,16 @@ shrink_path () { tilde=1 named=1 fi - zstyle -t ':prompt:shrink_path' last && lastfull=1 + + local last + zstyle -s ':prompt:shrink_path' last last + case "$last" in + (false|no|off|0) lastfull=0 ;; + (true|yes|on|1) lastfull=1 ;; + (""|*[^0-9]*) lastfull=0 ;; + (*) lastfull=$last ;; + esac + zstyle -t ':prompt:shrink_path' short && short=1 zstyle -t ':prompt:shrink_path' tilde && tilde=1 zstyle -t ':prompt:shrink_path' glob && ellipsis='*' @@ -78,7 +87,7 @@ shrink_path () { print 'Usage: shrink_path [-f -l -s -t] [directory]' print ' -f, --fish fish-simulation, like -l -s -t' print ' -g, --glob Add asterisk to allow globbing of shrunk path (equivalent to -e "*")' - print ' -l, --last Print the last directory''s full name' + print ' -l, --last [#] Print the last n directory''s full name (default 1).' print ' -s, --short Truncate directory names to the number of characters given by -#. Without' print ' -s, names are truncated without making them ambiguous.' print ' -t, --tilde Substitute ~ for the home directory' @@ -93,7 +102,13 @@ shrink_path () { print ' zstyle :prompt:shrink_path fish yes' return 0 ;; - -l|--last) lastfull=1 ;; + -l|--last) + lastfull=1 + if [[ -n "$2" && "$2" != *[^0-9]* ]]; then + shift + lastfull=$1 + fi + ;; -s|--short) short=1 ;; -t|--tilde) tilde=1 ;; -T|--nameddirs) @@ -148,8 +163,8 @@ shrink_path () { cd -q / } for dir in $tree; { - if (( lastfull && $#tree == 1 )) { - result+="/$tree" + if (( lastfull && $#tree <= lastfull )) { + result+="/${(j:/:)tree[@]}" break } expn=(a b) From 6c021fd432aae13ef594342f9b3739ccaca4fcdc Mon Sep 17 00:00:00 2001 From: "Nathaniel.Belles" <36868971+Nbelles@users.noreply.github.com> Date: Wed, 12 Jun 2024 13:07:01 -0400 Subject: [PATCH 654/672] fix(timer): skip timer after running `clear` (#12370) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Co-authored-by: Marc Cornellà --- plugins/timer/timer.plugin.zsh | 3 +++ 1 file changed, 3 insertions(+) diff --git a/plugins/timer/timer.plugin.zsh b/plugins/timer/timer.plugin.zsh index b261f71c5..d21d59989 100644 --- a/plugins/timer/timer.plugin.zsh +++ b/plugins/timer/timer.plugin.zsh @@ -23,9 +23,12 @@ __timer_display_timer_precmd() { local tdiff=$((cmd_end_time - __timer_cmd_start_time)) unset __timer_cmd_start_time if [[ -z "${TIMER_THRESHOLD}" || ${tdiff} -ge "${TIMER_THRESHOLD}" ]]; then + local last_cmd="${history[$((HISTCMD - 1))]%% *}" + if [[ "$last_cmd" != clear ]]; then local tdiffstr=$(__timer_format_duration ${tdiff}) local cols=$((COLUMNS - ${#tdiffstr} - 1)) echo -e "\033[1A\033[${cols}C ${tdiffstr}" + fi fi fi } From 8908e6d7207223d876b9a74f0be0f0ebb01b361f Mon Sep 17 00:00:00 2001 From: Nick Glenn <78454343+Sargates@users.noreply.github.com> Date: Thu, 13 Jun 2024 02:26:17 -0500 Subject: [PATCH 655/672] fix(history): fix logic error in prompt for `history -c` (#12500) Logic error in `history -c` when prompting for confirmation caused history to be deleted when typing anything but explicitly `n`, `N`, or sending `\n`. New logic prevents deletion by pressing wrong key and only deletes history when sending `y` or `Y`. Co-authored-by: Sargates --- lib/history.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/history.zsh b/lib/history.zsh index b13e1807f..1093ea80f 100644 --- a/lib/history.zsh +++ b/lib/history.zsh @@ -11,7 +11,7 @@ function omz_history { print -nu2 "This action will irreversibly delete your command history. Are you sure? [y/N] " builtin read -k1 [[ "$REPLY" = $'\n' ]] || print -u2 - [[ "$REPLY" != ([nN]|$'\n') ]] || return 0 + [[ "$REPLY" != ([yY]) ]] && return 0 print -nu2 >| "$HISTFILE" fc -p "$HISTFILE" From 0c9b42a863778d67aee22bbd43f296110fe1f047 Mon Sep 17 00:00:00 2001 From: Tim Abell Date: Thu, 13 Jun 2024 17:08:14 +0100 Subject: [PATCH 656/672] docs(alias-finder): add some examples (#12502) --- plugins/alias-finder/README.md | 37 +++++++++++++++++++++++++++++++++- 1 file changed, 36 insertions(+), 1 deletion(-) diff --git a/plugins/alias-finder/README.md b/plugins/alias-finder/README.md index 6c87c723a..a9bbd0838 100644 --- a/plugins/alias-finder/README.md +++ b/plugins/alias-finder/README.md @@ -2,7 +2,7 @@ This plugin searches the defined aliases and outputs any that match the command inputted. This makes learning new aliases easier. -## Usage +## Setup To use it, add `alias-finder` to the `plugins` array of your zshrc file: ``` @@ -22,6 +22,41 @@ zstyle ':omz:plugins:alias-finder' cheaper yes # disabled by default As you can see, options are also available with zstyle. +## Usage + +When you execute a command alias finder will look at your defined aliases and suggest shorter aliases you could have used, for example: + +Running the un-aliased `git status` command: +```sh +╭─tim@fox ~/repo/gitopolis ‹main› +╰─$ git status + +gst='git status' # <=== shorter suggestion from alias-finder + +On branch main +Your branch is up-to-date with 'origin/main'. +nothing to commit, working tree clean +``` + +Running a shorter `git st` alias from `.gitconfig` that it suggested : +```sh +╭─tim@fox ~/repo/gitopolis ‹main› +╰─$ git st +gs='git st' # <=== shorter suggestion from alias-finder +## main...origin/main +``` + +Running the shortest `gs` shell alias that it found: +```sh +╭─tim@fox ~/repo/gitopolis ‹main› +╰─$ gs + # <=== no suggestions alias-finder because this is the shortest +## main...origin/main +``` + +![image](https://github.com/ohmyzsh/ohmyzsh/assets/19378/39642750-fb10-4f1a-b7f9-f36789eeb01b) + + ### Options > In order to clarify, let's say `alias a=abc` has source 'abc' and destination 'a'. From 6fe78e06291bdf6fc62b805b0171e16a6b71eee1 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Sat, 15 Jun 2024 17:39:32 +0200 Subject: [PATCH 657/672] chore: better document top-level custom files for aliases (#12504) See discussion in https://github.com/ohmyzsh/ohmyzsh/discussions/12504 --- templates/zshrc.zsh-template | 13 ++++++++----- 1 file changed, 8 insertions(+), 5 deletions(-) diff --git a/templates/zshrc.zsh-template b/templates/zshrc.zsh-template index a73d60799..89fd0780e 100644 --- a/templates/zshrc.zsh-template +++ b/templates/zshrc.zsh-template @@ -1,11 +1,11 @@ # If you come from bash you might have to change your $PATH. # export PATH=$HOME/bin:$HOME/.local/bin:/usr/local/bin:$PATH -# Path to your oh-my-zsh installation. +# Path to your Oh My Zsh installation. export ZSH=$HOME/.oh-my-zsh # Set name of the theme to load --- if set to "random", it will -# load a random theme each time oh-my-zsh is loaded, in which case, +# load a random theme each time Oh My Zsh is loaded, in which case, # to know which specific one was loaded, run: echo $RANDOM_THEME # See https://github.com/ohmyzsh/ohmyzsh/wiki/Themes ZSH_THEME="robbyrussell" @@ -91,9 +91,12 @@ source $ZSH/oh-my-zsh.sh # Compilation flags # export ARCHFLAGS="-arch x86_64" -# Set personal aliases, overriding those provided by oh-my-zsh libs, -# plugins, and themes. Aliases can be placed here, though oh-my-zsh -# users are encouraged to define aliases within the ZSH_CUSTOM folder. +# Set personal aliases, overriding those provided by Oh My Zsh libs, +# plugins, and themes. Aliases can be placed here, though Oh My Zsh +# users are encouraged to define aliases within a top-level file in +# the $ZSH_CUSTOM folder, with .zsh extension. Examples: +# - $ZSH_CUSTOM/aliases.zsh +# - $ZSH_CUSTOM/macos.zsh # For a full list of active aliases, run `alias`. # # Example aliases From 677f5010daf226509cc19d7244a689df82820c82 Mon Sep 17 00:00:00 2001 From: "ohmyzsh[bot]" <54982679+ohmyzsh[bot]@users.noreply.github.com> Date: Sun, 16 Jun 2024 08:44:44 +0200 Subject: [PATCH 658/672] feat(wd): update to 498695ff (#12507) Closes #12489 Co-authored-by: ohmyzsh[bot] <54982679+ohmyzsh[bot]@users.noreply.github.com> --- .github/dependencies.yml | 2 +- plugins/wd/wd.sh | 10 ++++++---- 2 files changed, 7 insertions(+), 5 deletions(-) diff --git a/.github/dependencies.yml b/.github/dependencies.yml index ce28e34c9..43ec92fb7 100644 --- a/.github/dependencies.yml +++ b/.github/dependencies.yml @@ -39,7 +39,7 @@ dependencies: plugins/wd: repo: mfaerevaag/wd branch: master - version: tag:v0.7.0 + version: tag:v0.7.1 precopy: | set -e rm -r test diff --git a/plugins/wd/wd.sh b/plugins/wd/wd.sh index 160ab3be3..34f887a0e 100755 --- a/plugins/wd/wd.sh +++ b/plugins/wd/wd.sh @@ -261,9 +261,9 @@ wd_browse() { local entries=("${(@f)$(sed "s:${HOME}:~:g" "$WD_CONFIG" | awk -F ':' '{print $1 " -> " $2}')}") local script_path="${${(%):-%x}:h}" local wd_remove_output=$(mktemp "${TMPDIR:-/tmp}/wd.XXXXXXXXXX") - local entries_with_headers=("All warp points:" "Press enter to select. Press delete to remove" "${entries[@]}") + entries=("All warp points:" "Press enter to select. Press delete to remove" "${entries[@]}") local fzf_bind="delete:execute(echo {} | awk -F ' -> ' '{print \$1}' | xargs -I {} "$script_path/wd.sh" rm {} > "$wd_remove_output")+abort" - local fzf_command=$(printf '%s\n' "${entries_with_headers[@]}" | fzf --height 100% --reverse --header-lines=2 --bind="$fzf_bind") + local selected_entry=$(printf '%s\n' "${entries[@]}" | fzf --height 100% --reverse --header-lines=2 --bind="$fzf_bind") if [[ -e $wd_remove_output ]]; then cat "$wd_remove_output" rm "$wd_remove_output" @@ -287,8 +287,10 @@ wd_browse_widget() { } wd_restore_buffer() { - BUFFER=$saved_buffer - CURSOR=$saved_cursor + if [[ -n $saved_buffer ]]; then + BUFFER=$saved_buffer + CURSOR=$saved_cursor + fi saved_buffer= saved_cursor=1 } From 7e4ee3a3cd9b8bb287ad334035002b4ce1cd332c Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Mon, 17 Jun 2024 20:37:21 +0200 Subject: [PATCH 659/672] fix(encode64): use proper encode file flags Fixes #12509 --- plugins/encode64/encode64.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/encode64/encode64.plugin.zsh b/plugins/encode64/encode64.plugin.zsh index 6927f5216..8e6fdb169 100644 --- a/plugins/encode64/encode64.plugin.zsh +++ b/plugins/encode64/encode64.plugin.zsh @@ -10,7 +10,7 @@ encodefile64() { if [[ $# -eq 0 ]]; then echo "You must provide a filename" else - base64 -i $1 -o $1.txt + base64 $1 > $1.txt echo "${1}'s content encoded in base64 and saved as ${1}.txt" fi } From 373a1fd585a09b680fec0fc3a3c22901d86c0a4d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?S=C3=A9bastien=20MB?= Date: Mon, 17 Jun 2024 21:38:21 +0200 Subject: [PATCH 660/672] fix(essembeh): use async prompt (#12512) --- themes/essembeh.zsh-theme | 16 +--------------- 1 file changed, 1 insertion(+), 15 deletions(-) diff --git a/themes/essembeh.zsh-theme b/themes/essembeh.zsh-theme index 50b3f7772..65abe3a83 100644 --- a/themes/essembeh.zsh-theme +++ b/themes/essembeh.zsh-theme @@ -11,21 +11,7 @@ # git plugin ZSH_THEME_GIT_PROMPT_PREFIX="%{$fg[cyan]%}(" ZSH_THEME_GIT_PROMPT_SUFFIX=") %{$reset_color%}" -ZSH_THEME_GIT_PROMPT_UNTRACKED="%%" -ZSH_THEME_GIT_PROMPT_ADDED="+" -ZSH_THEME_GIT_PROMPT_MODIFIED="*" -ZSH_THEME_GIT_PROMPT_RENAMED="~" -ZSH_THEME_GIT_PROMPT_DELETED="!" -ZSH_THEME_GIT_PROMPT_UNMERGED="?" -function zsh_essembeh_gitstatus { - ref=$(git symbolic-ref HEAD 2> /dev/null) || return - GIT_STATUS=$(git_prompt_status) - if [[ -n $GIT_STATUS ]]; then - GIT_STATUS=" $GIT_STATUS" - fi - echo "$ZSH_THEME_GIT_PROMPT_PREFIX${ref#refs/heads/}$GIT_STATUS$ZSH_THEME_GIT_PROMPT_SUFFIX" -} # by default, use green for user@host and no prefix local ZSH_ESSEMBEH_COLOR="green" @@ -46,5 +32,5 @@ if [[ $UID = 0 ]]; then # always use magenta for root sessions, even in ssh ZSH_ESSEMBEH_COLOR="magenta" fi -PROMPT='${ZSH_ESSEMBEH_PREFIX}%{$fg[$ZSH_ESSEMBEH_COLOR]%}%n@%M%{$reset_color%}:%{%B$fg[yellow]%}%~%{$reset_color%b%} $(zsh_essembeh_gitstatus)%(!.#.$) ' +PROMPT='${ZSH_ESSEMBEH_PREFIX}%{$fg[$ZSH_ESSEMBEH_COLOR]%}%n@%M%{$reset_color%}:%{%B$fg[yellow]%}%~%{$reset_color%b%} $(git_prompt_info)%(!.#.$) ' RPROMPT="%(?..%{$fg[red]%}%?%{$reset_color%})" From c83ca51b1b2fce89c5eae0b0bc9600ee4df28e08 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Tue, 18 Jun 2024 07:26:38 +0200 Subject: [PATCH 661/672] fix(history): fix confirmation prompt to allow bypass See https://github.com/ohmyzsh/ohmyzsh/issues/12472#issuecomment-2171461005 --- lib/history.zsh | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/lib/history.zsh b/lib/history.zsh index 1093ea80f..fa3db927e 100644 --- a/lib/history.zsh +++ b/lib/history.zsh @@ -9,9 +9,8 @@ function omz_history { # confirm action before deleting history print -nu2 "This action will irreversibly delete your command history. Are you sure? [y/N] " - builtin read -k1 - [[ "$REPLY" = $'\n' ]] || print -u2 - [[ "$REPLY" != ([yY]) ]] && return 0 + builtin read + [[ "$REPLY" = [yY] ]] || return 0 print -nu2 >| "$HISTFILE" fc -p "$HISTFILE" From f2769acdfa283c663bb1bf2b98890766622e410c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Tue, 18 Jun 2024 13:32:22 +0200 Subject: [PATCH 662/672] chore(history): show input in confirmation prompt Fixes https://github.com/ohmyzsh/ohmyzsh/issues/12472#issuecomment-2175868971 --- lib/history.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/history.zsh b/lib/history.zsh index fa3db927e..35da57de2 100644 --- a/lib/history.zsh +++ b/lib/history.zsh @@ -9,7 +9,7 @@ function omz_history { # confirm action before deleting history print -nu2 "This action will irreversibly delete your command history. Are you sure? [y/N] " - builtin read + builtin read -E [[ "$REPLY" = [yY] ]] || return 0 print -nu2 >| "$HISTFILE" From c432ca09932bb0c2f2f7f8862b949b0875615724 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Tue, 18 Jun 2024 13:40:27 +0200 Subject: [PATCH 663/672] chore(deps): bump `urllib3` to 2.2.2 in `dependencies` workflow (#12516) Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> --- .github/workflows/dependencies/requirements.txt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/dependencies/requirements.txt b/.github/workflows/dependencies/requirements.txt index 7e840a74c..743d838b5 100644 --- a/.github/workflows/dependencies/requirements.txt +++ b/.github/workflows/dependencies/requirements.txt @@ -4,4 +4,4 @@ idna==3.7 PyYAML==6.0.1 requests==2.31.0 semver==3.0.2 -urllib3==2.2.1 +urllib3==2.2.2 From a87e9c715b2d3249681f9cc8f8d9718030674d50 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marc=20Cornell=C3=A0?= Date: Thu, 20 Jun 2024 19:51:51 +0200 Subject: [PATCH 664/672] fix(init): fix definition order for `$ZSH_CUSTOM` Tipped about this in https://github.com/ohmyzsh/ohmyzsh/commit/6754b7e67#commitcomment-143280115 --- oh-my-zsh.sh | 16 ++++++---------- 1 file changed, 6 insertions(+), 10 deletions(-) diff --git a/oh-my-zsh.sh b/oh-my-zsh.sh index 9660f93c9..694095afa 100644 --- a/oh-my-zsh.sh +++ b/oh-my-zsh.sh @@ -48,13 +48,15 @@ omz_f() { unset -f omz_f # If ZSH is not defined, use the current script's directory. -[[ -z "$ZSH" ]] && export ZSH="${${(%):-%x}:a:h}" +[[ -n "$ZSH" ]] || export ZSH="${${(%):-%x}:a:h}" + +# Set ZSH_CUSTOM to the path where your custom config files +# and plugins exists, or else we will use the default custom/ +[[ -n "$ZSH_CUSTOM" ]] || ZSH_CUSTOM="$ZSH/custom" # Set ZSH_CACHE_DIR to the path where cache files should be created # or else we will use the default cache/ -if [[ -z "$ZSH_CACHE_DIR" ]]; then - ZSH_CACHE_DIR="$ZSH/cache" -fi +[[ -n "$ZSH_CACHE_DIR" ]] || ZSH_CACHE_DIR="$ZSH/cache" # Make sure $ZSH_CACHE_DIR is writable, otherwise use a directory in $HOME if [[ ! -w "$ZSH_CACHE_DIR" ]]; then @@ -76,12 +78,6 @@ fpath=($ZSH/{functions,completions} $ZSH_CUSTOM/{functions,completions} $fpath) # Load all stock functions (from $fpath files) called below. autoload -U compaudit compinit zrecompile -# Set ZSH_CUSTOM to the path where your custom config files -# and plugins exists, or else we will use the default custom/ -if [[ -z "$ZSH_CUSTOM" ]]; then - ZSH_CUSTOM="$ZSH/custom" -fi - is_plugin() { local base_dir=$1 local name=$2 From a4313db16ab76cfb059d1ca716dae00278672c25 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Fri, 28 Jun 2024 11:52:47 +0200 Subject: [PATCH 665/672] chore(deps): bump certifi from 2024.2.2 to 2024.6.2 in /.github/workflows/dependencies (#12519) Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> --- .github/workflows/dependencies/requirements.txt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/dependencies/requirements.txt b/.github/workflows/dependencies/requirements.txt index 743d838b5..8c80c60a2 100644 --- a/.github/workflows/dependencies/requirements.txt +++ b/.github/workflows/dependencies/requirements.txt @@ -1,4 +1,4 @@ -certifi==2024.2.2 +certifi==2024.6.2 charset-normalizer==3.3.2 idna==3.7 PyYAML==6.0.1 From dd4be1b6fb9973d63eba334d8bd92b3da30b3e72 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Fri, 28 Jun 2024 11:53:03 +0200 Subject: [PATCH 666/672] chore(deps): bump requests from 2.31.0 to 2.32.3 in /.github/workflows/dependencies (#12518) Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> --- .github/workflows/dependencies/requirements.txt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/dependencies/requirements.txt b/.github/workflows/dependencies/requirements.txt index 8c80c60a2..f8d8d4289 100644 --- a/.github/workflows/dependencies/requirements.txt +++ b/.github/workflows/dependencies/requirements.txt @@ -2,6 +2,6 @@ certifi==2024.6.2 charset-normalizer==3.3.2 idna==3.7 PyYAML==6.0.1 -requests==2.31.0 +requests==2.32.3 semver==3.0.2 urllib3==2.2.2 From 5233759206b447ffbce50847dcb032d7ebc3b31b Mon Sep 17 00:00:00 2001 From: Turiiya <34311583+ttytm@users.noreply.github.com> Date: Tue, 2 Jul 2024 13:30:39 +0200 Subject: [PATCH 667/672] feat(git): add `gclf` alias (#12508) --- plugins/git/README.md | 3 ++- plugins/git/git.plugin.zsh | 1 + 2 files changed, 3 insertions(+), 1 deletion(-) diff --git a/plugins/git/README.md b/plugins/git/README.md index 4022f8c62..c10f1d88e 100644 --- a/plugins/git/README.md +++ b/plugins/git/README.md @@ -59,6 +59,7 @@ plugins=(... git) | `gcpc` | `git cherry-pick --continue` | | `gclean` | `git clean --interactive -d` | | `gcl` | `git clone --recurse-submodules` | +| `gclf` | `git clone --recursive --shallow-submodules --filter=blob:none --also-filter-submodules` | | `gccd` | `git clone --recurse-submodules "$@" && cd "$(basename $\_ .git)"` | | `gcam` | `git commit --all --message` | | `gcas` | `git commit --all --signoff` | @@ -111,7 +112,7 @@ plugins=(... git) | `gfg` | `git ls-files \| grep` | | `gm` | `git merge` | | `gma` | `git merge --abort` | -| `gmc` | `git merge --continue` | +| `gmc` | `git merge --continue` | | `gms` | `git merge --squash` | | `gmom` | `git merge origin/$(git_main_branch)` | | `gmum` | `git merge upstream/$(git_main_branch)` | diff --git a/plugins/git/git.plugin.zsh b/plugins/git/git.plugin.zsh index 1e65a7acc..99fcc4d07 100644 --- a/plugins/git/git.plugin.zsh +++ b/plugins/git/git.plugin.zsh @@ -165,6 +165,7 @@ alias gcpa='git cherry-pick --abort' alias gcpc='git cherry-pick --continue' alias gclean='git clean --interactive -d' alias gcl='git clone --recurse-submodules' +alias gclf='git clone --recursive --shallow-submodules --filter=blob:none --also-filter-submodules' function gccd() { setopt localoptions extendedglob From 80ec8cd5295b923bf65671e249115dbff8dd4b30 Mon Sep 17 00:00:00 2001 From: Pedro Barbiero Date: Tue, 2 Jul 2024 12:14:17 -0300 Subject: [PATCH 668/672] fix(bun): set `SHELL` when generating completions (#12533) --- plugins/bun/bun.plugin.zsh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/bun/bun.plugin.zsh b/plugins/bun/bun.plugin.zsh index 9924faa84..576dbbfeb 100644 --- a/plugins/bun/bun.plugin.zsh +++ b/plugins/bun/bun.plugin.zsh @@ -11,4 +11,4 @@ if [[ ! -f "$ZSH_CACHE_DIR/completions/_bun" ]]; then _comps[bun]=_bun fi -bun completions >| "$ZSH_CACHE_DIR/completions/_bun" &| +SHELL=zsh bun completions >| "$ZSH_CACHE_DIR/completions/_bun" &| From 35f1d362c1c3169aaaf3600886382661af1fc647 Mon Sep 17 00:00:00 2001 From: Ihor Date: Tue, 2 Jul 2024 17:15:22 +0200 Subject: [PATCH 669/672] docs: rename twitter to X, fix link (#12532) --- README.md | 2 +- tools/upgrade.sh | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/README.md b/README.md index 2d873c514..105c5db89 100644 --- a/README.md +++ b/README.md @@ -486,4 +486,4 @@ Oh My Zsh is released under the [MIT license](LICENSE.txt). ![Planet Argon](https://pa-github-assets.s3.amazonaws.com/PARGON_logo_digital_COL-small.jpg) -Oh My Zsh was started by the team at [Planet Argon](https://www.planetargon.com/?utm_source=github), a [Ruby on Rails development agency](http://www.planetargon.com/services/ruby-on-rails-development?utm_source=github). Check out our [other open source projects](https://www.planetargon.com/open-source?utm_source=github). +Oh My Zsh was started by the team at [Planet Argon](https://www.planetargon.com/?utm_source=github), a [Ruby on Rails development agency](https://www.planetargon.com/services/ruby-on-rails-development?utm_source=github). Check out our [other open source projects](https://www.planetargon.com/open-source?utm_source=github). diff --git a/tools/upgrade.sh b/tools/upgrade.sh index 5eb90ab41..c586610c4 100755 --- a/tools/upgrade.sh +++ b/tools/upgrade.sh @@ -271,7 +271,7 @@ if LANG= git pull --quiet --rebase $remote $branch; then printf '%s %s %s %s /____/ %s %s %s %s\n' $RAINBOW $RESET printf '\n' printf "${BLUE}%s${RESET}\n\n" "$message" - printf "${BLUE}${BOLD}%s %s${RESET}\n" "To keep up with the latest news and updates, follow us on Twitter:" "$(fmt_link @ohmyzsh https://twitter.com/ohmyzsh)" + printf "${BLUE}${BOLD}%s %s${RESET}\n" "To keep up with the latest news and updates, follow us on X:" "$(fmt_link @ohmyzsh https://x.com/ohmyzsh)" printf "${BLUE}${BOLD}%s %s${RESET}\n" "Want to get involved in the community? Join our Discord:" "$(fmt_link "Discord server" https://discord.gg/ohmyzsh)" printf "${BLUE}${BOLD}%s %s${RESET}\n" "Get your Oh My Zsh swag at:" "$(fmt_link "Planet Argon Shop" https://shop.planetargon.com/collections/oh-my-zsh)" elif [[ $verbose_mode == minimal ]]; then From bdd9ee3687ffcf2e6ba725a9ab1be62487b8d7e2 Mon Sep 17 00:00:00 2001 From: Luke Date: Tue, 2 Jul 2024 08:21:21 -0700 Subject: [PATCH 670/672] docs(command-not-found): mention gentoo support (#12530) --- plugins/command-not-found/README.md | 1 + 1 file changed, 1 insertion(+) diff --git a/plugins/command-not-found/README.md b/plugins/command-not-found/README.md index 5a373c537..88761bb88 100644 --- a/plugins/command-not-found/README.md +++ b/plugins/command-not-found/README.md @@ -30,5 +30,6 @@ It works out of the box with the command-not-found packages for: - [NixOS](https://github.com/NixOS/nixpkgs/tree/master/nixos/modules/programs/command-not-found) - [Termux](https://github.com/termux/command-not-found) - [SUSE](https://www.unix.com/man-page/suse/1/command-not-found/) +- [Gentoo](https://github.com/AndrewAmmerlaan/command-not-found-gentoo/tree/main) You can add support for other platforms by submitting a Pull Request. From 5acaa240d3dde98f2bc2354ad6201e6954254b2c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E5=BC=A0=E6=96=B0=E4=BC=9F?= Date: Tue, 2 Jul 2024 23:22:58 +0800 Subject: [PATCH 671/672] feat(battery): support custom AC indicator (#12528) --- plugins/battery/README.md | 7 +++++++ plugins/battery/battery.plugin.zsh | 2 +- 2 files changed, 8 insertions(+), 1 deletion(-) diff --git a/plugins/battery/README.md b/plugins/battery/README.md index 18e5bd882..73fcb693e 100644 --- a/plugins/battery/README.md +++ b/plugins/battery/README.md @@ -12,6 +12,13 @@ Then, add the `battery_pct_prompt` function to your custom theme. For example: RPROMPT='$(battery_pct_prompt) ...' ``` +Also, you set the `BATTERY_CHARGING` variable to your favor. +For example: + +```zsh +BATTERY_CHARGING="⚡️" +``` + ## Requirements - On Linux, you must have the `acpi` or `acpitool` commands installed on your operating system. diff --git a/plugins/battery/battery.plugin.zsh b/plugins/battery/battery.plugin.zsh index 1d3d529a3..7977e4d04 100644 --- a/plugins/battery/battery.plugin.zsh +++ b/plugins/battery/battery.plugin.zsh @@ -58,7 +58,7 @@ if [[ "$OSTYPE" = darwin* ]]; then fi echo "%{$fg[$color]%}[${battery_pct}%%]%{$reset_color%}" else - echo "∞" + echo "${BATTERY_CHARGING-⚡️}" fi } From 057f3ec67e65661d3c01b757ec5cad0a3718453e Mon Sep 17 00:00:00 2001 From: Carlo Sala Date: Wed, 3 Jul 2024 08:51:19 +0200 Subject: [PATCH 672/672] chore: replace all instances of twitter with X Closes #12536 --- README.md | 4 ++-- tools/install.sh | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/README.md b/README.md index 105c5db89..e9a571a37 100644 --- a/README.md +++ b/README.md @@ -10,7 +10,7 @@ Once installed, your terminal shell will become the talk of the town _or your mo Finally, you'll begin to get the sort of attention that you have always felt you deserved. ...or maybe you'll use the time that you're saving to start flossing more often. 😬 -To learn more, visit [ohmyz.sh](https://ohmyz.sh), follow [@ohmyzsh](https://twitter.com/ohmyzsh) on Twitter, and join us on [Discord](https://discord.gg/ohmyzsh). +To learn more, visit [ohmyz.sh](https://ohmyz.sh), follow [@ohmyzsh](https://x.com/ohmyzsh) on X (formerly Twitter), and join us on [Discord](https://discord.gg/ohmyzsh). [![CI](https://github.com/ohmyzsh/ohmyzsh/workflows/CI/badge.svg)](https://github.com/ohmyzsh/ohmyzsh/actions?query=workflow%3ACI) [![X (formerly Twitter) Follow](https://img.shields.io/twitter/follow/ohmyzsh?label=%40ohmyzsh&logo=x&style=flat)](https://twitter.com/intent/follow?screen_name=ohmyzsh) @@ -469,7 +469,7 @@ Thank you so much! We're on social media: -- [@ohmyzsh](https://twitter.com/ohmyzsh) on Twitter. You should follow it. +- [@ohmyzsh](https://x.com/ohmyzsh) on X (formerly Twitter). You should follow it. - [Facebook](https://www.facebook.com/Oh-My-Zsh-296616263819290/) poke us. - [Instagram](https://www.instagram.com/_ohmyzsh/) tag us in your post showing Oh My Zsh! - [Discord](https://discord.gg/ohmyzsh) to chat with us! diff --git a/tools/install.sh b/tools/install.sh index e3613a28b..e5f126915 100755 --- a/tools/install.sh +++ b/tools/install.sh @@ -482,7 +482,7 @@ print_success() { "$(fmt_code "$(fmt_link ".zshrc" "file://$zdot/.zshrc" --text)")" \ "file to select plugins, themes, and options." printf '\n' - printf '%s\n' "• Follow us on Twitter: $(fmt_link @ohmyzsh https://twitter.com/ohmyzsh)" + printf '%s\n' "• Follow us on X: $(fmt_link @ohmyzsh https://x.com/ohmyzsh)" printf '%s\n' "• Join our Discord community: $(fmt_link "Discord server" https://discord.gg/ohmyzsh)" printf '%s\n' "• Get stickers, t-shirts, coffee mugs and more: $(fmt_link "Planet Argon Shop" https://shop.planetargon.com/collections/oh-my-zsh)" printf '%s\n' $FMT_RESET

    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 rxI9p*{_ym=Zr9V$f?pZE# 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