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
|
/*
WCSTOD: double wcstod (wchar_t *np, const wchar_t **endp);
*/
#define TST_FUNCTION wcstod
#include "tsp_common.c"
#include "dat_wcstod.c"
int
tst_wcstod (FILE * fp, int debug_flg)
{
TST_DECL_VARS (double);
wchar_t *np, *endp, fwc;
double val;
TST_DO_TEST (wcstod)
{
TST_HEAD_LOCALE (wcstod, S_WCSTOD);
TST_DO_REC (wcstod)
{
TST_GET_ERRET (wcstod);
np = TST_INPUT (wcstod).np;
TST_CLEAR_ERRNO;
ret = wcstod (np, &endp);
TST_SAVE_ERRNO;
if (debug_flg)
{
fprintf (stdout, "wcstod() [ %s : %d ] ret = %f\n", locale,
rec + 1, ret);
fprintf (stdout, " *endp = 0x%lx\n",
(unsigned long int) *endp);
}
TST_IF_RETURN (S_WCSTOD)
{
if (ret != 0)
{
val = ret - TST_EXPECT (wcstod).val;
if (TST_ABS (val) < TST_DBL_EPS)
{
Result (C_SUCCESS, S_WCSTOD, CASE_3, MS_PASSED);
}
else
{
err_count++;
Result (C_FAILURE, S_WCSTOD, CASE_3, "return value is wrong");
}
}
}
fwc = TST_EXPECT (wcstod).fwc;
if (fwc == *endp)
{
Result (C_SUCCESS, S_WCSTOD, CASE_4, MS_PASSED);
}
else
{
err_count++;
Result (C_FAILURE, S_WCSTOD, CASE_4, "a final wc is wrong.");
}
}
}
return err_count;
}
|