]> git.saurik.com Git - wxWidgets.git/blame - tests/benchmarks/strings.cpp
Added wxPropertyGrid::SetSortFunction(); moved Sort() and SortChildren() to wxPropert...
[wxWidgets.git] / tests / benchmarks / strings.cpp
CommitLineData
dc2ae355
VZ
1/////////////////////////////////////////////////////////////////////////////
2// Name: tests/benchmarks/strings.cpp
3// Purpose: String-related benchmarks
4// Author: Vadim Zeitlin
5// Created: 2008-07-19
6// RCS-ID: $Id$
7// Copyright: (c) 2008 Vadim Zeitlin <vadim@wxwidgets.org>
8// Licence: wxWindows license
9/////////////////////////////////////////////////////////////////////////////
10
11#include "wx/string.h"
c21faa0a 12#include "wx/ffile.h"
dc2ae355
VZ
13
14#include "bench.h"
c21faa0a 15#include "htmlparser/htmlpars.h"
dc2ae355
VZ
16
17static const char asciistr[] =
18 "This is just the first line of a very long 7 bit ASCII string"
19 "This is just the second line of a very long 7 bit ASCII string"
20 "This is just the third line of a very long 7 bit ASCII string"
21 "This is just the fourth line of a very long 7 bit ASCII string"
22 "This is just the fifth line of a very long 7 bit ASCII string"
23 "This is just the sixth line of a very long 7 bit ASCII string"
24 "This is just the seventh line of a very long 7 bit ASCII string"
25 "This is just the eighth line of a very long 7 bit ASCII string"
26 "This is just the ninth line of a very long 7 bit ASCII string"
27 "This is just the tenth line of a very long 7 bit ASCII string"
28 ;
29
30static const char utf8str[] =
31 "\xD0\xA6\xD0\xB5\xD0\xBB\xD0\xBE\xD0\xB5 \xD1\x87\xD0\xB8\xD1\x81\xD0\xBB\xD0\xBE 0"
32 "\xD0\xA6\xD0\xB5\xD0\xBB\xD0\xBE\xD0\xB5 \xD1\x87\xD0\xB8\xD1\x81\xD0\xBB\xD0\xBE 1"
33 "\xD0\xA6\xD0\xB5\xD0\xBB\xD0\xBE\xD0\xB5 \xD1\x87\xD0\xB8\xD1\x81\xD0\xBB\xD0\xBE 2"
34 "\xD0\xA6\xD0\xB5\xD0\xBB\xD0\xBE\xD0\xB5 \xD1\x87\xD0\xB8\xD1\x81\xD0\xBB\xD0\xBE 3"
35 "\xD0\xA6\xD0\xB5\xD0\xBB\xD0\xBE\xD0\xB5 \xD1\x87\xD0\xB8\xD1\x81\xD0\xBB\xD0\xBE 4"
36 "\xD0\xA6\xD0\xB5\xD0\xBB\xD0\xBE\xD0\xB5 \xD1\x87\xD0\xB8\xD1\x81\xD0\xBB\xD0\xBE 5"
37 "\xD0\xA6\xD0\xB5\xD0\xBB\xD0\xBE\xD0\xB5 \xD1\x87\xD0\xB8\xD1\x81\xD0\xBB\xD0\xBE 6"
38 "\xD0\xA6\xD0\xB5\xD0\xBB\xD0\xBE\xD0\xB5 \xD1\x87\xD0\xB8\xD1\x81\xD0\xBB\xD0\xBE 7"
39 "\xD0\xA6\xD0\xB5\xD0\xBB\xD0\xBE\xD0\xB5 \xD1\x87\xD0\xB8\xD1\x81\xD0\xBB\xD0\xBE 8"
40 "\xD0\xA6\xD0\xB5\xD0\xBB\xD0\xBE\xD0\xB5 \xD1\x87\xD0\xB8\xD1\x81\xD0\xBB\xD0\xBE 9"
41 ;
42
33ccf3d1
VZ
43namespace
44{
45
46const wxString& GetTestAsciiString()
47{
48 static wxString testString;
49 if ( testString.empty() )
50 {
ebfa7cea
VZ
51 long num = Bench::GetNumericParameter();
52 if ( !num )
53 num = 1;
54
55 for ( long n = 0; n < num; n++ )
33ccf3d1
VZ
56 testString += wxString::FromAscii(asciistr);
57 }
58
59 return testString;
60}
61
62} // anonymous namespace
63
dc2ae355
VZ
64// this is just a baseline
65BENCHMARK_FUNC(Strlen)
66{
67 if ( strlen(utf8str) != WXSIZEOF(utf8str) - 1 )
68 return false;
69
70 if ( strlen(asciistr) != WXSIZEOF(asciistr) - 1 )
71 return false;
72
73 return true;
74}
75
76// ----------------------------------------------------------------------------
77// FromUTF8() benchmarks
78// ----------------------------------------------------------------------------
79
80BENCHMARK_FUNC(FromUTF8)
81{
82 wxString s = wxString::FromUTF8(utf8str);
83 if ( s.empty() )
84 return false;
85
86 s = wxString::FromUTF8(asciistr);
87 if ( s.empty() )
88 return false;
89
90 return true;
91}
92
93BENCHMARK_FUNC(FromUTF8WithNpos)
94{
95 wxString s = wxString::FromUTF8(utf8str, wxString::npos);
96 if ( s.empty() )
97 return false;
98
99 s = wxString::FromUTF8(asciistr, wxString::npos);
100 if ( s.empty() )
101 return false;
102
103 return true;
104}
105
106BENCHMARK_FUNC(FromUTF8WithLen)
107{
108 wxString s = wxString::FromUTF8(utf8str, WXSIZEOF(utf8str));
109 if ( s.empty() )
110 return false;
111
112 s = wxString::FromUTF8(asciistr, WXSIZEOF(asciistr));
113 if ( s.empty() )
114 return false;
115
116 return true;
117}
118
119// ----------------------------------------------------------------------------
120// FromUTF8Unchecked() benchmarks
121// ----------------------------------------------------------------------------
122
123BENCHMARK_FUNC(FromUTF8Unchecked)
124{
125 wxString s = wxString::FromUTF8Unchecked(utf8str);
126 if ( s.empty() )
127 return false;
128
129 s = wxString::FromUTF8Unchecked(asciistr);
130 if ( s.empty() )
131 return false;
132
133 return true;
134}
135
136BENCHMARK_FUNC(FromUTF8UncheckedWithNpos)
137{
138 wxString s = wxString::FromUTF8Unchecked(utf8str, wxString::npos);
139 if ( s.empty() )
140 return false;
141
142 s = wxString::FromUTF8Unchecked(asciistr, wxString::npos);
143 if ( s.empty() )
144 return false;
145
146 return true;
147}
148
149BENCHMARK_FUNC(FromUTF8UncheckedWithLen)
150{
151 wxString s = wxString::FromUTF8Unchecked(utf8str, WXSIZEOF(utf8str));
152 if ( s.empty() )
153 return false;
154
155 s = wxString::FromUTF8Unchecked(asciistr, WXSIZEOF(asciistr));
156 if ( s.empty() )
157 return false;
158
159 return true;
160}
161
162// ----------------------------------------------------------------------------
163// FromAscii() benchmarks
164// ----------------------------------------------------------------------------
165
166BENCHMARK_FUNC(FromAscii)
167{
168 wxString s = wxString::FromAscii(asciistr);
169 if ( s.empty() )
170 return false;
171
172 return true;
173}
174
175BENCHMARK_FUNC(FromAsciiWithNpos)
176{
177 wxString s = wxString::FromAscii(asciistr);
178 if ( s.empty() )
179 return false;
180
181 return true;
182}
183
184BENCHMARK_FUNC(FromAsciiWithLen)
185{
186 wxString s = wxString::FromAscii(asciistr, WXSIZEOF(asciistr));
187 if ( s.empty() )
188 return false;
189
190 return true;
191}
192
193// ----------------------------------------------------------------------------
194// simple string iteration
195// ----------------------------------------------------------------------------
196
197// baseline
198BENCHMARK_FUNC(ForCString)
199{
200 for ( size_t n = 0; n < WXSIZEOF(asciistr); n++ )
201 {
202 if ( asciistr[n] == '~' )
203 return false;
204 }
205
206 return true;
207}
208
209BENCHMARK_FUNC(ForStringIndex)
210{
33ccf3d1 211 const wxString& s = GetTestAsciiString();
dc2ae355
VZ
212 const size_t len = s.length();
213 for ( size_t n = 0; n < len; n++ )
214 {
215 if ( s[n] == '~' )
216 return false;
217 }
218
219 return true;
220}
221
222BENCHMARK_FUNC(ForStringIter)
223{
33ccf3d1 224 const wxString& s = GetTestAsciiString();
dc2ae355
VZ
225 const wxString::const_iterator end = s.end();
226 for ( wxString::const_iterator i = s.begin(); i != end; ++i )
227 {
228 if ( *i == '~' )
229 return false;
230 }
231
232 return true;
233}
234
235BENCHMARK_FUNC(ForStringRIter)
236{
33ccf3d1 237 const wxString& s = GetTestAsciiString();
dc2ae355
VZ
238 const wxString::const_reverse_iterator rend = s.rend();
239 for ( wxString::const_reverse_iterator i = s.rbegin(); i != rend; ++i )
240 {
241 if ( *i == '~' )
242 return false;
243 }
244
245 return true;
246}
247
9729777e
VZ
248// ----------------------------------------------------------------------------
249// wxString::Replace()
250// ----------------------------------------------------------------------------
251
0654c03a 252const size_t ASCIISTR_LEN = strlen(asciistr);
9729777e
VZ
253
254BENCHMARK_FUNC(ReplaceLoop)
255{
0654c03a
VS
256 wxString str('x', ASCIISTR_LEN);
257 for ( size_t n = 0; n < ASCIISTR_LEN; n++ )
9729777e
VZ
258 {
259 if ( str[n] == 'a' )
260 str[n] = 'z';
261 }
262
263 return str.length() != 0;
264}
265
543cf9ba 266BENCHMARK_FUNC(ReplaceNone)
9729777e 267{
0654c03a 268 wxString str('x', ASCIISTR_LEN);
543cf9ba
VZ
269 return str.Replace("a", "z") == 0;
270}
9729777e 271
543cf9ba
VZ
272BENCHMARK_FUNC(ReplaceSome)
273{
274 wxString str(asciistr);
275 return str.Replace("7", "8") != 0;
9729777e
VZ
276}
277
543cf9ba 278BENCHMARK_FUNC(ReplaceAll)
9729777e 279{
0654c03a 280 wxString str('x', ASCIISTR_LEN);
543cf9ba 281 return str.Replace("x", "y") != 0;
9729777e
VZ
282}
283
0654c03a
VS
284
285// ----------------------------------------------------------------------------
286// string buffers: wx[W]CharBuffer
287// ----------------------------------------------------------------------------
288
289BENCHMARK_FUNC(CharBuffer)
290{
291 wxString str(asciistr);
292
293 // NB: wxStrlen() is here to simulate some use of the returned buffer.
294 // Both mb_str() and wc_str() are used so that this code does something
295 // nontrivial in any build.
296 return wxStrlen(str.mb_str()) == ASCIISTR_LEN &&
297 wxStrlen(str.wc_str()) == ASCIISTR_LEN;
298}
c21faa0a
VS
299
300
301// ----------------------------------------------------------------------------
302// wxString::operator[] - parse large HTML page
303// ----------------------------------------------------------------------------
304
305class DummyParser : public wx28HtmlParser
306{
307public:
308 virtual wxObject* GetProduct() { return NULL; }
309 virtual void AddText(const wxChar*) {}
310};
311
312
313BENCHMARK_FUNC(ParseHTML)
314{
315 // static so that construction time is not counted
316 static DummyParser parser;
317 static wxString html;
318 if ( html.empty() )
319 {
8fad8b2e
VZ
320 wxString html1;
321 wxFFile("htmltest.html").ReadAll(&html1, wxConvUTF8);
322
323 // this is going to make for some invalid HTML, of course, but it
324 // doesn't really matter
ebfa7cea
VZ
325 long num = Bench::GetNumericParameter();
326 if ( !num )
327 num = 1;
328
329 for ( long n = 0; n < num; n++ )
8fad8b2e 330 html += html1;
c21faa0a
VS
331 }
332
333 parser.Parse(html);
334
335 return true;
336}