//===----------------------------------------------------------------------===// // // 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 basic_ostream; // operator<<(unsigned long long val); #include #include 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 __c = base::traits_type::eof()) { if (__c != base::traits_type::eof()) { int n = static_cast(str_.size()); str_.push_back(static_cast(__c)); str_.resize(str_.capacity()); base::setp(const_cast(str_.data()), const_cast(str_.data() + str_.size())); base::pbump(n+1); } return __c; } }; int main() { { std::ostream os((std::streambuf*)0); unsigned long long n = 0; os << n; assert(os.bad()); assert(os.fail()); } { testbuf sb; std::ostream os(&sb); unsigned long long n = 0; os << n; assert(sb.str() == "0"); } { testbuf sb; std::ostream os(&sb); unsigned long long n = 10; os << n; assert(sb.str() == "10"); } { testbuf sb; std::ostream os(&sb); hex(os); unsigned long long n = static_cast(-10); os << n; assert(sb.str() == "fffffffffffffff6"); } }