diff options
Diffstat (limited to 'completions/bash')
| -rw-r--r-- | completions/bash/brew | 637 |
1 files changed, 637 insertions, 0 deletions
diff --git a/completions/bash/brew b/completions/bash/brew new file mode 100644 index 000000000..67c4c6a3d --- /dev/null +++ b/completions/bash/brew @@ -0,0 +1,637 @@ +# Bash completion script for brew(1) + +__brewcomp_words_include() { + local i=1 + while [[ "$i" -lt "$COMP_CWORD" ]] + do + if [[ "${COMP_WORDS[i]}" = "$1" ]] + then + return 0 + fi + i="$((++i))" + done + return 1 +} + +# Find the previous non-switch word +__brewcomp_prev() { + local idx="$((COMP_CWORD - 1))" + local prv="${COMP_WORDS[idx]}" + while [[ "$prv" = -* ]] + do + idx="$((--idx))" + prv="${COMP_WORDS[idx]}" + done + echo "$prv" +} + +__brewcomp() { + # break $1 on space, tab, and newline characters, + # and turn it into a newline separated list of words + local list s sep=$'\n' IFS=$' '$'\t'$'\n' + local cur="${COMP_WORDS[COMP_CWORD]}" + + for s in $1 + do + __brewcomp_words_include "$s" && continue + list="$list$s$sep" + done + + IFS="$sep" + COMPREPLY=($(compgen -W "$list" -- "$cur")) +} + +# Don't use __brewcomp() in any of the __brew_complete_foo functions, as +# it is too slow and is not worth it just for duplicate elimination. +__brew_complete_formulae() { + local cur="${COMP_WORDS[COMP_CWORD]}" + local formulas="$(brew search)" + local shortnames="$(echo "$formulas" | grep / | cut -d / -f 3)" + COMPREPLY=($(compgen -W "$formulas $shortnames" -- "$cur")) +} + +__brew_complete_installed() { + local cur="${COMP_WORDS[COMP_CWORD]}" + local inst="$(ls "$(brew --cellar)")" + COMPREPLY=($(compgen -W "$inst" -- "$cur")) +} + +__brew_complete_outdated() { + local cur="${COMP_WORDS[COMP_CWORD]}" + local od="$(brew outdated --quiet)" + COMPREPLY=($(compgen -W "$od" -- "$cur")) +} + +__brew_complete_versions() { + local formula="$1" + local versions="$(brew list --versions "$formula")" + local cur="${COMP_WORDS[COMP_CWORD]}" + COMPREPLY=($(compgen -W "$versions" -X "$formula" -- "$cur")) +} + +__brew_complete_logs() { + local cur="${COMP_WORDS[COMP_CWORD]}" + local logs="$(ls "${HOMEBREW_LOGS:-~/Library/Logs/Homebrew/}")" + COMPREPLY=($(compgen -W "$logs" -- "$cur")) +} + +__brew_complete_tapped() { + local taplib="$(brew --repository)/Library/Taps" + local dir taps + + for dir in "$taplib"/*/* + do + [[ -d "$dir" ]] || continue + dir="${dir#${taplib}/}" + dir="${dir/homebrew-/}" + taps="$taps $dir" + done + __brewcomp "$taps" +} + +_brew_analytics() { + case "$COMP_CWORD" in + 2) __brewcomp "off on regenerate-uuid state" ;; + esac +} + +_brew_bottle() { + local cur="${COMP_WORDS[COMP_CWORD]}" + case "$cur" in + --*) + __brewcomp "--merge --rb --write --root_url=" + return + ;; + esac + __brew_complete_installed +} + +_brew_cleanup() { + __brew_complete_installed +} + +_brew_create() { + local cur="${COMP_WORDS[COMP_CWORD]}" + case "$cur" in + --*) + __brewcomp "--autotools --cmake --no-fetch --set-name --set-version" + return + ;; + esac +} + +_brew_deps() { + local cur="${COMP_WORDS[COMP_CWORD]}" + case "$cur" in + --*) + __brewcomp "--1 --all --tree" + return + ;; + esac + __brew_complete_formulae +} + +_brew_desc() { + local cur="${COMP_WORDS[COMP_CWORD]}" + case "$cur" in + --*) + __brewcomp "--search --name --description" + return + ;; + esac + __brew_complete_formulae +} + +_brew_diy() { + local cur="${COMP_WORDS[COMP_CWORD]}" + case "$cur" in + --*) + __brewcomp "--set-name --set-version" + return + ;; + esac +} + +_brew_doctor() { + local cur="${COMP_WORDS[COMP_CWORD]}" + __brewcomp "$(brew doctor --list-checks)" +} + +_brew_fetch() { + local cur="${COMP_WORDS[COMP_CWORD]}" + local prv="$(__brewcomp_prev)" + case "$cur" in + --*) + __brewcomp " + --deps --force + --devel --HEAD + --build-from-source --force-bottle --build-bottle + --retry + $(brew options --compact "$prv" 2>/dev/null) + " + return + ;; + esac + __brew_complete_formulae +} + +_brew_gist_logs() { + local cur="${COMP_WORDS[COMP_CWORD]}" + case "$cur" in + --*) + __brewcomp "--new-issue" + return + ;; + esac + __brew_complete_logs +} + +_brew_info() { + local cur="${COMP_WORDS[COMP_CWORD]}" + case "$cur" in + --*) + __brewcomp "--all --github --installed --json=v1" + return + ;; + esac + __brew_complete_formulae +} + +_brew_install() { + local cur="${COMP_WORDS[COMP_CWORD]}" + local prv="$(__brewcomp_prev)" + + case "$cur" in + --*) + if __brewcomp_words_include "--interactive" + then + __brewcomp "--devel --git --HEAD" + else + __brewcomp " + --build-from-source --build-bottle --force-bottle + --debug + --devel + --HEAD + --ignore-dependencies + --interactive + --only-dependencies + --verbose + $(brew options --compact "$prv" 2>/dev/null) + " + fi + return + ;; + esac + __brew_complete_formulae +} + +_brew_irb() { + local cur="${COMP_WORDS[COMP_CWORD]}" + case "$cur" in + --*) + __brewcomp "--examples" + return + ;; + esac +} + +_brew_link() { + local cur="${COMP_WORDS[COMP_CWORD]}" + case "$cur" in + --*) + __brewcomp "--dry-run --overwrite --force" + return + ;; + esac + __brew_complete_installed +} + +_brew_linkapps() { + local cur="${COMP_WORDS[COMP_CWORD]}" + case "$cur" in + --*) + __brewcomp "--local" + return + ;; + esac + __brew_complete_installed +} + +_brew_list() { + local allopts="--unbrewed --verbose --pinned --versions --multiple" + local cur="${COMP_WORDS[COMP_CWORD]}" + + case "$cur" in + --*) + # most options to brew-list are mutually exclusive + if __brewcomp_words_include "--unbrewed" + then + return + elif __brewcomp_words_include "--verbose" + then + return + elif __brewcomp_words_include "--pinned" + then + return + # --multiple only applies with --versions + elif __brewcomp_words_include "--multiple" + then + __brewcomp "--versions" + return + elif __brewcomp_words_include "--versions" + then + __brewcomp "--multiple" + return + else + __brewcomp "$allopts" + return + fi + ;; + esac + + # --multiple excludes formulae and *implies* --versions... + if __brewcomp_words_include "--multiple" + then + __brewcomp "--versions" + else + __brew_complete_installed + fi +} + +_brew_log() { + # if git-completion is loaded, then we complete git-log options + declare -F _git_log >/dev/null || return + local cur="${COMP_WORDS[COMP_CWORD]}" + case "$cur" in + --*) + __brewcomp " + $__git_log_common_options + $__git_log_shortlog_options + $__git_log_gitk_options + $__git_diff_common_options + --walk-reflogs --graph --decorate + --abbrev-commit --oneline --reverse + " + return + ;; + esac + __brew_complete_formulae +} + +_brew_man() { + local cur="${COMP_WORDS[COMP_CWORD]}" + case "$cur" in + --*) + __brewcomp "--link --server --verbose" + return + ;; + esac +} + +_brew_options() { + local cur="${COMP_WORDS[COMP_CWORD]}" + case "$cur" in + --*) + __brewcomp "--all --compact --installed" + return + ;; + esac + __brew_complete_formulae +} + +_brew_outdated() { + local cur="${COMP_WORDS[COMP_CWORD]}" + case "$cur" in + --*) + __brewcomp "--quiet --json=v1 --fetch-HEAD" + return + ;; + esac +} + +_brew_postinstall() { + local cur="${COMP_WORDS[COMP_CWORD]}" + case "$cur" in + --*) + __brewcomp "--debug --sandbox" + return + ;; + esac + __brew_complete_installed +} + +_brew_prune() { + local cur="${COMP_WORDS[COMP_CWORD]}" + case "$cur" in + --*) + __brewcomp "--dry-run --verbose" + return + ;; + esac +} + +_brew_pull() { + local cur="${COMP_WORDS[COMP_CWORD]}" + case "$cur" in + --*) + __brewcomp "--bottle --bump --clean --ignore-whitespace --install --resolve" + return + ;; + esac +} + +_brew_readall() { + local cur="${COMP_WORDS[COMP_CWORD]}" + case "$cur" in + --*) + __brewcomp "--syntax" + return + ;; + esac + __brew_complete_tapped +} + +_brew_search() { + local cur="${COMP_WORDS[COMP_CWORD]}" + case "$cur" in + --*) + __brewcomp "--debian --desc --fedora --fink --macports --opensuse --ubuntu" + return + ;; + esac +} + +_brew_style() { + local cur="${COMP_WORDS[COMP_CWORD]}" + case "$cur" in + --*) + __brewcomp "--fix" + return + ;; + esac + __brew_complete_formulae +} + +_brew_switch() { + case "$COMP_CWORD" in + 2) __brew_complete_installed ;; + 3) __brew_complete_versions "${COMP_WORDS[COMP_CWORD-1]}" ;; + *) ;; + esac +} + +_brew_tap() { + local cur="${COMP_WORDS[COMP_CWORD]}" + case "$cur" in + --*) + __brewcomp "--repair --list-official --list-pinned" + return + ;; + esac + __brewcomp "$(brew tap --list-official)" +} + +_brew_tap_info() { + local cur="${COMP_WORDS[COMP_CWORD]}" + case "$cur" in + --*) + __brewcomp "--installed --json=v1" + return + ;; + esac + __brew_complete_tapped +} + +_brew_tap_readme() { + local cur="${COMP_WORDS[COMP_CWORD]}" + case "$cur" in + --*) + __brewcomp "--verbose" + return + ;; + esac +} + +_brew_tap_unpin() { + __brewcomp "$(brew tap --list-pinned)" +} + +_brew_tests() { + local cur="${COMP_WORDS[COMP_CWORD]}" + case "$cur" in + --*) + __brewcomp "--verbose" + return + ;; + esac +} + +_brew_uninstall() { + local cur="${COMP_WORDS[COMP_CWORD]}" + case "$cur" in + --*) + __brewcomp "--force" + return + ;; + esac + __brew_complete_installed +} + +_brew_unlinkapps() { + local cur="${COMP_WORDS[COMP_CWORD]}" + case "$cur" in + --*) + __brewcomp "--dry-run --local" + return + ;; + esac + __brew_complete_installed +} + +_brew_unpack() { + local cur="${COMP_WORDS[COMP_CWORD]}" + case "$cur" in + --*) + __brewcomp "--git --patch --destdir=" + return + ;; + esac + __brew_complete_formulae +} +_brew_update() { + local cur="${COMP_WORDS[COMP_CWORD]}" + case "$cur" in + --*) + __brewcomp "--rebase --verbose" + return + ;; + esac +} + +_brew_upgrade() { + local cur="${COMP_WORDS[COMP_CWORD]}" + local prv="$(__brewcomp_prev)" + + case "$cur" in + --*) + __brewcomp " + --all + --build-from-source --build-bottle --force-bottle + --cleanup + --debug + --verbose + --fetch-HEAD + " + return + ;; + esac + __brew_complete_outdated +} + +_brew_uses() { + local cur="${COMP_WORDS[COMP_CWORD]}" + case "$cur" in + --*) + __brewcomp "--installed --recursive" + return + ;; + esac + __brew_complete_formulae +} + +_brew() { + local i=1 cmd + + # find the subcommand + while [[ "$i" -lt "$COMP_CWORD" ]] + do + local s="${COMP_WORDS[i]}" + case "$s" in + --*) + cmd="$s" + break + ;; + -*) + ;; + *) + cmd="$s" + break + ;; + esac + i="$((++i))" + done + + if [[ "$i" -eq "$COMP_CWORD" ]] + then + # Do not auto-complete "instal" abbreviation for "install" command. + # Prefix newline to prevent not checking the first command. + local cmds=$'\n'"$(brew commands --quiet --include-aliases)" + __brewcomp "${cmds/$'\n'instal$'\n'/$'\n'}" + return + fi + + # subcommands have their own completion functions + case "$cmd" in + --cache) __brew_complete_formulae ;; + --cellar) __brew_complete_formulae ;; + --prefix) __brew_complete_formulae ;; + analytics) _brew_analytics ;; + audit) __brew_complete_formulae ;; + bottle) _brew_bottle ;; + cat) __brew_complete_formulae ;; + cleanup) _brew_cleanup ;; + create) _brew_create ;; + deps) _brew_deps ;; + desc) _brew_desc ;; + diy|configure) _brew_diy ;; + doctor|dr) _brew_doctor ;; + edit) __brew_complete_formulae ;; + fetch) _brew_fetch ;; + gist-logs) _brew_gist_logs ;; + home|homepage) __brew_complete_formulae ;; + info|abv) _brew_info ;; + install|instal) _brew_install ;; + irb) _brew_irb ;; + link|ln) _brew_link ;; + linkapps) _brew_linkapps ;; + list|ls) _brew_list ;; + log) _brew_log ;; + man) _brew_man ;; + missing) __brew_complete_formulae ;; + options) _brew_options ;; + outdated) _brew_outdated ;; + pin) __brew_complete_formulae ;; + postinstall) _brew_postinstall ;; + prune) _brew_prune ;; + pull) _brew_pull ;; + readall) _brew_readall ;; + reinstall) _brew_install ;; + search|-S) _brew_search ;; + style) _brew_style ;; + switch) _brew_switch ;; + tap) _brew_tap ;; + tap-info) _brew_tap_info ;; + tap-pin) __brew_complete_tapped ;; + tap-readme) _brew_tap_readme ;; + tap-unpin) _brew_tap_unpin ;; + test) __brew_complete_installed ;; + tests) _brew_tests ;; + uninstall|remove|rm) _brew_uninstall ;; + unlink) __brew_complete_installed ;; + unlinkapps) _brew_unlinkapps ;; + unpack) _brew_unpack ;; + unpin) __brew_complete_formulae ;; + untap) __brew_complete_tapped ;; + update|up) _brew_update ;; + upgrade) _brew_upgrade ;; + uses) _brew_uses ;; + *) ;; + esac +} + +# keep around for compatibility +_brew_to_completion() { + _brew +} + +complete -o bashdefault -o default -F _brew brew |
