//===----------------------------------------------------------------------===// // // 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_stringbuf // int_type underflow(); #include #include template struct testbuf : public std::basic_stringbuf { typedef std::basic_stringbuf base; explicit testbuf(const std::basic_string& str) : base(str) {} typename base::int_type underflow() {return base::underflow();} void pbump(int n) {base::pbump(n);} }; int main() { { testbuf sb("123"); sb.pbump(3); assert(sb.underflow() == '1'); assert(sb.underflow() == '1'); assert(sb.snextc() == '2'); assert(sb.underflow() == '2'); assert(sb.underflow() == '2'); assert(sb.snextc() == '3'); assert(sb.underflow() == '3'); assert(sb.underflow() == '3'); assert(sb.snextc() == std::char_traits::eof()); assert(sb.underflow() == std::char_traits::eof()); assert(sb.underflow() == std::char_traits::eof()); sb.sputc('4'); assert(sb.underflow() == '4'); assert(sb.underflow() == '4'); } { testbuf sb(L"123"); sb.pbump(3); assert(sb.underflow() == L'1'); assert(sb.underflow() == L'1'); assert(sb.snextc() == L'2'); assert(sb.underflow() == L'2'); assert(sb.underflow() == L'2'); assert(sb.snextc() == L'3'); assert(sb.underflow() == L'3'); assert(sb.underflow() == L'3'); assert(sb.snextc() == std::char_traits::eof()); assert(sb.underflow() == std::char_traits::eof()); assert(sb.underflow() == std::char_traits::eof()); sb.sputc(L'4'); assert(sb.underflow() == L'4'); assert(sb.underflow() == L'4'); } }