/usr/include/cxxtools/textstream.h is in libcxxtools-dev 2.2.1-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 | /*
* Copyright (C) 2004 Marc Boris Duerner
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* As a special exception, you may use this file as part of a free
* software library without restriction. Specifically, if other files
* instantiate templates or use macros or inline functions from this
* file, or you compile this file and link it with other files to
* produce an executable, this file does not by itself cause the
* resulting executable to be covered by the GNU General Public
* License. This exception does not however invalidate any other
* reasons why the executable file might be covered by the GNU Library
* General Public License.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/
#ifndef cxxtools_BasicTextStream_h
#define cxxtools_BasicTextStream_h
#include <cxxtools/api.h>
#include <cxxtools/textbuffer.h>
#include <iostream>
namespace cxxtools
{
/** @brief Converts character sequences using a Codec.
This generic stream, which only supports input, wraps another input-stream and converts the
character data which is received from the stream on-the-fly using a Codec. The data which is
received from the wrapped input-stream is buffered.
This class derives from std::basic_istream which is the super-class of input-stream classes.
Stream classes are used to connect to an external device and transport characters
from this external device.
The internal character set can be specified using the template parameters 'I', the
external character set using 'E'. The external type is the input type and output
type when reading from or writing to the external device. The internal type is the type
which is used to internally store the data from the external device after the external
format was converted using the Codec which is passed when constructing an object of this
class.
The Codec object which is passed as pointer to the constructor will afterwards be
managed by this class and also be deleted by this class when it's destructed!
@see std::basic_istream
*/
template <typename CharT, typename ByteT>
class BasicTextIStream : public std::basic_istream<CharT>
{
public:
typedef ByteT extern_type;
typedef CharT intern_type;
typedef CharT char_type;
typedef typename std::char_traits<CharT> traits_type;
typedef typename traits_type::int_type int_type;
typedef typename traits_type::pos_type pos_type;
typedef typename traits_type::off_type off_type;
typedef std::basic_istream<extern_type> StreamType;
typedef TextCodec<char_type, extern_type> CodecType;
public:
/** @brief Construct by input stream and codec.
The input stream @a is is used ro read a character sequence and
convert it using the codec @a codec. The Codec object which is
passed as pointer will afterwards be managed by this class and
also be deleted on destruction
*/
BasicTextIStream(StreamType& is, CodecType* codec)
: std::basic_istream<intern_type>(0)
, _buffer( &is, codec )
{
std::basic_istream<CharT>::init(&_buffer);
std::basic_istream<CharT>::exceptions(is.exceptions());
}
explicit BasicTextIStream(CodecType* codec)
: std::basic_istream<intern_type>(0)
, _buffer( 0, codec )
{
std::basic_istream<CharT>::init(&_buffer);
}
//! @brief Deletes to codec.
~BasicTextIStream()
{ }
void attach(StreamType& is)
{
_buffer.attach( is );
this->clear();
std::basic_istream<CharT>::exceptions(is.exceptions());
}
void detach()
{
_buffer.detach();
this->clear();
}
void terminate()
{
_buffer.terminate();
}
BasicTextBuffer<intern_type, extern_type>& buffer()
{ return _buffer; }
private:
BasicTextBuffer<intern_type, extern_type> _buffer;
};
/** @brief Converts character sequences using a Codec.
This generic stream, which only supports output, wraps another input-stream and converts the
character data which is received from the stream on-the-fly using a Codec. The data which is
received from the wrapped input-stream is buffered.
This class derives from std::basic_istream which is the super-class of input-stream classes.
Stream classes are used to connect to an external device and transport characters
from this external device.
The internal character set can be specified using the template parameters 'I', the
external character set using 'E'. The external type is the input type and output
type when reading from or writing to the external device. The internal type is the type
which is used to internally store the data from the external device after the external
format was converted using the Codec which is passed when constructing an object of this
class.
The Codec object which is passed as pointer to the constructor will afterwards be
managed by this class and also be deleted by this class when it's destructed!
@see std::basic_istream
*/
template <typename CharT, typename ByteT>
class BasicTextOStream : public std::basic_ostream<CharT>
{
public:
typedef ByteT extern_type;
typedef CharT intern_type;
typedef CharT char_type;
typedef typename std::char_traits<CharT> traits_type;
typedef typename traits_type::int_type int_type;
typedef typename traits_type::pos_type pos_type;
typedef typename traits_type::off_type off_type;
typedef std::basic_ostream<extern_type> StreamType;
typedef TextCodec<char_type, extern_type> CodecType;
public:
/** @brief Construct by output stream and codec.
The output stream @a os is used to write a character sequence
which has been converted using the codec @a codec. The Codec
object which is passed as pointer will afterwards be managed
by this class and be deleted on destruction
*/
BasicTextOStream(StreamType& os, CodecType* codec)
: std::basic_ostream<intern_type>(0)
, _buffer( &os , codec )
{
std::basic_ostream<CharT>::init(&_buffer);
std::basic_ostream<CharT>::exceptions(os.exceptions());
}
explicit BasicTextOStream(CodecType* codec)
: std::basic_ostream<intern_type>(0)
, _buffer( 0 , codec )
{ std::basic_ostream<CharT>::init(&_buffer); }
//! @brief Deletes to codec.
~BasicTextOStream()
{ }
void attach(StreamType& os)
{
_buffer.attach( os );
std::basic_ostream<CharT>::exceptions(os.exceptions());
this->clear();
}
void detach()
{
_buffer.detach();
this->clear();
}
void terminate()
{
_buffer.terminate();
}
BasicTextBuffer<intern_type, extern_type>& buffer()
{ return _buffer; }
private:
BasicTextBuffer<intern_type, extern_type> _buffer;
};
/** @brief Converts character sequences using a Codec.
This generic stream, which only supports input and output, wraps another input-stream and converts the
character data which is received from the stream on-the-fly using a Codec. The data which is
received from the wrapped input-stream is buffered.
This class derives from std::basic_istream which is the super-class of input-stream classes.
Stream classes are used to connect to an external device and transport characters
from this external device.
The internal character set can be specified using the template parameters 'I', the
external character set using 'E'. The external type is the input type and output
type when reading from or writing to the external device. The internal type is the type
which is used to internally store the data from the external device after the external
format was converted using the Codec which is passed when constructing an object of this
class.
The Codec object which is passed as pointer to the constructor will afterwards be
managed by this class and also be deleted by this class when it's destructed!
@see std::basic_istream
*/
template <typename CharT, typename ByteT>
class BasicTextStream : public std::basic_iostream<CharT>
{
public:
typedef ByteT extern_type;
typedef CharT intern_type;
typedef CharT char_type;
typedef typename std::char_traits<CharT> traits_type;
typedef typename traits_type::int_type int_type;
typedef typename traits_type::pos_type pos_type;
typedef typename traits_type::off_type off_type;
typedef std::basic_iostream<extern_type> StreamType;
typedef TextCodec<char_type, extern_type> CodecType;
public:
/** @brief Construct by stream and codec.
The stream @a ios is used to read a character sequences and
convert is using the codec @a codec and write character
sequences which have been converted using the codec @a codec.
The codec object which is passed as pointer will afterwards
be managed by this class and be deleted on destruction
*/
BasicTextStream(StreamType& ios, CodecType* codec)
: std::basic_iostream<intern_type>(0)
, _buffer( &ios, codec)
{
std::basic_iostream<CharT>::init(&_buffer);
std::basic_iostream<CharT>::exceptions(ios.exceptions());
}
explicit BasicTextStream(CodecType* codec)
: std::basic_iostream<intern_type>(0)
, _buffer(0, codec)
{ std::basic_iostream<CharT>::init(&_buffer); }
//! @brief Deletes the codec.
~BasicTextStream()
{ }
void attach(StreamType& ios)
{
_buffer.attach( ios );
this->clear();
std::basic_iostream<CharT>::exceptions(ios.exceptions());
}
void detach()
{
_buffer.detach();
this->clear();
}
void terminate()
{
_buffer.terminate();
}
BasicTextBuffer<intern_type, extern_type>& buffer()
{ return _buffer; }
private:
BasicTextBuffer<intern_type, extern_type> _buffer;
};
/** @brief Text Input Stream for Character conversion
*/
class CXXTOOLS_API TextIStream : public BasicTextIStream<Char, char>
{
public:
typedef TextCodec<cxxtools::Char, char> Codec;
public:
/** @brief Constructor
The stream will read bytes from \a is and use the codec \a codec
for character conversion. The codec will be destroyed by the
buffer of this stream if the codec was constructed with a
refcount of 0.
*/
TextIStream(std::istream& is, Codec* codec);
explicit TextIStream(Codec* codec);
~TextIStream();
};
/** @brief Text Output Stream for Character conversion
*/
class CXXTOOLS_API TextOStream : public BasicTextOStream<Char, char>
{
public:
typedef TextCodec<cxxtools::Char, char> Codec;
public:
/** @brief Constructor
The stream will write bytes to \a os and use the codec \a codec
for character conversion. The codec will be destroyed by the
buffer of this stream if the codec was constructed with a
refcount of 0.
*/
TextOStream(std::ostream& os, Codec* codec);
explicit TextOStream(Codec* codec);
~TextOStream();
};
/** @brief Text Stream for Character conversion
*/
class CXXTOOLS_API TextStream : public BasicTextStream<Char, char>
{
public:
typedef TextCodec<cxxtools::Char, char> Codec;
public:
/** @brief Constructor
The stream will write or write bytes to \a ios and use the codec
\a codec for character conversion. The codec will be destroyed
by the buffer of this stream if the codec was constructed with a
refcount of 0.
*/
TextStream(std::iostream& ios, Codec* codec);
explicit TextStream(Codec* codec);
~TextStream();
};
inline std::basic_ostream<Char>& operator<< (std::basic_ostream<Char>& out, wchar_t ch)
{
return out << Char(ch);
}
inline std::basic_ostream<Char>& operator<< (std::basic_ostream<Char>& out, const wchar_t* str)
{
while (*str)
out << Char(*str++);
return out;
}
} // namespace cxxtools
#endif
|