mirror of
git://sourceware.org/git/glibc.git
synced 2024-11-21 01:12:26 +08:00
0e16ecfa1e
* locale/programs/ld-ctype.c (ctype_finish): Take all characters from the input charset into account when generating the hash table. (allocate_arrays): Correct setting default width. Not all empty slots in the table are filled, only those not covert explicitly by the locale description and in the charset. * stdio-common/vfscanf.c: Make sure to always return WEOF and EOF for wide character version. For %C handling, test correct pointer variable for NULL. * wcsmbs/wctob.c: Handle WEOF special. * wcsmbs/wcwidth.h: 0xff in width array means invalid character. * wctype/wctype.h: Protect gcc-isms with __extension__. Avoid always-true test to avoid warning.
85 lines
1.7 KiB
C
85 lines
1.7 KiB
C
/*-------------------------------------------------------------------------------------*/
|
|
/* 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,
|
|
ws1[i], i, 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;
|
|
}
|