xref: /openbsd-src/regress/lib/libc/locale/mbrtowc/test_mbrtowc.c (revision 7928e20dd0aca922c3a0e8ae17965431ff9265fb)
1*7928e20dSdlg /*	$OpenBSD: test_mbrtowc.c,v 1.3 2020/03/09 09:29:10 dlg Exp $	*/
2f6f031ffSschwarze /*
3f6f031ffSschwarze  * Copyright (c) 2016 Ingo Schwarze <schwarze@openbsd.org>
4f6f031ffSschwarze  *
5f6f031ffSschwarze  * Permission to use, copy, modify, and distribute this software for any
6f6f031ffSschwarze  * purpose with or without fee is hereby granted, provided that the above
7f6f031ffSschwarze  * copyright notice and this permission notice appear in all copies.
8f6f031ffSschwarze  *
9f6f031ffSschwarze  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
10f6f031ffSschwarze  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
11f6f031ffSschwarze  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
12f6f031ffSschwarze  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
13f6f031ffSschwarze  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
14f6f031ffSschwarze  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
15f6f031ffSschwarze  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
16f6f031ffSschwarze  */
17f6f031ffSschwarze 
18f6f031ffSschwarze #include <sys/types.h>
19f6f031ffSschwarze #include <err.h>
20f6f031ffSschwarze #include <errno.h>
21f6f031ffSschwarze #include <locale.h>
22f6f031ffSschwarze #include <stdlib.h>
23f6f031ffSschwarze #include <string.h>
24f6f031ffSschwarze #include <wchar.h>
25f6f031ffSschwarze 
26f6f031ffSschwarze static mbstate_t	 mbs;
27f6f031ffSschwarze 
28f6f031ffSschwarze void
onetest(const char * name,const char * in,size_t insz,int outerr,size_t outsz,wint_t out)29f6f031ffSschwarze onetest(const char *name, const char *in, size_t insz,
30f6f031ffSschwarze     int outerr, size_t outsz, wint_t out)
31f6f031ffSschwarze {
32f6f031ffSschwarze 	wchar_t		 wc;
33f6f031ffSschwarze 	size_t		 sz;
34f6f031ffSschwarze 
35f6f031ffSschwarze 	sz = mbrtowc(&wc, in, insz, &mbs);
36f6f031ffSschwarze 	if (errno != outerr)
3736cd4f11Sbluhm 		err(1, "%zu %s(%zd)", MB_CUR_MAX, name, insz);
38f6f031ffSschwarze 	if (sz != outsz || (out != WEOF && wc != out))
3936cd4f11Sbluhm 		errx(1, "%zu %s(%zd) = (%zd, %d) != (%zd, %d)",
40f6f031ffSschwarze 		    MB_CUR_MAX, name, insz, sz, wc, outsz, out);
41f6f031ffSschwarze 	if (mbsinit(&mbs) == (insz && outsz == (size_t)-2))
4236cd4f11Sbluhm 		errx(1, "%zu %s(%zd) mbsinit", MB_CUR_MAX, name, insz);
43f6f031ffSschwarze 	if (errno == 0 && outerr == 0)
44f6f031ffSschwarze 		return;
45f6f031ffSschwarze 	errno = 0;
46f6f031ffSschwarze 	memset(&mbs, 0, sizeof(mbs));
47f6f031ffSschwarze }
48f6f031ffSschwarze 
49f6f031ffSschwarze int
main(void)50f6f031ffSschwarze main(void)
51f6f031ffSschwarze {
52f6f031ffSschwarze 	onetest("NUL", "", 0, 0, -2, WEOF);
53f6f031ffSschwarze 	onetest("NUL", "", 2, 0, 0, L'\0');
54f6f031ffSschwarze 	onetest("BEL", "\a", 2, 0, 1, L'\a');
55f6f031ffSschwarze 	onetest("A", "A", 2, 0, 1, L'A');
56f6f031ffSschwarze 	onetest("DEL", "\177", 2, 0, 1, L'\177');
57f6f031ffSschwarze 	onetest("CSI", "\233", 2, 0, 1, L'\233');
58f6f031ffSschwarze 
59f6f031ffSschwarze 	if (setlocale(LC_CTYPE, "en_US.UTF-8") == NULL)
60*7928e20dSdlg 		errx(1, "setlocale(UTF-8) failed");
61f6f031ffSschwarze 
62f6f031ffSschwarze 	onetest("NUL", "", 0, 0, -2, WEOF);
63f6f031ffSschwarze 	onetest("NUL", "", 8, 0, 0, L'\0');
64f6f031ffSschwarze 	onetest("BEL", "\a", 8, 0, 1, L'\a');
65f6f031ffSschwarze 	onetest("A", "A", 8, 0, 1, L'A');
66f6f031ffSschwarze 	onetest("DEL", "\177", 8, 0, 1, L'\177');
67f6f031ffSschwarze 	onetest("0x80", "\200", 8, EILSEQ, -1, WEOF);
68f6f031ffSschwarze 	onetest("0xc3", "\303", 1, 0, -2, WEOF);
69f6f031ffSschwarze 	onetest("U+00E9", "\251", 8, 0, 1, 0xe9);
70f6f031ffSschwarze 	onetest("0xec", "\354", 1, 0, -2, WEOF);
71f6f031ffSschwarze 	onetest("0xecbf", "\277", 1, 0, -2, WEOF);
72f6f031ffSschwarze 	onetest("U+CFFF", "\277", 8, 0, 1, 0xcfff);
73f6f031ffSschwarze 
74f6f031ffSschwarze 	if (setlocale(LC_CTYPE, "POSIX") == NULL)
75*7928e20dSdlg 		errx(1, "setlocale(POSIX) failed");
76f6f031ffSschwarze 
77f6f031ffSschwarze 	onetest("0xff", "\277", 2, 0, 1, L'\277');
78f6f031ffSschwarze 
79f6f031ffSschwarze 	if (setlocale(LC_CTYPE, "en_US.UTF-8") == NULL)
80*7928e20dSdlg 		errx(1, "second setlocale(UTF-8) failed");
81f6f031ffSschwarze 
82f6f031ffSschwarze 	onetest("U+13000", "\360\223\200\200", 8, 0, 4, 0x13000);
83f6f031ffSschwarze 
84f6f031ffSschwarze 	return 0;
85f6f031ffSschwarze }
86