• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 //===----------------------------------------------------------------------===//
2 //
3 //                     The LLVM Compiler Infrastructure
4 //
5 // This file is dual licensed under the MIT and the University of Illinois Open
6 // Source Licenses. See LICENSE.TXT for details.
7 //
8 //===----------------------------------------------------------------------===//
9 
10 // <fstream>
11 
12 // int_type overflow(int_type c = traits::eof());
13 
14 // This test is not entirely portable
15 
16 #include <fstream>
17 #include <cassert>
18 
19 #include "platform_support.h" // locale name macros
20 
21 template <class CharT>
22 struct test_buf
23     : public std::basic_filebuf<CharT>
24 {
25     typedef std::basic_filebuf<CharT>  base;
26     typedef typename base::char_type   char_type;
27     typedef typename base::int_type    int_type;
28     typedef typename base::traits_type traits_type;
29 
pbasetest_buf30     char_type* pbase() const {return base::pbase();}
pptrtest_buf31     char_type* pptr()  const {return base::pptr();}
epptrtest_buf32     char_type* epptr() const {return base::epptr();}
gbumptest_buf33     void gbump(int n) {base::gbump(n);}
34 
overflowtest_buf35     virtual int_type overflow(int_type c = traits_type::eof()) {return base::overflow(c);}
36 };
37 
main()38 int main()
39 {
40     {
41         test_buf<char> f;
42         assert(f.open("overflow.dat", std::ios_base::out) != 0);
43         assert(f.is_open());
44         assert(f.pbase() == 0);
45         assert(f.pptr() == 0);
46         assert(f.epptr() == 0);
47         assert(f.overflow('a') == 'a');
48         assert(f.pbase() != 0);
49         assert(f.pptr() == f.pbase());
50         assert(f.epptr() - f.pbase() == 4095);
51     }
52     {
53         test_buf<char> f;
54         assert(f.open("overflow.dat", std::ios_base::in) != 0);
55         assert(f.is_open());
56         assert(f.sgetc() == 'a');
57     }
58     std::remove("overflow.dat");
59     {
60         test_buf<char> f;
61         f.pubsetbuf(0, 0);
62         assert(f.open("overflow.dat", std::ios_base::out) != 0);
63         assert(f.is_open());
64         assert(f.pbase() == 0);
65         assert(f.pptr() == 0);
66         assert(f.epptr() == 0);
67         assert(f.overflow('a') == 'a');
68         assert(f.pbase() == 0);
69         assert(f.pptr() == 0);
70         assert(f.epptr() == 0);
71     }
72     {
73         test_buf<char> f;
74         assert(f.open("overflow.dat", std::ios_base::in) != 0);
75         assert(f.is_open());
76         assert(f.sgetc() == 'a');
77     }
78     std::remove("overflow.dat");
79     {
80         test_buf<wchar_t> f;
81         assert(f.open("overflow.dat", std::ios_base::out) != 0);
82         assert(f.is_open());
83         assert(f.pbase() == 0);
84         assert(f.pptr() == 0);
85         assert(f.epptr() == 0);
86         assert(f.overflow(L'a') == L'a');
87         assert(f.pbase() != 0);
88         assert(f.pptr() == f.pbase());
89         assert(f.epptr() - f.pbase() == 4095);
90     }
91     {
92         test_buf<wchar_t> f;
93         assert(f.open("overflow.dat", std::ios_base::in) != 0);
94         assert(f.is_open());
95         assert(f.sgetc() == L'a');
96     }
97     std::remove("overflow.dat");
98     {
99         test_buf<wchar_t> f;
100         f.pubsetbuf(0, 0);
101         assert(f.open("overflow.dat", std::ios_base::out) != 0);
102         assert(f.is_open());
103         assert(f.pbase() == 0);
104         assert(f.pptr() == 0);
105         assert(f.epptr() == 0);
106         assert(f.overflow(L'a') == L'a');
107         assert(f.pbase() == 0);
108         assert(f.pptr() == 0);
109         assert(f.epptr() == 0);
110     }
111     {
112         test_buf<wchar_t> f;
113         assert(f.open("overflow.dat", std::ios_base::in) != 0);
114         assert(f.is_open());
115         assert(f.sgetc() == L'a');
116     }
117     std::remove("overflow.dat");
118 #if !defined(__ANDROID__)
119     // Remove tests setlocale() to other than "", "C", and "POSIX"
120     // for Android
121     {
122         test_buf<wchar_t> f;
123         f.pubimbue(std::locale(LOCALE_en_US_UTF_8));
124         assert(f.open("overflow.dat", std::ios_base::out) != 0);
125         assert(f.sputc(0x4E51) == 0x4E51);
126         assert(f.sputc(0x4E52) == 0x4E52);
127         assert(f.sputc(0x4E53) == 0x4E53);
128     }
129     {
130         test_buf<char> f;
131         assert(f.open("overflow.dat", std::ios_base::in) != 0);
132         assert(f.is_open());
133         assert(f.sbumpc() == 0xE4);
134         assert(f.sbumpc() == 0xB9);
135         assert(f.sbumpc() == 0x91);
136         assert(f.sbumpc() == 0xE4);
137         assert(f.sbumpc() == 0xB9);
138         assert(f.sbumpc() == 0x92);
139         assert(f.sbumpc() == 0xE4);
140         assert(f.sbumpc() == 0xB9);
141         assert(f.sbumpc() == 0x93);
142         assert(f.sbumpc() == -1);
143     }
144     std::remove("overflow.dat");
145 #endif // __ANDROID__
146 }
147