|
Packit |
6c4009 |
/*
|
|
Packit |
6c4009 |
MBRTOWC: size_t mbrtowc (wchar_t *pwc, const char *s, size_t n,
|
|
Packit |
6c4009 |
mbstate_t *ps)
|
|
Packit |
6c4009 |
*/
|
|
Packit |
6c4009 |
|
|
Packit |
6c4009 |
#define TST_FUNCTION mbrtowc
|
|
Packit |
6c4009 |
|
|
Packit |
6c4009 |
#include "tsp_common.c"
|
|
Packit |
6c4009 |
#include "dat_mbrtowc.c"
|
|
Packit |
6c4009 |
|
|
Packit |
6c4009 |
|
|
Packit |
6c4009 |
int
|
|
Packit |
6c4009 |
tst_mbrtowc (FILE * fp, int debug_flg)
|
|
Packit |
6c4009 |
{
|
|
Packit |
6c4009 |
TST_DECL_VARS (size_t);
|
|
Packit |
6c4009 |
char w_flg, s_flg;
|
|
Packit |
6c4009 |
char *s;
|
|
Packit |
6c4009 |
size_t n;
|
|
Packit |
6c4009 |
char t_flg;
|
|
Packit |
6c4009 |
static mbstate_t t = { 0 };
|
|
Packit |
6c4009 |
mbstate_t *pt;
|
|
Packit |
6c4009 |
wchar_t wc, *pwc, wc_ex;
|
|
Packit |
6c4009 |
|
|
Packit |
6c4009 |
TST_DO_TEST (mbrtowc)
|
|
Packit |
6c4009 |
{
|
|
Packit |
6c4009 |
TST_HEAD_LOCALE (mbrtowc, S_MBRTOWC);
|
|
Packit |
6c4009 |
TST_DO_REC (mbrtowc)
|
|
Packit |
6c4009 |
{
|
|
Packit |
6c4009 |
if (mbrtowc (NULL, "", 0, &t) != -2)
|
|
Packit |
6c4009 |
{
|
|
Packit |
6c4009 |
err_count++;
|
|
Packit |
6c4009 |
Result (C_FAILURE, S_MBRTOWC, CASE_3,
|
|
Packit |
6c4009 |
"Initialization failed - skipping this test case.");
|
|
Packit |
6c4009 |
continue;
|
|
Packit |
6c4009 |
}
|
|
Packit |
6c4009 |
|
|
Packit |
6c4009 |
TST_DO_SEQ (MBRTOWC_SEQNUM)
|
|
Packit |
6c4009 |
{
|
|
Packit |
6c4009 |
TST_GET_ERRET_SEQ (mbrtowc);
|
|
Packit |
6c4009 |
w_flg = TST_INPUT_SEQ (mbrtowc).w_flg;
|
|
Packit |
6c4009 |
s_flg = TST_INPUT_SEQ (mbrtowc).s_flg;
|
|
Packit |
6c4009 |
s = TST_INPUT_SEQ (mbrtowc).s;
|
|
Packit |
6c4009 |
n = TST_INPUT_SEQ (mbrtowc).n;
|
|
Packit |
6c4009 |
t_flg = TST_INPUT_SEQ (mbrtowc).t_flg;
|
|
Packit |
6c4009 |
pwc = (w_flg == 0) ? NULL : &wc;
|
|
Packit |
6c4009 |
|
|
Packit |
6c4009 |
if (s_flg == 0)
|
|
Packit |
6c4009 |
{
|
|
Packit |
6c4009 |
s = NULL;
|
|
Packit |
6c4009 |
}
|
|
Packit |
6c4009 |
|
|
Packit |
6c4009 |
if (n == USE_MBCURMAX)
|
|
Packit |
6c4009 |
{
|
|
Packit |
6c4009 |
n = MB_CUR_MAX;
|
|
Packit |
6c4009 |
}
|
|
Packit |
6c4009 |
|
|
Packit |
6c4009 |
pt = (t_flg == 0) ? NULL : &t;
|
|
Packit |
6c4009 |
|
|
Packit |
6c4009 |
TST_CLEAR_ERRNO;
|
|
Packit |
6c4009 |
ret = mbrtowc (pwc, s, n, pt);
|
|
Packit |
6c4009 |
TST_SAVE_ERRNO;
|
|
Packit |
6c4009 |
|
|
Packit |
6c4009 |
if (debug_flg)
|
|
Packit |
6c4009 |
{
|
|
Packit |
6c4009 |
fprintf (stdout, "mbrtowc() [ %s : %d : %d ] ret = %zd\n",
|
|
Packit |
6c4009 |
locale, rec + 1, seq_num + 1, ret);
|
|
Packit |
6c4009 |
fprintf (stdout, " errno = %hd\n",
|
|
Packit |
6c4009 |
errno_save);
|
|
Packit |
6c4009 |
}
|
|
Packit |
6c4009 |
|
|
Packit |
6c4009 |
TST_IF_RETURN (S_MBRTOWC)
|
|
Packit |
6c4009 |
{
|
|
Packit |
6c4009 |
};
|
|
Packit |
6c4009 |
|
|
Packit |
6c4009 |
if (pwc == NULL || s == NULL || ret == (size_t) - 1
|
|
Packit |
6c4009 |
|| ret == (size_t) - 2)
|
|
Packit |
6c4009 |
{
|
|
Packit |
6c4009 |
continue;
|
|
Packit |
6c4009 |
}
|
|
Packit |
6c4009 |
|
|
Packit |
6c4009 |
wc_ex = TST_EXPECT_SEQ (mbrtowc).wc;
|
|
Packit |
6c4009 |
if (wc_ex == wc)
|
|
Packit |
6c4009 |
{
|
|
Packit |
6c4009 |
Result (C_SUCCESS, S_MBRTOWC, CASE_4, MS_PASSED);
|
|
Packit |
6c4009 |
}
|
|
Packit |
6c4009 |
else
|
|
Packit |
6c4009 |
{
|
|
Packit |
6c4009 |
err_count++;
|
|
Packit |
6c4009 |
Result (C_FAILURE, S_MBRTOWC, CASE_4,
|
|
Packit |
6c4009 |
"converted wc is different from an expected wc");
|
|
Packit |
6c4009 |
}
|
|
Packit |
6c4009 |
}
|
|
Packit |
6c4009 |
}
|
|
Packit |
6c4009 |
}
|
|
Packit |
6c4009 |
|
|
Packit |
6c4009 |
return err_count;
|
|
Packit |
6c4009 |
}
|