1 // { dg-require-namedlocale "en_US" }
2 // { dg-require-namedlocale "fr_FR" }
3 // { dg-require-namedlocale "de_DE" }
5 // 2001-08-15 Benjamin Kosnik <bkoz@redhat.com>
7 // Copyright (C) 2001-2013 Free Software Foundation, Inc.
9 // This file is part of the GNU ISO C++ Library. This library is free
10 // software; you can redistribute it and/or modify it under the
11 // terms of the GNU General Public License as published by the
12 // Free Software Foundation; either version 3, or (at your option)
15 // This library is distributed in the hope that it will be useful,
16 // but WITHOUT ANY WARRANTY; without even the implied warranty of
17 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 // GNU General Public License for more details.
20 // You should have received a copy of the GNU General Public License along
21 // with this library; see the file COPYING3. If not see
22 // <http://www.gnu.org/licenses/>.
24 // 22.2.4.1.1 collate members
27 #include <testsuite_hooks.h>
32 typedef std::collate
<char>::string_type string_type
;
34 bool test
__attribute__((unused
)) = true;
37 locale loc_c
= locale::classic();
38 locale loc_us
= locale("en_US");
39 locale loc_fr
= locale("fr_FR");
40 locale loc_de
= locale("de_DE");
41 VERIFY( loc_c
!= loc_de
);
42 VERIFY( loc_us
!= loc_fr
);
43 VERIFY( loc_us
!= loc_de
);
44 VERIFY( loc_de
!= loc_fr
);
46 // cache the collate facets
47 const collate
<char>& coll_de
= use_facet
<collate
<char> >(loc_de
);
49 // long hash(const charT*, const charT*) cosnt
50 const char* strlit3
= "Äuglein Augment"; // "C" == "Augment Äuglein"
51 const char* strlit4
= "Base baß Baß Bast"; // "C" == "Base baß Baß Bast"
55 int size3
= char_traits
<char>::length(strlit3
) - 1;
56 int size4
= char_traits
<char>::length(strlit4
) - 1;
58 string_type str3
= coll_de
.transform(strlit3
, strlit3
+ size3
);
59 string_type str4
= coll_de
.transform(strlit4
, strlit4
+ size4
);
60 i1
= str3
.compare(str4
);
61 i2
= coll_de
.compare(strlit3
, strlit3
+ size3
, strlit4
, strlit4
+ size4
);
63 VERIFY ( i1
* i2
> 0 );