1 // 2001-01-24 Benjamin Kosnik  <bkoz@redhat.com>
2 
3 // Copyright (C) 2001 Free Software Foundation
4 //
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)
9 // any later version.
10 
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.
15 
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,
19 // USA.
20 
21 // 22.2.3.2 Template class numpunct_byname
22 
23 #include <locale>
24 #include <testsuite_hooks.h>
25 
26 // XXX This test is not working for non-glibc locale models.
27 // { dg-do run { xfail *-*-* } }
28 
test01()29 void test01()
30 {
31   using namespace std;
32 
33   bool test = true;
34   string str;
35 
36   locale loc_byname(locale::classic(), new numpunct_byname<char>("de_DE"));
37   str = loc_byname.name();
38 
39   locale loc_de("de_DE");
40   str = loc_de.name();
41 
42   locale loc_c = locale::classic();
43 
44   VERIFY( loc_de != loc_byname );
45 
46   // cache the numpunct facets
47   const numpunct<char>& nump_c = use_facet<numpunct<char> >(loc_c);
48   const numpunct<char>& nump_byname = use_facet<numpunct<char> >(loc_byname);
49   const numpunct<char>& nump_de = use_facet<numpunct<char> >(loc_de);
50 
51   // sanity check that the data match
52   char dp1 = nump_byname.decimal_point();
53   char th1 = nump_byname.thousands_sep();
54   string g1 = nump_byname.grouping();
55   string t1 = nump_byname.truename();
56   string f1 = nump_byname.falsename();
57 
58   char dp2 = nump_de.decimal_point();
59   char th2 = nump_de.thousands_sep();
60   string g2 = nump_de.grouping();
61   string t2 = nump_de.truename();
62   string f2 = nump_de.falsename();
63 
64   VERIFY( dp1 == dp2 );
65   VERIFY( th1 == th2 );
66   VERIFY( g1 == g2 );
67   VERIFY( t1 == t2 );
68   VERIFY( f1 == f2 );
69 
70   // ...and don't match "C"
71   char dp3 = nump_c.decimal_point();
72   VERIFY( dp1 != dp3 );
73 }
74 
test02()75 void test02()
76 {
77   using namespace std;
78 
79   bool test = true;
80 
81   locale loc_it("it_IT");
82 
83   const numpunct<char>& nump_it = use_facet<numpunct<char> >(loc_it);
84 
85   string g = nump_it.grouping();
86 
87   VERIFY( g == "" );
88 }
89 
90 
main()91 int main()
92 {
93   test01();
94   test02();
95 
96   return 0;
97 }
98