xref: /freebsd-src/contrib/netbsd-tests/lib/libc/locale/t_wctomb.c (revision d899be7d43d8df9cb485af5705e2724165a461c7)
157718be8SEnji Cooper /* $NetBSD: t_wctomb.c,v 1.3 2013/03/25 15:31:03 gson Exp $ */
257718be8SEnji Cooper 
357718be8SEnji Cooper /*-
457718be8SEnji Cooper  * Copyright (c) 2011 The NetBSD Foundation, Inc.
557718be8SEnji Cooper  * All rights reserved.
657718be8SEnji Cooper  *
757718be8SEnji Cooper  * Redistribution and use in source and binary forms, with or without
857718be8SEnji Cooper  * modification, are permitted provided that the following conditions
957718be8SEnji Cooper  * are met:
1057718be8SEnji Cooper  * 1. Redistributions of source code must retain the above copyright
1157718be8SEnji Cooper  *    notice, this list of conditions and the following disclaimer.
1257718be8SEnji Cooper  * 2. Redistributions in binary form must reproduce the above copyright
1357718be8SEnji Cooper  *    notice, this list of conditions and the following disclaimer in the
1457718be8SEnji Cooper  *    documentation and/or other materials provided with the distribution.
1557718be8SEnji Cooper  *
1657718be8SEnji Cooper  * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
1757718be8SEnji Cooper  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
1857718be8SEnji Cooper  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
1957718be8SEnji Cooper  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
2057718be8SEnji Cooper  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
2157718be8SEnji Cooper  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
2257718be8SEnji Cooper  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
2357718be8SEnji Cooper  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
2457718be8SEnji Cooper  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
2557718be8SEnji Cooper  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
2657718be8SEnji Cooper  * POSSIBILITY OF SUCH DAMAGE.
2757718be8SEnji Cooper  */
2857718be8SEnji Cooper 
2957718be8SEnji Cooper /*-
3057718be8SEnji Cooper  * Copyright (c)2004 Citrus Project,
3157718be8SEnji Cooper  * All rights reserved.
3257718be8SEnji Cooper  *
3357718be8SEnji Cooper  * Redistribution and use in source and binary forms, with or without
3457718be8SEnji Cooper  * modification, are permitted provided that the following conditions
3557718be8SEnji Cooper  * are met:
3657718be8SEnji Cooper  * 1. Redistributions of source code must retain the above copyright
3757718be8SEnji Cooper  *    notice, this list of conditions and the following disclaimer.
3857718be8SEnji Cooper  * 2. Redistributions in binary form must reproduce the above copyright
3957718be8SEnji Cooper  *    notice, this list of conditions and the following disclaimer in the
4057718be8SEnji Cooper  *    documentation and/or other materials provided with the distribution.
4157718be8SEnji Cooper  *
4257718be8SEnji Cooper  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
4357718be8SEnji Cooper  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
4457718be8SEnji Cooper  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
4557718be8SEnji Cooper  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
4657718be8SEnji Cooper  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
4757718be8SEnji Cooper  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
4857718be8SEnji Cooper  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
4957718be8SEnji Cooper  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
5057718be8SEnji Cooper  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
5157718be8SEnji Cooper  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
5257718be8SEnji Cooper  * SUCH DAMAGE.
5357718be8SEnji Cooper  */
5457718be8SEnji Cooper 
5557718be8SEnji Cooper #include <sys/cdefs.h>
5657718be8SEnji Cooper __COPYRIGHT("@(#) Copyright (c) 2011\
5757718be8SEnji Cooper  The NetBSD Foundation, inc. All rights reserved.");
5857718be8SEnji Cooper __RCSID("$NetBSD: t_wctomb.c,v 1.3 2013/03/25 15:31:03 gson Exp $");
5957718be8SEnji Cooper 
6057718be8SEnji Cooper #include <stdio.h>
6157718be8SEnji Cooper #include <stdlib.h>
6257718be8SEnji Cooper #include <locale.h>
6357718be8SEnji Cooper #include <vis.h>
6457718be8SEnji Cooper #include <wchar.h>
6557718be8SEnji Cooper #include <string.h>
6657718be8SEnji Cooper #include <limits.h>
6757718be8SEnji Cooper 
6857718be8SEnji Cooper #include <atf-c.h>
6957718be8SEnji Cooper 
7057718be8SEnji Cooper #define TC_WCTOMB	0
7157718be8SEnji Cooper #define TC_WCRTOMB	1
7257718be8SEnji Cooper #define TC_WCRTOMB_ST	2
7357718be8SEnji Cooper 
7457718be8SEnji Cooper static struct test {
7557718be8SEnji Cooper 	const char *locale;
7657718be8SEnji Cooper 	const char *data;
7757718be8SEnji Cooper 	size_t wclen;
7857718be8SEnji Cooper 	size_t mblen[16];
7957718be8SEnji Cooper } tests[] = {
8057718be8SEnji Cooper {
8157718be8SEnji Cooper 	"ja_JP.ISO2022-JP",
8257718be8SEnji Cooper 	"\x1b$B"	/* JIS X 0208-1983 */
8357718be8SEnji Cooper 	"\x46\x7c\x4b\x5c\x38\x6c" /* "nihongo" */
8457718be8SEnji Cooper 	"\x1b(B"	/* ISO 646 */
8557718be8SEnji Cooper 	"ABC"
8657718be8SEnji Cooper 	"\x1b(I"	/* JIS X 0201 katakana */
8757718be8SEnji Cooper 	"\xb1\xb2\xb3"	/* "aiu" */
8857718be8SEnji Cooper 	"\x1b(B",	/* ISO 646 */
8957718be8SEnji Cooper 	3 + 3 + 3,
9057718be8SEnji Cooper 	{ 3+2, 2, 2, 3+1, 1, 1, 3+1, 1, 1, 3+1 }
9157718be8SEnji Cooper }, {
9257718be8SEnji Cooper 	"C",
9357718be8SEnji Cooper 	"ABC",
9457718be8SEnji Cooper 	3,
9557718be8SEnji Cooper 	{ 1, 1, 1, 1 }
9657718be8SEnji Cooper }, { NULL, NULL, 0, { } }
9757718be8SEnji Cooper };
9857718be8SEnji Cooper 
9957718be8SEnji Cooper static void
h_wctomb(const struct test * t,char tc)10057718be8SEnji Cooper h_wctomb(const struct test *t, char tc)
10157718be8SEnji Cooper {
10257718be8SEnji Cooper 	wchar_t wcs[16 + 2];
10357718be8SEnji Cooper 	char buf[128];
10457718be8SEnji Cooper 	char cs[MB_LEN_MAX];
10557718be8SEnji Cooper 	const char *pcs;
10657718be8SEnji Cooper 	char *str;
10757718be8SEnji Cooper 	mbstate_t st;
10857718be8SEnji Cooper 	mbstate_t *stp = NULL;
10957718be8SEnji Cooper 	size_t sz, ret, i;
11057718be8SEnji Cooper 
11157718be8SEnji Cooper 	ATF_REQUIRE_STREQ(setlocale(LC_ALL, "C"), "C");
112*ff0ba872SEnji Cooper #ifdef __NetBSD__
11357718be8SEnji Cooper 	ATF_REQUIRE(setlocale(LC_CTYPE, t->locale) != NULL);
114effc3698SEnji Cooper #else
115effc3698SEnji Cooper 	if (setlocale(LC_CTYPE, t->locale) == NULL) {
116effc3698SEnji Cooper 		fprintf(stderr, "Locale %s not found.\n", t->locale);
117effc3698SEnji Cooper 		return;
118effc3698SEnji Cooper 	}
119effc3698SEnji Cooper #endif
12057718be8SEnji Cooper 
12157718be8SEnji Cooper 	(void)strvis(buf, t->data, VIS_WHITE | VIS_OCTAL);
12257718be8SEnji Cooper 	(void)printf("Checking sequence: \"%s\"\n", buf);
12357718be8SEnji Cooper 
12457718be8SEnji Cooper 	ATF_REQUIRE((str = setlocale(LC_ALL, NULL)) != NULL);
12557718be8SEnji Cooper 	(void)printf("Using locale: %s\n", str);
12657718be8SEnji Cooper 
12757718be8SEnji Cooper 	if (tc == TC_WCRTOMB_ST) {
12857718be8SEnji Cooper 		(void)memset(&st, 0, sizeof(st));
12957718be8SEnji Cooper 		stp = &st;
13057718be8SEnji Cooper 	}
13157718be8SEnji Cooper 
13257718be8SEnji Cooper 	wcs[t->wclen] = L'X'; /* poison */
13357718be8SEnji Cooper 	pcs = t->data;
13457718be8SEnji Cooper 	sz = mbsrtowcs(wcs, &pcs, t->wclen + 2, NULL);
13557718be8SEnji Cooper 	ATF_REQUIRE_EQ_MSG(sz, t->wclen, "mbsrtowcs() returned: "
13657718be8SEnji Cooper 		"%zu, expected: %zu", sz, t->wclen);
13757718be8SEnji Cooper 	ATF_REQUIRE_EQ(wcs[t->wclen], 0);
13857718be8SEnji Cooper 
13957718be8SEnji Cooper 	for (i = 0; i < t->wclen + 1; i++) {
14057718be8SEnji Cooper 		if (tc == TC_WCTOMB)
14157718be8SEnji Cooper 			ret = wctomb(cs, wcs[i]);
14257718be8SEnji Cooper 		else
14357718be8SEnji Cooper 			ret = wcrtomb(cs, wcs[i], stp);
14457718be8SEnji Cooper 
14557718be8SEnji Cooper 		if (ret == t->mblen[i])
14657718be8SEnji Cooper 			continue;
14757718be8SEnji Cooper 
14857718be8SEnji Cooper 		(void)printf("At position %zd:\n", i);
14957718be8SEnji Cooper 		(void)printf("  expected: %zd\n", t->mblen[i]);
15057718be8SEnji Cooper 		(void)printf("  got     : %zd\n", ret);
15157718be8SEnji Cooper 		atf_tc_fail("Test failed");
15257718be8SEnji Cooper 		/* NOTREACHED */
15357718be8SEnji Cooper 	}
15457718be8SEnji Cooper 
15557718be8SEnji Cooper 	(void)printf("Ok.\n");
15657718be8SEnji Cooper }
15757718be8SEnji Cooper 
15857718be8SEnji Cooper ATF_TC(wctomb);
ATF_TC_HEAD(wctomb,tc)15957718be8SEnji Cooper ATF_TC_HEAD(wctomb, tc)
16057718be8SEnji Cooper {
16157718be8SEnji Cooper 	atf_tc_set_md_var(tc, "descr", "Checks wctomb(3)");
16257718be8SEnji Cooper }
ATF_TC_BODY(wctomb,tc)16357718be8SEnji Cooper ATF_TC_BODY(wctomb, tc)
16457718be8SEnji Cooper {
16557718be8SEnji Cooper 	struct test *t;
16657718be8SEnji Cooper 
16757718be8SEnji Cooper 	(void)printf("Checking wctomb()\n");
16857718be8SEnji Cooper 
16957718be8SEnji Cooper 	for (t = &tests[0]; t->data != NULL; ++t)
17057718be8SEnji Cooper 		h_wctomb(t, TC_WCTOMB);
17157718be8SEnji Cooper }
17257718be8SEnji Cooper 
17357718be8SEnji Cooper ATF_TC(wcrtomb_state);
ATF_TC_HEAD(wcrtomb_state,tc)17457718be8SEnji Cooper ATF_TC_HEAD(wcrtomb_state, tc)
17557718be8SEnji Cooper {
17657718be8SEnji Cooper 	atf_tc_set_md_var(tc, "descr",
17757718be8SEnji Cooper 		"Checks wcrtomb(3) (using state object)");
17857718be8SEnji Cooper }
ATF_TC_BODY(wcrtomb_state,tc)17957718be8SEnji Cooper ATF_TC_BODY(wcrtomb_state, tc)
18057718be8SEnji Cooper {
18157718be8SEnji Cooper 	struct test *t;
18257718be8SEnji Cooper 
18357718be8SEnji Cooper 	(void)printf("Checking wcrtomb() (with state object)\n");
18457718be8SEnji Cooper 
18557718be8SEnji Cooper 	for (t = &tests[0]; t->data != NULL; ++t)
18657718be8SEnji Cooper 		h_wctomb(t, TC_WCRTOMB_ST);
18757718be8SEnji Cooper }
18857718be8SEnji Cooper 
18957718be8SEnji Cooper ATF_TC(wcrtomb);
ATF_TC_HEAD(wcrtomb,tc)19057718be8SEnji Cooper ATF_TC_HEAD(wcrtomb, tc)
19157718be8SEnji Cooper {
19257718be8SEnji Cooper 	atf_tc_set_md_var(tc, "descr",
19357718be8SEnji Cooper 		"Checks wcrtomb(3) (using internal state)");
19457718be8SEnji Cooper }
ATF_TC_BODY(wcrtomb,tc)19557718be8SEnji Cooper ATF_TC_BODY(wcrtomb, tc)
19657718be8SEnji Cooper {
19757718be8SEnji Cooper 	struct test *t;
19857718be8SEnji Cooper 
19957718be8SEnji Cooper 	(void)printf("Checking wcrtomb() (using internal state)\n");
20057718be8SEnji Cooper 
20157718be8SEnji Cooper 	for (t = &tests[0]; t->data != NULL; ++t)
20257718be8SEnji Cooper 		h_wctomb(t, TC_WCRTOMB);
20357718be8SEnji Cooper }
20457718be8SEnji Cooper 
ATF_TP_ADD_TCS(tp)20557718be8SEnji Cooper ATF_TP_ADD_TCS(tp)
20657718be8SEnji Cooper {
20757718be8SEnji Cooper 	ATF_TP_ADD_TC(tp, wctomb);
20857718be8SEnji Cooper 	ATF_TP_ADD_TC(tp, wcrtomb);
20957718be8SEnji Cooper 	ATF_TP_ADD_TC(tp, wcrtomb_state);
21057718be8SEnji Cooper 
21157718be8SEnji Cooper 	return atf_no_error();
21257718be8SEnji Cooper }
213