about summary refs log tree commit diff
diff options
context:
space:
mode:
authorSven Wischnowsky <wischnow@users.sourceforge.net>2000-05-25 12:01:37 +0000
committerSven Wischnowsky <wischnow@users.sourceforge.net>2000-05-25 12:01:37 +0000
commit105456d250059c773f7dba9af29e007b568786c4 (patch)
treeefffb6c23a807133d98fab409d5bb5755b2df36c
parentc99a94e365d43983121f1e9ae6c345eaf13ab55a (diff)
downloadzsh-105456d250059c773f7dba9af29e007b568786c4.tar.gz
zsh-105456d250059c773f7dba9af29e007b568786c4.tar.xz
zsh-105456d250059c773f7dba9af29e007b568786c4.zip
fix for special-dirs when used with -g patterns (11570)
-rw-r--r--ChangeLog3
-rw-r--r--Completion/Core/_path_files14
2 files changed, 11 insertions, 6 deletions
diff --git a/ChangeLog b/ChangeLog
index 176f0dadc..80d44c36b 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,8 @@
 2000-05-25  Sven Wischnowsky  <wischnow@zsh.org>
 
+	* 11570: Completion/Core/_path_files: fix for special-dirs when
+ 	used with -g patterns
+	
 	* 11569: Src/Zle/complist.c: better cursor-movement in
  	menu-selection
 	
diff --git a/Completion/Core/_path_files b/Completion/Core/_path_files
index 31dbcea15..bfe370eed 100644
--- a/Completion/Core/_path_files
+++ b/Completion/Core/_path_files
@@ -142,6 +142,9 @@ fi
 zstyle -s ":completion:${curcontext}:paths" special-dirs sdirs &&
     [[ "$sdirs" = (yes|true|on|1) ]] && sdirs=yes
 
+[[ "$pats" = ((|*[[:blank:]])\*(|[[:blank:]]*)|*\([^[:blank:]]#/[^[:blank:]]#\)*) ]] &&
+    sopt=$sopt/
+
 zstyle -s ":completion:${curcontext}:files" ignore-parents ignpar
 
 # We get the prefix and the suffix from the line and save the whole
@@ -293,9 +296,9 @@ for prepath in "$prepaths[@]"; do
       fi
       if [[ -n "$sdirs" && ( -o globdots || "$PREFIX" = .* ) ]]; then
 	if [[ "$sdirs" = yes ]]; then
-	  tmp1=( "$tmp1[@]" . .. )
+	  tmp1=( "$tmp1[@]" $^tmp2${skipped}{.,..} )
 	elif [[ "$sdirs" = .. ]]; then
-	  tmp1=( "$tmp1[@]" .. )
+	  tmp1=( "$tmp1[@]" $^tmp2${skipped}.. )
         fi
       fi
     else
@@ -304,13 +307,12 @@ for prepath in "$prepaths[@]"; do
       else
         tmp1=( ${^tmp1}${skipped}${^~pats} )
       fi
-      if [[ -n "$sdirs" &&
-            ( "$sopt" = *[/f]* || "$pats" = *\([^[:blank:]]#/[^[:blank:]]#\)* ) &&
+      if [[ -n "$sdirs" && "$sopt" = *[/f]* &&
             ( -o globdots || "$PREFIX" = .* ) ]]; then
 	if [[ "$sdirs" = yes ]]; then
-	  tmp1=( "$tmp1[@]" . .. )
+	  tmp1=( "$tmp1[@]" $^tmp2${skipped}{.,..} )
 	elif [[ "$sdirs" = .. ]]; then
-	  tmp1=( "$tmp1[@]" .. )
+	  tmp1=( "$tmp1[@]" $^tmp2${skipped}.. )
         fi
       fi
     fi