summaryrefslogtreecommitdiff
path: root/plugins/composer/composer.plugin.zsh
diff options
context:
space:
mode:
authoryleo77 <ylep77@gmail.com>2013-07-16 16:37:18 +0800
committeryleo77 <ylep77@gmail.com>2013-07-16 16:37:18 +0800
commit67b2781f6200a0dff35055eb67937a0df2be2c51 (patch)
tree73b692f4146042966f7d2fed10ab88946cbc077b /plugins/composer/composer.plugin.zsh
parent6b832b93588567cb00b9a9e8170a5ebf539dea51 (diff)
parent7f74294d7aa7ab86e18e70a1153c15fa373c5849 (diff)
downloadzsh-67b2781f6200a0dff35055eb67937a0df2be2c51.tar.gz
zsh-67b2781f6200a0dff35055eb67937a0df2be2c51.tar.bz2
zsh-67b2781f6200a0dff35055eb67937a0df2be2c51.zip
Merge remote-tracking branch 'robbyrussell/master'
Diffstat (limited to 'plugins/composer/composer.plugin.zsh')
-rw-r--r--plugins/composer/composer.plugin.zsh18
1 files changed, 17 insertions, 1 deletions
diff --git a/plugins/composer/composer.plugin.zsh b/plugins/composer/composer.plugin.zsh
index 2d1557541..9975aaca4 100644
--- a/plugins/composer/composer.plugin.zsh
+++ b/plugins/composer/composer.plugin.zsh
@@ -10,9 +10,25 @@ _composer_get_command_list () {
composer --no-ansi | sed "1,/Available commands/d" | awk '/^ [a-z]+/ { print $1 }'
}
+_composer_get_required_list () {
+ composer show -s --no-ansi | sed '1,/requires/d' | awk 'NF > 0 && !/^requires \(dev\)/{ print $1 }'
+}
+
_composer () {
+ local curcontext="$curcontext" state line
+ typeset -A opt_args
+ _arguments \
+ '1: :->command'\
+ '*: :->args'
if [ -f composer.json ]; then
- compadd `_composer_get_command_list`
+ case $state in
+ command)
+ compadd `_composer_get_command_list`
+ ;;
+ *)
+ compadd `_composer_get_required_list`
+ ;;
+ esac
else
compadd create-project init search selfupdate show
fi