summaryrefslogtreecommitdiff
path: root/plugins/npm
diff options
context:
space:
mode:
authorRoman Kamyk <roman.kamyk@gmail.com>2011-05-12 13:40:07 +0200
committerRoman Kamyk <roman.kamyk@gmail.com>2011-05-12 13:40:07 +0200
commitf71647fa85267d558d0d69034902f53aeeed67ad (patch)
treee48c05b9de6c435ccb5df37c6d0a5b4c351b380e /plugins/npm
parentdccfdf7dbf707b2e860fde1b6540e66ec6bda207 (diff)
parent0365ef0529ddfb912ca8202773e45916c55fdf4f (diff)
downloadzsh-f71647fa85267d558d0d69034902f53aeeed67ad.tar.gz
zsh-f71647fa85267d558d0d69034902f53aeeed67ad.tar.bz2
zsh-f71647fa85267d558d0d69034902f53aeeed67ad.zip
Merge branch 'master' of http://github.com/robbyrussell/oh-my-zsh
Diffstat (limited to 'plugins/npm')
-rw-r--r--plugins/npm/_npm19
1 files changed, 19 insertions, 0 deletions
diff --git a/plugins/npm/_npm b/plugins/npm/_npm
new file mode 100644
index 000000000..24b536188
--- /dev/null
+++ b/plugins/npm/_npm
@@ -0,0 +1,19 @@
+#compdef npm
+
+# Node Package Manager 0.3.15 completion, letting npm do all the completion work
+
+_npm() {
+ compadd -- $(_npm_complete $words)
+}
+
+# We want to show all errors of any substance, but never the "npm (not )ok" one.
+# (Also doesn't consider "ERR! no match found" worth breaking the terminal for.)
+_npm_complete() {
+ local ask_npm
+ ask_npm=(npm completion --color false --loglevel error -- $@)
+ { _call_program npm $ask_npm 2>&1 >&3 \
+ | egrep -v '^(npm (not |)ok|ERR! no match found)$' >&2; \
+ } 3>&1
+}
+
+_npm "$@"