]> git.saurik.com Git - wxWidgets.git/blame_incremental - include/wx/sstream.h
Don't define __STRICT_ANSI__, we should build both with and without it.
[wxWidgets.git] / include / wx / sstream.h
... / ...
CommitLineData
1///////////////////////////////////////////////////////////////////////////////
2// Name: wx/sstream.h
3// Purpose: string-based streams
4// Author: Vadim Zeitlin
5// Modified by:
6// Created: 2004-09-19
7// Copyright: (c) 2004 Vadim Zeitlin <vadim@wxwindows.org>
8// Licence: wxWindows licence
9///////////////////////////////////////////////////////////////////////////////
10
11#ifndef _WX_SSTREAM_H_
12#define _WX_SSTREAM_H_
13
14#include "wx/stream.h"
15
16#if wxUSE_STREAMS
17
18// ----------------------------------------------------------------------------
19// wxStringInputStream is a stream reading from the given (fixed size) string
20// ----------------------------------------------------------------------------
21
22class WXDLLIMPEXP_BASE wxStringInputStream : public wxInputStream
23{
24public:
25 // ctor associates the stream with the given string which makes a copy of
26 // it
27 wxStringInputStream(const wxString& s);
28
29 virtual wxFileOffset GetLength() const;
30 virtual bool IsSeekable() const { return true; }
31
32protected:
33 virtual wxFileOffset OnSysSeek(wxFileOffset ofs, wxSeekMode mode);
34 virtual wxFileOffset OnSysTell() const;
35 virtual size_t OnSysRead(void *buffer, size_t size);
36
37private:
38 // the string that was passed in the ctor
39 wxString m_str;
40
41 // the buffer we're reading from
42 wxCharBuffer m_buf;
43
44 // length of the buffer we're reading from
45 size_t m_len;
46
47 // position in the stream in bytes, *not* in chars
48 size_t m_pos;
49
50 wxDECLARE_NO_COPY_CLASS(wxStringInputStream);
51};
52
53// ----------------------------------------------------------------------------
54// wxStringOutputStream writes data to the given string, expanding it as needed
55// ----------------------------------------------------------------------------
56
57class WXDLLIMPEXP_BASE wxStringOutputStream : public wxOutputStream
58{
59public:
60 // The stream will write data either to the provided string or to an
61 // internal string which can be retrieved using GetString()
62 //
63 // Note that the conversion object should have the life time greater than
64 // this stream.
65 wxStringOutputStream(wxString *pString = NULL,
66 wxMBConv& conv = wxConvUTF8)
67 : m_conv(conv)
68#if wxUSE_UNICODE
69 , m_unconv(0)
70#endif // wxUSE_UNICODE
71 {
72 m_str = pString ? pString : &m_strInternal;
73 m_pos = m_str->length() / sizeof(wxChar);
74 }
75
76 // get the string containing current output
77 const wxString& GetString() const { return *m_str; }
78
79 virtual bool IsSeekable() const { return true; }
80
81protected:
82 virtual wxFileOffset OnSysTell() const;
83 virtual size_t OnSysWrite(const void *buffer, size_t size);
84
85private:
86 // internal string, not used if caller provided his own string
87 wxString m_strInternal;
88
89 // pointer given by the caller or just pointer to m_strInternal
90 wxString *m_str;
91
92 // position in the stream in bytes, *not* in chars
93 size_t m_pos;
94
95 // converter to use: notice that with the default UTF-8 one the input
96 // stream must contain valid UTF-8 data, use wxConvISO8859_1 to work with
97 // arbitrary 8 bit data
98 wxMBConv& m_conv;
99
100#if wxUSE_UNICODE
101 // unconverted data from the last call to OnSysWrite()
102 wxMemoryBuffer m_unconv;
103#endif // wxUSE_UNICODE
104
105 wxDECLARE_NO_COPY_CLASS(wxStringOutputStream);
106};
107
108#endif // wxUSE_STREAMS
109
110#endif // _WX_SSTREAM_H_
111