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
24 // { dg-xfail-if "" { "*-*-hpux11.23" } { "*" } { "" } } */
25 // { dg-options "-finput-charset=ISO8859-1" }
26 // { dg-require-iconv "ISO8859-1" }
29 #include <testsuite_hooks.h>
31 // Check German "de_DE" locale.
35 typedef std::collate<wchar_t>::string_type string_type;
36 bool test __attribute__((unused)) = true;
39 locale loc_c = locale::classic();
40 locale loc_us = __gnu_test::try_named_locale("en_US");
41 locale loc_fr = __gnu_test::try_named_locale("fr_FR");
42 locale loc_de = __gnu_test::try_named_locale("de_DE");
43 VERIFY( loc_c != loc_de );
44 VERIFY( loc_us != loc_fr );
45 VERIFY( loc_us != loc_de );
46 VERIFY( loc_de != loc_fr );
48 // cache the collate facets
49 const collate<wchar_t>& coll_de = use_facet<collate<wchar_t> >(loc_de);
51 // long hash(const charT*, const charT*) cosnt
52 const wchar_t* strlit3 = L"Äuglein Augment"; // "C" == "Augment Äuglein"
53 const wchar_t* strlit4 = L"Base baß Baß Bast"; // "C" == "Base baß Baß Bast"
57 int size3 = char_traits<wchar_t>::length(strlit4) - 1;
58 int size4 = char_traits<wchar_t>::length(strlit3) - 1;
60 l1 = coll_de.hash(strlit3, strlit3 + size3);
61 l2 = coll_de.hash(strlit3, strlit3 + size3 - 1);
63 l1 = coll_de.hash(strlit3, strlit3 + size3);
64 l2 = coll_de.hash(strlit4, strlit4 + size4);