1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
|
/*
MBRTOWC: size_t mbrtowc (wchar_t *pwc, const char *s, size_t n,
mbstate_t *ps)
*/
#define TST_FUNCTION mbrtowc
#include "tsp_common.c"
#include "dat_mbrtowc.c"
int
tst_mbrtowc (FILE * fp, int debug_flg)
{
TST_DECL_VARS (size_t);
char w_flg, s_flg;
char *s;
size_t n;
char t_flg;
static mbstate_t t = { 0 };
mbstate_t *pt;
wchar_t wc, *pwc, wc_ex;
TST_DO_TEST (mbrtowc)
{
TST_HEAD_LOCALE (mbrtowc, S_MBRTOWC);
TST_DO_REC (mbrtowc)
{
if (mbrtowc (NULL, "", 0, &t) != -2)
{
err_count++;
Result (C_FAILURE, S_MBRTOWC, CASE_3,
"Initialization failed - skipping this test case.");
continue;
}
TST_DO_SEQ (MBRTOWC_SEQNUM)
{
TST_GET_ERRET_SEQ (mbrtowc);
w_flg = TST_INPUT_SEQ (mbrtowc).w_flg;
s_flg = TST_INPUT_SEQ (mbrtowc).s_flg;
s = TST_INPUT_SEQ (mbrtowc).s;
n = TST_INPUT_SEQ (mbrtowc).n;
t_flg = TST_INPUT_SEQ (mbrtowc).t_flg;
pwc = (w_flg == 0) ? NULL : &wc;
if (s_flg == 0)
{
s = NULL;
}
if (n == USE_MBCURMAX)
{
n = MB_CUR_MAX;
}
pt = (t_flg == 0) ? NULL : &t;
TST_CLEAR_ERRNO;
ret = mbrtowc (pwc, s, n, pt);
TST_SAVE_ERRNO;
if (debug_flg)
{
fprintf (stdout, "mbrtowc() [ %s : %d : %d ] ret = %zd\n",
locale, rec + 1, seq_num + 1, ret);
fprintf (stdout, " errno = %hd\n",
errno_save);
}
TST_IF_RETURN (S_MBRTOWC)
{
};
if (pwc == NULL || s == NULL || ret == (size_t) - 1
|| ret == (size_t) - 2)
{
continue;
}
wc_ex = TST_EXPECT_SEQ (mbrtowc).wc;
if (wc_ex == wc)
{
Result (C_SUCCESS, S_MBRTOWC, CASE_4, MS_PASSED);
}
else
{
err_count++;
Result (C_FAILURE, S_MBRTOWC, CASE_4,
"converted wc is different from an expected wc");
}
}
}
}
return err_count;
}
|