//===----------------------------------------------------------------------===// // // 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 , class Allocator = allocator > // class basic_stringstream // explicit basic_stringstream(const basic_string& str, // ios_base::openmode which = ios_base::out|ios_base::in); #include #include template struct NoDefaultAllocator : std::allocator { template struct rebind { using other = NoDefaultAllocator; }; NoDefaultAllocator(int id) : id(id) { } template NoDefaultAllocator(const NoDefaultAllocator& a) : id(a.id) { } int id; }; int main() { { std::stringstream ss(" 123 456 "); assert(ss.rdbuf() != 0); assert(ss.good()); assert(ss.str() == " 123 456 "); int i = 0; ss >> i; assert(i == 123); ss >> i; assert(i == 456); ss << i << ' ' << 123; assert(ss.str() == "456 1236 "); } { std::wstringstream ss(L" 123 456 "); assert(ss.rdbuf() != 0); assert(ss.good()); assert(ss.str() == L" 123 456 "); int i = 0; ss >> i; assert(i == 123); ss >> i; assert(i == 456); ss << i << ' ' << 123; assert(ss.str() == L"456 1236 "); } { // This is https://bugs.llvm.org/show_bug.cgi?id=33727 typedef std::basic_string , NoDefaultAllocator > S; typedef std::basic_stringbuf, NoDefaultAllocator > SB; S s(NoDefaultAllocator(1)); SB sb(s); // This test is not required by the standard, but *where else* could it get the allocator? assert(sb.str().get_allocator() == s.get_allocator()); } }