From 394ab0aeb72190e66aca3b3d21c9d3264fe1129f Mon Sep 17 00:00:00 2001 From: Peter Stephenson Date: Mon, 5 Sep 2005 13:55:47 +0000 Subject: [PATCH] 21698: Jean-Baptiste Quenot: _ant recursive completion could change dir --- ChangeLog | 5 +++++ Completion/Unix/Command/_ant | 10 +++++----- 2 files changed, 10 insertions(+), 5 deletions(-) diff --git a/ChangeLog b/ChangeLog index 179e009c4..ad5d5a0fd 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,8 @@ +2005-09-05 Peter Stephenson + + * 21698: Jean-Baptiste Quenot: Completion/Unix/Command/_ant: + recursive completion could change directory. + 2005-09-02 Clint Adams * 21696: Completion/Unix/Command/_date: completion for diff --git a/Completion/Unix/Command/_ant b/Completion/Unix/Command/_ant index bf70915d7..7e7d14c2a 100644 --- a/Completion/Unix/Command/_ant +++ b/Completion/Unix/Command/_ant @@ -8,14 +8,13 @@ local buildfile classpath cp userjars importedfiles target='*:target:->target' t find_targets() { importedfiles=( $(sed -n "s/ *]* file=[\"']\([^\"']*\)[\"'].*/\1/p" < $1) ) - targets=( $(sed -n "s/ *]* name=[\"']\([^\"']*\)[\"'].*/\1/p" $1) ) + sed -n "s/ *]* name=[\"']\([^\"']*\)[\"'].*/\1/p" $1 if (( $#importedfiles )) ; then - cd $1:h + ( cd $1:h for file in $importedfiles ; do find_targets $file - done + done ) fi - _wanted targets expl target compadd -a targets && ret=0 } if [[ $service = *ANT_ARGS* ]]; then @@ -126,7 +125,8 @@ case $state in )//$'\015'}" _describe 'target' tmp && ret=0 else - find_targets $buildfile + targets=( $(find_targets $buildfile) ) + _wanted targets expl target compadd -a targets && ret=0 fi else _message -e targets target