about summary refs log tree commit diff
path: root/Etc
diff options
context:
space:
mode:
authorPeter Stephenson <p.stephenson@samsung.com>2019-07-08 14:27:08 +0100
committerPeter Stephenson <p.stephenson@samsung.com>2019-07-08 14:27:08 +0100
commit61a697f977cd5152c15d9fd3a3628826d2b5fc52 (patch)
treeb4fbd5fd1d8e7c00d60b52bf5342ae458cc5d803 /Etc
parent3bdf4d6641fb34d1c2f130abddb847169a793afe (diff)
downloadzsh-61a697f977cd5152c15d9fd3a3628826d2b5fc52.tar.gz
zsh-61a697f977cd5152c15d9fd3a3628826d2b5fc52.tar.xz
zsh-61a697f977cd5152c15d9fd3a3628826d2b5fc52.zip
users/24030 (minor tweak): note on *.{bla,hbl,ahb}.
This is an expansion, not a form of pattern match.  Describe
the problem and what to do instead.
Diffstat (limited to 'Etc')
-rw-r--r--Etc/FAQ.yo39
1 files changed, 39 insertions, 0 deletions
diff --git a/Etc/FAQ.yo b/Etc/FAQ.yo
index c4f65e97a..be4e1f8a8 100644
--- a/Etc/FAQ.yo
+++ b/Etc/FAQ.yo
@@ -128,6 +128,7 @@ Chapter 3:  How to get various things to work
 3.27. What are these `^' and `~' pattern characters, anyway?
 3.28. How do I edit the input buffer in $EDITOR?
 3.29. Why does `which' output for missing commands go to stdout?
+3.30. Why doesn't the expansion mytt(*.{tex,aux,pdf}) do what I expect?
 
 Chapter 4:  The mysteries of completion
 4.1. What is completion?
@@ -1995,6 +1996,44 @@ sect(Why does `which' output for missing commands go to stdout?)
   the exit status does reflect the fact the command can't be found.
 
 
+sect(Why doesn't the expansion mytt(*.{tex,aux,pdf}) do what I expect?)
+
+  Based on the behaviour of some other shells, you might guess that the
+  following expression:
+  verb(
+    echo *.{tex,aux,pdf}
+  )
+  would be the way to echo any files ending in mytt(.tex), mytt(.aux) or
+  mytt(.pdf) in the current directory.  Depending on your settings for
+  matching (see link(2.1)(21), in particular tt(NO_NOMATCH)), you may
+  see something else, in particular an error about (say) mytt(*.aux) if
+  there were no files ending mytt(.aux).
+
+  The reason for this is that the brace expansion isn't actually
+  a form of pattern matching.  Instead, the line above is equivalent to
+  verb(
+    echo *.tex *.aux *.pdf
+  )
+  giving you three separate patterns.  With the default mytt(NOMATCH)
+  behaviour in effect, any pattern that fails to match is an error.
+
+  However, there em(is) a way of doing exactly what you want, using
+  parentheses instead of braces:
+  verb(
+    echo *.(tex|aux|pdf)
+  )
+  This is now a pattern matching expression, so is considered as a
+  single pattern.  Now any file that exists will supress the
+  mytt(NOMATCH) behaviour, but you'll still get all the files that do
+  match.
+
+  This use of parentheses is special to zsh.  Modern Bourne-like shells
+  have a syntax like this, too, but with an mytt(@) in front of the
+  parentheses: again, see link(2.1)(21), and search for mytt(@+LPAR()).
+  This is harder for the user to remember but easier for the shell to
+  parse!
+
+
 chapter(The mysteries of completion)