From 6d73a3b843ac1961ccce067a0c191c1bcdf20d7f Mon Sep 17 00:00:00 2001 From: Oliver Kiddle Date: Wed, 8 May 2002 12:56:46 +0000 Subject: 17072: fix pushdminus handling in completion after directory stack references --- Completion/Unix/Type/_path_files | 17 ++++++----------- 1 file changed, 6 insertions(+), 11 deletions(-) (limited to 'Completion') diff --git a/Completion/Unix/Type/_path_files b/Completion/Unix/Type/_path_files index 32bf51fef..a6d2a2834 100644 --- a/Completion/Unix/Type/_path_files +++ b/Completion/Unix/Type/_path_files @@ -220,20 +220,15 @@ elif [[ "$pre[1]" = \~ && -z "$compstate[quote]" ]]; then realpath="${HOME%/}/" elif [[ "$linepath" = ([-+]|)[0-9]## ]]; then if [[ "$linepath" != [-+]* ]]; then - if [[ -o pushdminus ]]; then - tmp1="-$linepath" - else - tmp1="+$linepath" - fi - else tmp1="$linepath" - fi - if [[ "$linepath" = -* ]]; then - tmp1=$(( $#dirstack $tmp1 )) else - tmp1=$tmp1[2,-1] + if [[ "$linepath" = -* ]]; then + tmp1=$(( $#dirstack $linepath )) + else + tmp1=$linepath[2,-1] + fi + [[ -o pushdminus ]] && tmp1=$(( $#dirstack - $tmp1 )) fi - [[ -o pushdminus ]] && tmp1=$(( $#dirstack - $tmp1 )) if (( ! tmp1 )); then realpath=$PWD/ elif [[ tmp1 -le $#dirstack ]]; then -- cgit 1.4.1