123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778 |
- /*
- 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;
- }
|