]> git.saurik.com Git - wxWidgets.git/blame - docs/latex/wx/regex.tex
Applied patch [ 874495 ] wxMSW: Flat buttons
[wxWidgets.git] / docs / latex / wx / regex.tex
CommitLineData
11ec1f16
VZ
1%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
2%% Name: regex.tex
3%% Purpose: wxRegEx documentation
4%% Author: Vadim Zeitlin
5%% Modified by:
6%% Created: 14.07.01
7%% RCS-ID: $Id$
8%% Copyright: (c) 2001 Vadim Zeitlin
9%% License: wxWindows license
10%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
11
12\section{\class{wxRegEx}}\label{wxregex}
13
14wxRegEx represents a regular expression. The regular expressions syntax
15supported is the POSIX one. Both basic and extended regular expressions are
16supported but, unlike POSIX C API, the extended ones are used by default.
17
18This class provides support for regular expressions matching and also
19replacement. It is built on top of either the system library (if it has support
20for POSIX regular expressions - which is the case of the most modern Unices) or
f220b009 21uses the built-in Henry Spencer's library from tcl.
11ec1f16
VZ
22
23\wxheading{Derived from}
24
25No base class
26
27\wxheading{Data structures}
28
29Flags for regex compilation to be used with \helpref{Compile()}{wxregexcompile}:
5ef298b3 30
11ec1f16
VZ
31\begin{verbatim}
32enum
33{
34 // use extended regex syntax (default)
a43e748a 35 wxRE_EXTENDED = 0,
11ec1f16
VZ
36
37 // use basic RE syntax
a43e748a 38 wxRE_BASIC = 2,
11ec1f16
VZ
39
40 // ignore case in match
a43e748a 41 wxRE_ICASE = 4,
11ec1f16
VZ
42
43 // only check match, don't set back references
a43e748a 44 wxRE_NOSUB = 8,
11ec1f16
VZ
45
46 // if not set, treat '\n' as an ordinary character, otherwise it is
47 // special: it is not matched by '.' and '^' and '$' always match
a43e748a
GT
48 // after/before it regardless of the setting of wxRE_NOT[BE]OL
49 wxRE_NEWLINE = 16,
11ec1f16
VZ
50
51 // default flags
a43e748a 52 wxRE_DEFAULT = wxRE_EXTENDED
11ec1f16
VZ
53}
54\end{verbatim}
55
56Flags for regex matching to be used with \helpref{Matches()}{wxregexmatches}.
57
58These flags are mainly useful when doing several matches in a long string
7af3ca16 59to prevent erroneous matches for {\tt '\textasciicircum'} and {\tt '\$'}:
5ef298b3 60
11ec1f16
VZ
61\begin{verbatim}
62enum
63{
64 // '^' doesn't match at the start of line
a43e748a 65 wxRE_NOTBOL = 32,
11ec1f16
VZ
66
67 // '$' doesn't match at the end of line
a43e748a 68 wxRE_NOTEOL = 64
11ec1f16
VZ
69}
70\end{verbatim}
71
5ef298b3
VZ
72\wxheading{Examples}
73
74A bad example of processing some text containing email addresses (the example
75is bad because the real email addresses can have more complicated form than
76{\tt user@host.net}):
77
78\begin{verbatim}
79wxString text;
80...
81wxRegEx reEmail = "([^@]+)@([[:alnum:].-_].)+([[:alnum:]]+)";
82if ( reEmail.Matches(text) )
83{
84 wxString text = reEmail.GetMatch(email);
85 wxString username = reEmail.GetMatch(email, 1);
86 if ( reEmail.GetMatch(email, 3) == "com" ) // .com TLD?
87 {
88 ...
89 }
90}
91
92// or we could do this to hide the email address
93size_t count = reEmail.ReplaceAll(text, "HIDDEN@\\2\\3");
94printf("text now contains %u hidden addresses", count);
95\end{verbatim}
96
11ec1f16
VZ
97\latexignore{\rtfignore{\wxheading{Members}}}
98
99\membersection{wxRegEx::wxRegEx}\label{wxregexwxregex}
100
101\func{}{wxRegEx}{\void}
102
103Default ctor: use \helpref{Compile()}{wxregexcompile} later.
104
11ec1f16
VZ
105\func{}{wxRegEx}{\param{const wxString\& }{expr}, \param{int }{flags = wxRE\_DEFAULT}}
106
107Create and compile the regular expression, use
108\helpref{IsValid}{wxregexisvalid} to test for compilation errors.
109
110\membersection{wxRegEx::\destruct{wxRegEx}}\label{wxregexdtor}
111
112\func{}{\destruct{wxRegEx}}{\void}
113
114dtor not virtual, don't derive from this class
115
116\membersection{wxRegEx::Compile}\label{wxregexcompile}
117
118\func{bool}{Compile}{\param{const wxString\& }{pattern}, \param{int }{flags = wxRE\_DEFAULT}}
119
cc81d32f 120Compile the string into regular expression, return {\tt true} if ok or {\tt false}
11ec1f16
VZ
121if string has a syntax error.
122
123\membersection{wxRegEx::IsValid}\label{wxregexisvalid}
124
125\constfunc{bool}{IsValid}{\void}
126
cc81d32f 127Return {\tt true} if this is a valid compiled regular expression, {\tt false}
11ec1f16
VZ
128otherwise.
129
130\membersection{wxRegEx::GetMatch}\label{wxregexgetmatch}
131
132\constfunc{bool}{GetMatch}{\param{size\_t* }{start}, \param{size\_t* }{len}, \param{size\_t }{index = 0}}
133
134Get the start index and the length of the match of the expression
135(if {\it index} is $0$) or a bracketed subexpression ({\it index} different
136from $0$).
137
138May only be called after successful call to \helpref{Matches()}{wxregexmatches}
139and only if {\tt wxRE\_NOSUB} was {\bf not} used in
140\helpref{Compile()}{wxregexcompile}.
141
cc81d32f 142Returns {\tt false} if no match or if an error occured.
11ec1f16
VZ
143
144\constfunc{wxString}{GetMatch}{\param{const wxString\& }{text}, \param{size\_t }{index = 0}}
145
146Returns the part of string corresponding to the match where {\it index} is
147interpreted as above. Empty string is returned if match failed
148
149May only be called after successful call to \helpref{Matches()}{wxregexmatches}
150and only if {\tt wxRE\_NOSUB} was {\bf not} used in
151\helpref{Compile()}{wxregexcompile}.
152
153\membersection{wxRegEx::Matches}\label{wxregexmatches}
154
155\constfunc{bool}{Matches}{\param{const wxChar* }{text}, \param{int }{flags = 0}}
156
157Matches the precompiled regular expression against the string {\it text},
cc81d32f 158returns {\tt true} if matches and {\tt false} otherwise.
11ec1f16
VZ
159
160Flags may be combination of {\tt wxRE\_NOTBOL} and {\tt wxRE\_NOTEOL}.
161
162May only be called after successful call to \helpref{Compile()}{wxregexcompile}.
163
164\membersection{wxRegEx::Replace}\label{wxregexreplace}
165
166\constfunc{int}{Replace}{\param{wxString* }{text}, \param{const wxString\& }{replacement}, \param{size\_t }{maxMatches = 0}}
167
168Replaces the current regular expression in the string pointed to by
169{\it text}, with the text in {\it replacement} and return number of matches
170replaced (maybe $0$ if none found) or $-1$ on error.
171
6465d401 172The replacement text may contain back references {\tt $\backslash$number} which will be
11ec1f16 173replaced with the value of the corresponding subexpression in the
6465d401 174pattern match. {\tt $\backslash$0} corresponds to the entire match and {\tt \&} is a
11ec1f16
VZ
175synonym for it. Backslash may be used to quote itself or {\tt \&} character.
176
177{\it maxMatches} may be used to limit the number of replacements made, setting
2edb0bde 178it to $1$, for example, will only replace first occurrence (if any) of the
11ec1f16
VZ
179pattern in the text while default value of $0$ means replace all.
180
181\membersection{wxRegEx::ReplaceAll}\label{wxregexreplaceall}
182
183\constfunc{int}{ReplaceAll}{\param{wxString* }{text}, \param{const wxString\& }{replacement}}
184
2edb0bde 185Replace all occurrences: this is actually a synonym for
11ec1f16
VZ
186\helpref{Replace()}{wxregexreplace}.
187
188\wxheading{See also}
189
190\helpref{ReplaceFirst}{wxregexreplacefirst}
191
192\membersection{wxRegEx::ReplaceFirst}\label{wxregexreplacefirst}
193
194\constfunc{int}{ReplaceFirst}{\param{wxString* }{text}, \param{const wxString\& }{replacement}}
195
2edb0bde 196Replace the first occurrence.
11ec1f16
VZ
197
198\wxheading{See also}
199
200\helpref{Replace}{wxregexreplace}
201