]> git.saurik.com Git - wxWidgets.git/blame_incremental - docs/latex/wx/txtstrm.tex
Changed test for INT32 to work with latest Cygwin. But might break other versions :-(
[wxWidgets.git] / docs / latex / wx / txtstrm.tex
... / ...
CommitLineData
1% ----------------------------------------------------------------------------
2% wxTextInputStream
3% ----------------------------------------------------------------------------
4\section{\class{wxTextInputStream}}\label{wxtextinputstream}
5
6This class provides functions that read text datas using an input stream.
7So, you can read {\it text} floats, integers.
8
9The wxTextInputStream correctly reads text files (or streams) in DOS, Macintosh
10and Unix formats and reports a single newline char as a line ending.
11
12Operator >> is overloaded and you can use this class like a standard C++ iostream.
13Note, however, that the arguments are the fixed size types wxUint32, wxInt32 etc
14and on a typical 32-bit computer, none of these match to the "long" type (wxInt32
15is defined as int on 32-bit architectures) so that you cannot use long. To avoid
16problems (here and elsewhere), make use of wxInt32, wxUint32 and similar types.
17
18For example:
19
20\begin{verbatim}
21 wxFileInputStream input( "mytext.txt" );
22 wxTextInputStream text( input );
23 wxUint8 i1;
24 float f2;
25 wxString line;
26
27 text >> i1; // read a 8 bit integer.
28 text >> i1 >> f2; // read a 8 bit integer followed by float.
29 text >> line; // read a text line
30\end{verbatim}
31
32\wxheading{Include files}
33
34<wx/txtstrm.h>
35
36\latexignore{\rtfignore{\wxheading{Members}}}
37
38\membersection{wxTextInputStream::wxTextInputStream}\label{wxtextinputstreamconstr}
39
40\func{}{wxTextInputStream}{\param{wxInputStream\&}{ stream}}
41
42Constructs a text stream object from an input stream. Only read methods will
43be available.
44
45\wxheading{Parameters}
46
47\docparam{stream}{The input stream.}
48
49\membersection{wxTextInputStream::\destruct{wxTextInputStream}}
50
51\func{}{\destruct{wxTextInputStream}}{\void}
52
53Destroys the wxTextInputStream object.
54
55\membersection{wxTextInputStream::Read8}
56
57\func{wxUint8}{Read8}{\void}
58
59Reads a single byte from the stream.
60
61\membersection{wxTextInputStream::Read16}
62
63\func{wxUint16}{Read16}{\void}
64
65Reads a 16 bit integer from the stream.
66
67\membersection{wxTextInputStream::Read32}
68
69\func{wxUint16}{Read32}{\void}
70
71Reads a 32 bit integer from the stream.
72
73\membersection{wxTextInputStream::ReadDouble}
74
75\func{double}{ReadDouble}{\void}
76
77Reads a double (IEEE encoded) from the stream.
78
79\membersection{wxTextInputStream::ReadLine}\label{wxtextinputstreamreadline}
80
81\func{wxString}{wxTextInputStream::ReadLine}{\void}
82
83Reads a line from the input stream and returns it (without the end of line
84character).
85
86\membersection{wxTextInputStream::ReadString}
87
88\func{wxString}{wxTextInputStream::ReadString}{\void}
89
90{\bf NB:} This method is deprecated, use \helpref{ReadLine}{wxtextinputstreamreadline}
91or \helpref{ReadWord}{wxtextinputstreamreadword} instead.
92
93Same as \helpref{ReadLine}{wxtextinputstreamreadline}.
94
95\membersection{wxTextInputStream::ReadWord}\label{wxtextinputstreamreadword}
96
97\func{wxString}{wxTextInputStream::ReadWord}{\void}
98
99Reads a word (a sequence of characters until the next separator) from the
100input stream.
101
102\wxheading{See also}
103
104\helpref{SetStringSeparators}{wxtextinputstreamsetstringseparators}
105
106\membersection{wxTextInputStream::SetStringSeparators}\label{wxtextinputstreamsetstringseparators}
107
108\func{void}{SetStringSeparators}{\param{const wxString\& }{sep}}
109
110Sets the characters which are used to define the word boundaries in
111\helpref{ReadWord}{wxtextinputstreamreadword}.
112
113The default separators are the space and {\tt TAB} characters.
114
115% ----------------------------------------------------------------------------
116% wxTextOutputStream
117% ----------------------------------------------------------------------------
118
119\section{\class{wxTextOutputStream}}\label{wxtextoutputstream}
120
121This class provides functions that write text datas using an output stream.
122So, you can write {\it text} floats, integers.
123
124You can also simulate the C++ cout class:
125
126\begin{verbatim}
127 wxFFileOutputStream output( stderr );
128 wxTextOutputStream cout( output );
129
130 cout << "This is a text line" << endl;
131 cout << 1234;
132 cout << 1.23456;
133\end{verbatim}
134
135The wxTextOutputStream writes text files (or streams) on DOS, Macintosh
136and Unix in their native formats (concerning the line ending).
137
138\latexignore{\rtfignore{\wxheading{Members}}}
139
140\membersection{wxTextOutputStream::wxTextOutputStream}\label{wxtextoutputstreamconstr}
141
142\func{}{wxTextOutputStream}{\param{wxOutputStream\&}{ stream}, \param{wxEOL}{ mode = wxEOL\_NATIVE}}
143
144Constructs a text stream object from an output stream. Only write methods will
145be available.
146
147\wxheading{Parameters}
148
149\docparam{stream}{The output stream.}
150
151\docparam{mode}{The end-of-line mode. One of {\bf wxEOL\_NATIVE}, {\bf wxEOL\_DOS}, {\bf wxEOL\_MAC} and {\bf wxEOL\_UNIX}.}
152
153\membersection{wxTextOutputStream::\destruct{wxTextOutputStream}}
154
155\func{}{\destruct{wxTextOutputStream}}{\void}
156
157Destroys the wxTextOutputStream object.
158
159\membersection{wxTextOutputStream::GetMode}
160
161\func{wxEOL}{wxTextOutputStream::GetMode}{\void}
162
163Returns the end-of-line mode. One of {\bf wxEOL\_DOS}, {\bf wxEOL\_MAC} and {\bf wxEOL\_UNIX}.
164
165\membersection{wxTextOutputStream::SetMode}
166
167\func{void}{wxTextOutputStream::SetMode}{{\param wxEOL}{ mode = wxEOL\_NATIVE}}
168
169Set the end-of-line mode. One of {\bf wxEOL\_NATIVE}, {\bf wxEOL\_DOS}, {\bf wxEOL\_MAC} and {\bf wxEOL\_UNIX}.
170
171\membersection{wxTextOutputStream::Write8}
172
173\func{void}{wxTextOutputStream::Write8}{{\param wxUint8 }{i8}}
174
175Writes the single byte {\it i8} to the stream.
176
177\membersection{wxTextOutputStream::Write16}
178
179\func{void}{wxTextOutputStream::Write16}{{\param wxUint16 }{i16}}
180
181Writes the 16 bit integer {\it i16} to the stream.
182
183\membersection{wxTextOutputStream::Write32}
184
185\func{void}{wxTextOutputStream::Write32}{{\param wxUint32 }{i32}}
186
187Writes the 32 bit integer {\it i32} to the stream.
188
189\membersection{wxTextOutputStream::WriteDouble}
190
191\func{virtual void}{wxTextOutputStream::WriteDouble}{{\param double }{f}}
192
193Writes the double {\it f} to the stream using the IEEE format.
194
195\membersection{wxTextOutputStream::WriteString}
196
197\func{virtual void}{wxTextOutputStream::WriteString}{{\param const wxString\& }{string}}
198
199Writes {\it string} as a line. Depending on the end-of-line mode, it adds
200$\backslash$n, $\backslash$r or $\backslash$r$\backslash$n.
201