summaryrefslogtreecommitdiff
path: root/plugins/ant/ant.plugin.zsh
diff options
context:
space:
mode:
authorPete Clark <pete.clark@gmail.com>2011-05-29 18:51:32 -0400
committerPete Clark <pete.clark@gmail.com>2011-05-29 18:51:32 -0400
commit8411a39a869cd80474e3898f2fa4f204599b943a (patch)
treea77b33ce1d48249a405c8c9e66936351d00d637f /plugins/ant/ant.plugin.zsh
parent1e86678f9d3c8c979ff8d3c8b5aac19e9e611441 (diff)
parent142c03dbd223683fd2d99f878b68f0f075cf33fb (diff)
downloadzsh-8411a39a869cd80474e3898f2fa4f204599b943a.tar.gz
zsh-8411a39a869cd80474e3898f2fa4f204599b943a.tar.bz2
zsh-8411a39a869cd80474e3898f2fa4f204599b943a.zip
Merge branch 'master' of git://github.com/robbyrussell/oh-my-zsh into taskwarrior-plugin
Diffstat (limited to 'plugins/ant/ant.plugin.zsh')
-rw-r--r--plugins/ant/ant.plugin.zsh26
1 files changed, 26 insertions, 0 deletions
diff --git a/plugins/ant/ant.plugin.zsh b/plugins/ant/ant.plugin.zsh
new file mode 100644
index 000000000..23bc7756a
--- /dev/null
+++ b/plugins/ant/ant.plugin.zsh
@@ -0,0 +1,26 @@
+stat -f%m . > /dev/null 2>&1
+if [ "$?" = 0 ]; then
+ stat_cmd=(stat -f%m)
+else
+ stat_cmd=(stat -L --format=%y)
+fi
+
+_ant_does_target_list_need_generating () {
+ if [ ! -f .ant_targets ]; then return 0;
+ else
+ accurate=$($stat_cmd -f%m .ant_targets)
+ changed=$($stat_cmd -f%m build.xml)
+ return $(expr $accurate '>=' $changed)
+ fi
+}
+
+_ant () {
+ if [ -f build.xml ]; then
+ if _ant_does_target_list_need_generating; then
+ sed -n '/<target/s/<target.*name="\([^"]*\).*$/\1/p' build.xml > .ant_targets
+ fi
+ compadd `cat .ant_targets`
+ fi
+}
+
+compdef _ant ant