1 /*
2 WCSCAT: wchar_t *wcscat (wchar_t *ws1, const wchar_t *ws2);
3 */
4
5 #define TST_FUNCTION wcscat
6
7 #include "tsp_common.c"
8 #include "dat_wcscat.c"
9
10 int
tst_wcscat(FILE * fp,int debug_flg)11 tst_wcscat (FILE * fp, int debug_flg)
12 {
13 TST_DECL_VARS (wchar_t *);
14 wchar_t *ws1, *ws2, *ws_ex;
15 int i, err;
16
17 TST_DO_TEST (wcscat)
18 {
19 TST_HEAD_LOCALE (wcscat, S_WCSCAT);
20 TST_DO_REC (wcscat)
21 {
22 TST_GET_ERRET (wcscat);
23 ws1 = TST_INPUT (wcscat).ws1; /* external value: size WCSSIZE */
24 ws2 = TST_INPUT (wcscat).ws2;
25
26 TST_CLEAR_ERRNO;
27 ret = wcscat (ws1, ws2);
28 TST_SAVE_ERRNO;
29
30 TST_IF_RETURN (S_WCSCAT)
31 {
32 if (ret == ws1)
33 {
34 Result (C_SUCCESS, S_WCSCAT, CASE_3, MS_PASSED);
35 }
36 else
37 {
38 err_count++;
39 Result (C_FAILURE, S_WCSCAT, CASE_3,
40 "the return address may not be correct");
41 }
42 }
43
44 /* function specific test cases here */
45
46 if (ret == ws1)
47 {
48 ws_ex = TST_EXPECT (wcscat).ws;
49 for (err = 0, i = 0;
50 (ws1[i] != 0L || ws_ex[i] != 0L) && i < WCSSIZE; i++)
51 {
52 if (debug_flg)
53 {
54 fprintf (stdout, "tst_wcscat() : ws1[%d] = 0x%lx\n", i,
55 (unsigned long int) ws1[i]);
56 }
57
58 if (ws1[i] != ws_ex[i])
59 {
60 err++;
61 err_count++;
62 Result (C_FAILURE, S_WCSCAT, CASE_4,
63 "concatinated string is different from an "
64 "expected string");
65 break;
66 }
67 }
68
69 if (!err)
70 {
71 Result (C_SUCCESS, S_WCSCAT, CASE_4, MS_PASSED);
72 }
73 }
74 }
75 }
76
77 return err_count;
78 }
79