//===----------------------------------------------------------------------===// // // 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_syncbuf; // explicit basic_syncbuf(streambuf_type* obuf); #include #include #include #include "test_macros.h" #include "constexpr_char_traits.h" #include "test_allocator.h" template void test() { { using Buf = std::basic_syncbuf; static_assert(!std::convertible_to*, Buf>); static_assert(std::constructible_from*>); { Buf buf{nullptr}; assert(buf.get_wrapped() == nullptr); assert(buf.get_allocator() == std::allocator()); } { Buf w; #if defined(_LIBCPP_VERSION) && !defined(TEST_HAS_NO_THREADS) assert(std::__wrapped_streambuf_mutex::__instance().__get_count(&w) == 0); #endif { Buf buf{&w}; #if defined(_LIBCPP_VERSION) && !defined(TEST_HAS_NO_THREADS) assert(std::__wrapped_streambuf_mutex::__instance().__get_count(&w) == 1); #endif assert(buf.get_wrapped() == &w); assert(buf.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 Buf = std::basic_syncbuf>; static_assert(!std::convertible_to>*, Buf>); static_assert(std::constructible_from>*>); { Buf buf{nullptr}; assert(buf.get_wrapped() == nullptr); assert(buf.get_allocator() == std::allocator()); } { Buf w; #if defined(_LIBCPP_VERSION) && !defined(TEST_HAS_NO_THREADS) assert(std::__wrapped_streambuf_mutex::__instance().__get_count(&w) == 0); #endif { Buf buf{&w}; #if defined(_LIBCPP_VERSION) && !defined(TEST_HAS_NO_THREADS) assert(std::__wrapped_streambuf_mutex::__instance().__get_count(&w) == 1); #endif assert(buf.get_wrapped() == &w); assert(buf.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 Buf = std::basic_syncbuf, test_allocator>; static_assert(!std::convertible_to>*, Buf>); static_assert(std::constructible_from>*>); { Buf buf{nullptr}; assert(buf.get_wrapped() == nullptr); assert(buf.get_allocator() == test_allocator()); } { Buf w; #if defined(_LIBCPP_VERSION) && !defined(TEST_HAS_NO_THREADS) assert(std::__wrapped_streambuf_mutex::__instance().__get_count(&w) == 0); #endif { Buf buf{&w}; #if defined(_LIBCPP_VERSION) && !defined(TEST_HAS_NO_THREADS) assert(std::__wrapped_streambuf_mutex::__instance().__get_count(&w) == 1); #endif assert(buf.get_wrapped() == &w); assert(buf.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; }