1 /* Test of Unicode compliance of canonical decomposition of UTF-32 strings.
2 Copyright (C) 2009-2025 Free Software Foundation, Inc.
4 This program is free software: you can redistribute it and/or modify
5 it under the terms of the GNU General Public License as published by
6 the Free Software Foundation, either version 3 of the License, or
7 (at your option) any later version.
9 This program 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. See the
12 GNU General Public License for more details.
14 You should have received a copy of the GNU General Public License
15 along with this program. If not, see <https://www.gnu.org/licenses/>. */
17 /* Written by Bruno Haible <bruno@clisp.org>, 2009. */
21 #if GNULIB_TEST_UNINORM_U32_NORMALIZE
28 #include "test-u32-normalize-big.h"
32 check (const uint32_t *c1
, size_t c1_length
,
33 const uint32_t *c2
, size_t c2_length
,
34 const uint32_t *c3
, size_t c3_length
,
35 const uint32_t *c4
, size_t c4_length
,
36 const uint32_t *c5
, size_t c5_length
)
39 c3 == NFD(c1) == NFD(c2) == NFD(c3)
40 c5 == NFD(c4) == NFD(c5)
46 result
= u32_normalize (UNINORM_NFD
, c1
, c1_length
, NULL
, &length
);
48 && length
== c3_length
49 && u32_cmp (result
, c3
, c3_length
) == 0))
57 result
= u32_normalize (UNINORM_NFD
, c2
, c2_length
, NULL
, &length
);
59 && length
== c3_length
60 && u32_cmp (result
, c3
, c3_length
) == 0))
68 result
= u32_normalize (UNINORM_NFD
, c3
, c3_length
, NULL
, &length
);
70 && length
== c3_length
71 && u32_cmp (result
, c3
, c3_length
) == 0))
79 result
= u32_normalize (UNINORM_NFD
, c4
, c4_length
, NULL
, &length
);
81 && length
== c5_length
82 && u32_cmp (result
, c5
, c5_length
) == 0))
90 result
= u32_normalize (UNINORM_NFD
, c5
, c5_length
, NULL
, &length
);
92 && length
== c5_length
93 && u32_cmp (result
, c5
, c5_length
) == 0))
101 main (int argc
, char *argv
[])
103 struct normalization_test_file file
;
105 read_normalization_test_file (argv
[1], &file
);
107 test_specific (&file
, check
);
108 test_other (&file
, UNINORM_NFD
);
110 free_normalization_test_file (&file
);
112 return test_exit_status
;
122 fprintf (stderr
, "Skipping test: uninorm/u32-normalize module not included.\n");