summaryrefslogtreecommitdiff
path: root/plugins/cake
diff options
context:
space:
mode:
authorRobby Russell <robby@planetargon.com>2011-07-23 08:41:44 -0700
committerRobby Russell <robby@planetargon.com>2011-07-23 08:41:44 -0700
commit8a102b941f80050a82b26b1e8ac79ffa4cc3a855 (patch)
treee5ba8557676b72f5284e865bf4e1de5c85e7996b /plugins/cake
parent3a56297ce8f597631202b6f532cbfb8daa5c537b (diff)
parent2a64d08889c8df8fe74228d05adfe82d0eb899ed (diff)
downloadzsh-8a102b941f80050a82b26b1e8ac79ffa4cc3a855.tar.gz
zsh-8a102b941f80050a82b26b1e8ac79ffa4cc3a855.tar.bz2
zsh-8a102b941f80050a82b26b1e8ac79ffa4cc3a855.zip
Merge branch 'master' of github.com:robbyrussell/oh-my-zsh
Diffstat (limited to 'plugins/cake')
-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..f968c71d5
--- /dev/null
+++ b/plugins/cake/cake.plugin.zsh
@@ -0,0 +1,32 @@
+# Set this to 1 if you want to cache the tasks
+cache_task_list=1
+
+# Cache filename
+cache_file='.cake_task_cache'
+
+_cake_does_target_list_need_generating () {
+
+ if [ $cache_task_list -eq 0 ]; then
+ return 1;
+ fi
+
+ if [ ! -f $cache_file ]; then return 0;
+ else
+ accurate=$(stat -f%m $cache_file)
+ 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 '^$' > $cache_file
+ compadd `cat $cache_file`
+ else
+ compadd `cake | sed -e "s/cake \([^ ]*\) .*/\1/" | grep -v '^$'`
+ fi
+ fi
+}
+
+compdef _cake cake