Commit faf81b1a by Benjamin Kosnik Committed by Benjamin Kosnik

9780-2.cc: Add test for "C" locale, add sanity checks in case of grouping.

2011-12-15  Benjamin Kosnik  <bkoz@redhat.com>

        * testsuite/22_locale/num_put/put/char/9780-2.cc: Add test for "C"
        locale, add sanity checks in case of grouping.

From-SVN: r182385
parent a3fd80ea
2011-12-15 Benjamin Kosnik <bkoz@redhat.com>
* testsuite/22_locale/num_put/put/char/9780-2.cc: Add test for "C"
locale, add sanity checks in case of grouping.
2011-12-15 Jonathan Wakely <jwakely.gcc@gmail.com> 2011-12-15 Jonathan Wakely <jwakely.gcc@gmail.com>
PR libstdc++/51540 PR libstdc++/51540
......
// { dg-require-namedlocale "de_DE" } // { dg-require-namedlocale "de_DE" }
// { dg-require-namedlocale "es_ES" } // { dg-require-namedlocale "es_ES" }
// Copyright (C) 2004, 2005, 2009 Free Software Foundation, Inc. // Copyright (C) 2004, 2005, 2009, 2011 Free Software Foundation, Inc.
// //
// This file is part of the GNU ISO C++ Library. This library is free // This file is part of the GNU ISO C++ Library. This library is free
// software; you can redistribute it and/or modify it under the // software; you can redistribute it and/or modify it under the
...@@ -22,23 +22,60 @@ ...@@ -22,23 +22,60 @@
#include <locale> #include <locale>
#include <testsuite_hooks.h> #include <testsuite_hooks.h>
int main() // Make sure that formatted output uses the locale in the output stream.
using namespace std;
locale l1 = locale("de_DE");
const num_put<char>& np = use_facet<num_put<char> >(l1);
const numpunct<char>& npunct = use_facet<numpunct<char> >(l1);
void test01()
{ {
using namespace std; bool test __attribute__((unused)) = true;
locale l2 = locale("C");
const numpunct<char>& npunct2 = use_facet<numpunct<char> >(l2);
char c = npunct2.thousands_sep();
string s = npunct2.grouping();
ostringstream oss;
oss.imbue(l2);
long l = 1234567890;
np.put(oss.rdbuf(), oss, ' ', l);
string res = oss.str();
VERIFY( res == "1234567890" );
}
void test02()
{
bool test __attribute__((unused)) = true; bool test __attribute__((unused)) = true;
locale l1 = locale("de_DE");
locale l2 = locale("es_ES"); locale l2 = locale("es_ES");
const numpunct<char>& npunct3 = use_facet<numpunct<char> >(l2);
const num_put<char>& np = use_facet<num_put<char> >(l1); char c = npunct3.thousands_sep();
string s = npunct3.grouping();
ostringstream oss; ostringstream oss;
oss.imbue(l2); oss.imbue(l2);
long l = 1234567890; long l = 1234567890;
np.put(oss.rdbuf(), oss, ' ', l); // 1234567890 np.put(oss.rdbuf(), oss, ' ', l);
string res = oss.str(); string res = oss.str();
VERIFY( res == "1234567890" );
if (!s.empty())
VERIFY( res == "1.234.567.890" );
else
VERIFY( res == "1234567890" );
}
int main()
{
// Sanity check.
char c = npunct.thousands_sep();
string s = npunct.grouping();
test01();
test02();
return 0; return 0;
} }
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment