1 // 2001-08-15 Benjamin Kosnik <bkoz@redhat.com>
3 // Copyright (C) 2001, 2002, 2003 Free Software Foundation
5 // This file is part of the GNU ISO C++ Library. This library is free
6 // software; you can redistribute it and/or modify it under the
7 // terms of the GNU General Public License as published by the
8 // Free Software Foundation; either version 2, or (at your option)
11 // This library is distributed in the hope that it will be useful,
12 // but WITHOUT ANY WARRANTY; without even the implied warranty of
13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 // GNU General Public License for more details.
16 // You should have received a copy of the GNU General Public License along
17 // with this library; see the file COPYING. If not, write to the Free
18 // Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
21 // 22.2.4.1.1 collate members
23 // Doesn't work due to use of literal ISO8859.1 characters. PR 11439
24 // { dg-do compile { xfail *-*-* } } should be run
25 // { dg-excess-errors "" }
28 #include <testsuite_hooks.h>
30 // Check German "de_DE" locale.
34 typedef std::collate
<wchar_t>::string_type string_type
;
35 bool test
__attribute__((unused
)) = true;
38 locale loc_c
= locale::classic();
39 locale loc_us
= __gnu_test::try_named_locale("en_US");
40 locale loc_fr
= __gnu_test::try_named_locale("fr_FR");
41 locale loc_de
= __gnu_test::try_named_locale("de_DE");
42 VERIFY( loc_c
!= loc_de
);
43 VERIFY( loc_us
!= loc_fr
);
44 VERIFY( loc_us
!= loc_de
);
45 VERIFY( loc_de
!= loc_fr
);
47 // cache the collate facets
48 const collate
<wchar_t>& coll_de
= use_facet
<collate
<wchar_t> >(loc_de
);
50 // long hash(const charT*, const charT*) cosnt
51 const wchar_t* strlit3
= L
"Äuglein Augment"; // "C" == "Augment Äuglein"
52 const wchar_t* strlit4
= L
"Base baß Baß Bast"; // "C" == "Base baß Baß Bast"
56 int size3
= char_traits
<wchar_t>::length(strlit4
) - 1;
57 int size4
= char_traits
<wchar_t>::length(strlit3
) - 1;
59 l1
= coll_de
.hash(strlit3
, strlit3
+ size3
);
60 l2
= coll_de
.hash(strlit3
, strlit3
+ size3
- 1);
62 l1
= coll_de
.hash(strlit3
, strlit3
+ size3
);
63 l2
= coll_de
.hash(strlit4
, strlit4
+ size4
);