SYNOPSIS

#include <deflateoutputstreambuf.h>

Inherits zipios::FilterOutputStreambuf.

Inherited by zipios::GZIPOutputStreambuf, and zipios::ZipOutputStreambuf.

Public Member Functions

DeflateOutputStreambuf (streambuf *outbuf, bool user_init=false, bool del_outbuf=false)

DeflateOutputStreambuf constructor. virtual ~DeflateOutputStreambuf ()

Destructor. bool init (int comp_level=6)

bool closeStream ()

uint32 getCrc32 () const

Returns the CRC32 for the current stream. uint32 getCount () const

Returns the number of bytes written to the streambuf, that has been processed from the input buffer by the compressor.

Protected Member Functions

virtual int overflow (int c=EOF)

virtual int sync ()

bool flushOutvec ()

Flushes _outvec and updates _zs.next_out and _zs.avail_out. void endDeflation ()

Flushes the remaining data in the zlib buffers, after which the only possible operations are deflateEnd() or deflateReset().

Protected Attributes

const int _invecsize

vector< char > _invec

const int _outvecsize

vector< char > _outvec

uint32 _crc32

uint32 _overflown_bytes

Detailed Description

DeflateOutputStreambuf is an output stream filter, that deflates the data that is written to it before it passes it on to the output stream it is attached to.

Deflation/Inflation is a compression/decompression method used in gzip and zip. The zlib library is used to perform the actual deflation, this class only wraps the functionality in an output stream filter.

Definition at line 25 of file deflateoutputstreambuf.h.

Constructor & Destructor Documentation

zipios::DeflateOutputStreambuf::DeflateOutputStreambuf (streambuf *outbuf, booluser_init = \fCfalse\fP, booldel_outbuf = \fCfalse\fP)\fC [explicit]\fP

DeflateOutputStreambuf constructor. Parameters:

outbuf the streambuf to use for output.

user_init If false user must invoke init() before writing any data. (ZipOutputStreambuf needs to do this)

del_outbuf if true is specified outbuf will be deleted, when the DeflateOutputStreambuf is destructed.

Definition at line 18 of file deflateoutputstreambuf.cpp.

zipios::DeflateOutputStreambuf::~DeflateOutputStreambuf ()\fC [virtual]\fP

Destructor.

Definition at line 43 of file deflateoutputstreambuf.cpp.

Member Function Documentation

void zipios::DeflateOutputStreambuf::endDeflation ()\fC [protected]\fP

Flushes the remaining data in the zlib buffers, after which the only possible operations are deflateEnd() or deflateReset().

Definition at line 173 of file deflateoutputstreambuf.cpp.

bool zipios::DeflateOutputStreambuf::flushOutvec ()\fC [protected]\fP

Flushes _outvec and updates _zs.next_out and _zs.avail_out.

Definition at line 162 of file deflateoutputstreambuf.cpp.

uint32 zipios::DeflateOutputStreambuf::getCount () const\fC [inline]\fP

Returns the number of bytes written to the streambuf, that has been processed from the input buffer by the compressor. After closeStream() has been called this number is the total number of bytes written to the stream.

Definition at line 55 of file deflateoutputstreambuf.h.

uint32 zipios::DeflateOutputStreambuf::getCrc32 () const\fC [inline]\fP

Returns the CRC32 for the current stream. The returned value is the CRC for the data that has been compressed already (due to a call to overflow()). As DeflateOutputStreambuf may buffer an arbitrary amount of bytes until closeStream() has been invoked, the returned value is not very useful before closeStream() has been called.

Definition at line 49 of file deflateoutputstreambuf.h.

Author

Generated automatically by Doxygen for Zipios++ from the source code.