diff options
author | Pete Clark <pete.clark@gmail.com> | 2011-05-29 18:51:32 -0400 |
---|---|---|
committer | Pete Clark <pete.clark@gmail.com> | 2011-05-29 18:51:32 -0400 |
commit | 8411a39a869cd80474e3898f2fa4f204599b943a (patch) | |
tree | a77b33ce1d48249a405c8c9e66936351d00d637f /plugins/ant/ant.plugin.zsh | |
parent | 1e86678f9d3c8c979ff8d3c8b5aac19e9e611441 (diff) | |
parent | 142c03dbd223683fd2d99f878b68f0f075cf33fb (diff) | |
download | zsh-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.zsh | 26 |
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 |