]> git.saurik.com Git - wxWidgets.git/blame - docs/latex/wx/re_syntax.tex
reSWIGged
[wxWidgets.git] / docs / latex / wx / re_syntax.tex
CommitLineData
0aa7fa9a
VS
1% manual page source format generated by PolyglotMan v3.0.9,
2% available via anonymous ftp from ftp.cs.berkeley.edu:/ucb/people/phelps/tcltk/rman.tar.Z
3
4\section{Syntax of the builtin regular expression library}\label{wxresyn}
5
6A {\it regular expression} describes strings of characters. It's a
7pattern that matches certain strings and doesn't match others.
8
9\wxheading{See also}
10
11\helpref{wxRegEx}{wxregex}
12
0aa7fa9a
VS
13\subsection{Different Flavors of REs}
14
15\helpref{Syntax of the builtin regular expression library}{wxresyn}
16
17Regular expressions (``RE''s), as defined by POSIX, come in two
18flavors: {\it extended} REs (``EREs'') and {\it basic} REs (``BREs''). EREs are roughly those
19of the traditional {\it egrep}, while BREs are roughly those of the traditional
20 {\it ed}. This implementation adds a third flavor, {\it advanced} REs (``AREs''), basically
21EREs with some significant extensions.
22
23This manual page primarily describes
d2c2afc9
JS
24AREs. BREs mostly exist for backward compatibility in some old programs;
25they will be discussed at the \helpref{end}{wxresynbre}. POSIX EREs are almost an exact subset
26of AREs. Features of AREs that are not present in EREs will be indicated.
0aa7fa9a 27
0aa7fa9a
VS
28\subsection{Regular Expression Syntax}
29
30\helpref{Syntax of the builtin regular expression library}{wxresyn}
31
32These regular expressions are implemented using
33the package written by Henry Spencer, based on the 1003.2 spec and some
34(not quite all) of the Perl5 extensions (thanks, Henry!). Much of the description
35of regular expressions below is copied verbatim from his manual entry.
36
d2c2afc9 37An ARE is one or more {\it branches}, separated by `{\bf $|$}', matching anything that matches
0aa7fa9a
VS
38any of the branches.
39
40A branch is zero or more {\it constraints} or {\it quantified
41atoms}, concatenated. It matches a match for the first, followed by a match
42for the second, etc; an empty branch matches the empty string.
43
d2c2afc9 44A quantified atom is an {\it atom} possibly followed by a single {\it quantifier}. Without a quantifier,
0aa7fa9a
VS
45it matches a match for the atom. The quantifiers, and what a so-quantified
46atom matches, are:
47
48\begin{twocollist}\twocolwidtha{4cm}
49\twocolitem{{\bf *}}{a sequence of 0 or more matches of the atom}
50\twocolitem{{\bf +}}{a sequence of 1 or more matches of the atom}
51\twocolitem{{\bf ?}}{a sequence of 0 or 1 matches of the atom}
52\twocolitem{{\bf \{m\}}}{a sequence of exactly {\it m} matches of the atom}
53\twocolitem{{\bf \{m,\}}}{a sequence of {\it m} or more matches of the atom}
54\twocolitem{{\bf \{m,n\}}}{a sequence of {\it m} through {\it n} (inclusive)
55matches of the atom; {\it m} may not exceed {\it n}}
56\twocolitem{{\bf *? +? ?? \{m\}? \{m,\}? \{m,n\}?}}{{\it non-greedy} quantifiers,
57which match the same possibilities, but prefer the
58smallest number rather than the largest number of matches (see \helpref{Matching}{wxresynmatching})}
59\end{twocollist}
60
61The forms using {\bf \{} and {\bf \}} are known as {\it bound}s. The numbers {\it m} and {\it n} are unsigned
62decimal integers with permissible values from 0 to 255 inclusive.
63An atom is one of:
64
65\begin{twocollist}\twocolwidtha{4cm}
66\twocolitem{{\bf (re)}}{(where {\it re} is any regular expression) matches a match for
67 {\it re}, with the match noted for possible reporting}
68\twocolitem{{\bf (?:re)}}{as previous, but
69does no reporting (a ``non-capturing'' set of parentheses)}
70\twocolitem{{\bf ()}}{matches an empty
71string, noted for possible reporting}
72\twocolitem{{\bf (?:)}}{matches an empty string, without reporting}
73\twocolitem{{\bf $[chars]$}}{a {\it bracket expression}, matching any one of the {\it chars}
74(see \helpref{Bracket Expressions}{wxresynbracket} for more detail)}
75\twocolitem{{\bf .}}{matches any single character }
76\twocolitem{{\bf $\backslash$k}}{(where {\it k} is a non-alphanumeric character)
77matches that character taken as an ordinary character, e.g. $\backslash\backslash$ matches a backslash
78character}
79\twocolitem{{\bf $\backslash$c}}{where {\it c} is alphanumeric (possibly followed by other characters),
80an {\it escape} (AREs only), see \helpref{Escapes}{wxresynescapes} below}
81\twocolitem{{\bf \{}}{when followed by a character
82other than a digit, matches the left-brace character `{\bf \{}'; when followed by
83a digit, it is the beginning of a {\it bound} (see above)}
84\twocolitem{{\bf x}}{where {\it x} is a single
85character with no other significance, matches that character.}
86\end{twocollist}
87
d2c2afc9 88A {\it constraint} matches an empty string when specific conditions are met. A constraint may
0aa7fa9a
VS
89not be followed by a quantifier. The simple constraints are as follows;
90some more constraints are described later, under \helpref{Escapes}{wxresynescapes}.
91
92\begin{twocollist}\twocolwidtha{4cm}
e119d049 93\twocolitem{{\bf \caret}}{matches at the beginning of a line}
0aa7fa9a
VS
94\twocolitem{{\bf \$}}{matches at the end of a line}
95\twocolitem{{\bf (?=re)}}{{\it positive lookahead}
96(AREs only), matches at any point where a substring matching {\it re} begins}
97\twocolitem{{\bf (?!re)}}{{\it negative lookahead} (AREs only),
98matches at any point where no substring matching {\it re} begins}
99\end{twocollist}
100
101The lookahead constraints may not contain back references
102(see later), and all parentheses within them are considered non-capturing.
103
104An RE may not end with `{\bf $\backslash$}'.
105
0aa7fa9a
VS
106\subsection{Bracket Expressions}\label{wxresynbracket}
107
108\helpref{Syntax of the builtin regular expression library}{wxresyn}
109
110A {\it bracket expression} is a list
111of characters enclosed in `{\bf $[]$}'. It normally matches any single character from
e119d049 112the list (but see below). If the list begins with `{\bf \caret}', it matches any single
0aa7fa9a
VS
113character (but see below) {\it not} from the rest of the list.
114
115If two characters
116in the list are separated by `{\bf -}', this is shorthand for the full {\it range} of
117characters between those two (inclusive) in the collating sequence, e.g.
118 {\bf $[0-9]$} in ASCII matches any decimal digit. Two ranges may not share an endpoint,
119so e.g. {\bf a-c-e} is illegal. Ranges are very collating-sequence-dependent, and portable
120programs should avoid relying on them.
121
122To include a literal {\bf $]$} or {\bf -} in the
123list, the simplest method is to enclose it in {\bf $[.$} and {\bf $.]$} to make it a collating
124element (see below). Alternatively, make it the first character (following
e119d049 125a possible `{\bf \caret}'), or (AREs only) precede it with `{\bf $\backslash$}'.
0aa7fa9a
VS
126Alternatively, for `{\bf -}', make
127it the last character, or the second endpoint of a range. To use a literal
128 {\bf -} as the first endpoint of a range, make it a collating element or (AREs
129only) precede it with `{\bf $\backslash$}'. With the exception of these, some combinations using
130 {\bf $[$} (see next paragraphs), and escapes, all other special characters lose
131their special significance within a bracket expression.
132
133Within a bracket
134expression, a collating element (a character, a multi-character sequence
135that collates as if it were a single character, or a collating-sequence
136name for either) enclosed in {\bf $[.$} and {\bf $.]$} stands for the
137sequence of characters of that collating element.
138
14ffa743 139{\it wxWidgets}: Currently no multi-character collating elements are defined.
0aa7fa9a
VS
140So in {\bf $[.X.]$}, {\it X} can either be a single character literal or
141the name of a character. For example, the following are both identical
142 {\bf $[[.0.]-[.9.]]$} and {\bf $[[.zero.]-[.nine.]]$} and mean the same as
143 {\bf $[0-9]$}.
144 See \helpref{Character Names}{wxresynchars}.
145
146%The sequence is a single element of the bracket
147%expression's list. A bracket expression in a locale that has multi-character
148%collating elements can thus match more than one character. So (insidiously),
e119d049 149%a bracket expression that starts with {\bf \caret} can match multi-character collating
0aa7fa9a
VS
150%elements even if none of them appear in the bracket expression! ({\it Note:}
151%Tcl currently has no multi-character collating elements. This information
152%is only for illustration.)
153%
154%For example, assume the collating sequence includes
155%a {\bf ch} multi-character collating element. Then the RE {\bf $[[.ch.]]*c$} (zero or more
156% {\bf ch}'s followed by {\bf c}) matches the first five characters of `{\bf chchcc}'. Also, the
157%RE {\bf $[^c]b$} matches all of `{\bf chb}' (because {\bf $[^c]$} matches the multi-character {\bf ch}).
158
159Within a bracket expression, a collating element enclosed in {\bf $[=$} and {\bf $=]$}
160is an equivalence class, standing for the sequences of characters of all
161collating elements equivalent to that one, including itself.
162%(If there are
163%no other equivalent collating elements, the treatment is as if the enclosing
164%delimiters were `{\bf $[.$}' and `{\bf $.]$}'.) For example, if {\bf o}
e119d049
JS
165%and {\bf \caret} are the members of an
166%equivalence class, then `{\bf $[[$=o=$]]$}', `{\bf $[[$=\caret=$]]$}',
0aa7fa9a
VS
167%and `{\bf $[o^]$}' are all synonymous.
168An equivalence class may not be an endpoint of a range.
169
170%({\it Note:} Tcl currently
171%implements only the Unicode locale. It doesn't define any equivalence classes.
172%The examples above are just illustrations.)
173
14ffa743 174{\it wxWidgets}: Currently no equivalence classes are defined, so
0aa7fa9a
VS
175{\bf $[=X=]$} stands for just the single character {\it X}.
176 {\it X} can either be a single character literal or the name of a character,
177see \helpref{Character Names}{wxresynchars}.
178
179Within a bracket expression,
180the name of a {\it character class} enclosed in {\bf $[:$} and {\bf $:]$} stands for the list
181of all characters (not all collating elements!) belonging to that class.
182Standard character classes are:
183
184\begin{twocollist}\twocolwidtha{3cm}
185\twocolitem{{\bf alpha}}{A letter.}
186\twocolitem{{\bf upper}}{An upper-case letter.}
187\twocolitem{{\bf lower}}{A lower-case letter.}
188\twocolitem{{\bf digit}}{A decimal digit.}
189\twocolitem{{\bf xdigit}}{A hexadecimal digit.}
190\twocolitem{{\bf alnum}}{An alphanumeric (letter or digit).}
191\twocolitem{{\bf print}}{An alphanumeric (same as alnum).}
192\twocolitem{{\bf blank}}{A space or tab character.}
193\twocolitem{{\bf space}}{A character producing white space in displayed text.}
194\twocolitem{{\bf punct}}{A punctuation character.}
195\twocolitem{{\bf graph}}{A character with a visible representation.}
196\twocolitem{{\bf cntrl}}{A control character.}
197\end{twocollist}
198
199%A locale may provide others. (Note that the current Tcl
200%implementation has only one locale: the Unicode locale.)
201A character class may not be used as an endpoint of a range.
202
14ffa743 203{\it wxWidgets}: In a non-Unicode build, these character classifications depend on the
0aa7fa9a
VS
204current locale, and correspond to the values return by the ANSI C 'is'
205functions: isalpha, isupper, etc. In Unicode mode they are based on
206Unicode classifications, and are not affected by the current locale.
207
208There are two special cases of bracket expressions:
209the bracket expressions {\bf $[[:$<$:]]$} and {\bf $[[:$>$:]]$} are constraints, matching empty
210strings at the beginning and end of a word respectively. A word is defined
211as a sequence of word characters that is neither preceded nor followed
212by word characters. A word character is an {\it alnum} character or an underscore
213({\bf \_}). These special bracket expressions are deprecated; users of AREs should
214use constraint escapes instead (see \helpref{Escapes}{wxresynescapes} below).
215
0aa7fa9a
VS
216\subsection{Escapes}\label{wxresynescapes}
217
218\helpref{Syntax of the builtin regular expression library}{wxresyn}
219
220Escapes (AREs only),
221which begin with a {\bf $\backslash$} followed by an alphanumeric character, come in several
222varieties: character entry, class shorthands, constraint escapes, and back
223references. A {\bf $\backslash$} followed by an alphanumeric character but not constituting
224a valid escape is illegal in AREs. In EREs, there are no escapes: outside
225a bracket expression, a {\bf $\backslash$} followed by an alphanumeric character merely stands
226for that character as an ordinary character, and inside a bracket expression,
227 {\bf $\backslash$} is an ordinary character. (The latter is the one actual incompatibility
228between EREs and AREs.)
229
230Character-entry escapes (AREs only) exist to make
231it easier to specify non-printing and otherwise inconvenient characters
232in REs:
233
234\begin{twocollist}\twocolwidtha{4cm}
235\twocolitem{{\bf $\backslash$a}}{alert (bell) character, as in C}
236\twocolitem{{\bf $\backslash$b}}{backspace, as in C}
237\twocolitem{{\bf $\backslash$B}}{synonym
238for {\bf $\backslash$} to help reduce backslash doubling in some applications where there
239are multiple levels of backslash processing}
240\twocolitem{{\bf $\backslash$c{\it X}}}{(where X is any character)
241the character whose low-order 5 bits are the same as those of {\it X}, and whose
242other bits are all zero}
243\twocolitem{{\bf $\backslash$e}}{the character whose collating-sequence name is
244`{\bf ESC}', or failing that, the character with octal value 033}
245\twocolitem{{\bf $\backslash$f}}{formfeed, as in C}
246\twocolitem{{\bf $\backslash$n}}{newline, as in C}
247\twocolitem{{\bf $\backslash$r}}{carriage return, as in C}
248\twocolitem{{\bf $\backslash$t}}{horizontal tab, as in C}
249\twocolitem{{\bf $\backslash$u{\it wxyz}}}{(where {\it wxyz} is exactly four hexadecimal digits)
250the Unicode
251character {\bf U+{\it wxyz}} in the local byte ordering}
252\twocolitem{{\bf $\backslash$U{\it stuvwxyz}}}{(where {\it stuvwxyz} is
253exactly eight hexadecimal digits) reserved for a somewhat-hypothetical Unicode
254extension to 32 bits}
255\twocolitem{{\bf $\backslash$v}}{vertical tab, as in C are all available.}
256\twocolitem{{\bf $\backslash$x{\it hhh}}}{(where
257 {\it hhh} is any sequence of hexadecimal digits) the character whose hexadecimal
258value is {\bf 0x{\it hhh}} (a single character no matter how many hexadecimal digits
259are used).}
260\twocolitem{{\bf $\backslash$0}}{the character whose value is {\bf 0}}
261\twocolitem{{\bf $\backslash${\it xy}}}{(where {\it xy} is exactly two
262octal digits, and is not a {\it back reference} (see below)) the character whose
263octal value is {\bf 0{\it xy}}}
264\twocolitem{{\bf $\backslash${\it xyz}}}{(where {\it xyz} is exactly three octal digits, and is
265not a back reference (see below))
266the character whose octal value is {\bf 0{\it xyz}}}
267\end{twocollist}
268
269Hexadecimal digits are `{\bf 0}'-`{\bf 9}', `{\bf a}'-`{\bf f}', and `{\bf A}'-`{\bf F}'. Octal
270digits are `{\bf 0}'-`{\bf 7}'.
271
272The character-entry
273escapes are always taken as ordinary characters. For example, {\bf $\backslash$135} is {\bf ]} in
274ASCII, but {\bf $\backslash$135} does not terminate a bracket expression. Beware, however,
275that some applications (e.g., C compilers) interpret such sequences themselves
276before the regular-expression package gets to see them, which may require
277doubling (quadrupling, etc.) the `{\bf $\backslash$}'.
278
279Class-shorthand escapes (AREs only) provide
280shorthands for certain commonly-used character classes:
281
282\begin{twocollist}\twocolwidtha{4cm}
283\twocolitem{{\bf $\backslash$d}}{{\bf $[[:digit:]]$}}
284\twocolitem{{\bf $\backslash$s}}{{\bf $[[:space:]]$}}
285\twocolitem{{\bf $\backslash$w}}{{\bf $[[:alnum:]\_]$} (note underscore)}
286\twocolitem{{\bf $\backslash$D}}{{\bf $[^[:digit:]]$}}
287\twocolitem{{\bf $\backslash$S}}{{\bf $[^[:space:]]$}}
288\twocolitem{{\bf $\backslash$W}}{{\bf $[^[:alnum:]\_]$} (note underscore)}
289\end{twocollist}
290
291Within bracket expressions, `{\bf $\backslash$d}', `{\bf $\backslash$s}', and
292`{\bf $\backslash$w}' lose their outer brackets, and `{\bf $\backslash$D}',
293`{\bf $\backslash$S}', and `{\bf $\backslash$W}' are illegal. (So, for example,
294 {\bf $[$a-c$\backslash$d$]$} is equivalent to {\bf $[a-c[:digit:]]$}.
295Also, {\bf $[$a-c$\backslash$D$]$}, which is equivalent to
296 {\bf $[a-c^[:digit:]]$}, is illegal.)
297
298A constraint escape (AREs only) is a constraint,
299matching the empty string if specific conditions are met, written as an
300escape:
301
302\begin{twocollist}\twocolwidtha{4cm}
303\twocolitem{{\bf $\backslash$A}}{matches only at the beginning of the string
304(see \helpref{Matching}{wxresynmatching}, below,
e119d049 305for how this differs from `{\bf \caret}')}
0aa7fa9a
VS
306\twocolitem{{\bf $\backslash$m}}{matches only at the beginning of a word}
307\twocolitem{{\bf $\backslash$M}}{matches only at the end of a word}
308\twocolitem{{\bf $\backslash$y}}{matches only at the beginning or end of a word}
309\twocolitem{{\bf $\backslash$Y}}{matches only at a point that is not the beginning or end of
310a word}
311\twocolitem{{\bf $\backslash$Z}}{matches only at the end of the string
312(see \helpref{Matching}{wxresynmatching}, below, for
313how this differs from `{\bf \$}')}
314\twocolitem{{\bf $\backslash${\it m}}}{(where {\it m} is a nonzero digit) a {\it back reference},
315see below}
316\twocolitem{{\bf $\backslash${\it mnn}}}{(where {\it m} is a nonzero digit, and {\it nn} is some more digits,
317and the decimal value {\it mnn} is not greater than the number of closing capturing
318parentheses seen so far) a {\it back reference}, see below}
319\end{twocollist}
320
321A word is defined
322as in the specification of {\bf $[[:$<$:]]$} and {\bf $[[:$>$:]]$} above. Constraint escapes are
323illegal within bracket expressions.
324
325A back reference (AREs only) matches
326the same string matched by the parenthesized subexpression specified by
327the number, so that (e.g.) {\bf ($[bc]$)$\backslash$1} matches {\bf bb} or {\bf cc} but not `{\bf bc}'.
328The subexpression
329must entirely precede the back reference in the RE. Subexpressions are numbered
330in the order of their leading parentheses. Non-capturing parentheses do not
331define subexpressions.
332
333There is an inherent historical ambiguity between
334octal character-entry escapes and back references, which is resolved by
335heuristics, as hinted at above. A leading zero always indicates an octal
336escape. A single non-zero digit, not followed by another digit, is always
337taken as a back reference. A multi-digit sequence not starting with a zero
338is taken as a back reference if it comes after a suitable subexpression
339(i.e. the number is in the legal range for a back reference), and otherwise
340is taken as octal.
341
0aa7fa9a
VS
342\subsection{Metasyntax}
343
344\helpref{Syntax of the builtin regular expression library}{wxresyn}
345
346In addition to the main syntax described above,
347there are some special forms and miscellaneous syntactic facilities available.
348
349Normally the flavor of RE being used is specified by application-dependent
350means. However, this can be overridden by a {\it director}. If an RE of any flavor
351begins with `{\bf ***:}', the rest of the RE is an ARE. If an RE of any flavor begins
352with `{\bf ***=}', the rest of the RE is taken to be a literal string, with all
353characters considered ordinary characters.
354
355An ARE may begin with {\it embedded options}: a sequence {\bf (?xyz)}
356(where {\it xyz} is one or more alphabetic characters)
357specifies options affecting the rest of the RE. These supplement, and can
358override, any options specified by the application. The available option
359letters are:
360
361\begin{twocollist}\twocolwidtha{4cm}
362\twocolitem{{\bf b}}{rest of RE is a BRE}
363\twocolitem{{\bf c}}{case-sensitive matching (usual default)}
364\twocolitem{{\bf e}}{rest of RE is an ERE}
365\twocolitem{{\bf i}}{case-insensitive matching (see \helpref{Matching}{wxresynmatching}, below)}
366\twocolitem{{\bf m}}{historical synonym for {\bf n}}
367\twocolitem{{\bf n}}{newline-sensitive matching (see \helpref{Matching}{wxresynmatching}, below)}
368\twocolitem{{\bf p}}{partial newline-sensitive matching (see \helpref{Matching}{wxresynmatching}, below)}
369\twocolitem{{\bf q}}{rest of RE
370is a literal (``quoted'') string, all ordinary characters}
371\twocolitem{{\bf s}}{non-newline-sensitive matching (usual default)}
372\twocolitem{{\bf t}}{tight syntax (usual default; see below)}
373\twocolitem{{\bf w}}{inverse
374partial newline-sensitive (``weird'') matching (see \helpref{Matching}{wxresynmatching}, below)}
375\twocolitem{{\bf x}}{expanded syntax (see below)}
376\end{twocollist}
377
378Embedded options take effect at the {\bf )} terminating the
379sequence. They are available only at the start of an ARE, and may not be
380used later within it.
381
382In addition to the usual ({\it tight}) RE syntax, in which
383all characters are significant, there is an {\it expanded} syntax, available
384%in all flavors of RE with the {\bf -expanded} switch, or
385in AREs with the embedded
386x option. In the expanded syntax, white-space characters are ignored and
387all characters between a {\bf \#} and the following newline (or the end of the
388RE) are ignored, permitting paragraphing and commenting a complex RE. There
389are three exceptions to that basic rule:
390{\itemize
391\item%
392a white-space character or `{\bf \#}' preceded
393by `{\bf $\backslash$}' is retained
394\item%
395white space or `{\bf \#}' within a bracket expression is retained
396\item%
397white space and comments are illegal within multi-character symbols like
398the ARE `{\bf (?:}' or the BRE `{\bf $\backslash$(}'
399}
400Expanded-syntax white-space characters are blank,
401tab, newline, and any character that belongs to the {\it space} character class.
402
403Finally, in an ARE, outside bracket expressions, the sequence `{\bf (?\#ttt)}' (where
404 {\it ttt} is any text not containing a `{\bf )}') is a comment, completely ignored. Again,
405this is not allowed between the characters of multi-character symbols like
406`{\bf (?:}'. Such comments are more a historical artifact than a useful facility,
407and their use is deprecated; use the expanded syntax instead.
408
409{\it None} of these
410metasyntax extensions is available if the application (or an initial {\bf ***=}
411director) has specified that the user's input be treated as a literal string
412rather than as an RE.
413
0aa7fa9a
VS
414\subsection{Matching}\label{wxresynmatching}
415
416\helpref{Syntax of the builtin regular expression library}{wxresyn}
417
418In the event that an RE could match more than
419one substring of a given string, the RE matches the one starting earliest
420in the string. If the RE could match more than one substring starting at
421that point, its choice is determined by its {\it preference}: either the longest
422substring, or the shortest.
423
424Most atoms, and all constraints, have no preference.
425A parenthesized RE has the same preference (possibly none) as the RE. A
426quantified atom with quantifier {\bf \{m\}} or {\bf \{m\}?} has the same preference (possibly
427none) as the atom itself. A quantified atom with other normal quantifiers
428(including {\bf \{m,n\}} with {\it m} equal to {\it n}) prefers longest match. A quantified
429atom with other non-greedy quantifiers (including {\bf \{m,n\}?} with {\it m} equal to
430 {\it n}) prefers shortest match. A branch has the same preference as the first
431quantified atom in it which has a preference. An RE consisting of two or
432more branches connected by the {\bf $|$} operator prefers longest match.
433
d2c2afc9 434Subject to the constraints imposed by the rules for matching the whole RE, subexpressions
0aa7fa9a
VS
435also match the longest or shortest possible substrings, based on their
436preferences, with subexpressions starting earlier in the RE taking priority
437over ones starting later. Note that outer subexpressions thus take priority
438over their component subexpressions.
439
440Note that the quantifiers {\bf \{1,1\}} and
441 {\bf \{1,1\}?} can be used to force longest and shortest preference, respectively,
442on a subexpression or a whole RE.
443
444Match lengths are measured in characters,
445not collating elements. An empty string is considered longer than no match
446at all. For example, {\bf bb*} matches the three middle characters
447of `{\bf abbbc}', {\bf (week$|$wee)(night$|$knights)}
448matches all ten characters of `{\bf weeknights}', when {\bf (.*).*} is matched against
449 {\bf abc} the parenthesized subexpression matches all three characters, and when
450 {\bf (a*)*} is matched against {\bf bc} both the whole RE and the parenthesized subexpression
451match an empty string.
452
453If case-independent matching is specified, the effect
454is much as if all case distinctions had vanished from the alphabet. When
455an alphabetic that exists in multiple cases appears as an ordinary character
456outside a bracket expression, it is effectively transformed into a bracket
457expression containing both cases, so that {\bf x} becomes `{\bf $[xX]$}'. When it appears
458inside a bracket expression, all case counterparts of it are added to the
459bracket expression, so that {\bf $[x]$} becomes {\bf $[xX]$} and {\bf $[^x]$} becomes `{\bf $[^xX]$}'.
460
461If newline-sensitive
e119d049 462matching is specified, {\bf .} and bracket expressions using {\bf \caret} will never match
0aa7fa9a 463the newline character (so that matches will never cross newlines unless
e119d049 464the RE explicitly arranges it) and {\bf \caret} and {\bf \$} will match the empty string after
0aa7fa9a
VS
465and before a newline respectively, in addition to matching at beginning
466and end of string respectively. ARE {\bf $\backslash$A} and {\bf $\backslash$Z} continue to match beginning
467or end of string {\it only}.
468
469If partial newline-sensitive matching is specified,
470this affects {\bf .} and bracket expressions as with newline-sensitive matching,
e119d049 471but not {\bf \caret} and `{\bf \$}'.
0aa7fa9a
VS
472
473If inverse partial newline-sensitive matching is specified,
e119d049 474this affects {\bf \caret} and {\bf \$} as with newline-sensitive matching, but not {\bf .} and bracket
0aa7fa9a
VS
475expressions. This isn't very useful but is provided for symmetry.
476
0aa7fa9a
VS
477\subsection{Limits And Compatibility}
478
479\helpref{Syntax of the builtin regular expression library}{wxresyn}
480
481No particular limit is imposed on the length of REs. Programs
482intended to be highly portable should not employ REs longer than 256 bytes,
483as a POSIX-compliant implementation can refuse to accept such REs.
484
485The only
486feature of AREs that is actually incompatible with POSIX EREs is that {\bf $\backslash$}
487does not lose its special significance inside bracket expressions. All other
488ARE features use syntax which is illegal or has undefined or unspecified
489effects in POSIX EREs; the {\bf ***} syntax of directors likewise is outside
490the POSIX syntax for both BREs and EREs.
491
492Many of the ARE extensions are
493borrowed from Perl, but some have been changed to clean them up, and a
494few Perl extensions are not present. Incompatibilities of note include `{\bf $\backslash$b}',
495`{\bf $\backslash$B}', the lack of special treatment for a trailing newline, the addition of
496complemented bracket expressions to the things affected by newline-sensitive
497matching, the restrictions on parentheses and back references in lookahead
498constraints, and the longest/shortest-match (rather than first-match) matching
499semantics.
500
501The matching rules for REs containing both normal and non-greedy
502quantifiers have changed since early beta-test versions of this package.
503(The new rules are much simpler and cleaner, but don't work as hard at guessing
504the user's real intentions.)
505
506Henry Spencer's original 1986 {\it regexp} package, still in widespread use,
507%(e.g., in pre-8.1 releases of Tcl),
508implemented an early version of today's EREs. There are four incompatibilities between {\it regexp}'s
509near-EREs (`RREs' for short) and AREs. In roughly increasing order of significance:
510{\itemize
d2c2afc9 511\item In AREs, {\bf $\backslash$} followed by an alphanumeric character is either an escape or
0aa7fa9a
VS
512an error, while in RREs, it was just another way of writing the alphanumeric.
513This should not be a problem because there was no reason to write such
514a sequence in RREs.
515
d2c2afc9 516\item {\bf \{} followed by a digit in an ARE is the beginning of
0aa7fa9a
VS
517a bound, while in RREs, {\bf \{} was always an ordinary character. Such sequences
518should be rare, and will often result in an error because following characters
519will not look like a valid bound.
520
d2c2afc9 521\item In AREs, {\bf $\backslash$} remains a special character
0aa7fa9a
VS
522within `{\bf $[]$}', so a literal {\bf $\backslash$} within {\bf $[]$} must be
523written `{\bf $\backslash\backslash$}'. {\bf $\backslash\backslash$} also gives a literal
524 {\bf $\backslash$} within {\bf $[]$} in RREs, but only truly paranoid programmers routinely doubled
525the backslash.
526
d2c2afc9 527\item AREs report the longest/shortest match for the RE, rather
0aa7fa9a
VS
528than the first found in a specified search order. This may affect some RREs
529which were written in the expectation that the first match would be reported.
530(The careful crafting of RREs to optimize the search order for fast matching
531is obsolete (AREs examine all possible matches in parallel, and their performance
532is largely insensitive to their complexity) but cases where the search
533order was exploited to deliberately find a match which was {\it not} the longest/shortest
534will need rewriting.)
535}
536
0aa7fa9a
VS
537\subsection{Basic Regular Expressions}\label{wxresynbre}
538
539\helpref{Syntax of the builtin regular expression library}{wxresyn}
540
541BREs differ from EREs in
542several respects. `{\bf $|$}', `{\bf +}', and {\bf ?} are ordinary characters and there is no equivalent
543for their functionality. The delimiters for bounds
544are {\bf $\backslash$\{} and `{\bf $\backslash$\}}', with {\bf \{} and
545 {\bf \}} by themselves ordinary characters. The parentheses for nested subexpressions
546are {\bf $\backslash$(} and `{\bf $\backslash$)}', with {\bf (} and {\bf )} by themselves
e119d049 547ordinary characters. {\bf \caret} is an ordinary
0aa7fa9a
VS
548character except at the beginning of the RE or the beginning of a parenthesized
549subexpression, {\bf \$} is an ordinary character except at the end of the RE or
550the end of a parenthesized subexpression, and {\bf *} is an ordinary character
551if it appears at the beginning of the RE or the beginning of a parenthesized
e119d049 552subexpression (after a possible leading `{\bf \caret}'). Finally, single-digit back references
0aa7fa9a
VS
553are available, and {\bf $\backslash<$} and {\bf $\backslash>$} are synonyms
554for {\bf $[[:<:]]$} and {\bf $[[:>:]]$} respectively;
555no other escapes are available.
556
0aa7fa9a
VS
557\subsection{Regular Expression Character Names}\label{wxresynchars}
558
559\helpref{Syntax of the builtin regular expression library}{wxresyn}
560
561Note that the character names are case sensitive.
562
563\begin{twocollist}
564\twocolitem{NUL}{'$\backslash$0'}
565\twocolitem{SOH}{'$\backslash$001'}
566\twocolitem{STX}{'$\backslash$002'}
567\twocolitem{ETX}{'$\backslash$003'}
568\twocolitem{EOT}{'$\backslash$004'}
569\twocolitem{ENQ}{'$\backslash$005'}
570\twocolitem{ACK}{'$\backslash$006'}
571\twocolitem{BEL}{'$\backslash$007'}
572\twocolitem{alert}{'$\backslash$007'}
573\twocolitem{BS}{'$\backslash$010'}
574\twocolitem{backspace}{'$\backslash$b'}
575\twocolitem{HT}{'$\backslash$011'}
576\twocolitem{tab}{'$\backslash$t'}
577\twocolitem{LF}{'$\backslash$012'}
578\twocolitem{newline}{'$\backslash$n'}
579\twocolitem{VT}{'$\backslash$013'}
580\twocolitem{vertical-tab}{'$\backslash$v'}
581\twocolitem{FF}{'$\backslash$014'}
582\twocolitem{form-feed}{'$\backslash$f'}
583\twocolitem{CR}{'$\backslash$015'}
584\twocolitem{carriage-return}{'$\backslash$r'}
585\twocolitem{SO}{'$\backslash$016'}
586\twocolitem{SI}{'$\backslash$017'}
587\twocolitem{DLE}{'$\backslash$020'}
588\twocolitem{DC1}{'$\backslash$021'}
589\twocolitem{DC2}{'$\backslash$022'}
590\twocolitem{DC3}{'$\backslash$023'}
591\twocolitem{DC4}{'$\backslash$024'}
592\twocolitem{NAK}{'$\backslash$025'}
593\twocolitem{SYN}{'$\backslash$026'}
594\twocolitem{ETB}{'$\backslash$027'}
595\twocolitem{CAN}{'$\backslash$030'}
596\twocolitem{EM}{'$\backslash$031'}
597\twocolitem{SUB}{'$\backslash$032'}
598\twocolitem{ESC}{'$\backslash$033'}
599\twocolitem{IS4}{'$\backslash$034'}
600\twocolitem{FS}{'$\backslash$034'}
601\twocolitem{IS3}{'$\backslash$035'}
602\twocolitem{GS}{'$\backslash$035'}
603\twocolitem{IS2}{'$\backslash$036'}
604\twocolitem{RS}{'$\backslash$036'}
605\twocolitem{IS1}{'$\backslash$037'}
606\twocolitem{US}{'$\backslash$037'}
607\twocolitem{space}{' '}
608\twocolitem{exclamation-mark}{'!'}
609\twocolitem{quotation-mark}{'"'}
610\twocolitem{number-sign}{'\#'}
611\twocolitem{dollar-sign}{'\$'}
612\twocolitem{percent-sign}{'\%'}
1dc049cc 613\twocolitem{ampersand}{'\&'}
0aa7fa9a
VS
614\twocolitem{apostrophe}{'$\backslash$''}
615\twocolitem{left-parenthesis}{'('}
616\twocolitem{right-parenthesis}{')'}
617\twocolitem{asterisk}{'*'}
618\twocolitem{plus-sign}{'+'}
619\twocolitem{comma}{','}
620\twocolitem{hyphen}{'-'}
621\twocolitem{hyphen-minus}{'-'}
622\twocolitem{period}{'.'}
623\twocolitem{full-stop}{'.'}
624\twocolitem{slash}{'/'}
625\twocolitem{solidus}{'/'}
626\twocolitem{zero}{'0'}
627\twocolitem{one}{'1'}
628\twocolitem{two}{'2'}
629\twocolitem{three}{'3'}
630\twocolitem{four}{'4'}
631\twocolitem{five}{'5'}
632\twocolitem{six}{'6'}
633\twocolitem{seven}{'7'}
634\twocolitem{eight}{'8'}
635\twocolitem{nine}{'9'}
636\twocolitem{colon}{':'}
637\twocolitem{semicolon}{';'}
638\twocolitem{less-than-sign}{'<'}
639\twocolitem{equals-sign}{'='}
640\twocolitem{greater-than-sign}{'>'}
641\twocolitem{question-mark}{'?'}
642\twocolitem{commercial-at}{'@'}
643\twocolitem{left-square-bracket}{'$[$'}
644\twocolitem{backslash}{'$\backslash$'}
645\twocolitem{reverse-solidus}{'$\backslash$'}
646\twocolitem{right-square-bracket}{'$]$'}
e119d049
JS
647\twocolitem{circumflex}{'\caret'}
648\twocolitem{circumflex-accent}{'\caret'}
0aa7fa9a
VS
649\twocolitem{underscore}{'\_'}
650\twocolitem{low-line}{'\_'}
651\twocolitem{grave-accent}{'`'}
652\twocolitem{left-brace}{'\{'}
653\twocolitem{left-curly-bracket}{'\{'}
1dc049cc 654\twocolitem{vertical-line}{'$|$'}
0aa7fa9a
VS
655\twocolitem{right-brace}{'\}'}
656\twocolitem{right-curly-bracket}{'\}'}
14ffa743 657\twocolitem{tilde}{'\destruct{}'}
0aa7fa9a
VS
658\twocolitem{DEL}{'$\backslash$177'}
659\end{twocollist}
d2c2afc9 660