12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485 |
- /*-------------------------------------------------------------------------------------*/
- /* WCSCPY: wchar_t *wcscpy( wchar_t *ws1, const wchar_t *ws2 ) */
- /*-------------------------------------------------------------------------------------*/
- #define TST_FUNCTION wcscpy
- #include "tsp_common.c"
- #include "dat_wcscpy.c"
- int
- tst_wcscpy (FILE * fp, int debug_flg)
- {
- TST_DECL_VARS (wchar_t *);
- wchar_t ws1[WCSSIZE], *ws2, *ws_ex;
- int err, i;
- TST_DO_TEST (wcscpy)
- {
- TST_HEAD_LOCALE (wcscpy, S_WCSCPY);
- TST_DO_REC (wcscpy)
- {
- TST_GET_ERRET (wcscpy);
- ws2 = TST_INPUT (wcscpy).ws; /* external value: size WCSSIZE */
- ret = wcscpy (ws1, ws2);
- TST_IF_RETURN (S_WCSCPY)
- {
- if (ret == ws1)
- {
- Result (C_SUCCESS, S_WCSCPY, CASE_3, MS_PASSED);
- }
- else
- {
- err_count++;
- Result (C_FAILURE, S_WCSCPY, CASE_3,
- "the return address may not be correct");
- }
- }
- if (ret == ws1)
- {
- ws_ex = TST_EXPECT (wcscpy).ws;
- for (err = 0, i = 0;
- (ws1[i] != 0L || ws_ex[i] != 0L) && i < WCSSIZE; i++)
- {
- if (debug_flg)
- {
- fprintf (stderr,
- "ws1[ %d ] = 0x%lx <-> wx_ex[ %d ] = 0x%lx\n", i,
- (unsigned long int) ws1[i], i,
- (unsigned long int) ws_ex[i]);
- }
- if (ws1[i] != ws_ex[i])
- {
- err++;
- err_count++;
- Result (C_FAILURE, S_WCSCPY, CASE_4,
- "copied string is different from an"
- " expected string");
- break;
- }
- }
- if (!err)
- {
- Result (C_SUCCESS, S_WCSCPY, CASE_4, MS_PASSED);
- }
- if (ws1[i] == 0L)
- {
- Result (C_SUCCESS, S_WCSCPY, CASE_5, MS_PASSED);
- }
- else
- {
- err_count++;
- Result (C_FAILURE, S_WCSCPY, CASE_5,
- "copied string is not null-terminated");
- }
- }
- }
- }
- return err_count;
- }
|