| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209 | /* *  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_en },    {      { /*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.  */    }  },#if 0  {    { 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.  */    }  },#else  {    { Tstrcoll, TST_LOC_ja_UTF8 },    {      { /*input.*/ { "\343\201\202\343\201\204\343\201\206\343\201\210\343\201\212",		     "\343\201\202\343\201\204\343\201\206\343\201\210\343\201\212" },  /* #1 */	/*expect*/ { 0,1,0,			      },      },      { /*input.*/ { "\343\201\202\343\201\204\343\201\206\343\201\210\343\201\212",		     "\343\201\202\343\201\204\343\202\223\343\201\210\343\201\212" },  /* #2 */	/*expect*/ { 0,0,-1,			      },      },      { /*input.*/ { "\343\201\202\343\201\204\343\202\223\343\201\210\343\201\212",		     "\343\201\202\343\201\204\343\201\206\343\201\210\343\201\212" },  /* #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.  */    }  },#endif  {    { Tstrcoll, TST_LOC_end }  }};
 |