1 /* Test that mbsalign works as advertised.
2 Copyright (C) 2010-2015 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 <http://www.gnu.org/licenses/>. */
17 /* Written by Pádraig Brady. */
29 char dest
[4 * 16 + 1];
32 /* Test unibyte truncation. */
34 n
= mbsalign ("t\tés", dest
, sizeof dest
, &width
, MBS_ALIGN_LEFT
, 0);
37 /* Test center alignment. */
39 n
= mbsalign ("es", dest
, sizeof dest
, &width
, MBS_ALIGN_CENTER
, 0);
40 ASSERT (*dest
== ' ' && *(dest
+ n
- 1) == ' ');
43 /* Test center alignment, with no trailing padding. */
45 n
= mbsalign ("es", dest
, sizeof dest
, &width
, MBS_ALIGN_CENTER
,
48 ASSERT (*dest
== ' ' && *(dest
+ n
- 1) == 's');
50 /* Test left alignment, with no trailing padding. (truncate only). */
52 n
= mbsalign ("es", dest
, sizeof dest
, &width
, MBS_ALIGN_LEFT
,
55 ASSERT (*dest
== 'e' && *(dest
+ n
- 1) == 's');
57 /* Test center alignment, with no padding. (truncate only). */
59 n
= mbsalign ("es", dest
, sizeof dest
, &width
, MBS_ALIGN_CENTER
,
60 MBA_NO_LEFT_PAD
| MBA_NO_RIGHT_PAD
);
62 ASSERT (*dest
== 'e' && *(dest
+ n
- 1) == 's');
64 /* Test center alignment, with no left padding. (may be useful for RTL?) */
66 n
= mbsalign ("es", dest
, sizeof dest
, &width
, MBS_ALIGN_CENTER
,
69 ASSERT (*dest
== 'e' && *(dest
+ n
- 1) == ' ');
71 if (setlocale (LC_ALL
, "en_US.UTF8"))
73 /* Check invalid input is flagged. */
75 n
= mbsalign ("t\xe1\xe2s", dest
, sizeof dest
, &width
, MBS_ALIGN_LEFT
, 0);
76 ASSERT (n
== (size_t) -1);
78 /* Check invalid input is treated as unibyte */
80 n
= mbsalign ("t\xe1\xe2s", dest
, sizeof dest
, &width
,
81 MBS_ALIGN_LEFT
, MBA_UNIBYTE_FALLBACK
);
84 /* Test multibyte center alignment. */
86 n
= mbsalign ("és", dest
, sizeof dest
, &width
, MBS_ALIGN_CENTER
, 0);
88 ASSERT (*dest
== ' ' && *(dest
+ n
- 1) == ' ');
90 /* Test multibyte left alignment. */
92 n
= mbsalign ("és", dest
, sizeof dest
, &width
, MBS_ALIGN_LEFT
, 0);
94 ASSERT (*(dest
+ n
- 1) == ' ' && *(dest
+ n
- 2) == ' ');
96 /* Test multibyte right alignment. */
98 n
= mbsalign ("és", dest
, sizeof dest
, &width
, MBS_ALIGN_RIGHT
, 0);
100 ASSERT (*(dest
) == ' ' && *(dest
+ 1) == ' ');
102 /* multibyte multicell truncation. */
103 width
= 4; /* cells */
104 n
= mbsalign ("日月火水", dest
, sizeof dest
, &width
,
106 ASSERT (n
== 6); /* 2 characters */
108 /* multibyte unicell truncation. */
109 width
= 3; /* cells */
110 n
= mbsalign ("¹²³⁴", dest
, sizeof dest
, &width
, MBS_ALIGN_LEFT
, 0);
111 ASSERT (n
== 6); /* 3 characters */
113 /* Check independence from dest buffer. */
114 width
= 4; /* cells */
115 n
= mbsalign ("¹²³⁴", dest
, 0, &width
, MBS_ALIGN_LEFT
, 0);
116 ASSERT (n
== 9); /* 4 characters */
118 /* Check that width is updated with cells required before padding. */
119 width
= 4; /* cells */
120 n
= mbsalign ("¹²³", dest
, 0, &width
, MBS_ALIGN_LEFT
, 0);
123 /* Test case where output is larger than input
124 (as tab converted to multi byte replacement char). */
126 n
= mbsalign ("t\tés" /* 6 including NUL */ , dest
, sizeof dest
,
127 &width
, MBS_ALIGN_LEFT
, 0);
130 /* Test forced unibyte truncation. */
132 n
= mbsalign ("t\tés", dest
, sizeof dest
, &width
, MBS_ALIGN_LEFT
,