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()29void 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()75void 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()91int main() 92 { 93 test01(); 94 test02(); 95 96 return 0; 97 } 98