/* WCSCAT: wchar_t *wcscat (wchar_t *ws1, const wchar_t *ws2); */ #define TST_FUNCTION wcscat #include "tsp_common.c" #include "dat_wcscat.c" int tst_wcscat (FILE * fp, int debug_flg) { TST_DECL_VARS (wchar_t *); wchar_t *ws1, *ws2, *ws_ex; int i, err; TST_DO_TEST (wcscat) { TST_HEAD_LOCALE (wcscat, S_WCSCAT); TST_DO_REC (wcscat) { TST_GET_ERRET (wcscat); ws1 = TST_INPUT (wcscat).ws1; /* external value: size WCSSIZE */ ws2 = TST_INPUT (wcscat).ws2; TST_CLEAR_ERRNO; ret = wcscat (ws1, ws2); TST_SAVE_ERRNO; TST_IF_RETURN (S_WCSCAT) { if (ret == ws1) { Result (C_SUCCESS, S_WCSCAT, CASE_3, MS_PASSED); } else { err_count++; Result (C_FAILURE, S_WCSCAT, CASE_3, "the return address may not be correct"); } } /* function specific test cases here */ if (ret == ws1) { ws_ex = TST_EXPECT (wcscat).ws; for (err = 0, i = 0; (ws1[i] != 0L || ws_ex[i] != 0L) && i < WCSSIZE; i++) { if (debug_flg) { fprintf (stdout, "tst_wcscat() : ws1[%d] = 0x%lx\n", i, (unsigned long int) ws1[i]); } if (ws1[i] != ws_ex[i]) { err++; err_count++; Result (C_FAILURE, S_WCSCAT, CASE_4, "concatinated string is different from an " "expected string"); break; } } if (!err) { Result (C_SUCCESS, S_WCSCAT, CASE_4, MS_PASSED); } } } } return err_count; }