source: tests/collections/string-api-coverage.cfa@ ebbe941

ADT ast-experimental
Last change on this file since ebbe941 was 2b30370, checked in by Michael Brooks <mlbrooks@…>, 4 years ago

Bug fixes for empty-string from no-arg ctor with sharing off

  • Property mode set to 100644
File size: 8.9 KB
RevLine 
[f450f2f]1#include <containers/string.hfa>
[6f7aff3]2#include <string_sharectx.hfa>
[f450f2f]3
4void assertWellFormedHandleList( int maxLen ) { // with(HeapArea)
5 // HandleNode *n;
6 // int limit1 = maxLen;
7 // for ( n = Header.flink; (limit1-- > 0) && n != &Header; n = n->flink ) {}
8 // assert (n == &Header);
9 // int limit2 = maxLen;
10 // for ( n = Header.blink; (limit2-- > 0) && n != &Header; n = n->blink ) {}
11 // assert (n == &Header);
12 // assert (limit1 == limit2);
13}
14
15// The given string is reachable.
16void assertOnHandleList( string & q ) { // with(HeapArea)
17 // HandleNode *n;
18 // for ( n = Header.flink; n != &Header; n = n->flink ) {
19 // if ( n == & q.inner->Handle ) return;
20 // }
21 // assert( false );
22}
23
24
25// Purpose: call each function in string.hfa, top to bottom
26
27int main () {
[6f7aff3]28
29 #ifdef STRING_SHARING_OFF
30 string_sharectx c = { NO_SHARING };
31 #endif
32
[f450f2f]33 string s = "hello";
34 string s2 = "hello";
35 string s3 = "world";
36 string frag = "ell";
37
38 // IO operator, x2
[2b30370]39 sout | s | s | s; // hello hello hello
40
41 // empty ctor then assign
42 string sxx;
43 sout | sxx; // (blank line)
44 sxx = s;
45 sout | sxx; // hello
[f450f2f]46
47 // Comparisons
48 // all print "true false"
49 sout | (s == s2) | (s == s3);
50 sout | (s != s3) | (s != s2);
51 sout | (s == "hello") | (s == "world");
52 sout | (s != "world") | (s != "hello");
53 sout | ( frag == s(1,4) ) | ( s3 == s(1,4) );
54 sout | ( s3 != s(1,4) ) | ( frag != s(1,4) );
55 sout | ( s2(1,4) == s(1,4) ) | ( s3(1,4) == s(1,4) );
56 sout | ( s3(1,4) != s(1,4) ) | ( s2(1,4) != s(1,4) );
57 sout | ( s(1,4) == frag ) | ( s(1,4) == s3 );
58 sout | ( s(1,4) != s3 ) | ( s(1,4) != frag );
59 sout | ( s(1,4) == "ell" ) | ( s(1,4) == "world" );
60 sout | ( s(1,4) != "world" ) | ( s(1,4) != "ell" );
61
62
63 assertWellFormedHandleList( 10 );
64 //
65 // breadth Constructors
66 //
67 {
68 string b1 = { "1234567", 3 };
69 sout | b1; // 123
70
71 string b2 = s;
72 sout | b2; // hello
73
74 // todo: a plain string &
75 const string & s_ref = s;
76 string b3 = s_ref;
77 sout | b3; // hello
78
79 & s_ref = & s3;
80 b3 = s_ref;
81 sout | b3; // world
82
83 const string & s_constref = s;
84 string b4 = s_constref;
85 sout | b4; // hello
86
87 & s_constref = & s3;
88 b4 = s_constref;
89 sout | b4; // world
90 }
91 assertWellFormedHandleList( 10 );
92
93 sout | size(s); // 5
94
95 //
96 // concatenation/append
97 //
98
99 string sx = s + s3;
100 assertWellFormedHandleList( 10 );
101 sout | sx; // helloworld
102 assertWellFormedHandleList( 10 );
103 sx = "xx";
104 assertWellFormedHandleList( 10 );
105 sx = s + s3;
106 assertWellFormedHandleList( 10 );
107 sout | sx; // helloworld
108 assertWellFormedHandleList( 10 );
109
110 sx += '!';
111 sout | sx; // helloworld!
112 sx = s + '!';
113 sout | sx; // hello!
114
115 sx = s;
116 sx += s;
117 sout | sx; // hellohello
118 assertWellFormedHandleList( 10 );
119 sx += ", friend";
120 sout | sx; // hellohello, friend
121
122 sx = s + ", friend";
123 sout | sx; // hello, friend
124
125 sx = "bye, " + "friend";
126 sout | sx; // bye, friend
127
128 //
129 // repetition
130 //
131 sx = s * 3;
132 sout | sx; // hellohellohello
133
134 sx = 'Q' * (size_t)3;
135 sout | sx; // QQQ
136
137 sx = "asdf" * 3;
138 sout | sx; // asdfasdfasdf
139
140 //
141 // slicing
142 //
143
144 //...
145
146 //
147 // character access
148 //
149
150 char c = s[1];
151 sout | c; // e
152
153 s[3] = "p!!!";
154 sout | s; // help!!!o
155
156 s[7] = '!';
157 sout | s; // help!!!!
158
159 s[7] = "";
160 sout | s; // help!!!
161
162 sout | s[3]; // p
163
164 //
165 // search
166 //
167
168 s += '?'; // already tested
169 sout | contains( s, 'h' ) | contains( s, '?' ) | contains( s, 'o' ); // true true false
170
171 sout
172 | find( s, 'h' ) // 0
173 | find( s, '!' ) // 4
174 | find( s, '?' ) // 7
175 | find( s, 'o' ); // 8, not found
176
177 string alphabet = "abcdefghijklmnopqrstuvwxyz";
178
179 sout
180 | find( alphabet, "" ) // 0
181 | find( alphabet, "a" ) // 0
182 | find( alphabet, "z" ) // 25
183 | find( alphabet, "abc" ) // 0
184 | find( alphabet, "abq" ) // 26, not found
185 | find( alphabet, "def"); // 3
186
187 sout
188 | includes( alphabet, "" ) // true
189 | includes( alphabet, "a" ) // true
190 | includes( alphabet, "z" ) // true
191 | includes( alphabet, "abc" ) // true
192 | includes( alphabet, "abq" ) // false
193 | includes( alphabet, "def"); // true
194
195 {
196 char *empty_c = "";
197 char *a_c = "a";
198 char *z_c = "z";
199 char *dex_c = "dex";
200
201 sout
202 | find( alphabet, empty_c ) // 0
203 | find( alphabet, a_c ) // 0
204 | find( alphabet, dex_c ) // 26, not found
205 | find( alphabet, dex_c, 2 ); // 3
206
207 sout
208 | includes( alphabet, empty_c ) // true
209 | includes( alphabet, a_c ) // true
210 | includes( alphabet, dex_c ) // false
211 | includes( alphabet, dex_c, 2 ); // true
212
213 sout
214 | startsWith( alphabet, a_c) // true
215 | endsWith ( alphabet, a_c) // false
216 | startsWith( alphabet, z_c) // false
217 | endsWith ( alphabet, z_c); // true
218
219 string empty = empty_c;
220 string a = a_c;
221 string z = z_c;
222 string dex = dex_c;
223
224 sout
225 | find( alphabet, empty ) // 0
226 | find( alphabet, a ) // 0
227 | find( alphabet, dex ) // 26, not found
228 | find( alphabet, dex(0,2) ); // 3
229
230 sout
231 | includes( alphabet, empty ) // true
232 | includes( alphabet, a ) // true
233 | includes( alphabet, dex ) // false
234 | includes( alphabet, dex(0,2) ); // true
235
236 sout
237 | startsWith( alphabet, a) // true
238 | endsWith ( alphabet, a) // false
239 | startsWith( alphabet, z) // false
240 | endsWith ( alphabet, z); // true
241 }
242
243 sout
244 | find( alphabet , "def") // 3
245 | find( alphabet( 0, 26), "def") // 3
246 | find( alphabet( 2, 26), "def") // 1
247 | find( alphabet( 3, 26), "def") // 0
248 | find( alphabet( 4, 26), "def") // 22, not found
249 | find( alphabet( 4, 26), "ef") // 0
250 | find( alphabet( 0, 6), "def") // 3
251 | find( alphabet( 0, 5), "def") // 5, not found
252 | find( alphabet( 0, 5), "de" ); // 3
253
254 sout
255 | includes( alphabet , "def") // true
256 | includes( alphabet( 0, 26), "def") // true
257 | includes( alphabet( 2, 26), "def") // true
258 | includes( alphabet( 3, 26), "def") // true
259 | includes( alphabet( 4, 26), "def") // false
260 | includes( alphabet( 4, 26), "ef") // true
261 | includes( alphabet( 0, 6), "def") // true
262 | includes( alphabet( 0, 5), "def") // false
263 | includes( alphabet( 0, 5), "de" ); // true
264
265 sout
266 | startsWith( alphabet , "abc") // true
267 | startsWith( alphabet( 0, 26), "abc") // true
268 | startsWith( alphabet( 1, 26), "abc") // false
269 | startsWith( alphabet( 1, 26), "bc") // true
270 | startsWith( alphabet( 0, 26), "abc") // true
271 | startsWith( alphabet( 0, 4), "abc") // true
272 | startsWith( alphabet( 0, 3), "abc") // true
273 | startsWith( alphabet( 0, 3), "ab" ) // true
274 | startsWith( alphabet , "xyz"); // false
275
276 sout
277 | endsWith( alphabet , "xyz") // true
278 | endsWith( alphabet , "xyzz") // false
279 | endsWith( alphabet( 0, 26), "xyz") // true
280 | endsWith( alphabet( 0, 25), "xyz") // false
281 | endsWith( alphabet( 0, 25), "xy" ) // true
282 | endsWith( alphabet( 0, 26), "xyz") // true
283 | endsWith( alphabet(23, 26), "xyz") // true
284 | endsWith( alphabet(24, 26), "xyz") // false
285 | endsWith( alphabet(24, 26), "yz") // true
286 | endsWith( alphabet , "abc"); // false
287
288 charclass cc_cba = {"cba"};
289 charclass cc_onml = {"onml"};
290 charclass cc_alphabet = {alphabet};
291
292 // include (rest of the) numbers: tell me where the numbers stop
293 // exclude (until) numbers: tell me where the numbers start (include rest of the non-numbers)
294
295 sout
296 | include( alphabet, cc_cba ) // 3
297 | exclude( alphabet, cc_cba ) // 0
298 | include( alphabet, cc_onml ) // 0
299 | exclude( alphabet, cc_onml ) // 11
300 | include( alphabet, cc_alphabet ) // 26
301 | exclude( alphabet, cc_alphabet ); // 0
302}
303
Note: See TracBrowser for help on using the repository browser.