//===----------------------------------------------------------------------===// // // 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 // // template // Stream&& operator<<(Stream&& os, const T& x); #include #include #include "test_macros.h" template class testbuf : public std::basic_streambuf { typedef std::basic_streambuf base; std::basic_string str_; public: testbuf() { } std::basic_string str() const {return std::basic_string(base::pbase(), base::pptr());} protected: virtual typename base::int_type overflow(typename base::int_type ch = base::traits_type::eof()) { if (ch != base::traits_type::eof()) { int n = static_cast(str_.size()); str_.push_back(static_cast(ch)); str_.resize(str_.capacity()); base::setp(const_cast(str_.data()), const_cast(str_.data() + str_.size())); base::pbump(n+1); } return ch; } }; struct Int { int value; template friend void operator<<(std::basic_ostream& os, Int const& self) { os << self.value; } }; int main(int, char**) { { testbuf sb; std::ostream os(&sb); Int const i = {123}; std::ostream&& result = (std::move(os) << i); assert(&result == &os); assert(sb.str() == "123"); } { testbuf sb; std::wostream os(&sb); Int const i = {123}; std::wostream&& result = (std::move(os) << i); assert(&result == &os); assert(sb.str() == L"123"); } return 0; }