1 /* Unit tests for utilities
2 * Copyright (C) 2010 Red Hat, Inc.
3 * Copyright (C) 2011 Google, Inc.
5 * This work is provided "as is"; redistribution and modification
6 * in whole or in part, in any medium, physical or electronic is
7 * permitted without restriction.
9 * This work is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
13 * In no event shall the authors or contributors be liable for any
14 * direct, indirect, incidental, special, exemplary, or consequential
15 * damages (including, but not limited to, procurement of substitute
16 * goods or services; loss of use, data, or profits; or business
17 * interruption) however caused and on any theory of liability, whether
18 * in contract, strict liability, or tort (including negligence or
19 * otherwise) arising in any way out of the use of this software, even
20 * if advised of the possibility of such damage.
22 * Author: Matthias Clasen, Behdad Esfahbod
25 /* We are testing some deprecated APIs here */
26 #define GLIB_DISABLE_DEPRECATION_WARNINGS
31 test_unichar_validate (void)
33 g_assert (g_unichar_validate ('j'));
34 g_assert (g_unichar_validate (8356));
35 g_assert (g_unichar_validate (8356));
36 g_assert (g_unichar_validate (0xfdd1));
37 g_assert (g_unichar_validate (917760));
38 g_assert (!g_unichar_validate (0x110000));
42 test_unichar_character_type (void)
49 { G_UNICODE_CONTROL, 0x000D },
50 { G_UNICODE_FORMAT, 0x200E },
51 /* G_UNICODE_UNASSIGNED */
52 { G_UNICODE_PRIVATE_USE, 0xE000 },
53 { G_UNICODE_SURROGATE, 0xD800 },
54 { G_UNICODE_LOWERCASE_LETTER, 0x0061 },
55 { G_UNICODE_MODIFIER_LETTER, 0x02B0 },
56 { G_UNICODE_OTHER_LETTER, 0x3400 },
57 { G_UNICODE_TITLECASE_LETTER, 0x01C5 },
58 { G_UNICODE_UPPERCASE_LETTER, 0xFF21 },
59 { G_UNICODE_COMBINING_MARK, 0x0903 },
60 { G_UNICODE_ENCLOSING_MARK, 0x20DD },
61 { G_UNICODE_NON_SPACING_MARK, 0xA806 },
62 { G_UNICODE_DECIMAL_NUMBER, 0xFF10 },
63 { G_UNICODE_LETTER_NUMBER, 0x16EE },
64 { G_UNICODE_OTHER_NUMBER, 0x17F0 },
65 { G_UNICODE_CONNECT_PUNCTUATION, 0x005F },
66 { G_UNICODE_DASH_PUNCTUATION, 0x058A },
67 { G_UNICODE_CLOSE_PUNCTUATION, 0x0F3B },
68 { G_UNICODE_FINAL_PUNCTUATION, 0x2019 },
69 { G_UNICODE_INITIAL_PUNCTUATION, 0x2018 },
70 { G_UNICODE_OTHER_PUNCTUATION, 0x2016 },
71 { G_UNICODE_OPEN_PUNCTUATION, 0x0F3A },
72 { G_UNICODE_CURRENCY_SYMBOL, 0x20A0 },
73 { G_UNICODE_MODIFIER_SYMBOL, 0x309B },
74 { G_UNICODE_MATH_SYMBOL, 0xFB29 },
75 { G_UNICODE_OTHER_SYMBOL, 0x00A6 },
76 { G_UNICODE_LINE_SEPARATOR, 0x2028 },
77 { G_UNICODE_PARAGRAPH_SEPARATOR, 0x2029 },
78 { G_UNICODE_SPACE_SEPARATOR, 0x202F },
81 for (i = 0; i < G_N_ELEMENTS (examples); i++)
83 g_assert_cmpint (g_unichar_type (examples[i].c), ==, examples[i].type);
88 test_unichar_break_type (void)
92 GUnicodeBreakType type;
95 { G_UNICODE_BREAK_MANDATORY, 0x2028 },
96 { G_UNICODE_BREAK_CARRIAGE_RETURN, 0x000D },
97 { G_UNICODE_BREAK_LINE_FEED, 0x000A },
98 { G_UNICODE_BREAK_COMBINING_MARK, 0x0300 },
99 { G_UNICODE_BREAK_SURROGATE, 0xD800 },
100 { G_UNICODE_BREAK_ZERO_WIDTH_SPACE, 0x200B },
101 { G_UNICODE_BREAK_INSEPARABLE, 0x2024 },
102 { G_UNICODE_BREAK_NON_BREAKING_GLUE, 0x00A0 },
103 { G_UNICODE_BREAK_CONTINGENT, 0xFFFC },
104 { G_UNICODE_BREAK_SPACE, 0x0020 },
105 { G_UNICODE_BREAK_AFTER, 0x05BE },
106 { G_UNICODE_BREAK_BEFORE, 0x02C8 },
107 { G_UNICODE_BREAK_BEFORE_AND_AFTER, 0x2014 },
108 { G_UNICODE_BREAK_HYPHEN, 0x002D },
109 { G_UNICODE_BREAK_NON_STARTER, 0x17D6 },
110 { G_UNICODE_BREAK_OPEN_PUNCTUATION, 0x0028 },
111 { G_UNICODE_BREAK_CLOSE_PARANTHESIS, 0x0029 },
112 { G_UNICODE_BREAK_CLOSE_PUNCTUATION, 0x007D },
113 { G_UNICODE_BREAK_QUOTATION, 0x0022 },
114 { G_UNICODE_BREAK_EXCLAMATION, 0x0021 },
115 { G_UNICODE_BREAK_IDEOGRAPHIC, 0x2E80 },
116 { G_UNICODE_BREAK_NUMERIC, 0x0030 },
117 { G_UNICODE_BREAK_INFIX_SEPARATOR, 0x002C },
118 { G_UNICODE_BREAK_SYMBOL, 0x002F },
119 { G_UNICODE_BREAK_ALPHABETIC, 0x0023 },
120 { G_UNICODE_BREAK_PREFIX, 0x0024 },
121 { G_UNICODE_BREAK_POSTFIX, 0x0025 },
122 { G_UNICODE_BREAK_COMPLEX_CONTEXT, 0x0E01 },
123 { G_UNICODE_BREAK_AMBIGUOUS, 0x00F7 },
124 { G_UNICODE_BREAK_UNKNOWN, 0xE000 },
125 { G_UNICODE_BREAK_NEXT_LINE, 0x0085 },
126 { G_UNICODE_BREAK_WORD_JOINER, 0x2060 },
127 { G_UNICODE_BREAK_HANGUL_L_JAMO, 0x1100 },
128 { G_UNICODE_BREAK_HANGUL_V_JAMO, 0x1160 },
129 { G_UNICODE_BREAK_HANGUL_T_JAMO, 0x11A8 },
130 { G_UNICODE_BREAK_HANGUL_LV_SYLLABLE, 0xAC00 },
131 { G_UNICODE_BREAK_HANGUL_LVT_SYLLABLE, 0xAC01 },
132 { G_UNICODE_BREAK_CONDITIONAL_JAPANESE_STARTER, 0x3041 },
133 { G_UNICODE_BREAK_HEBREW_LETTER, 0x05D0 },
134 { G_UNICODE_BREAK_REGIONAL_INDICATOR, 0x1F1F6 }
137 for (i = 0; i < G_N_ELEMENTS (examples); i++)
139 g_assert_cmpint (g_unichar_break_type (examples[i].c), ==, examples[i].type);
144 test_unichar_script (void)
148 GUnicodeScript script;
151 { G_UNICODE_SCRIPT_COMMON, 0x002A },
152 { G_UNICODE_SCRIPT_INHERITED, 0x1CED },
153 { G_UNICODE_SCRIPT_INHERITED, 0x0670 },
154 { G_UNICODE_SCRIPT_ARABIC, 0x060D },
155 { G_UNICODE_SCRIPT_ARMENIAN, 0x0559 },
156 { G_UNICODE_SCRIPT_BENGALI, 0x09CD },
157 { G_UNICODE_SCRIPT_BOPOMOFO, 0x31B6 },
158 { G_UNICODE_SCRIPT_CHEROKEE, 0x13A2 },
159 { G_UNICODE_SCRIPT_COPTIC, 0x2CFD },
160 { G_UNICODE_SCRIPT_CYRILLIC, 0x0482 },
161 { G_UNICODE_SCRIPT_DESERET, 0x10401 },
162 { G_UNICODE_SCRIPT_DEVANAGARI, 0x094D },
163 { G_UNICODE_SCRIPT_ETHIOPIC, 0x1258 },
164 { G_UNICODE_SCRIPT_GEORGIAN, 0x10FC },
165 { G_UNICODE_SCRIPT_GOTHIC, 0x10341 },
166 { G_UNICODE_SCRIPT_GREEK, 0x0375 },
167 { G_UNICODE_SCRIPT_GUJARATI, 0x0A83 },
168 { G_UNICODE_SCRIPT_GURMUKHI, 0x0A3C },
169 { G_UNICODE_SCRIPT_HAN, 0x3005 },
170 { G_UNICODE_SCRIPT_HANGUL, 0x1100 },
171 { G_UNICODE_SCRIPT_HEBREW, 0x05BF },
172 { G_UNICODE_SCRIPT_HIRAGANA, 0x309F },
173 { G_UNICODE_SCRIPT_KANNADA, 0x0CBC },
174 { G_UNICODE_SCRIPT_KATAKANA, 0x30FF },
175 { G_UNICODE_SCRIPT_KHMER, 0x17DD },
176 { G_UNICODE_SCRIPT_LAO, 0x0EDD },
177 { G_UNICODE_SCRIPT_LATIN, 0x0061 },
178 { G_UNICODE_SCRIPT_MALAYALAM, 0x0D3D },
179 { G_UNICODE_SCRIPT_MONGOLIAN, 0x1843 },
180 { G_UNICODE_SCRIPT_MYANMAR, 0x1031 },
181 { G_UNICODE_SCRIPT_OGHAM, 0x169C },
182 { G_UNICODE_SCRIPT_OLD_ITALIC, 0x10322 },
183 { G_UNICODE_SCRIPT_ORIYA, 0x0B3C },
184 { G_UNICODE_SCRIPT_RUNIC, 0x16EF },
185 { G_UNICODE_SCRIPT_SINHALA, 0x0DBD },
186 { G_UNICODE_SCRIPT_SYRIAC, 0x0711 },
187 { G_UNICODE_SCRIPT_TAMIL, 0x0B82 },
188 { G_UNICODE_SCRIPT_TELUGU, 0x0C03 },
189 { G_UNICODE_SCRIPT_THAANA, 0x07B1 },
190 { G_UNICODE_SCRIPT_THAI, 0x0E31 },
191 { G_UNICODE_SCRIPT_TIBETAN, 0x0FD4 },
192 { G_UNICODE_SCRIPT_CANADIAN_ABORIGINAL, 0x1400 },
193 { G_UNICODE_SCRIPT_CANADIAN_ABORIGINAL, 0x1401 },
194 { G_UNICODE_SCRIPT_YI, 0xA015 },
195 { G_UNICODE_SCRIPT_TAGALOG, 0x1700 },
196 { G_UNICODE_SCRIPT_HANUNOO, 0x1720 },
197 { G_UNICODE_SCRIPT_BUHID, 0x1740 },
198 { G_UNICODE_SCRIPT_TAGBANWA, 0x1760 },
199 { G_UNICODE_SCRIPT_BRAILLE, 0x2800 },
200 { G_UNICODE_SCRIPT_CYPRIOT, 0x10808 },
201 { G_UNICODE_SCRIPT_LIMBU, 0x1932 },
202 { G_UNICODE_SCRIPT_OSMANYA, 0x10480 },
203 { G_UNICODE_SCRIPT_SHAVIAN, 0x10450 },
204 { G_UNICODE_SCRIPT_LINEAR_B, 0x10000 },
205 { G_UNICODE_SCRIPT_TAI_LE, 0x1950 },
206 { G_UNICODE_SCRIPT_UGARITIC, 0x1039F },
207 { G_UNICODE_SCRIPT_NEW_TAI_LUE, 0x1980 },
208 { G_UNICODE_SCRIPT_BUGINESE, 0x1A1F },
209 { G_UNICODE_SCRIPT_GLAGOLITIC, 0x2C00 },
210 { G_UNICODE_SCRIPT_TIFINAGH, 0x2D6F },
211 { G_UNICODE_SCRIPT_SYLOTI_NAGRI, 0xA800 },
212 { G_UNICODE_SCRIPT_OLD_PERSIAN, 0x103D0 },
213 { G_UNICODE_SCRIPT_KHAROSHTHI, 0x10A3F },
214 { G_UNICODE_SCRIPT_UNKNOWN, 0x1111111 },
215 { G_UNICODE_SCRIPT_BALINESE, 0x1B04 },
216 { G_UNICODE_SCRIPT_CUNEIFORM, 0x12000 },
217 { G_UNICODE_SCRIPT_PHOENICIAN, 0x10900 },
218 { G_UNICODE_SCRIPT_PHAGS_PA, 0xA840 },
219 { G_UNICODE_SCRIPT_NKO, 0x07C0 },
220 { G_UNICODE_SCRIPT_KAYAH_LI, 0xA900 },
221 { G_UNICODE_SCRIPT_LEPCHA, 0x1C00 },
222 { G_UNICODE_SCRIPT_REJANG, 0xA930 },
223 { G_UNICODE_SCRIPT_SUNDANESE, 0x1B80 },
224 { G_UNICODE_SCRIPT_SAURASHTRA, 0xA880 },
225 { G_UNICODE_SCRIPT_CHAM, 0xAA00 },
226 { G_UNICODE_SCRIPT_OL_CHIKI, 0x1C50 },
227 { G_UNICODE_SCRIPT_VAI, 0xA500 },
228 { G_UNICODE_SCRIPT_CARIAN, 0x102A0 },
229 { G_UNICODE_SCRIPT_LYCIAN, 0x10280 },
230 { G_UNICODE_SCRIPT_LYDIAN, 0x1093F },
231 { G_UNICODE_SCRIPT_AVESTAN, 0x10B00 },
232 { G_UNICODE_SCRIPT_BAMUM, 0xA6A0 },
233 { G_UNICODE_SCRIPT_EGYPTIAN_HIEROGLYPHS, 0x13000 },
234 { G_UNICODE_SCRIPT_IMPERIAL_ARAMAIC, 0x10840 },
235 { G_UNICODE_SCRIPT_INSCRIPTIONAL_PAHLAVI, 0x10B60 },
236 { G_UNICODE_SCRIPT_INSCRIPTIONAL_PARTHIAN, 0x10B40 },
237 { G_UNICODE_SCRIPT_JAVANESE, 0xA980 },
238 { G_UNICODE_SCRIPT_KAITHI, 0x11082 },
239 { G_UNICODE_SCRIPT_LISU, 0xA4D0 },
240 { G_UNICODE_SCRIPT_MEETEI_MAYEK, 0xABE5 },
241 { G_UNICODE_SCRIPT_OLD_SOUTH_ARABIAN, 0x10A60 },
242 { G_UNICODE_SCRIPT_OLD_TURKIC, 0x10C00 },
243 { G_UNICODE_SCRIPT_SAMARITAN, 0x0800 },
244 { G_UNICODE_SCRIPT_TAI_THAM, 0x1A20 },
245 { G_UNICODE_SCRIPT_TAI_VIET, 0xAA80 },
246 { G_UNICODE_SCRIPT_BATAK, 0x1BC0 },
247 { G_UNICODE_SCRIPT_BRAHMI, 0x11000 },
248 { G_UNICODE_SCRIPT_MANDAIC, 0x0840 },
249 { G_UNICODE_SCRIPT_CHAKMA, 0x11100 },
250 { G_UNICODE_SCRIPT_MEROITIC_CURSIVE, 0x109A0 },
251 { G_UNICODE_SCRIPT_MEROITIC_HIEROGLYPHS, 0x10980 },
252 { G_UNICODE_SCRIPT_MIAO, 0x16F00 },
253 { G_UNICODE_SCRIPT_SHARADA, 0x11180 },
254 { G_UNICODE_SCRIPT_SORA_SOMPENG, 0x110D0 },
255 { G_UNICODE_SCRIPT_TAKRI, 0x11680 }
257 for (i = 0; i < G_N_ELEMENTS (examples); i++)
259 g_assert_cmpint (g_unichar_get_script (examples[i].c), ==, examples[i].script);
264 test_combining_class (void)
305 for (i = 0; i < G_N_ELEMENTS (examples); i++)
307 g_assert_cmpint (g_unichar_combining_class (examples[i].c), ==, examples[i].class);
316 g_assert (g_unichar_get_mirror_char ('(', &mirror));
317 g_assert_cmpint (mirror, ==, ')');
318 g_assert (g_unichar_get_mirror_char (')', &mirror));
319 g_assert_cmpint (mirror, ==, '(');
320 g_assert (g_unichar_get_mirror_char ('{', &mirror));
321 g_assert_cmpint (mirror, ==, '}');
322 g_assert (g_unichar_get_mirror_char ('}', &mirror));
323 g_assert_cmpint (mirror, ==, '{');
324 g_assert (g_unichar_get_mirror_char (0x208D, &mirror));
325 g_assert_cmpint (mirror, ==, 0x208E);
326 g_assert (g_unichar_get_mirror_char (0x208E, &mirror));
327 g_assert_cmpint (mirror, ==, 0x208D);
328 g_assert (!g_unichar_get_mirror_char ('a', &mirror));
334 g_assert (g_unichar_ismark (0x0903));
335 g_assert (g_unichar_ismark (0x20DD));
336 g_assert (g_unichar_ismark (0xA806));
337 g_assert (!g_unichar_ismark ('a'));
341 test_zerowidth (void)
343 g_assert (!g_unichar_iszerowidth (0x00AD));
344 g_assert (!g_unichar_iszerowidth (0x00AD));
345 g_assert (!g_unichar_iszerowidth (0x115F));
346 g_assert (g_unichar_iszerowidth (0x1160));
347 g_assert (g_unichar_iszerowidth (0x11AA));
348 g_assert (g_unichar_iszerowidth (0x11FF));
349 g_assert (!g_unichar_iszerowidth (0x1200));
350 g_assert (g_unichar_iszerowidth (0x200B));
351 g_assert (g_unichar_iszerowidth (0x591));
357 g_assert (g_unichar_istitle (0x01c5));
358 g_assert (g_unichar_istitle (0x1f88));
359 g_assert (g_unichar_istitle (0x1fcc));
360 g_assert (!g_unichar_istitle ('a'));
361 g_assert (!g_unichar_istitle ('A'));
363 g_assert_cmphex (g_unichar_totitle (0x01c6), ==, 0x01c5);
364 g_assert_cmphex (g_unichar_totitle (0x01c4), ==, 0x01c5);
365 g_assert_cmphex (g_unichar_totitle (0x01c5), ==, 0x01c5);
366 g_assert_cmphex (g_unichar_totitle (0x1f80), ==, 0x1f88);
367 g_assert_cmphex (g_unichar_totitle (0x1f88), ==, 0x1f88);
368 g_assert_cmphex (g_unichar_totitle ('a'), ==, 'A');
369 g_assert_cmphex (g_unichar_totitle ('A'), ==, 'A');
375 g_assert_cmphex (g_unichar_toupper ('a'), ==, 'A');
376 g_assert_cmphex (g_unichar_toupper ('A'), ==, 'A');
377 g_assert_cmphex (g_unichar_toupper (0x01C5), ==, 0x01C4);
378 g_assert_cmphex (g_unichar_toupper (0x01C6), ==, 0x01C4);
379 g_assert_cmphex (g_unichar_tolower ('A'), ==, 'a');
380 g_assert_cmphex (g_unichar_tolower ('a'), ==, 'a');
381 g_assert_cmphex (g_unichar_tolower (0x01C4), ==, 0x01C6);
382 g_assert_cmphex (g_unichar_tolower (0x01C5), ==, 0x01C6);
383 g_assert_cmphex (g_unichar_tolower (0x1F8A), ==, 0x1F82);
384 g_assert_cmphex (g_unichar_totitle (0x1F8A), ==, 0x1F8A);
385 g_assert_cmphex (g_unichar_toupper (0x1F8A), ==, 0x1F8A);
386 g_assert_cmphex (g_unichar_tolower (0x1FB2), ==, 0x1FB2);
387 g_assert_cmphex (g_unichar_toupper (0x1FB2), ==, 0x1FB2);
393 g_assert (g_unichar_isdefined (0x0903));
394 g_assert (g_unichar_isdefined (0x20DD));
395 g_assert (g_unichar_isdefined (0x20BA));
396 g_assert (g_unichar_isdefined (0xA806));
397 g_assert (g_unichar_isdefined ('a'));
398 g_assert (!g_unichar_isdefined (0x10C49));
399 g_assert (!g_unichar_isdefined (0x169D));
415 { 0x0000, NOT_WIDE },
416 { 0x0483, NOT_WIDE },
417 { 0x0641, NOT_WIDE },
418 { 0xFFFC, NOT_WIDE },
419 { 0x10000, NOT_WIDE },
420 { 0xE0001, NOT_WIDE },
423 { 0x0020, NOT_WIDE },
424 { 0x0041, NOT_WIDE },
425 { 0x27E6, NOT_WIDE },
428 { 0x20A9, NOT_WIDE },
429 { 0xFF61, NOT_WIDE },
430 { 0xFF69, NOT_WIDE },
431 { 0xFFEE, NOT_WIDE },
434 { 0x00A1, WIDE_CJK },
435 { 0x00BE, WIDE_CJK },
436 { 0x02DD, WIDE_CJK },
437 { 0x2020, WIDE_CJK },
438 { 0xFFFD, WIDE_CJK },
439 { 0x00A1, WIDE_CJK },
440 { 0x1F100, WIDE_CJK },
441 { 0xE0100, WIDE_CJK },
442 { 0x100000, WIDE_CJK },
443 { 0x10FFFD, WIDE_CJK },
456 /* Default Wide blocks */
465 /* Uniode-5.2 character additions */
469 /* Uniode-6.0 character additions */
474 { 0x111111, NOT_WIDE }
477 for (i = 0; i < G_N_ELEMENTS (examples); i++)
479 g_assert_cmpint (g_unichar_iswide (examples[i].c), ==, (examples[i].wide == WIDE));
480 g_assert_cmpint (g_unichar_iswide_cjk (examples[i].c), ==, (examples[i].wide != NOT_WIDE));
490 g_assert (!g_unichar_compose (0x0041, 0x0042, &ch) && ch == 0);
491 g_assert (!g_unichar_compose (0x0041, 0, &ch) && ch == 0);
492 g_assert (!g_unichar_compose (0x0066, 0x0069, &ch) && ch == 0);
494 /* Tricky non-composable */
495 g_assert (!g_unichar_compose (0x0308, 0x0301, &ch) && ch == 0); /* !0x0344 */
496 g_assert (!g_unichar_compose (0x0F71, 0x0F72, &ch) && ch == 0); /* !0x0F73 */
498 /* Singletons should not compose */
499 g_assert (!g_unichar_compose (0x212B, 0, &ch) && ch == 0);
500 g_assert (!g_unichar_compose (0x00C5, 0, &ch) && ch == 0);
501 g_assert (!g_unichar_compose (0x2126, 0, &ch) && ch == 0);
502 g_assert (!g_unichar_compose (0x03A9, 0, &ch) && ch == 0);
505 g_assert (g_unichar_compose (0x0041, 0x030A, &ch) && ch == 0x00C5);
506 g_assert (g_unichar_compose (0x006F, 0x0302, &ch) && ch == 0x00F4);
507 g_assert (g_unichar_compose (0x1E63, 0x0307, &ch) && ch == 0x1E69);
508 g_assert (g_unichar_compose (0x0073, 0x0323, &ch) && ch == 0x1E63);
509 g_assert (g_unichar_compose (0x0064, 0x0307, &ch) && ch == 0x1E0B);
510 g_assert (g_unichar_compose (0x0064, 0x0323, &ch) && ch == 0x1E0D);
513 g_assert (g_unichar_compose (0xD4CC, 0x11B6, &ch) && ch == 0xD4DB);
514 g_assert (g_unichar_compose (0x1111, 0x1171, &ch) && ch == 0xD4CC);
515 g_assert (g_unichar_compose (0xCE20, 0x11B8, &ch) && ch == 0xCE31);
516 g_assert (g_unichar_compose (0x110E, 0x1173, &ch) && ch == 0xCE20);
520 test_decompose (void)
524 /* Not decomposable */
525 g_assert (!g_unichar_decompose (0x0041, &a, &b) && a == 0x0041 && b == 0);
526 g_assert (!g_unichar_decompose (0xFB01, &a, &b) && a == 0xFB01 && b == 0);
529 g_assert (g_unichar_decompose (0x212B, &a, &b) && a == 0x00C5 && b == 0);
530 g_assert (g_unichar_decompose (0x2126, &a, &b) && a == 0x03A9 && b == 0);
533 g_assert (g_unichar_decompose (0x0344, &a, &b) && a == 0x0308 && b == 0x0301);
534 g_assert (g_unichar_decompose (0x0F73, &a, &b) && a == 0x0F71 && b == 0x0F72);
537 g_assert (g_unichar_decompose (0x00C5, &a, &b) && a == 0x0041 && b == 0x030A);
538 g_assert (g_unichar_decompose (0x00F4, &a, &b) && a == 0x006F && b == 0x0302);
539 g_assert (g_unichar_decompose (0x1E69, &a, &b) && a == 0x1E63 && b == 0x0307);
540 g_assert (g_unichar_decompose (0x1E63, &a, &b) && a == 0x0073 && b == 0x0323);
541 g_assert (g_unichar_decompose (0x1E0B, &a, &b) && a == 0x0064 && b == 0x0307);
542 g_assert (g_unichar_decompose (0x1E0D, &a, &b) && a == 0x0064 && b == 0x0323);
545 g_assert (g_unichar_decompose (0xD4DB, &a, &b) && a == 0xD4CC && b == 0x11B6);
546 g_assert (g_unichar_decompose (0xD4CC, &a, &b) && a == 0x1111 && b == 0x1171);
547 g_assert (g_unichar_decompose (0xCE31, &a, &b) && a == 0xCE20 && b == 0x11B8);
548 g_assert (g_unichar_decompose (0xCE20, &a, &b) && a == 0x110E && b == 0x1173);
552 test_fully_decompose_canonical (void)
557 #define TEST_DECOMP(ch, expected_len, a, b, c, d) \
558 len = g_unichar_fully_decompose (ch, FALSE, decomp, G_N_ELEMENTS (decomp)); \
559 g_assert_cmpint (expected_len, ==, len); \
560 if (expected_len >= 1) g_assert_cmphex (decomp[0], ==, a); \
561 if (expected_len >= 2) g_assert_cmphex (decomp[1], ==, b); \
562 if (expected_len >= 3) g_assert_cmphex (decomp[2], ==, c); \
563 if (expected_len >= 4) g_assert_cmphex (decomp[3], ==, d); \
565 #define TEST0(ch) TEST_DECOMP (ch, 1, ch, 0, 0, 0)
566 #define TEST1(ch, a) TEST_DECOMP (ch, 1, a, 0, 0, 0)
567 #define TEST2(ch, a, b) TEST_DECOMP (ch, 2, a, b, 0, 0)
568 #define TEST3(ch, a, b, c) TEST_DECOMP (ch, 3, a, b, c, 0)
569 #define TEST4(ch, a, b, c, d) TEST_DECOMP (ch, 4, a, b, c, d)
571 /* Not decomposable */
576 TEST2 (0x212B, 0x0041, 0x030A);
577 TEST1 (0x2126, 0x03A9);
580 TEST2 (0x0344, 0x0308, 0x0301);
581 TEST2 (0x0F73, 0x0F71, 0x0F72);
584 TEST2 (0x00C5, 0x0041, 0x030A);
585 TEST2 (0x00F4, 0x006F, 0x0302);
586 TEST3 (0x1E69, 0x0073, 0x0323, 0x0307);
587 TEST2 (0x1E63, 0x0073, 0x0323);
588 TEST2 (0x1E0B, 0x0064, 0x0307);
589 TEST2 (0x1E0D, 0x0064, 0x0323);
592 TEST3 (0xD4DB, 0x1111, 0x1171, 0x11B6);
593 TEST2 (0xD4CC, 0x1111, 0x1171);
594 TEST3 (0xCE31, 0x110E, 0x1173, 0x11B8);
595 TEST2 (0xCE20, 0x110E, 0x1173);
601 test_canonical_decomposition (void)
606 #define TEST_DECOMP(ch, expected_len, a, b, c, d) \
607 decomp = g_unicode_canonical_decomposition (ch, &len); \
608 g_assert_cmpint (expected_len, ==, len); \
609 if (expected_len >= 1) g_assert_cmphex (decomp[0], ==, a); \
610 if (expected_len >= 2) g_assert_cmphex (decomp[1], ==, b); \
611 if (expected_len >= 3) g_assert_cmphex (decomp[2], ==, c); \
612 if (expected_len >= 4) g_assert_cmphex (decomp[3], ==, d); \
615 #define TEST0(ch) TEST_DECOMP (ch, 1, ch, 0, 0, 0)
616 #define TEST1(ch, a) TEST_DECOMP (ch, 1, a, 0, 0, 0)
617 #define TEST2(ch, a, b) TEST_DECOMP (ch, 2, a, b, 0, 0)
618 #define TEST3(ch, a, b, c) TEST_DECOMP (ch, 3, a, b, c, 0)
619 #define TEST4(ch, a, b, c, d) TEST_DECOMP (ch, 4, a, b, c, d)
621 /* Not decomposable */
626 TEST2 (0x212B, 0x0041, 0x030A);
627 TEST1 (0x2126, 0x03A9);
630 TEST2 (0x0344, 0x0308, 0x0301);
631 TEST2 (0x0F73, 0x0F71, 0x0F72);
634 TEST2 (0x00C5, 0x0041, 0x030A);
635 TEST2 (0x00F4, 0x006F, 0x0302);
636 TEST3 (0x1E69, 0x0073, 0x0323, 0x0307);
637 TEST2 (0x1E63, 0x0073, 0x0323);
638 TEST2 (0x1E0B, 0x0064, 0x0307);
639 TEST2 (0x1E0D, 0x0064, 0x0323);
642 TEST3 (0xD4DB, 0x1111, 0x1171, 0x11B6);
643 TEST2 (0xD4CC, 0x1111, 0x1171);
644 TEST3 (0xCE31, 0x110E, 0x1173, 0x11B8);
645 TEST2 (0xCE20, 0x110E, 0x1173);
651 test_decompose_tail (void)
653 gunichar ch, a, b, c, d;
655 /* Test that whenever a char ch decomposes into a and b, b itself
656 * won't decompose any further. */
658 for (ch = 0; ch < 0x110000; ch++)
659 if (g_unichar_decompose (ch, &a, &b))
660 g_assert (!g_unichar_decompose (b, &c, &d));
663 g_assert_cmpuint (a, ==, ch);
664 g_assert_cmpuint (b, ==, 0);
669 test_fully_decompose_len (void)
673 /* Test that all canonical decompositions are at most 4 in length,
674 * and compatibility decompositions are at most 18 in length.
677 for (ch = 0; ch < 0x110000; ch++) {
678 g_assert_cmpint (g_unichar_fully_decompose (ch, FALSE, NULL, 0), <=, 4);
679 g_assert_cmpint (g_unichar_fully_decompose (ch, TRUE, NULL, 0), <=, 18);
687 GUnicodeScript script;
688 char four_letter_code[5];
690 { G_UNICODE_SCRIPT_COMMON, "Zyyy" },
691 { G_UNICODE_SCRIPT_INHERITED, "Zinh" },
692 { G_UNICODE_SCRIPT_ARABIC, "Arab" },
693 { G_UNICODE_SCRIPT_ARMENIAN, "Armn" },
694 { G_UNICODE_SCRIPT_BENGALI, "Beng" },
695 { G_UNICODE_SCRIPT_BOPOMOFO, "Bopo" },
696 { G_UNICODE_SCRIPT_CHEROKEE, "Cher" },
697 { G_UNICODE_SCRIPT_COPTIC, "Copt" },
698 { G_UNICODE_SCRIPT_CYRILLIC, "Cyrl" },
699 { G_UNICODE_SCRIPT_DESERET, "Dsrt" },
700 { G_UNICODE_SCRIPT_DEVANAGARI, "Deva" },
701 { G_UNICODE_SCRIPT_ETHIOPIC, "Ethi" },
702 { G_UNICODE_SCRIPT_GEORGIAN, "Geor" },
703 { G_UNICODE_SCRIPT_GOTHIC, "Goth" },
704 { G_UNICODE_SCRIPT_GREEK, "Grek" },
705 { G_UNICODE_SCRIPT_GUJARATI, "Gujr" },
706 { G_UNICODE_SCRIPT_GURMUKHI, "Guru" },
707 { G_UNICODE_SCRIPT_HAN, "Hani" },
708 { G_UNICODE_SCRIPT_HANGUL, "Hang" },
709 { G_UNICODE_SCRIPT_HEBREW, "Hebr" },
710 { G_UNICODE_SCRIPT_HIRAGANA, "Hira" },
711 { G_UNICODE_SCRIPT_KANNADA, "Knda" },
712 { G_UNICODE_SCRIPT_KATAKANA, "Kana" },
713 { G_UNICODE_SCRIPT_KHMER, "Khmr" },
714 { G_UNICODE_SCRIPT_LAO, "Laoo" },
715 { G_UNICODE_SCRIPT_LATIN, "Latn" },
716 { G_UNICODE_SCRIPT_MALAYALAM, "Mlym" },
717 { G_UNICODE_SCRIPT_MONGOLIAN, "Mong" },
718 { G_UNICODE_SCRIPT_MYANMAR, "Mymr" },
719 { G_UNICODE_SCRIPT_OGHAM, "Ogam" },
720 { G_UNICODE_SCRIPT_OLD_ITALIC, "Ital" },
721 { G_UNICODE_SCRIPT_ORIYA, "Orya" },
722 { G_UNICODE_SCRIPT_RUNIC, "Runr" },
723 { G_UNICODE_SCRIPT_SINHALA, "Sinh" },
724 { G_UNICODE_SCRIPT_SYRIAC, "Syrc" },
725 { G_UNICODE_SCRIPT_TAMIL, "Taml" },
726 { G_UNICODE_SCRIPT_TELUGU, "Telu" },
727 { G_UNICODE_SCRIPT_THAANA, "Thaa" },
728 { G_UNICODE_SCRIPT_THAI, "Thai" },
729 { G_UNICODE_SCRIPT_TIBETAN, "Tibt" },
730 { G_UNICODE_SCRIPT_CANADIAN_ABORIGINAL, "Cans" },
731 { G_UNICODE_SCRIPT_YI, "Yiii" },
732 { G_UNICODE_SCRIPT_TAGALOG, "Tglg" },
733 { G_UNICODE_SCRIPT_HANUNOO, "Hano" },
734 { G_UNICODE_SCRIPT_BUHID, "Buhd" },
735 { G_UNICODE_SCRIPT_TAGBANWA, "Tagb" },
737 /* Unicode-4.0 additions */
738 { G_UNICODE_SCRIPT_BRAILLE, "Brai" },
739 { G_UNICODE_SCRIPT_CYPRIOT, "Cprt" },
740 { G_UNICODE_SCRIPT_LIMBU, "Limb" },
741 { G_UNICODE_SCRIPT_OSMANYA, "Osma" },
742 { G_UNICODE_SCRIPT_SHAVIAN, "Shaw" },
743 { G_UNICODE_SCRIPT_LINEAR_B, "Linb" },
744 { G_UNICODE_SCRIPT_TAI_LE, "Tale" },
745 { G_UNICODE_SCRIPT_UGARITIC, "Ugar" },
747 /* Unicode-4.1 additions */
748 { G_UNICODE_SCRIPT_NEW_TAI_LUE, "Talu" },
749 { G_UNICODE_SCRIPT_BUGINESE, "Bugi" },
750 { G_UNICODE_SCRIPT_GLAGOLITIC, "Glag" },
751 { G_UNICODE_SCRIPT_TIFINAGH, "Tfng" },
752 { G_UNICODE_SCRIPT_SYLOTI_NAGRI, "Sylo" },
753 { G_UNICODE_SCRIPT_OLD_PERSIAN, "Xpeo" },
754 { G_UNICODE_SCRIPT_KHAROSHTHI, "Khar" },
756 /* Unicode-5.0 additions */
757 { G_UNICODE_SCRIPT_UNKNOWN, "Zzzz" },
758 { G_UNICODE_SCRIPT_BALINESE, "Bali" },
759 { G_UNICODE_SCRIPT_CUNEIFORM, "Xsux" },
760 { G_UNICODE_SCRIPT_PHOENICIAN, "Phnx" },
761 { G_UNICODE_SCRIPT_PHAGS_PA, "Phag" },
762 { G_UNICODE_SCRIPT_NKO, "Nkoo" },
764 /* Unicode-5.1 additions */
765 { G_UNICODE_SCRIPT_KAYAH_LI, "Kali" },
766 { G_UNICODE_SCRIPT_LEPCHA, "Lepc" },
767 { G_UNICODE_SCRIPT_REJANG, "Rjng" },
768 { G_UNICODE_SCRIPT_SUNDANESE, "Sund" },
769 { G_UNICODE_SCRIPT_SAURASHTRA, "Saur" },
770 { G_UNICODE_SCRIPT_CHAM, "Cham" },
771 { G_UNICODE_SCRIPT_OL_CHIKI, "Olck" },
772 { G_UNICODE_SCRIPT_VAI, "Vaii" },
773 { G_UNICODE_SCRIPT_CARIAN, "Cari" },
774 { G_UNICODE_SCRIPT_LYCIAN, "Lyci" },
775 { G_UNICODE_SCRIPT_LYDIAN, "Lydi" },
777 /* Unicode-5.2 additions */
778 { G_UNICODE_SCRIPT_AVESTAN, "Avst" },
779 { G_UNICODE_SCRIPT_BAMUM, "Bamu" },
780 { G_UNICODE_SCRIPT_EGYPTIAN_HIEROGLYPHS, "Egyp" },
781 { G_UNICODE_SCRIPT_IMPERIAL_ARAMAIC, "Armi" },
782 { G_UNICODE_SCRIPT_INSCRIPTIONAL_PAHLAVI, "Phli" },
783 { G_UNICODE_SCRIPT_INSCRIPTIONAL_PARTHIAN, "Prti" },
784 { G_UNICODE_SCRIPT_JAVANESE, "Java" },
785 { G_UNICODE_SCRIPT_KAITHI, "Kthi" },
786 { G_UNICODE_SCRIPT_LISU, "Lisu" },
787 { G_UNICODE_SCRIPT_MEETEI_MAYEK, "Mtei" },
788 { G_UNICODE_SCRIPT_OLD_SOUTH_ARABIAN, "Sarb" },
789 { G_UNICODE_SCRIPT_OLD_TURKIC, "Orkh" },
790 { G_UNICODE_SCRIPT_SAMARITAN, "Samr" },
791 { G_UNICODE_SCRIPT_TAI_THAM, "Lana" },
792 { G_UNICODE_SCRIPT_TAI_VIET, "Tavt" },
794 /* Unicode-6.0 additions */
795 { G_UNICODE_SCRIPT_BATAK, "Batk" },
796 { G_UNICODE_SCRIPT_BRAHMI, "Brah" },
797 { G_UNICODE_SCRIPT_MANDAIC, "Mand" },
799 /* Unicode-6.1 additions */
800 { G_UNICODE_SCRIPT_CHAKMA, "Cakm" },
801 { G_UNICODE_SCRIPT_MEROITIC_CURSIVE, "Merc" },
802 { G_UNICODE_SCRIPT_MEROITIC_HIEROGLYPHS, "Mero" },
803 { G_UNICODE_SCRIPT_MIAO, "Plrd" },
804 { G_UNICODE_SCRIPT_SHARADA, "Shrd" },
805 { G_UNICODE_SCRIPT_SORA_SOMPENG, "Sora" },
806 { G_UNICODE_SCRIPT_TAKRI, "Takr" },
810 g_assert_cmphex (0, ==, g_unicode_script_to_iso15924 (G_UNICODE_SCRIPT_INVALID_CODE));
811 g_assert_cmphex (0x5A7A7A7A, ==, g_unicode_script_to_iso15924 (1000));
812 g_assert_cmphex (0x41726162, ==, g_unicode_script_to_iso15924 (G_UNICODE_SCRIPT_ARABIC));
814 g_assert_cmphex (G_UNICODE_SCRIPT_INVALID_CODE, ==, g_unicode_script_from_iso15924 (0));
815 g_assert_cmphex (G_UNICODE_SCRIPT_UNKNOWN, ==, g_unicode_script_from_iso15924 (0x12345678));
817 #define PACK(a,b,c,d) ((guint32)((((guint8)(a))<<24)|(((guint8)(b))<<16)|(((guint8)(c))<<8)|((guint8)(d))))
819 for (i = 0; i < G_N_ELEMENTS (data); i++)
821 guint32 code = PACK (data[i].four_letter_code[0],
822 data[i].four_letter_code[1],
823 data[i].four_letter_code[2],
824 data[i].four_letter_code[3]);
826 g_assert_cmphex (g_unicode_script_to_iso15924 (data[i].script), ==, code);
827 g_assert_cmpint (g_unicode_script_from_iso15924 (code), ==, data[i].script);
837 g_test_init (&argc, &argv, NULL);
839 g_test_add_func ("/unicode/validate", test_unichar_validate);
840 g_test_add_func ("/unicode/character-type", test_unichar_character_type);
841 g_test_add_func ("/unicode/break-type", test_unichar_break_type);
842 g_test_add_func ("/unicode/script", test_unichar_script);
843 g_test_add_func ("/unicode/combining-class", test_combining_class);
844 g_test_add_func ("/unicode/mirror", test_mirror);
845 g_test_add_func ("/unicode/mark", test_mark);
846 g_test_add_func ("/unicode/title", test_title);
847 g_test_add_func ("/unicode/zero-width", test_zerowidth);
848 g_test_add_func ("/unicode/defined", test_defined);
849 g_test_add_func ("/unicode/wide", test_wide);
850 g_test_add_func ("/unicode/compose", test_compose);
851 g_test_add_func ("/unicode/decompose", test_decompose);
852 g_test_add_func ("/unicode/fully-decompose-canonical", test_fully_decompose_canonical);
853 g_test_add_func ("/unicode/canonical-decomposition", test_canonical_decomposition);
854 g_test_add_func ("/unicode/decompose-tail", test_decompose_tail);
855 g_test_add_func ("/unicode/fully-decompose-len", test_fully_decompose_len);
856 g_test_add_func ("/unicode/iso15924", test_iso15924);
857 g_test_add_func ("/unicode/cases", test_cases);