diff options
-rw-r--r-- | ChangeLog | 7 | ||||
-rw-r--r-- | Completion/Unix/Type/_files | 6 | ||||
-rw-r--r-- | Completion/Unix/Type/_path_files | 8 |
3 files changed, 18 insertions, 3 deletions
diff --git a/ChangeLog b/ChangeLog index c9d592af5..2679f36cd 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,10 @@ +2001-07-13 Sven Wischnowsky <wischnow@zsh.org> + + * 15389: Completion/Unix/Type/_files, + Completion/Unix/Type/_path_files: make _files not use its own + description if there is one from a calling function; improve + -P-prefix handling in _path_files + 2001-07-11 Bart Schaefer <schaefer@zsh.org> * 15375: Doc/Zsh/options.yo: Explain the effect of CORRECT on diff --git a/Completion/Unix/Type/_files b/Completion/Unix/Type/_files index a291ee786..87234eb2d 100644 --- a/Completion/Unix/Type/_files +++ b/Completion/Unix/Type/_files @@ -65,7 +65,11 @@ for def in "$pats[@]"; do if [[ "$sdef" = *:${tag}:* ]]; then descr="${(Q)sdef#*:${tag}:}" else - descr=file + if (( $opts[(I)-X] )); then + descr= + else + descr=file + fi end=yes fi diff --git a/Completion/Unix/Type/_path_files b/Completion/Unix/Type/_path_files index 9cf7e2d9e..0e1f9fe3f 100644 --- a/Completion/Unix/Type/_path_files +++ b/Completion/Unix/Type/_path_files @@ -5,7 +5,7 @@ local linepath realpath donepath prepath testpath exppath skips skipped local tmp1 tmp2 tmp3 tmp4 i orig eorig pre suf tpre tsuf opre osuf cpre -local pats haspats ignore pfxsfx sopt gopt opt sdirs ignpar cfopt listsfx +local pats haspats ignore pfx pfxsfx sopt gopt opt sdirs ignpar cfopt listsfx local nm=$compstate[nmatches] menu matcher mopts sort match mid accex fake typeset -U prepaths exppaths @@ -15,7 +15,7 @@ exppaths=() # Get the options. zparseopts -a mopts \ - 'P:=pfxsfx' 'S:=pfxsfx' 'q=pfxsfx' 'r:=pfxsfx' 'R:=pfxsfx' \ + 'P:=pfx' 'S:=pfxsfx' 'q=pfxsfx' 'r:=pfxsfx' 'R:=pfxsfx' \ 'W:=prepaths' 'F:=ignore' 'M+:=matcher' \ J+: V+: X+: 1: 2: n: 'f=tmp1' '/=tmp1' 'g+:-=tmp1' @@ -29,6 +29,10 @@ else fi pats=( "${(@)pats:# #}" ) +if (( $#pfx )); then + compset -P "$pfx[2]" || pfxsfx=( "$pfx[@]" "$pfxsfx[@]" ) +fi + if (( $#prepaths )); then tmp1="${prepaths[2]}" if [[ "$tmp1[1]" = '(' ]]; then |