//===----------------------------------------------------------------------===// // // The LLVM Compiler Infrastructure // // This file is dual licensed under the MIT and the University of Illinois Open // Source Licenses. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// // // template locale combine(const locale& other) const; #include #include #include int new_called = 0; void* operator new(std::size_t s) throw(std::bad_alloc) { ++new_called; return std::malloc(s); } void operator delete(void* p) throw() { --new_called; std::free(p); } void check(const std::locale& loc) { assert(std::has_facet >(loc)); assert(std::has_facet >(loc)); assert(std::has_facet >(loc)); assert(std::has_facet >(loc)); assert((std::has_facet >(loc))); assert((std::has_facet >(loc))); assert((std::has_facet >(loc))); assert((std::has_facet >(loc))); assert((std::has_facet >(loc))); assert((std::has_facet >(loc))); assert((std::has_facet >(loc))); assert((std::has_facet >(loc))); assert((std::has_facet >(loc))); assert((std::has_facet >(loc))); assert((std::has_facet >(loc))); assert((std::has_facet >(loc))); assert((std::has_facet >(loc))); assert((std::has_facet >(loc))); assert((std::has_facet >(loc))); assert((std::has_facet >(loc))); assert((std::has_facet >(loc))); assert((std::has_facet >(loc))); assert((std::has_facet >(loc))); assert((std::has_facet >(loc))); assert((std::has_facet >(loc))); assert((std::has_facet >(loc))); } struct my_facet : public std::locale::facet { int test() const {return 5;} static std::locale::id id; }; std::locale::id my_facet::id; int main() { { { std::locale loc; std::locale loc2(loc, new my_facet); std::locale loc3 = loc.combine(loc2); check(loc3); assert(loc3.name() == "*"); assert((std::has_facet(loc3))); const my_facet& f = std::use_facet(loc3); assert(f.test() == 5); } assert(new_called == 0); } { { std::locale loc; std::locale loc2; try { std::locale loc3 = loc.combine(loc2); assert(false); } catch (std::runtime_error&) { } } assert(new_called == 0); } }