//==----------------------------------------------------------------------===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// // UNSUPPORTED: c++03, c++11, c++14, c++17 // UNSUPPORTED: no-localization // UNSUPPORTED: libcpp-has-no-experimental-syncstream // // template // class basic_osyncstream; // explicit basic_osyncstream(streambuf_type* os); #include #include #include #include #include "test_macros.h" #include "constexpr_char_traits.h" #include "test_allocator.h" template void test() { { using OS = std::basic_osyncstream; using W = std::basic_stringbuf; static_assert(!std::convertible_to*, OS>); static_assert(std::constructible_from*>); { OS os{nullptr}; assert(os.get_wrapped() == nullptr); assert(os.rdbuf()->get_wrapped() == nullptr); assert(os.rdbuf()->get_allocator() == std::allocator()); } { W w; #if defined(_LIBCPP_VERSION) && !defined(TEST_HAS_NO_THREADS) assert(std::__wrapped_streambuf_mutex::__instance().__get_count(&w) == 0); #endif { OS os{&w}; #if defined(_LIBCPP_VERSION) && !defined(TEST_HAS_NO_THREADS) assert(std::__wrapped_streambuf_mutex::__instance().__get_count(&w) == 1); #endif assert(os.get_wrapped() == &w); assert(os.rdbuf()->get_wrapped() == &w); assert(os.rdbuf()->get_allocator() == std::allocator()); } #if defined(_LIBCPP_VERSION) && !defined(TEST_HAS_NO_THREADS) assert(std::__wrapped_streambuf_mutex::__instance().__get_count(&w) == 0); #endif } } { using OS = std::basic_osyncstream>; using W = std::basic_stringbuf>; static_assert(!std::convertible_to>*, OS>); static_assert(std::constructible_from>*>); { OS os{nullptr}; assert(os.get_wrapped() == nullptr); assert(os.rdbuf()->get_wrapped() == nullptr); assert(os.rdbuf()->get_allocator() == std::allocator()); } { W w; #if defined(_LIBCPP_VERSION) && !defined(TEST_HAS_NO_THREADS) assert(std::__wrapped_streambuf_mutex::__instance().__get_count(&w) == 0); #endif { OS os{&w}; #if defined(_LIBCPP_VERSION) && !defined(TEST_HAS_NO_THREADS) assert(std::__wrapped_streambuf_mutex::__instance().__get_count(&w) == 1); #endif assert(os.get_wrapped() == &w); assert(os.rdbuf()->get_wrapped() == &w); assert(os.rdbuf()->get_allocator() == std::allocator()); } #if defined(_LIBCPP_VERSION) && !defined(TEST_HAS_NO_THREADS) assert(std::__wrapped_streambuf_mutex::__instance().__get_count(&w) == 0); #endif } } { using OS = std::basic_osyncstream, test_allocator>; using W = std::basic_stringbuf, test_allocator>; static_assert( !std::convertible_to, test_allocator>*, OS>); static_assert( std::constructible_from, test_allocator>*>); { OS os{nullptr}; assert(os.get_wrapped() == nullptr); assert(os.rdbuf()->get_wrapped() == nullptr); assert(os.rdbuf()->get_allocator() == test_allocator()); } { W w; #if defined(_LIBCPP_VERSION) && !defined(TEST_HAS_NO_THREADS) assert(std::__wrapped_streambuf_mutex::__instance().__get_count(&w) == 0); #endif { OS os{&w}; #if defined(_LIBCPP_VERSION) && !defined(TEST_HAS_NO_THREADS) assert(std::__wrapped_streambuf_mutex::__instance().__get_count(&w) == 1); #endif assert(os.get_wrapped() == &w); assert(os.rdbuf()->get_wrapped() == &w); assert(os.rdbuf()->get_allocator() == test_allocator()); } #if defined(_LIBCPP_VERSION) && !defined(TEST_HAS_NO_THREADS) assert(std::__wrapped_streambuf_mutex::__instance().__get_count(&w) == 0); #endif } } } int main(int, char**) { test(); #ifndef TEST_HAS_NO_WIDE_CHARACTERS test(); #endif return 0; }