summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRobby Russell <robby@planetargon.com>2011-07-17 22:09:47 -0700
committerRobby Russell <robby@planetargon.com>2011-07-17 22:09:47 -0700
commitf951740656d7390583b1eaa91d9ebae931d4e3be (patch)
treef900840521c8ea9d3047dbfe79960136fef44f49
parent4dce1d5d4adc8662e77f936ceab15ae41f3759fe (diff)
parent66c6260c10422bf50c474c9654a7928ce99e7ceb (diff)
downloadzsh-f951740656d7390583b1eaa91d9ebae931d4e3be.tar.gz
zsh-f951740656d7390583b1eaa91d9ebae931d4e3be.tar.bz2
zsh-f951740656d7390583b1eaa91d9ebae931d4e3be.zip
Merge pull request #474 from PabloSerbo/master
Adding a completion plugin for cake the coffee-script
-rw-r--r--plugins/cake/cake.plugin.zsh32
1 files changed, 32 insertions, 0 deletions
diff --git a/plugins/cake/cake.plugin.zsh b/plugins/cake/cake.plugin.zsh
new file mode 100644
index 000000000..75997521a
--- /dev/null
+++ b/plugins/cake/cake.plugin.zsh
@@ -0,0 +1,32 @@
+# Set this to 1 if you want to cache the tasks
+cacheTaskList=1
+
+# Cache filename
+cacheFile='.cake-task-cache'
+
+_cake_does_target_list_need_generating () {
+
+ if [ $cacheTaskList -eq 0 ]; then
+ return 1;
+ fi
+
+ if [ ! -f $cacheFile ]; then return 0;
+ else
+ accurate=$(stat -f%m $cacheFile)
+ changed=$(stat -f%m Cakefile)
+ return $(expr $accurate '>=' $changed)
+ fi
+}
+
+_cake () {
+ if [ -f Cakefile ]; then
+ if _cake_does_target_list_need_generating; then
+ cake | sed -e "s/cake \([^ ]*\) .*/\1/" | grep -v '^$' > $cacheFile
+ compadd `cat $cacheFile`
+ else
+ compadd `cake | sed -e "s/cake \([^ ]*\) .*/\1/" | grep -v '^$'`
+ fi
+ fi
+}
+
+compdef _cake cake