/* STRCOLL: int strcoll (const char *s1, const char *s2) */ #define TST_FUNCTION strcoll #include "tsp_common.c" #include "dat_strcoll.c" int tst_strcoll (FILE * fp, int debug_flg) { TST_DECL_VARS (int); const char *s1, *s2; TST_DO_TEST (strcoll) { TST_HEAD_LOCALE (strcoll, S_STRCOLL); TST_DO_REC (strcoll) { TST_GET_ERRET (strcoll); s1 = TST_INPUT (strcoll).s1; s2 = TST_INPUT (strcoll).s2; TST_CLEAR_ERRNO; ret = strcoll (s1, s2); TST_SAVE_ERRNO; if (debug_flg) { fprintf (stdout, "strcoll() [ %s : %d ] ret = %d\n", locale, rec + 1, ret); fprintf (stdout, " errno = %d\n", errno_save); fprintf (stdout, " LC_COLLATE = %s\n", (setlocale (LC_COLLATE, NULL)) ? setlocale (LC_COLLATE, NULL) : ""); } TST_IF_RETURN (S_STRCOLL) { if (ret_exp == +1) { if (ret > 0) { Result (C_SUCCESS, S_STRCOLL, CASE_3, MS_PASSED); } else { err_count++; Result (C_FAILURE, S_STRCOLL, CASE_3, "the return value should be greater than 0," " but is not ..."); } } else if (ret_exp == -1) { if (ret < 0) { Result (C_SUCCESS, S_STRCOLL, CASE_3, MS_PASSED); } else { err_count++; Result (C_FAILURE, S_STRCOLL, CASE_3, "the return value should less than 0, but not ..."); } } else if (ret_exp != 0) { if (debug_flg) { fprintf (stderr, "*** Warning *** : tst_strcoll : " "(check the test data); should set ret_flg=1" " to check a return value"); } warn_count++; Result (C_INVALID, S_WCSCHR, CASE_3, "(check the test data); " "should set ret_flg=1 to check a return value"); } } } } return err_count; }