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 #include <testsuite_hooks.h>
26 // Check German "de_DE" locale.
30 typedef std::collate
<wchar_t>::string_type string_type
;
35 locale loc_c
= locale::classic();
36 locale
loc_us("en_US");
37 locale
loc_fr("fr_FR");
38 locale
loc_de("de_DE");
39 VERIFY( loc_c
!= loc_de
);
40 VERIFY( loc_us
!= loc_fr
);
41 VERIFY( loc_us
!= loc_de
);
42 VERIFY( loc_de
!= loc_fr
);
44 // cache the collate facets
45 const collate
<wchar_t>& coll_c
= use_facet
<collate
<wchar_t> >(loc_c
);
46 const collate
<wchar_t>& coll_us
= use_facet
<collate
<wchar_t> >(loc_us
);
47 const collate
<wchar_t>& coll_fr
= use_facet
<collate
<wchar_t> >(loc_fr
);
48 const collate
<wchar_t>& coll_de
= use_facet
<collate
<wchar_t> >(loc_de
);
50 // int compare(const charT*, const charT*, const charT*, const charT*) const
52 const wchar_t* strlit1
= L
"monkey picked tikuanyin oolong";
53 const wchar_t* strlit2
= L
"imperial tea court green oolong";
54 const wchar_t* strlit3
= L
"Äuglein Augment"; // "C" == "Augment Äuglein"
55 const wchar_t* strlit4
= L
"Base baß Baß Bast"; // "C" == "Base baß Baß Bast"
59 int size1
= char_traits
<wchar_t>::length(strlit1
) - 1;
60 int size2
= char_traits
<wchar_t>::length(strlit2
) - 1;
61 int size3
= char_traits
<wchar_t>::length(strlit3
) - 1;
62 int size4
= char_traits
<wchar_t>::length(strlit4
) - 1;
64 i1
= coll_de
.compare(strlit3
, strlit3
+ size3
, strlit3
, strlit3
+ 7);
66 i1
= coll_de
.compare(strlit3
, strlit3
+ 7, strlit3
, strlit3
+ size1
);
68 i1
= coll_de
.compare(strlit3
, strlit3
+ 7, strlit3
, strlit3
+ 7);
71 i1
= coll_de
.compare(strlit3
, strlit3
+ 6, strlit3
+ 8, strlit3
+ 14);
74 i2
= coll_de
.compare(strlit4
, strlit4
+ size4
, strlit4
, strlit4
+ 13);
76 i2
= coll_de
.compare(strlit4
, strlit4
+ 13, strlit4
, strlit4
+ size4
);
78 i2
= coll_de
.compare(strlit4
, strlit4
+ size4
, strlit4
, strlit4
+ size4
);