From 9cb71e2f7cc2809b7d41e9160188ffe8af9e3b7d Mon Sep 17 00:00:00 2001 From: Sven Wischnowsky Date: Thu, 6 Apr 2000 11:36:33 +0000 Subject: tag in file-patterns optional, use `files' as default (10542) --- Completion/Core/_files | 25 ++++++++++++++++--------- 1 file changed, 16 insertions(+), 9 deletions(-) (limited to 'Completion') diff --git a/Completion/Core/_files b/Completion/Core/_files index 0c0231cb4..7a4fdc3a0 100644 --- a/Completion/Core/_files +++ b/Completion/Core/_files @@ -1,6 +1,6 @@ #autoload -local opts tmp glob pats expl tag i pat descr end ign ret=1 +local opts tmp glob pat pats expl tag i def descr end ign ret=1 zparseopts -a opts \ '/=tmp' 'f=tmp' 'g+:-=tmp' q n 1 2 P: S: r: R: W: X+: M+: F: J+: V+: @@ -19,9 +19,16 @@ else ign= fi -if zstyle -a ":completion:${curcontext}:" file-patterns pats; then +if zstyle -a ":completion:${curcontext}:" file-patterns tmp; then [[ "$type" = */* ]] && glob="$glob *(-/)" - pats=( \ ${(M)^${pats//\\%p/ ${glob:-\*} }:#*[^\\]:*} ) + pats=() + for i in ${tmp//\\%p/ ${${glob:-\*}//:/\\:} }; do + if [[ $i = *[^\\]:* ]]; then + pats=( "$pats[@]" " $i" ) + else + pats=( "$pats[@]" " ${i}:files" ) + fi + done else if [[ "$type" = *g* ]]; then if [[ "$type" = */* ]]; then @@ -37,14 +44,14 @@ else fi fi -for tag in "${(@)${(@)pats#*[^\\]:}%%:*}"; do +for def in "$pats[@]"; do ###"${(@)${(@)pats#*[^\\]:}%%:*}"; do - i="$pats[(I)*[^\\\\]:${tag}(|:*)]" - pat="${${pats[i]%%:${tag}*}//\\\\:/:}" + tag="${${def#*[^\\]:}%%:*}" + pat="${${def%%:${tag}*}//\\\\:/:}" - if [[ i -gt 0 && "$pat" != \ # ]]; then - if [[ "$pats[i]" = *:${tag}:* ]]; then - descr="${pats[i]#*:${tag}:}" + if [[ "$pat" != \ # ]]; then + if [[ "$def" = *:${tag}:* ]]; then + descr="${def#*:${tag}:}" else descr=file end=yes -- cgit 1.4.1