summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDaniel Schauenberg <d@unwiredcouch.com>2010-09-01 13:21:38 +0200
committerDaniel Schauenberg <d@unwiredcouch.com>2010-09-01 13:21:38 +0200
commit7ca9a3f91d131a2e8983a7157582b82130dee629 (patch)
tree45da7f90314e005dd4a5becc22f579e512c2b786
parent99f159e0a7c63e6756f8e6e40691914da8f7a96c (diff)
parent7b6be5611763f25eca043f9ed0d46066a3454205 (diff)
downloadzsh-7ca9a3f91d131a2e8983a7157582b82130dee629.tar.gz
zsh-7ca9a3f91d131a2e8983a7157582b82130dee629.tar.bz2
zsh-7ca9a3f91d131a2e8983a7157582b82130dee629.zip
Merge branch 'brew_plugin_fix'
-rw-r--r--functions/brew/_brew69
-rw-r--r--plugins/brew.plugin.zsh71
2 files changed, 73 insertions, 67 deletions
diff --git a/functions/brew/_brew b/functions/brew/_brew
new file mode 100644
index 000000000..4e590ac63
--- /dev/null
+++ b/functions/brew/_brew
@@ -0,0 +1,69 @@
+#compdef brew
+#autoload
+
+# imported from the latest homebrew contributions
+
+_brew_all_formulae() {
+ formulae=(`brew search`)
+}
+
+_brew_installed_formulae() {
+ installed_formulae=(`brew list`)
+}
+
+local -a _1st_arguments
+_1st_arguments=(
+ 'cat:display formula file for a formula'
+ 'cleanup:uninstall unused and old versions of packages'
+ 'create:create a new formula'
+ 'deps:list dependencies and dependants of a formula'
+ 'doctor:audits your installation for common issues'
+ 'edit:edit a formula'
+ 'home:visit the homepage of a formula or the brew project'
+ 'info:information about a formula'
+ 'install:install a formula'
+ 'link:link a formula'
+ 'list:list files in a formula or not-installed formulae'
+ 'log:git commit log for a formula'
+ 'outdated:list formulas for which a newer version is available'
+ 'prune:remove dead links'
+ 'remove:remove a formula'
+ 'search:search for a formula (/regex/ or string)'
+ 'unlink:unlink a formula'
+ 'update:freshen up links'
+ 'uses:show formulas which depend on a formula'
+)
+
+local expl
+local -a formula installed_formulae
+
+_arguments \
+ '(-v --verbose)'{-v,--verbose}'[verbose]' \
+ '(--version)--version[version information]' \
+ '(--prefix)--prefix[where brew lives on this system]' \
+ '(--cache)--cache[brew cache]' \
+ '*:: :->subcmds' && return 0
+
+if (( CURRENT == 1 )); then
+ _describe -t commands "brew subcommand" _1st_arguments
+ return
+fi
+
+case "$words[1]" in
+ list)
+ _arguments \
+ '(--unbrewed)--unbrewed[files in brew --prefix not controlled by brew]' \
+ '1: :->forms' && return 0
+
+ if [[ "$state" == forms ]]; then
+ _brew_installed_formulae
+ _requested installed_formulae expl 'installed formulae' compadd -a installed_formulae
+ fi ;;
+ install|home|log|info|uses|cat|deps)
+ _brew_all_formulae
+ _wanted formulae expl 'all formulae' compadd -a formulae ;;
+ remove|edit|xo)
+ _brew_installed_formulae
+ _wanted installed_formulae expl 'installed formulae' compadd -a installed_formulae ;;
+esac
+
diff --git a/plugins/brew.plugin.zsh b/plugins/brew.plugin.zsh
index 162eb6442..a30540966 100644
--- a/plugins/brew.plugin.zsh
+++ b/plugins/brew.plugin.zsh
@@ -1,67 +1,4 @@
-#compdef brew
-
-# imported from the latest homebrew contributions
-
-_brew_all_formulae() {
- formulae=(`brew search`)
-}
-
-_brew_installed_formulae() {
- installed_formulae=(`brew list`)
-}
-
-local -a _1st_arguments
-_1st_arguments=(
- 'cat:display formula file for a formula'
- 'cleanup:uninstall unused and old versions of packages'
- 'create:create a new formula'
- 'deps:list dependencies and dependants of a formula'
- 'doctor:audits your installation for common issues'
- 'edit:edit a formula'
- 'home:visit the homepage of a formula or the brew project'
- 'info:information about a formula'
- 'install:install a formula'
- 'link:link a formula'
- 'list:list files in a formula or not-installed formulae'
- 'log:git commit log for a formula'
- 'outdated:list formulas for which a newer version is available'
- 'prune:remove dead links'
- 'remove:remove a formula'
- 'search:search for a formula (/regex/ or string)'
- 'unlink:unlink a formula'
- 'update:freshen up links'
- 'uses:show formulas which depend on a formula'
-)
-
-local expl
-local -a formula installed_formulae
-
-_arguments \
- '(-v --verbose)'{-v,--verbose}'[verbose]' \
- '(--version)--version[version information]' \
- '(--prefix)--prefix[where brew lives on this system]' \
- '(--cache)--cache[brew cache]' \
- '*:: :->subcmds' && return 0
-
-if (( CURRENT == 1 )); then
- _describe -t commands "brew subcommand" _1st_arguments
- return
-fi
-
-case "$words[1]" in
- list)
- _arguments \
- '(--unbrewed)--unbrewed[files in brew --prefix not controlled by brew]' \
- '1: :->forms' && return 0
-
- if [[ "$state" == forms ]]; then
- _brew_installed_formulae
- _requested installed_formulae expl 'installed formulae' compadd -a installed_formulae
- fi ;;
- install|home|log|info|uses|cat|deps)
- _brew_all_formulae
- _wanted formulae expl 'all formulae' compadd -a formulae ;;
- remove|edit|xo)
- _brew_installed_formulae
- _wanted installed_formulae expl 'installed formulae' compadd -a installed_formulae ;;
-esac
+# add brew completion function to path
+fpath=($ZSH/functions/brew $fpath)
+autoload -U compinit
+compinit -i