X-Git-Url: https://oss.titaniummirror.com/gitweb?a=blobdiff_plain;f=libstdc%2B%2B-v3%2Ftestsuite%2F22_locale%2Flocale%2Fcons%2F6.cc;fp=libstdc%2B%2B-v3%2Ftestsuite%2F22_locale%2Flocale%2Fcons%2F6.cc;h=c2518420386773aa6402e06d5d4c9a2c4122cf7c;hb=6fed43773c9b0ce596dca5686f37ac3fc0fa11c0;hp=0000000000000000000000000000000000000000;hpb=27b11d56b743098deb193d510b337ba22dc52e5c;p=msp430-gcc.git diff --git a/libstdc++-v3/testsuite/22_locale/locale/cons/6.cc b/libstdc++-v3/testsuite/22_locale/locale/cons/6.cc new file mode 100644 index 00000000..c2518420 --- /dev/null +++ b/libstdc++-v3/testsuite/22_locale/locale/cons/6.cc @@ -0,0 +1,58 @@ +// 2001-01-19 Benjamin Kosnik + +// Copyright (C) 2001, 2003, 2009 Free Software Foundation +// +// 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 +// terms of the GNU General Public License as published by the +// Free Software Foundation; either version 3, or (at your option) +// any later version. + +// This library is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +// GNU General Public License for more details. + +// You should have received a copy of the GNU General Public License along +// with this library; see the file COPYING3. If not see +// . + +// 22.1.1 - Class locale [lib.locale] + +#include +#include +#include + +// creating unnamed locales 1 using new + combine +void +test01() +{ + using namespace std; + bool test __attribute__((unused)) = true; + const string name_c("C"); + const string str_unnamed("*"); + string str; + + // construct a locale object with the specialized facet. + locale loc_c = locale::classic(); + locale loc_1(locale::classic(), new numpunct); + + // check names + VERIFY( loc_c.name() == name_c ); + VERIFY( loc_1.name() == str_unnamed ); + + // sanity check the constructed locale has the specialized facet. + VERIFY( has_facet >(loc_1) ); + VERIFY( has_facet >(loc_c) ); + + // attempt to re-synthesize classic locale + locale loc_2 = loc_1.combine >(loc_c); + VERIFY( loc_2.name() == str_unnamed ); + VERIFY( loc_2 != loc_c ); +} + +int main() +{ + test01(); + return 0; +}