mirror of
https://sourceware.org/git/glibc.git
synced 2025-01-15 05:20:05 +00:00
1cb990bc19
2003-01-03 Andreas Jaeger <aj@suse.de>, Jakub Jelinek <jakub@redhat.com> * resolv/res_libc.c: Provide declaration for __res_init_weak and reorder declarations. 2003-01-03 Art Haas <ahaas@airmail.net> * localedata/tests-mbwc/dat_iswalnum.c: Convert GCC extension initiailzer syntax to C99. * localedata/tests-mbwc/dat_iswalpha.c: Likewise. * localedata/tests-mbwc/dat_iswcntrl.c: Likewise. * localedata/tests-mbwc/dat_iswctype.c: Likewise. * localedata/tests-mbwc/dat_iswdigit.c: Likewise. * localedata/tests-mbwc/dat_iswgraph.c: Likewise. * localedata/tests-mbwc/dat_iswlower.c: Likewise. * localedata/tests-mbwc/dat_iswprint.c: Likewise. * localedata/tests-mbwc/dat_iswpunct.c: Likewise. * localedata/tests-mbwc/dat_iswspace.c: Likewise. * localedata/tests-mbwc/dat_iswupper.c: Likewise. * localedata/tests-mbwc/dat_iswxdigit.c: Likewise. * localedata/tests-mbwc/dat_mblen.c: Likewise. * localedata/tests-mbwc/dat_mbrlen.c: Likewise. * localedata/tests-mbwc/dat_mbrtowc.c: Likewise. * localedata/tests-mbwc/dat_mbsrtowcs.c: Likewise. * localedata/tests-mbwc/dat_mbstowcs.c: Likewise. * localedata/tests-mbwc/dat_mbtowc.c: Likewise. * localedata/tests-mbwc/dat_strcoll.c: Likewise. * localedata/tests-mbwc/dat_strfmon.c: Likewise. * localedata/tests-mbwc/dat_strxfrm.c: Likewise. * localedata/tests-mbwc/dat_swscanf.c: Likewise. * localedata/tests-mbwc/dat_towctrans.c: Likewise. * localedata/tests-mbwc/dat_towlower.c: Likewise. * localedata/tests-mbwc/dat_towupper.c: Likewise. * localedata/tests-mbwc/dat_wcrtomb.c: Likewise. * localedata/tests-mbwc/dat_wcscat.c: Likewise. * localedata/tests-mbwc/dat_wcschr.c: Likewise. * localedata/tests-mbwc/dat_wcscmp.c: Likewise. * localedata/tests-mbwc/dat_wcscoll.c: Likewise. * localedata/tests-mbwc/dat_wcscpy.c: Likewise. * localedata/tests-mbwc/dat_wcscspn.c: Likewise. * localedata/tests-mbwc/dat_wcslen.c: Likewise. * localedata/tests-mbwc/dat_wcsncat.c: Likewise. * localedata/tests-mbwc/dat_wcsncmp.c: Likewise. * localedata/tests-mbwc/dat_wcsncpy.c: Likewise. * localedata/tests-mbwc/dat_wcspbrk.c: Likewise. * localedata/tests-mbwc/dat_wcsrtombs.c: Likewise. * localedata/tests-mbwc/dat_wcsspn.c: Likewise. * localedata/tests-mbwc/dat_wcsstr.c: Likewise. * localedata/tests-mbwc/dat_wcstod.c: Likewise. * localedata/tests-mbwc/dat_wcstok.c: Likewise. * localedata/tests-mbwc/dat_wcstombs.c: Likewise. * localedata/tests-mbwc/dat_wcswidth.c: Likewise. * localedata/tests-mbwc/dat_wcsxfrm.c: Likewise. * localedata/tests-mbwc/dat_wctob.c: Likewise. * localedata/tests-mbwc/dat_wctomb.c: Likewise. * localedata/tests-mbwc/dat_wctrans.c: Likewise. * localedata/tests-mbwc/dat_wctype.c: Likewise. * localedata/tests-mbwc/dat_wcwidth.c: Likewise. 2003-01-03 Richard Henderson <rth@redhat.com> * sysdeps/unix/sysv/linux/alpha/sysdep.h (inline_syscall_r0_asm): New. (inline_syscall_r0_constraint): New. (inline_syscall[0-6]): Use them.
163 lines
4.5 KiB
C
163 lines
4.5 KiB
C
/*
|
|
* TEST SUITE FOR MB/WC FUNCTIONS IN C LIBRARY
|
|
*
|
|
* FILE: dat_strcoll.c
|
|
*
|
|
* STRCOLL: int strcoll (const char *s1, const char *s2);
|
|
*/
|
|
|
|
/*
|
|
NOTE:
|
|
|
|
If a return value is expected to be 0, set ret_flg=1 and the
|
|
expected value = 0. If a return value is expected to be a
|
|
positive/negative value, set ret_flg=0, and set the expected value
|
|
= +1/-1.
|
|
There is inconsistensy between tst_strcoll() and tst_wcscoll()(it
|
|
has cmp_flg) for input data. I'll fix it.
|
|
|
|
Assuming en_US to be en_US.ascii. (maybe, should be iso8859-1).
|
|
|
|
|
|
|
|
ASCII CODE : A,B,C, ... , a, b, c, ... B,a:-1 a,B:+1
|
|
DICTIONARY : A,a,B,b,C,c,.... a,B:-1 B,a:+1 */
|
|
|
|
TST_STRCOLL tst_strcoll_loc [] = {
|
|
{
|
|
{ Tstrcoll, TST_LOC_de },
|
|
{
|
|
{ /*input.*/ { "ÄBCDEFG", "ÄBCDEFG" }, /* #1 */
|
|
/*expect*/ { 0,1,0, },
|
|
},
|
|
{ /*input.*/ { "XX Ä XX", "XX B XX" }, /* #2 */
|
|
/*expect*/ { 0,0,-1, },
|
|
},
|
|
{ /*input.*/ { "XX B XX", "XX Ä XX" }, /* #3 */
|
|
/*expect*/ { 0,0,+1, },
|
|
},
|
|
{ /*input.*/ { "B", "a" }, /* #4 */
|
|
/*expect*/ { 0,0,+1, },
|
|
},
|
|
{ /*input.*/ { "a", "B" }, /* #5 */
|
|
/*expect*/ { 0,0,-1, },
|
|
},
|
|
{ /*input.*/ { "b", "A" }, /* #6 */
|
|
/*expect*/ { 0,0,+1, },
|
|
},
|
|
{ /*input.*/ { "A", "b" }, /* #7 */
|
|
/*expect*/ { 0,0,-1, },
|
|
},
|
|
{ /*input.*/ { "ä", "B" }, /* #8 */
|
|
/*expect*/ { 0,0,-1, },
|
|
},
|
|
{ /*input.*/ { "B", "ä" }, /* #9 */
|
|
/*expect*/ { 0,0,+1, },
|
|
},
|
|
{ .is_last = 1 } /* Last element. */
|
|
}
|
|
},
|
|
{
|
|
{ Tstrcoll, TST_LOC_enUS },
|
|
{
|
|
{ /*input.*/ { "ABCDEFG", "ABCDEFG" }, /* #1 */
|
|
/*expect*/ { 0,1,0, },
|
|
},
|
|
{ /*input.*/ { "XX a XX", "XX B XX" }, /* #2 */
|
|
/*expect*/ { 0,0,-1, },
|
|
},
|
|
{ /*input.*/ { "XX B XX", "XX a XX" }, /* #3 */
|
|
/*expect*/ { 0,0,+1, },
|
|
},
|
|
{
|
|
/* <WAIVER> */
|
|
/*input.*/ { "B", "a" }, /* #4 */
|
|
#ifdef SHOJI_IS_RIGHT
|
|
/*expect*/ { 0,0,-1, },
|
|
#else
|
|
/* XXX We are not testing the C locale. */
|
|
/*expect*/ { 0,0,+1, },
|
|
#endif
|
|
},
|
|
{
|
|
/* <WAIVER> */
|
|
/*input.*/ { "a", "B" }, /* #5 */
|
|
#ifdef SHOJI_IS_RIGHT
|
|
/*expect*/ { 0,0,+1, },
|
|
#else
|
|
/* XXX We are not testing the C locale. */
|
|
/*expect*/ { 0,0,-1, },
|
|
#endif
|
|
},
|
|
{ /*input.*/ { "b", "A" }, /* #6 */
|
|
/*expect*/ { 0,0,+1, },
|
|
},
|
|
{ /*input.*/ { "A", "b" }, /* #7 */
|
|
/*expect*/ { 0,0,-1, },
|
|
},
|
|
#ifdef NO_WAIVER
|
|
/* XXX I do not yet know whether strcoll really should reject
|
|
characters outside the multibyte character range. */
|
|
{
|
|
/* #8 */ /* <WAIVER> */
|
|
/*input.*/ { "\244\242\244\244\244\246\244\250\244\252", "ABCDEFG" },
|
|
/*expect*/ { EINVAL,0,0, },
|
|
},
|
|
{
|
|
/* #9 */ /* <WAIVER> */
|
|
/*input.*/ { "ABCZEFG", "\244\242\244\244\244\246\244\250\244\252" },
|
|
/*expect*/ { EINVAL,0,0, },
|
|
},
|
|
#endif
|
|
{ .is_last = 1 } /* Last element. */
|
|
}
|
|
},
|
|
{
|
|
{ Tstrcoll, TST_LOC_eucJP },
|
|
{
|
|
{ /*input.*/ { "\244\242\244\244\244\246\244\250\244\252",
|
|
"\244\242\244\244\244\246\244\250\244\252" }, /* #1 */
|
|
/*expect*/ { 0,1,0, },
|
|
},
|
|
{ /*input.*/ { "\244\242\244\244\244\246\244\250\244\252",
|
|
"\244\242\244\244\244\363\244\250\244\252" }, /* #2 */
|
|
/*expect*/ { 0,0,-1, },
|
|
},
|
|
{ /*input.*/ { "\244\242\244\244\244\363\244\250\244\252",
|
|
"\244\242\244\244\244\246\244\250\244\252" }, /* #3 */
|
|
/*expect*/ { 0,0,+1, },
|
|
},
|
|
{ /*input.*/ { "B", "a" }, /* #4 */
|
|
/*expect*/ { 0,0,-1, },
|
|
},
|
|
{ /*input.*/ { "a", "B" }, /* #5 */
|
|
/*expect*/ { 0,0,+1, },
|
|
},
|
|
{ /*input.*/ { "b", "A" }, /* #6 */
|
|
/*expect*/ { 0,0,+1, },
|
|
},
|
|
{ /*input.*/ { "A", "b" }, /* #7 */
|
|
/*expect*/ { 0,0,-1, },
|
|
},
|
|
#ifdef NO_WAIVER
|
|
/* XXX I do not yet know whether strcoll really should reject
|
|
characters outside the multibyte character range. */
|
|
{
|
|
/* <WAIVER> */
|
|
/*input.*/ { "\200\216\217", "ABCDEFG" }, /* #8 */
|
|
/*expect*/ { EINVAL,0,0, },
|
|
},
|
|
{
|
|
/* <WAIVER> */
|
|
/*input.*/ { "ABCZEFG", "\200\216\217" }, /* #9 */
|
|
/*expect*/ { EINVAL,0,0, },
|
|
},
|
|
#endif
|
|
{ .is_last = 1 } /* Last element. */
|
|
}
|
|
},
|
|
{
|
|
{ Tstrcoll, TST_LOC_end }
|
|
}
|
|
};
|