blob: 4ff34a55be4d707f8dbee7fc2116e26b6fa1b47f [file] [log] [blame]
Howard Hinnantc51e1022010-05-11 19:42:16 +00001// -*- C++ -*-
2//===--------------------------- strstream --------------------------------===//
3//
Howard Hinnantc566dc32010-05-11 21:36:01 +00004// The LLVM Compiler Infrastructure
Howard Hinnantc51e1022010-05-11 19:42:16 +00005//
Howard Hinnantee11c312010-11-16 22:09:02 +00006// This file is dual licensed under the MIT and the University of Illinois Open
7// Source Licenses. See LICENSE.TXT for details.
Howard Hinnantc51e1022010-05-11 19:42:16 +00008//
9//===----------------------------------------------------------------------===//
10
11#ifndef _LIBCPP_STRSTREAM
12#define _LIBCPP_STRSTREAM
13
14/*
15 strstream synopsis
16
17class strstreambuf
18 : public basic_streambuf<char>
19{
20public:
21 explicit strstreambuf(streamsize alsize_arg = 0);
22 strstreambuf(void* (*palloc_arg)(size_t), void (*pfree_arg)(void*));
23 strstreambuf(char* gnext_arg, streamsize n, char* pbeg_arg = 0);
24 strstreambuf(const char* gnext_arg, streamsize n);
25
26 strstreambuf(signed char* gnext_arg, streamsize n, signed char* pbeg_arg = 0);
27 strstreambuf(const signed char* gnext_arg, streamsize n);
28 strstreambuf(unsigned char* gnext_arg, streamsize n, unsigned char* pbeg_arg = 0);
29 strstreambuf(const unsigned char* gnext_arg, streamsize n);
30
31 strstreambuf(strstreambuf&& rhs);
32 strstreambuf& operator=(strstreambuf&& rhs);
33
34 virtual ~strstreambuf();
35
36 void swap(strstreambuf& rhs);
37
38 void freeze(bool freezefl = true);
39 char* str();
Howard Hinnantc566dc32010-05-11 21:36:01 +000040 int pcount() const;
Howard Hinnantc51e1022010-05-11 19:42:16 +000041
42protected:
43 virtual int_type overflow (int_type c = EOF);
44 virtual int_type pbackfail(int_type c = EOF);
45 virtual int_type underflow();
46 virtual pos_type seekoff(off_type off, ios_base::seekdir way,
47 ios_base::openmode which = ios_base::in | ios_base::out);
48 virtual pos_type seekpos(pos_type sp,
49 ios_base::openmode which = ios_base::in | ios_base::out);
50 virtual streambuf* setbuf(char* s, streamsize n);
51
52private:
53 typedef T1 strstate; // exposition only
54 static const strstate allocated; // exposition only
55 static const strstate constant; // exposition only
56 static const strstate dynamic; // exposition only
57 static const strstate frozen; // exposition only
58 strstate strmode; // exposition only
59 streamsize alsize; // exposition only
60 void* (*palloc)(size_t); // exposition only
61 void (*pfree)(void*); // exposition only
62};
63
64class istrstream
65 : public basic_istream<char>
66{
67public:
68 explicit istrstream(const char* s);
69 explicit istrstream(char* s);
70 istrstream(const char* s, streamsize n);
71 istrstream(char* s, streamsize n);
72
73 virtual ~istrstream();
74
75 strstreambuf* rdbuf() const;
76 char *str();
77
78private:
Howard Hinnantc566dc32010-05-11 21:36:01 +000079 strstreambuf sb; // exposition only
Howard Hinnantc51e1022010-05-11 19:42:16 +000080};
81
82class ostrstream
83 : public basic_ostream<char>
84{
85public:
86 ostrstream();
87 ostrstream(char* s, int n, ios_base::openmode mode = ios_base::out);
88
89 virtual ~ostrstream();
90
91 strstreambuf* rdbuf() const;
92 void freeze(bool freezefl = true);
93 char* str();
94 int pcount() const;
95
96private:
Howard Hinnantc566dc32010-05-11 21:36:01 +000097 strstreambuf sb; // exposition only
Howard Hinnantc51e1022010-05-11 19:42:16 +000098};
99
100class strstream
101 : public basic_iostream<char>
102{
103public:
104 // Types
105 typedef char char_type;
106 typedef char_traits<char>::int_type int_type;
107 typedef char_traits<char>::pos_type pos_type;
108 typedef char_traits<char>::off_type off_type;
109
110 // constructors/destructor
111 strstream();
112 strstream(char* s, int n, ios_base::openmode mode = ios_base::in | ios_base::out);
113
114 virtual ~strstream();
115
116 // Members:
117 strstreambuf* rdbuf() const;
118 void freeze(bool freezefl = true);
119 int pcount() const;
120 char* str();
121
122private:
Howard Hinnantc566dc32010-05-11 21:36:01 +0000123 strstreambuf sb; // exposition only
Howard Hinnantc51e1022010-05-11 19:42:16 +0000124};
125
126} // std
127
128*/
129
130#include <__config>
131#include <ostream>
132#include <istream>
133
134#pragma GCC system_header
135
136_LIBCPP_BEGIN_NAMESPACE_STD
137
Howard Hinnant186dca82010-09-23 17:31:07 +0000138class _LIBCPP_VISIBLE strstreambuf
Howard Hinnantc51e1022010-05-11 19:42:16 +0000139 : public streambuf
140{
141public:
142 explicit strstreambuf(streamsize __alsize = 0);
143 strstreambuf(void* (*__palloc)(size_t), void (*__pfree)(void*));
144 strstreambuf(char* __gnext, streamsize __n, char* __pbeg = 0);
145 strstreambuf(const char* __gnext, streamsize __n);
146
147 strstreambuf(signed char* __gnext, streamsize __n, signed char* __pbeg = 0);
148 strstreambuf(const signed char* __gnext, streamsize __n);
149 strstreambuf(unsigned char* __gnext, streamsize __n, unsigned char* __pbeg = 0);
150 strstreambuf(const unsigned char* __gnext, streamsize __n);
151
Howard Hinnant74279a52010-09-04 23:28:19 +0000152#ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES
Howard Hinnant0dcdf022011-07-07 21:03:52 +0000153 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantc51e1022010-05-11 19:42:16 +0000154 strstreambuf(strstreambuf&& __rhs);
Howard Hinnant0dcdf022011-07-07 21:03:52 +0000155 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantc51e1022010-05-11 19:42:16 +0000156 strstreambuf& operator=(strstreambuf&& __rhs);
Howard Hinnant74279a52010-09-04 23:28:19 +0000157#endif // _LIBCPP_HAS_NO_RVALUE_REFERENCES
Howard Hinnantc51e1022010-05-11 19:42:16 +0000158
159 virtual ~strstreambuf();
160
161 void swap(strstreambuf& __rhs);
162
163 void freeze(bool __freezefl = true);
164 char* str();
Howard Hinnantc566dc32010-05-11 21:36:01 +0000165 int pcount() const;
Howard Hinnantc51e1022010-05-11 19:42:16 +0000166
167protected:
168 virtual int_type overflow (int_type __c = EOF);
169 virtual int_type pbackfail(int_type __c = EOF);
170 virtual int_type underflow();
171 virtual pos_type seekoff(off_type __off, ios_base::seekdir __way,
172 ios_base::openmode __which = ios_base::in | ios_base::out);
173 virtual pos_type seekpos(pos_type __sp,
174 ios_base::openmode __which = ios_base::in | ios_base::out);
175
176private:
177 typedef unsigned __mode_type;
178 static const __mode_type __allocated = 0x01;
179 static const __mode_type __constant = 0x02;
180 static const __mode_type __dynamic = 0x04;
181 static const __mode_type __frozen = 0x08;
182 static const streamsize __default_alsize = 4096;
183
184 __mode_type __strmode_;
185 streamsize __alsize_;
186 void* (*__palloc_)(size_t);
187 void (*__pfree_)(void*);
188
189 void __init(char* __gnext, streamsize __n, char* __pbeg);
190};
191
Howard Hinnant0dcdf022011-07-07 21:03:52 +0000192#ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES
193
194inline _LIBCPP_INLINE_VISIBILITY
195strstreambuf::strstreambuf(strstreambuf&& __rhs)
196 : streambuf(__rhs),
197 __strmode_(__rhs.__strmode_),
198 __alsize_(__rhs.__alsize_),
199 __palloc_(__rhs.__palloc_),
200 __pfree_(__rhs.__pfree_)
201{
202 __rhs.setg(nullptr, nullptr, nullptr);
203 __rhs.setp(nullptr, nullptr);
204}
205
206inline _LIBCPP_INLINE_VISIBILITY
207strstreambuf&
208strstreambuf::operator=(strstreambuf&& __rhs)
209{
210 if (eback() && (__strmode_ & __allocated) != 0 && (__strmode_ & __frozen) == 0)
211 {
212 if (__pfree_)
213 __pfree_(eback());
214 else
215 delete [] eback();
216 }
217 streambuf::operator=(__rhs);
218 __strmode_ = __rhs.__strmode_;
219 __alsize_ = __rhs.__alsize_;
220 __palloc_ = __rhs.__palloc_;
221 __pfree_ = __rhs.__pfree_;
222 __rhs.setg(nullptr, nullptr, nullptr);
223 __rhs.setp(nullptr, nullptr);
224 return *this;
225}
226
227#endif // _LIBCPP_HAS_NO_RVALUE_REFERENCES
228
Howard Hinnant186dca82010-09-23 17:31:07 +0000229class _LIBCPP_VISIBLE istrstream
Howard Hinnantc51e1022010-05-11 19:42:16 +0000230 : public istream
231{
232public:
Howard Hinnant186dca82010-09-23 17:31:07 +0000233 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantc51e1022010-05-11 19:42:16 +0000234 explicit istrstream(const char* __s)
235 : istream(&__sb_), __sb_(__s, 0) {}
Howard Hinnant186dca82010-09-23 17:31:07 +0000236 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantc51e1022010-05-11 19:42:16 +0000237 explicit istrstream(char* __s)
238 : istream(&__sb_), __sb_(__s, 0) {}
Howard Hinnant186dca82010-09-23 17:31:07 +0000239 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantc51e1022010-05-11 19:42:16 +0000240 istrstream(const char* __s, streamsize __n)
241 : istream(&__sb_), __sb_(__s, __n) {}
Howard Hinnant186dca82010-09-23 17:31:07 +0000242 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantc51e1022010-05-11 19:42:16 +0000243 istrstream(char* __s, streamsize __n)
244 : istream(&__sb_), __sb_(__s, __n) {}
245
Howard Hinnant74279a52010-09-04 23:28:19 +0000246#ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES
Howard Hinnant186dca82010-09-23 17:31:07 +0000247 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantc51e1022010-05-11 19:42:16 +0000248 istrstream(istrstream&& __rhs)
Howard Hinnantb1ad5a82011-06-30 21:18:19 +0000249 : istream(_VSTD::move(__rhs)),
250 __sb_(_VSTD::move(__rhs.__sb_))
Howard Hinnantc51e1022010-05-11 19:42:16 +0000251 {
252 istream::set_rdbuf(&__sb_);
253 }
254
Howard Hinnant186dca82010-09-23 17:31:07 +0000255 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantc51e1022010-05-11 19:42:16 +0000256 istrstream& operator=(istrstream&& __rhs)
257 {
Howard Hinnantb1ad5a82011-06-30 21:18:19 +0000258 istream::operator=(_VSTD::move(__rhs));
259 __sb_ = _VSTD::move(__rhs.__sb_);
Howard Hinnantc51e1022010-05-11 19:42:16 +0000260 return *this;
261 }
Howard Hinnant74279a52010-09-04 23:28:19 +0000262#endif // _LIBCPP_HAS_NO_RVALUE_REFERENCES
Howard Hinnantc51e1022010-05-11 19:42:16 +0000263
264 virtual ~istrstream();
265
Howard Hinnant186dca82010-09-23 17:31:07 +0000266 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantc51e1022010-05-11 19:42:16 +0000267 void swap(istrstream& __rhs)
268 {
269 istream::swap(__rhs);
270 __sb_.swap(__rhs.__sb_);
271 }
272
Howard Hinnant186dca82010-09-23 17:31:07 +0000273 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantc51e1022010-05-11 19:42:16 +0000274 strstreambuf* rdbuf() const {return const_cast<strstreambuf*>(&__sb_);}
Howard Hinnant186dca82010-09-23 17:31:07 +0000275 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantc51e1022010-05-11 19:42:16 +0000276 char *str() {return __sb_.str();}
277
278private:
279 strstreambuf __sb_;
280};
281
Howard Hinnant186dca82010-09-23 17:31:07 +0000282class _LIBCPP_VISIBLE ostrstream
Howard Hinnantc51e1022010-05-11 19:42:16 +0000283 : public ostream
284{
285public:
Howard Hinnant186dca82010-09-23 17:31:07 +0000286 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantc51e1022010-05-11 19:42:16 +0000287 ostrstream()
288 : ostream(&__sb_) {}
Howard Hinnant186dca82010-09-23 17:31:07 +0000289 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantc51e1022010-05-11 19:42:16 +0000290 ostrstream(char* __s, int __n, ios_base::openmode __mode = ios_base::out)
291 : ostream(&__sb_),
292 __sb_(__s, __n, __s + (__mode & ios::app ? strlen(__s) : 0))
293 {}
294
Howard Hinnant74279a52010-09-04 23:28:19 +0000295#ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES
Howard Hinnant186dca82010-09-23 17:31:07 +0000296 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantc51e1022010-05-11 19:42:16 +0000297 ostrstream(ostrstream&& __rhs)
Howard Hinnantb1ad5a82011-06-30 21:18:19 +0000298 : ostream(_VSTD::move(__rhs)),
299 __sb_(_VSTD::move(__rhs.__sb_))
Howard Hinnantc51e1022010-05-11 19:42:16 +0000300 {
301 ostream::set_rdbuf(&__sb_);
302 }
303
Howard Hinnant186dca82010-09-23 17:31:07 +0000304 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantc51e1022010-05-11 19:42:16 +0000305 ostrstream& operator=(ostrstream&& __rhs)
306 {
Howard Hinnantb1ad5a82011-06-30 21:18:19 +0000307 ostream::operator=(_VSTD::move(__rhs));
308 __sb_ = _VSTD::move(__rhs.__sb_);
Howard Hinnantc51e1022010-05-11 19:42:16 +0000309 return *this;
310 }
Howard Hinnant74279a52010-09-04 23:28:19 +0000311#endif // _LIBCPP_HAS_NO_RVALUE_REFERENCES
Howard Hinnantc51e1022010-05-11 19:42:16 +0000312
313 virtual ~ostrstream();
314
Howard Hinnant186dca82010-09-23 17:31:07 +0000315 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantc51e1022010-05-11 19:42:16 +0000316 void swap(ostrstream& __rhs)
317 {
318 ostream::swap(__rhs);
319 __sb_.swap(__rhs.__sb_);
320 }
321
Howard Hinnant186dca82010-09-23 17:31:07 +0000322 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantc51e1022010-05-11 19:42:16 +0000323 strstreambuf* rdbuf() const {return const_cast<strstreambuf*>(&__sb_);}
Howard Hinnant186dca82010-09-23 17:31:07 +0000324 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantc51e1022010-05-11 19:42:16 +0000325 void freeze(bool __freezefl = true) {__sb_.freeze(__freezefl);}
Howard Hinnant186dca82010-09-23 17:31:07 +0000326 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantc51e1022010-05-11 19:42:16 +0000327 char* str() {return __sb_.str();}
Howard Hinnant186dca82010-09-23 17:31:07 +0000328 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantc51e1022010-05-11 19:42:16 +0000329 int pcount() const {return __sb_.pcount();}
330
331private:
Howard Hinnantc566dc32010-05-11 21:36:01 +0000332 strstreambuf __sb_; // exposition only
Howard Hinnantc51e1022010-05-11 19:42:16 +0000333};
334
Howard Hinnant186dca82010-09-23 17:31:07 +0000335class _LIBCPP_VISIBLE strstream
Howard Hinnantc51e1022010-05-11 19:42:16 +0000336 : public iostream
337{
338public:
339 // Types
340 typedef char char_type;
341 typedef char_traits<char>::int_type int_type;
342 typedef char_traits<char>::pos_type pos_type;
343 typedef char_traits<char>::off_type off_type;
344
345 // constructors/destructor
Howard Hinnant186dca82010-09-23 17:31:07 +0000346 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantc51e1022010-05-11 19:42:16 +0000347 strstream()
348 : iostream(&__sb_) {}
Howard Hinnant186dca82010-09-23 17:31:07 +0000349 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantc51e1022010-05-11 19:42:16 +0000350 strstream(char* __s, int __n, ios_base::openmode __mode = ios_base::in | ios_base::out)
351 : iostream(&__sb_),
352 __sb_(__s, __n, __s + (__mode & ios::app ? strlen(__s) : 0))
353 {}
354
Howard Hinnant74279a52010-09-04 23:28:19 +0000355#ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES
Howard Hinnant186dca82010-09-23 17:31:07 +0000356 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantc51e1022010-05-11 19:42:16 +0000357 strstream(strstream&& __rhs)
Howard Hinnantb1ad5a82011-06-30 21:18:19 +0000358 : iostream(_VSTD::move(__rhs)),
359 __sb_(_VSTD::move(__rhs.__sb_))
Howard Hinnantc51e1022010-05-11 19:42:16 +0000360 {
361 iostream::set_rdbuf(&__sb_);
362 }
363
Howard Hinnant186dca82010-09-23 17:31:07 +0000364 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantc51e1022010-05-11 19:42:16 +0000365 strstream& operator=(strstream&& __rhs)
366 {
Howard Hinnantb1ad5a82011-06-30 21:18:19 +0000367 iostream::operator=(_VSTD::move(__rhs));
368 __sb_ = _VSTD::move(__rhs.__sb_);
Howard Hinnantc51e1022010-05-11 19:42:16 +0000369 return *this;
370 }
Howard Hinnant74279a52010-09-04 23:28:19 +0000371#endif // _LIBCPP_HAS_NO_RVALUE_REFERENCES
Howard Hinnantc51e1022010-05-11 19:42:16 +0000372
373 virtual ~strstream();
374
Howard Hinnant186dca82010-09-23 17:31:07 +0000375 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantc51e1022010-05-11 19:42:16 +0000376 void swap(strstream& __rhs)
377 {
378 iostream::swap(__rhs);
379 __sb_.swap(__rhs.__sb_);
380 }
381
382 // Members:
Howard Hinnant186dca82010-09-23 17:31:07 +0000383 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantc51e1022010-05-11 19:42:16 +0000384 strstreambuf* rdbuf() const {return const_cast<strstreambuf*>(&__sb_);}
Howard Hinnant186dca82010-09-23 17:31:07 +0000385 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantc51e1022010-05-11 19:42:16 +0000386 void freeze(bool __freezefl = true) {__sb_.freeze(__freezefl);}
Howard Hinnant186dca82010-09-23 17:31:07 +0000387 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantc51e1022010-05-11 19:42:16 +0000388 int pcount() const {return __sb_.pcount();}
Howard Hinnant186dca82010-09-23 17:31:07 +0000389 _LIBCPP_INLINE_VISIBILITY
Howard Hinnantc51e1022010-05-11 19:42:16 +0000390 char* str() {return __sb_.str();}
391
392private:
Howard Hinnantc566dc32010-05-11 21:36:01 +0000393 strstreambuf __sb_; // exposition only
Howard Hinnantc51e1022010-05-11 19:42:16 +0000394};
395
396_LIBCPP_END_NAMESPACE_STD
397
398#endif // _LIBCPP_STRSTREAM