Mercurial > minori
comparison dep/utf8proc/test/normtest.c @ 343:1faa72660932
*: transfer back to cmake from autotools
autotools just made lots of things more complicated than
they should have and many things broke (i.e. translations)
author | Paper <paper@paper.us.eu.org> |
---|---|
date | Thu, 20 Jun 2024 05:56:06 -0400 |
parents | |
children |
comparison
equal
deleted
inserted
replaced
342:adb79bdde329 | 343:1faa72660932 |
---|---|
1 #include "tests.h" | |
2 | |
3 #define CHECK_NORM(NRM, norm, src) { \ | |
4 unsigned char *src_norm = (unsigned char*) utf8proc_ ## NRM((utf8proc_uint8_t*) src); \ | |
5 check(!strcmp((char *) norm, (char *) src_norm), \ | |
6 "normalization failed for %s -> %s", src, norm); \ | |
7 free(src_norm); \ | |
8 } | |
9 | |
10 int main(int argc, char **argv) | |
11 { | |
12 unsigned char buf[8192]; | |
13 FILE *f = argc > 1 ? fopen(argv[1], "r") : NULL; | |
14 unsigned char source[1024], NFC[1024], NFD[1024], NFKC[1024], NFKD[1024]; | |
15 | |
16 check(f != NULL, "error opening NormalizationTest.txt"); | |
17 while (simple_getline(buf, f) > 0) { | |
18 size_t offset; | |
19 lineno += 1; | |
20 | |
21 if (buf[0] == '@') { | |
22 printf("line %zd: %s", lineno, buf + 1); | |
23 continue; | |
24 } | |
25 else if (lineno % 1000 == 0) | |
26 printf("checking line %zd...\n", lineno); | |
27 | |
28 if (buf[0] == '#') continue; | |
29 | |
30 offset = encode(source, buf); | |
31 offset += encode(NFC, buf + offset); | |
32 offset += encode(NFD, buf + offset); | |
33 offset += encode(NFKC, buf + offset); | |
34 offset += encode(NFKD, buf + offset); | |
35 | |
36 CHECK_NORM(NFC, NFC, source); | |
37 CHECK_NORM(NFC, NFC, NFC); | |
38 CHECK_NORM(NFC, NFC, NFD); | |
39 CHECK_NORM(NFC, NFKC, NFKC); | |
40 CHECK_NORM(NFC, NFKC, NFKD); | |
41 | |
42 CHECK_NORM(NFD, NFD, source); | |
43 CHECK_NORM(NFD, NFD, NFC); | |
44 CHECK_NORM(NFD, NFD, NFD); | |
45 CHECK_NORM(NFD, NFKD, NFKC); | |
46 CHECK_NORM(NFD, NFKD, NFKD); | |
47 | |
48 CHECK_NORM(NFKC, NFKC, source); | |
49 CHECK_NORM(NFKC, NFKC, NFC); | |
50 CHECK_NORM(NFKC, NFKC, NFD); | |
51 CHECK_NORM(NFKC, NFKC, NFKC); | |
52 CHECK_NORM(NFKC, NFKC, NFKD); | |
53 | |
54 CHECK_NORM(NFKD, NFKD, source); | |
55 CHECK_NORM(NFKD, NFKD, NFC); | |
56 CHECK_NORM(NFKD, NFKD, NFD); | |
57 CHECK_NORM(NFKD, NFKD, NFKC); | |
58 CHECK_NORM(NFKD, NFKD, NFKD); | |
59 } | |
60 fclose(f); | |
61 printf("Passed tests after %zd lines!\n", lineno); | |
62 return 0; | |
63 } |