[X86] Fix ABI for passing after i128 (#124134)
[llvm-project.git] / libcxx / test / std / input.output / stream.buffers / streambuf / streambuf.members / streambuf.pub.get / snextc.pass.cpp
blob85bd0e4b0be24247cb2688ad7dfbb05e6c5ebe13
1 //===----------------------------------------------------------------------===//
2 //
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6 //
7 //===----------------------------------------------------------------------===//
9 // <streambuf>
11 // template <class charT, class traits = char_traits<charT> >
12 // class basic_streambuf;
14 // int_type snextc();
16 #include <streambuf>
17 #include <cassert>
19 #include "test_macros.h"
21 int uflow_called = 0;
23 struct test
24 : public std::basic_streambuf<char>
26 typedef std::basic_streambuf<char> base;
28 test() {}
30 void setg(char* gbeg, char* gnext, char* gend)
32 base::setg(gbeg, gnext, gend);
35 protected:
36 int_type uflow()
38 ++uflow_called;
39 return 'a';
43 int main(int, char**)
46 test t;
47 assert(uflow_called == 0);
48 assert(t.snextc() == -1);
49 assert(uflow_called == 1);
50 char in[] = "ABC";
51 t.setg(in, in, in+sizeof(in));
52 assert(t.snextc() == 'B');
53 assert(uflow_called == 1);
54 assert(t.snextc() == 'C');
55 assert(uflow_called == 1);
58 return 0;