]> git.saurik.com Git - wxWidgets.git/blame_incremental - docs/latex/wx/wxstring.tex
__MWERKS__ check now doesn't give compilation error with VC++
[wxWidgets.git] / docs / latex / wx / wxstring.tex
... / ...
CommitLineData
1\section{\class{wxString}}\label{wxstring}
2
3\wxheading{Derived from}
4
5None
6
7\wxheading{See also}
8
9\overview{Overview}{wxstringoverview}
10
11\latexignore{\rtfignore{\wxheading{Members}}}
12
13\membersection{wxString::wxString}\label{wxstringconstruct}
14
15\func{}{wxString}{\void}
16
17Default constructor.
18
19\func{}{wxString}{\param{const wxString\&}{ x}}
20
21Copy constructor.
22
23\func{}{wxString}{\param{char}{ ch}, \param{size\_t}{ n = 1}}
24
25Constructs a string of {\it n} copies of character {\it ch}.
26
27\func{}{wxString}{\param{const char*}{ psz}, \param{size\_t}{ nLength = STRING\_MAXLEN}}
28
29Takes first {\it nLength} characters from the C string {\it psz}.
30The default value of STRING\_MAXLEN means take all the string.
31
32\func{}{wxString}{\param{const unsigned char*}{ psz}, \param{size\_t}{ nLength = STRING\_MAXLEN}}
33
34For compilers using unsigned char: takes first {\it nLength} characters from the C string {\it psz}.
35The default value of STRING\_MAXLEN means take all the string.
36
37\func{}{wxString}{\param{const wchar\_t*}{ psz}}
38
39Constructs a string from the wide (UNICODE) string.
40
41\membersection{wxString::\destruct{wxString}}\label{wxstringdestruct}
42
43\func{}{\destruct{wxString}}{\void}
44
45String destructor. Note that this is not virtual, so wxString must not be inherited from.
46
47\membersection{wxString::Alloc}\label{wxstringAlloc}
48
49\func{void}{Alloc}{\param{uint}{ newsize}}
50
51Preallocate some space for wxString. Only works if the data of this string is not shared.
52
53\membersection{wxString::Append}\label{wxstringAppend}
54
55\func{wxString\&}{Append}{\param{const char*}{ psz}}
56
57Concatenates {\it psz} to this string, returning a reference to it.
58
59\func{wxString\&}{Append}{\param{char}{ ch}, \param{int}{ count = 1}}
60
61Concatenates character {\it ch} to this string, {\it count} times, returning a reference
62to it.
63
64\membersection{wxString::After}\label{wxstringAfter}
65
66\constfunc{wxString}{After}{\param{char}{ ch}}
67
68Gets all the characters after the first occurence of {\it ch}.
69Returns the empty string if {\it ch} is not found.
70
71\membersection{wxString::Before}\label{wxstringBefore}
72
73\constfunc{wxString}{Before}{\param{char}{ ch}}
74
75Gets all characters before the last occurence of {\it ch}.
76Returns empty string if {\it ch} is not found.
77
78\membersection{wxString::Cmp}\label{wxstringcmp}
79
80\constfunc{int}{Cmp}{\param{const char*}{ psz}}
81
82Case-sensitive comparison.
83
84Returns 0 if equal, +1 if greater or -1 if less.
85
86See also CmpNoCase, IsSameAs.
87
88\membersection{wxString::CmpNoCase}\label{wxstringcmpnocase}
89
90\constfunc{int}{CmpNoCase}{\param{const char*}{ psz}}
91
92Case-insensitive comparison.
93
94Returns 0 if equal, +1 if greater or -1 if less.
95
96See also Cmp, IsSameAs.
97
98\membersection{wxString::CompareTo}\label{wxstringCompareTo}
99
100\begin{verbatim}
101#define NO_POS ((int)(-1)) // undefined position
102enum caseCompare {exact, ignoreCase};
103\end{verbatim}
104
105\constfunc{int}{CompareTo}{\param{const char*}{ psz}, \param{caseCompare}{ cmp = exact}}
106
107Case-sensitive comparison. Returns 0 if equal, 1 if greater or -1 if less.
108
109\membersection{wxString::Contains}\label{wxstringContains}
110
111\func{bool}{Contains}{\param{const wxString\&}{ str}}
112
113Returns 1 if target appears anyhere in wxString; else 0.
114
115\membersection{wxString::Empty}\label{wxstringempty}
116
117\func{void}{Empty}{\void}
118
119Reinitializes the string and frees the data.
120
121\membersection{wxString::Find}\label{wxstringfind}
122
123\constfunc{int}{Find}{\param{char}{ ch}, \param{bool}{ fromEnd = FALSE}}
124
125Searches for the given character. Returns the starting index, or -1 if not found.
126
127\constfunc{int}{Find}{\param{const char*}{ sz}}
128
129Searches for the given string. Returns the starting index, or -1 if not found.
130
131\membersection{wxString::First}\label{wxstringfirst}
132
133\func{size\_t}{First}{\param{char}{ c}}
134
135\constfunc{size\_t}{First}{\param{const char*}{ psz}}
136
137\constfunc{size\_t}{First}{\param{const wxString\&}{ str}}
138
139\constfunc{size\_t}{First}{\param{const char}{ ch}}
140
141Returns the first occurrence of the item.
142
143\membersection{wxString::GetChar}\label{wxstringgetchar}
144
145\constfunc{char}{GetChar}{\param{size\_t}{ n}}
146
147Returns the character at position {\it n} (read-only).
148
149\membersection{wxString::GetData}\label{wxstringGetData}
150
151\constfunc{const char*}{GetData}{\void}
152
153wxWindows compatibility conversion. Returns a constant pointer to the data in the string.
154
155\membersection{wxString::GetWritableChar}\label{wxstringgetwritablechar}
156
157\func{char\&}{GetWritableChar}{\param{size\_t}{ n}}
158
159Returns a reference to the character at position {\it n}.
160
161\membersection{wxString::GetWriteBuf}\label{wxstringgetwritebuf}
162
163\func{char*}{GetWriteBuf}{\param{uint}{ len}}
164
165Returns a writable buffer of at least {\it len} bytes.
166
167Call \helpref{wxString::UngetWriteBuf}{wxstringungetwritebuf} as soon as possible
168to put the string back into a reasonable state.
169
170\membersection{wxString::Index}\label{wxstringIndex}
171
172\constfunc{size\_t}{Index}{\param{char}{ ch}, \param{int}{ startpos = 0}}
173
174Same as \helpref{wxString::Find}{wxstringfind}.
175
176\constfunc{size\_t}{Index}{\param{const char*}{ sz}}
177
178Same as \helpref{wxString::Find}{wxstringfind}.
179
180\constfunc{size\_t}{Index}{\param{const char*}{ sz}, \param{bool}{ caseSensitive = TRUE}, \param{bool}{ fromEnd = FALSE}}
181
182Search the element in the array, starting from either side.
183
184If {\it fromEnd} is TRUE, reverse search direction.
185
186If {\bf caseSensitive}, comparison is case sensitive (the default).
187
188Returns the index of the first item matched, or NOT\_FOUND.
189
190\membersection{wxString::Insert}\label{wxstringInsert}
191
192\func{void}{Insert}{\param{const wxString\&}{ str}, \param{uint}{ index}}
193
194Add new element at the given position.
195
196\membersection{wxString::IsAscii}\label{wxstringIsAscii}
197
198\constfunc{bool}{IsAscii}{\void}
199
200Returns TRUE if the string is ASCII.
201
202\membersection{wxString::IsEmpty}\label{wxstringisempty}
203
204\constfunc{bool}{IsEmpty}{\void}
205
206Returns TRUE if the string is NULL.
207
208\membersection{wxString::IsNull}\label{wxstringIsNull}
209
210\constfunc{bool}{IsNull}{\void}
211
212Returns TRUE if the string is NULL (same as IsEmpty).
213
214\membersection{wxString::IsNumber}\label{wxstringIsNumber}
215
216\constfunc{bool}{IsNumber}{\void}
217
218Returns TRUE if the string is a number.
219
220\membersection{wxString::IsSameAs}\label{wxstringissameas}
221
222\constfunc{bool}{IsSameAs}{\param{const char*}{ psz}, \param{bool}{ caseSensitive = TRUE}}
223
224Test for string equality, case-sensitive (default) or not.
225
226caseSensitive is TRUE by default (case matters).
227
228Returns TRUE if strings are equal, FALSE otherwise.
229
230See also Cmp, CmpNoCase.
231
232\membersection{wxString::IsWord}\label{wxstringIsWord}
233
234\constfunc{bool}{IsWord}{\void}
235
236Returns TRUE if the string is a word. TODO: what's the definition of a word?
237
238\membersection{wxString::Last}\label{wxstringLast}
239
240\constfunc{char}{Last}{\void}
241
242Returns the last character.
243
244\func{char\&}{Last}{\void}
245
246Returns a reference to the last character (writable).
247
248\membersection{wxString::Left}\label{wxstringleft}
249
250\constfunc{wxString}{Left}{\param{size\_t}{ count}}
251
252Returns the first {\it count} characters.
253
254\constfunc{wxString}{Left}{\param{char}{ ch}}
255
256Returns all characters before the first occurence of {\it ch}.
257Returns the whole string if {\it ch} is not found.
258
259\membersection{wxString::Len}\label{wxstringlen}
260
261\constfunc{size\_t}{Len}{\void}
262
263Returns the length of the string.
264
265\membersection{wxString::Length}\label{wxstringlength}
266
267\constfunc{size\_t}{Length}{\void}
268
269Returns the length of the string (same as Len).
270
271\membersection{wxString::LowerCase}\label{wxstringLowerCase}
272
273\func{void}{LowerCase}{\void}
274
275Same as MakeLower.
276
277\membersection{wxString::MakeLower}\label{wxstringmakelower}
278
279\func{void}{MakeLower}{\void}
280
281Converts all characters to lower case.
282
283\membersection{wxString::MakeUpper}\label{wxstringmakeupper}
284
285\func{void}{MakeUpper}{\void}
286
287Converts all characters to upper case.
288
289\membersection{wxString::Matches}\label{wxstringMatches}
290
291\constfunc{bool}{Matches}{\param{const char*}{ szMask}}
292
293Returns TRUE if the string contents matches a mask containing '*' and '?'.
294
295\membersection{wxString::Mid}\label{wxstringmid}
296
297\constfunc{wxString}{Mid}{\param{size\_t}{ first}, \param{size\_t}{ count = STRING\_MAXLEN}}
298
299Returns a substring starting at {\it first}, with length {\it count}, or the rest of
300the string if {\it count} is the default value.
301
302\membersection{wxString::Pad}\label{wxstringpad}
303
304\func{wxString\&}{Pad}{\param{size\_t}{ count}, \param{char}{ pad = ' '}, \param{bool}{ fromRight = TRUE}}
305
306Adds {\it count} copies of {\it pad} to the beginning, or to the end of the string (the default).
307
308Removes spaces from the left or from the right (default).
309
310\membersection{wxString::Prepend}\label{wxstringPrepend}
311
312\func{wxString\&}{Prepend}{\param{const wxString\&}{ str}}
313
314Prepends {\it str} to this string, returning a reference to this string.
315
316\membersection{wxString::Printf}\label{wxstringprintf}
317
318\func{int}{Printf}{\param{const char* }{pszFormat}, \param{}{...}}
319
320Similar to sprintf. Returns the number of characters written, or an integer less than zero
321on error.
322
323\membersection{wxString::PrintfV}\label{wxstringprintfv}
324
325\func{int}{PrintfV}{\param{const char* }{pszFormat}, \param{va\_list}{ argPtr}}
326
327Similar to vprintf. Returns the number of characters written, or an integer less than zero
328on error.
329
330\membersection{wxString::Remove}\label{wxstringRemove}
331
332\func{wxString\&}{Remove}{\param{size\_t}{ pos}}
333
334Same as Truncate. Removes the portion from {\it pos} to the end of the string.
335
336\func{wxString\&}{Remove}{\param{size\_t}{ pos}, \param{size\_t}{ len}}
337
338Removes the last {\it len} characters from the string, starting at {\it pos}.
339
340\membersection{wxString::RemoveLast}\label{wxstringremovelast}
341
342\func{wxString\&}{RemoveLast}{\void}
343
344Removes the last character.
345
346\membersection{wxString::Replace}\label{wxstringReplace}
347
348\func{uint}{Replace}{\param{const char*}{ szOld}, \param{const char*}{ szNew}, \param{bool}{ replaceAll}}
349
350Replace first (or all) occurences of substring with another one.
351
352{\it replaceAll}: global replace (default), or only the first occurence.
353
354Returns the number of replacements made.
355
356\membersection{wxString::Right}\label{wxstringright}
357
358\constfunc{wxString}{Right}{\param{size\_t}{ count}}
359
360Returns the last {\it count} characters.
361
362\constfunc{wxString}{Right}{\param{char}{ ch}}
363
364Returns all characters after the last occurence of {\it ch}.
365Returns the whole string if {\it ch} is not found.
366
367\membersection{wxString::SetChar}\label{wxstringsetchar}
368
369\func{void}{SetChar}{\param{size\_t}{ n}, \param{char}{ch}}
370
371Sets the character at position {\it n}.
372
373\membersection{wxString::Shrink}\label{wxstringshrink}
374
375\func{void}{Shrink}{\void}
376
377Minimizes the string's memory. Only works if the data of this string is not shared.
378
379\membersection{wxString::sprintf}\label{wxstringsprintf}
380
381\func{void}{sprintf}{\param{const char* }{ fmt}}
382
383The same as Printf.
384
385\membersection{wxString::Strip}\label{wxstringStrip}
386
387\begin{verbatim}
388enum stripType {leading = 0x1, trailing = 0x2, both = 0x3};
389\end{verbatim}
390
391\constfunc{wxString}{Strip}{\param{stripType}{ s = trailing}}
392
393Strip characters at the front and/or end. The same as Trim except that it
394doesn't change this string.
395
396\membersection{wxString::Trim}\label{wxstringtrim}
397
398\func{wxString\&}{Trim}{\param{bool}{ fromRight = TRUE}}
399
400Removes spaces from the left or from the right (default).
401
402\membersection{wxString::Truncate}\label{wxstringtruncate}
403
404\func{wxString\&}{Truncate}{\param{size\_t}{ len}}
405
406Truncate the string to the given length.
407
408\membersection{wxString::UngetWriteBuf}\label{wxstringungetwritebuf}
409
410\func{void}{UngetWriteBuf}{\void}
411
412Puts the string back into a reasonable state, after
413\rtfsp\helpref{wxString::GetWriteBuf}{wxstringgetwritebuf} was called.
414
415\membersection{wxString::UpperCase}\label{wxstringUpperCase}
416
417\func{void}{UpperCase}{\void}
418
419The same as MakeUpper.
420
421\membersection{wxString::operator $=$}\label{wxstringoperatorassign}
422
423\func{wxString\&}{operator $=$}{\param{const wxString\&}{ str}}
424
425\func{wxString\&}{operator $=$}{\param{const char*}{ psz}}
426
427\func{wxString\&}{operator $=$}{\param{char}{ c}}
428
429\func{wxString\&}{operator $=$}{\param{const unsigned char*}{ psz}}
430
431\func{wxString\&}{operator $=$}{\param{const wchar\_t*}{ pwz}}
432
433Assignment.
434
435\membersection{operator wxString::$+$}\label{wxstringoperatorplus}
436
437Concatenation.
438
439\func{wxString}{operator $+$}{\param{const wxString\&}{ x}, \param{const wxString\&}{ y}}
440
441\func{wxString}{operator $+$}{\param{const wxString\&}{ x}, \param{const char*}{ y}}
442
443\func{wxString}{operator $+$}{\param{const wxString\&}{ x}, \param{char}{ y}}
444
445\func{wxString}{operator $+$}{\param{const char*}{ x}, \param{const wxString\&}{ y}}
446
447\membersection{wxString::operator $+=$}\label{wxstringPlusEqual}
448
449\func{void}{operator $+=$}{\param{const wxString\&}{ str}}
450
451\func{void}{operator $+=$}{\param{const char*}{ psz}}
452
453\func{void}{operator $+=$}{\param{char}{ c}}
454
455Concatenation.
456
457\membersection{wxString::operator []}\label{wxstringoperatorbracket}
458
459\func{char\&}{operator []}{\param{size\_t}{ i}}
460
461\func{char}{operator []}{\param{size\_t}{ i}}
462
463\func{char}{operator []}{\param{int}{ i}}
464
465Element extraction.
466
467\membersection{wxString::operator ()}\label{wxstringoperatorparenth}
468
469\func{wxString}{operator ()}{\param{size\_t}{ start}, \param{size\_t}{ len}}
470
471Same as Mid (substring extraction).
472
473\membersection{wxString::operator \cinsert}\label{wxstringoperatorout}
474
475\func{wxString\&}{operator \cinsert}{\\param{const wxString\&}{ str}}
476
477\func{wxString\&}{operator \cinsert}{\\param{const char*}{ psz}}
478
479\func{wxString\&}{operator \cinsert}{\\param{char }{ch}}
480
481Same as $+=$.
482
483\membersection{wxString::operator \cextract}\label{wxstringoperatorin}
484
485\func{friend istream\&}{operator \cextract}{\param{istream\&}{ is}, \param{wxString\&}{ str}}
486
487Extraction from a stream.
488
489\membersection{wxString::operator const char*}\label{wxstringoperatorconstcharpt}
490
491\constfunc{}{operator const char*}{\void}
492
493Implicit conversion to a C string.
494
495\membersection{Comparison operators}\label{wxstringComparison}
496
497\func{bool}{operator $==$}{\param{const wxString\&}{ x}, \param{const wxString\&}{ y}}
498
499\func{bool}{operator $==$}{\param{const wxString\&}{ x}, \param{const char*}{ t}}
500
501\func{bool}{operator $!=$}{\param{const wxString\&}{ x}, \param{const wxString\&}{ y}}
502
503\func{bool}{operator $!=$}{\param{const wxString\&}{ x}, \param{const char*}{ t}}
504
505\func{bool}{operator $>$}{\param{const wxString\&}{ x}, \param{const wxString\&}{ y}}
506
507\func{bool}{operator $>$}{\param{const wxString\&}{ x}, \param{const char*}{ t}}
508
509\func{bool}{operator $>=$}{\param{const wxString\&}{ x}, \param{const wxString\&}{ y}}
510
511\func{bool}{operator $>=$}{\param{const wxString\&}{ x}, \param{const char*}{ t}}
512
513\func{bool}{operator $<$}{\param{const wxString\&}{ x}, \param{const wxString\&}{ y}}
514
515\func{bool}{operator $<$}{\param{const wxString\&}{ x}, \param{const char*}{ t}}
516
517\func{bool}{operator $<=$}{\param{const wxString\&}{ x}, \param{const wxString\&}{ y}}
518
519\func{bool}{operator $<=$}{\param{const wxString\&}{ x}, \param{const char*}{ t}}
520
521\wxheading{Remarks}
522
523These comparisons are case-sensitive.
524
525