]>
git.saurik.com Git - wxWidgets.git/blob - interface/wx/zstream.h
   1 ///////////////////////////////////////////////////////////////////////////// 
   3 // Purpose:     interface of wxZlibOutputStream 
   4 // Author:      wxWidgets team 
   6 // Licence:     wxWindows license 
   7 ///////////////////////////////////////////////////////////////////////////// 
  11 enum wxZlibCompressionLevels 
{ 
  12     wxZ_DEFAULT_COMPRESSION 
= -1, 
  13     wxZ_NO_COMPRESSION 
= 0, 
  15     wxZ_BEST_COMPRESSION 
= 9 
  20     wxZLIB_NO_HEADER 
= 0,    //!< raw deflate stream, no header or checksum 
  21     wxZLIB_ZLIB 
= 1,         //!< zlib header and checksum 
  22     wxZLIB_GZIP 
= 2,         //!< gzip header and checksum, requires zlib 1.2.1+ 
  23     wxZLIB_AUTO 
= 3          //!< autodetect header zlib or gzip 
  28     @class wxZlibOutputStream 
  30     This stream compresses all data written to it. 
  32     The compressed output can be in zlib or gzip format. 
  33     Note that writing the gzip format requires zlib version 1.2.1 or greater 
  34     (the builtin version does support gzip format). 
  36     The stream is not seekable, wxOutputStream::SeekO() returns 
  42     @see wxOutputStream, wxZlibInputStream 
  44 class wxZlibOutputStream 
: public wxFilterOutputStream
 
  49         Creates a new write-only compressed stream. 
  51         @a level means level of compression. It is number between 0 and 9 
  52         (including these values) where 0 means no compression and 9 best but 
  53         slowest compression. -1 is default value (currently equivalent to 6). 
  55         If the parent stream is passed as a pointer then the new filter stream 
  56         takes ownership of it. If it is passed by reference then it does not. 
  58         The @a flags wxZLIB_ZLIB and wxZLIB_GZIP specify whether the output data 
  59         will be in zlib or gzip format. wxZLIB_ZLIB is the default. 
  61         If @a flags is wxZLIB_NO_HEADER, then a raw deflate stream is output 
  62         without either zlib or gzip headers. This is a lower level mode, which 
  63         is not usually used directly. It can be used to embed a raw deflate 
  64         stream in a higher level protocol. 
  66         The values of the ::wxZlibCompressionLevels and ::wxZLibFlags 
  67         enumerations can be used. 
  69     wxZlibOutputStream(wxOutputStream
& stream
, int level 
= -1, 
  70                        int flags 
= wxZLIB_ZLIB
); 
  71     wxZlibOutputStream(wxOutputStream
* stream
, int level 
= -1, 
  72                        int flags 
= wxZLIB_ZLIB
); 
  76         Returns @true if zlib library in use can handle gzip compressed data. 
  78     static bool CanHandleGZip(); 
  84     @class wxZlibInputStream 
  86     This filter stream decompresses a stream that is in zlib or gzip format. 
  87     Note that reading the gzip format requires zlib version 1.2.1 or greater, 
  88     (the builtin version does support gzip format). 
  90     The stream is not seekable, wxInputStream::SeekI returns ::wxInvalidOffset. 
  91     Also wxStreamBase::GetSize() is not supported, it always returns 0. 
  96     @see wxInputStream, wxZlibOutputStream. 
  98 class wxZlibInputStream 
: public wxFilterInputStream
 
 103         If the parent stream is passed as a pointer then the new filter stream 
 104         takes ownership of it. If it is passed by reference then it does not. 
 106         The @a flags wxZLIB_ZLIB and wxZLIB_GZIP specify whether the input data 
 107         is in zlib or gzip format. If wxZLIB_AUTO is used, then zlib will 
 108         autodetect the stream type, this is the default. 
 110         If @a flags is wxZLIB_NO_HEADER, then the data is assumed to be a raw 
 111         deflate stream without either zlib or gzip headers. This is a lower level 
 112         mode, which is not usually used directly. It can be used to read a raw 
 113         deflate stream embedded in a higher level protocol. 
 115         The values of the ::wxZLibFlags enumeration can be used. 
 117     wxZlibInputStream(wxInputStream
& stream
, int flags 
= wxZLIB_AUTO
); 
 118     wxZlibInputStream(wxInputStream
* stream
, int flags 
= wxZLIB_AUTO
); 
 122         Returns @true if zlib library in use can handle gzip compressed data. 
 124     static bool CanHandleGZip();