1 | These classes provide a C++ stream interface to the zlib library. It allows you
|
---|
2 | to do things like:
|
---|
3 |
|
---|
4 | gzofstream outf("blah.gz");
|
---|
5 | outf << "These go into the gzip file " << 123 << endl;
|
---|
6 |
|
---|
7 | It does this by deriving a specialized stream buffer for gzipped files, which is
|
---|
8 | the way Stroustrup would have done it. :->
|
---|
9 |
|
---|
10 | The gzifstream and gzofstream classes were originally written by Kevin Ruland
|
---|
11 | and made available in the zlib contrib/iostream directory. The older version still
|
---|
12 | compiles under gcc 2.xx, but not under gcc 3.xx, which sparked the development of
|
---|
13 | this version.
|
---|
14 |
|
---|
15 | The new classes are as standard-compliant as possible, closely following the
|
---|
16 | approach of the standard library's fstream classes. It compiles under gcc versions
|
---|
17 | 3.2 and 3.3, but not under gcc 2.xx. This is mainly due to changes in the standard
|
---|
18 | library naming scheme. The new version of gzifstream/gzofstream/gzfilebuf differs
|
---|
19 | from the previous one in the following respects:
|
---|
20 | - added showmanyc
|
---|
21 | - added setbuf, with support for unbuffered output via setbuf(0,0)
|
---|
22 | - a few bug fixes of stream behavior
|
---|
23 | - gzipped output file opened with default compression level instead of maximum level
|
---|
24 | - setcompressionlevel()/strategy() members replaced by single setcompression()
|
---|
25 |
|
---|
26 | The code is provided "as is", with the permission to use, copy, modify, distribute
|
---|
27 | and sell it for any purpose without fee.
|
---|
28 |
|
---|
29 | Ludwig Schwardt
|
---|
30 | <schwardt@sun.ac.za>
|
---|
31 |
|
---|
32 | DSP Lab
|
---|
33 | Electrical & Electronic Engineering Department
|
---|
34 | University of Stellenbosch
|
---|
35 | South Africa
|
---|