Add class factories for filter streams. Also filters now follow the convention
that they own their parent if they are created on a pointer to the parent. git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@42413 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -39,6 +39,7 @@ enum {
|
|||||||
class WXDLLIMPEXP_BASE wxZlibInputStream: public wxFilterInputStream {
|
class WXDLLIMPEXP_BASE wxZlibInputStream: public wxFilterInputStream {
|
||||||
public:
|
public:
|
||||||
wxZlibInputStream(wxInputStream& stream, int flags = wxZLIB_AUTO);
|
wxZlibInputStream(wxInputStream& stream, int flags = wxZLIB_AUTO);
|
||||||
|
wxZlibInputStream(wxInputStream *stream, int flags = wxZLIB_AUTO);
|
||||||
virtual ~wxZlibInputStream();
|
virtual ~wxZlibInputStream();
|
||||||
|
|
||||||
char Peek() { return wxInputStream::Peek(); }
|
char Peek() { return wxInputStream::Peek(); }
|
||||||
@@ -50,6 +51,9 @@ class WXDLLIMPEXP_BASE wxZlibInputStream: public wxFilterInputStream {
|
|||||||
size_t OnSysRead(void *buffer, size_t size);
|
size_t OnSysRead(void *buffer, size_t size);
|
||||||
wxFileOffset OnSysTell() const { return m_pos; }
|
wxFileOffset OnSysTell() const { return m_pos; }
|
||||||
|
|
||||||
|
private:
|
||||||
|
void Init(int flags);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
size_t m_z_size;
|
size_t m_z_size;
|
||||||
unsigned char *m_z_buffer;
|
unsigned char *m_z_buffer;
|
||||||
@@ -65,6 +69,7 @@ class WXDLLIMPEXP_BASE wxZlibInputStream: public wxFilterInputStream {
|
|||||||
class WXDLLIMPEXP_BASE wxZlibOutputStream: public wxFilterOutputStream {
|
class WXDLLIMPEXP_BASE wxZlibOutputStream: public wxFilterOutputStream {
|
||||||
public:
|
public:
|
||||||
wxZlibOutputStream(wxOutputStream& stream, int level = -1, int flags = wxZLIB_ZLIB);
|
wxZlibOutputStream(wxOutputStream& stream, int level = -1, int flags = wxZLIB_ZLIB);
|
||||||
|
wxZlibOutputStream(wxOutputStream *stream, int level = -1, int flags = wxZLIB_ZLIB);
|
||||||
virtual ~wxZlibOutputStream() { Close(); }
|
virtual ~wxZlibOutputStream() { Close(); }
|
||||||
|
|
||||||
void Sync() { DoFlush(false); }
|
void Sync() { DoFlush(false); }
|
||||||
@@ -79,6 +84,9 @@ class WXDLLIMPEXP_BASE wxZlibOutputStream: public wxFilterOutputStream {
|
|||||||
|
|
||||||
virtual void DoFlush(bool final);
|
virtual void DoFlush(bool final);
|
||||||
|
|
||||||
|
private:
|
||||||
|
void Init(int level, int flags);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
size_t m_z_size;
|
size_t m_z_size;
|
||||||
unsigned char *m_z_buffer;
|
unsigned char *m_z_buffer;
|
||||||
@@ -88,6 +96,48 @@ class WXDLLIMPEXP_BASE wxZlibOutputStream: public wxFilterOutputStream {
|
|||||||
DECLARE_NO_COPY_CLASS(wxZlibOutputStream)
|
DECLARE_NO_COPY_CLASS(wxZlibOutputStream)
|
||||||
};
|
};
|
||||||
|
|
||||||
|
class WXDLLIMPEXP_BASE wxZlibClassFactory: public wxFilterClassFactory
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
wxZlibClassFactory();
|
||||||
|
|
||||||
|
wxFilterInputStream *NewStream(wxInputStream& stream) const
|
||||||
|
{ return new wxZlibInputStream(stream); }
|
||||||
|
wxFilterOutputStream *NewStream(wxOutputStream& stream) const
|
||||||
|
{ return new wxZlibOutputStream(stream, -1); }
|
||||||
|
wxFilterInputStream *NewStream(wxInputStream *stream) const
|
||||||
|
{ return new wxZlibInputStream(stream); }
|
||||||
|
wxFilterOutputStream *NewStream(wxOutputStream *stream) const
|
||||||
|
{ return new wxZlibOutputStream(stream, -1); }
|
||||||
|
|
||||||
|
const wxChar * const *GetProtocols(wxStreamProtocolType type
|
||||||
|
= wxSTREAM_PROTOCOL) const;
|
||||||
|
|
||||||
|
private:
|
||||||
|
DECLARE_DYNAMIC_CLASS(wxZlibClassFactory)
|
||||||
|
};
|
||||||
|
|
||||||
|
class WXDLLIMPEXP_BASE wxGzipClassFactory: public wxFilterClassFactory
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
wxGzipClassFactory();
|
||||||
|
|
||||||
|
wxFilterInputStream *NewStream(wxInputStream& stream) const
|
||||||
|
{ return new wxZlibInputStream(stream); }
|
||||||
|
wxFilterOutputStream *NewStream(wxOutputStream& stream) const
|
||||||
|
{ return new wxZlibOutputStream(stream, -1); }
|
||||||
|
wxFilterInputStream *NewStream(wxInputStream *stream) const
|
||||||
|
{ return new wxZlibInputStream(stream); }
|
||||||
|
wxFilterOutputStream *NewStream(wxOutputStream *stream) const
|
||||||
|
{ return new wxZlibOutputStream(stream, -1); }
|
||||||
|
|
||||||
|
const wxChar * const *GetProtocols(wxStreamProtocolType type
|
||||||
|
= wxSTREAM_PROTOCOL) const;
|
||||||
|
|
||||||
|
private:
|
||||||
|
DECLARE_DYNAMIC_CLASS(wxGzipClassFactory)
|
||||||
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
// wxUSE_ZLIB && wxUSE_STREAMS
|
// wxUSE_ZLIB && wxUSE_STREAMS
|
||||||
|
|
||||||
|
@@ -43,12 +43,89 @@ enum {
|
|||||||
ZSTREAM_AUTO = 0x20 // auto detect between gzip and zlib
|
ZSTREAM_AUTO = 0x20 // auto detect between gzip and zlib
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
/////////////////////////////////////////////////////////////////////////////
|
||||||
|
// Zlib Class factory
|
||||||
|
|
||||||
|
IMPLEMENT_DYNAMIC_CLASS(wxZlibClassFactory, wxFilterClassFactory)
|
||||||
|
|
||||||
|
static wxZlibClassFactory g_wxZlibClassFactory;
|
||||||
|
|
||||||
|
wxZlibClassFactory::wxZlibClassFactory()
|
||||||
|
{
|
||||||
|
if (this == &g_wxZlibClassFactory)
|
||||||
|
PushFront();
|
||||||
|
}
|
||||||
|
|
||||||
|
const wxChar * const *
|
||||||
|
wxZlibClassFactory::GetProtocols(wxStreamProtocolType type) const
|
||||||
|
{
|
||||||
|
static const wxChar *mimes[] = { _T("application/x-deflate"), NULL };
|
||||||
|
static const wxChar *encs[] = { _T("deflate"), NULL };
|
||||||
|
static const wxChar *empty[] = { NULL };
|
||||||
|
|
||||||
|
switch (type) {
|
||||||
|
case wxSTREAM_MIMETYPE: return mimes;
|
||||||
|
case wxSTREAM_ENCODING: return encs;
|
||||||
|
default: return empty;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/////////////////////////////////////////////////////////////////////////////
|
||||||
|
// Gzip Class factory
|
||||||
|
|
||||||
|
IMPLEMENT_DYNAMIC_CLASS(wxGzipClassFactory, wxFilterClassFactory)
|
||||||
|
|
||||||
|
static wxGzipClassFactory g_wxGzipClassFactory;
|
||||||
|
|
||||||
|
wxGzipClassFactory::wxGzipClassFactory()
|
||||||
|
{
|
||||||
|
if (this == &g_wxGzipClassFactory && wxZlibInputStream::CanHandleGZip())
|
||||||
|
PushFront();
|
||||||
|
}
|
||||||
|
|
||||||
|
const wxChar * const *
|
||||||
|
wxGzipClassFactory::GetProtocols(wxStreamProtocolType type) const
|
||||||
|
{
|
||||||
|
static const wxChar *protos[] =
|
||||||
|
{ _T("gzip"), NULL };
|
||||||
|
static const wxChar *mimes[] =
|
||||||
|
{ _T("application/gzip"), _T("application/x-gzip"), NULL };
|
||||||
|
static const wxChar *encs[] =
|
||||||
|
{ _T("gzip"), NULL };
|
||||||
|
static const wxChar *exts[] =
|
||||||
|
{ _T(".gz"), _T(".gzip"), NULL };
|
||||||
|
static const wxChar *empty[] =
|
||||||
|
{ NULL };
|
||||||
|
|
||||||
|
switch (type) {
|
||||||
|
case wxSTREAM_PROTOCOL: return protos;
|
||||||
|
case wxSTREAM_MIMETYPE: return mimes;
|
||||||
|
case wxSTREAM_ENCODING: return encs;
|
||||||
|
case wxSTREAM_FILEEXTENSION: return exts;
|
||||||
|
default: return empty;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
//////////////////////
|
//////////////////////
|
||||||
// wxZlibInputStream
|
// wxZlibInputStream
|
||||||
//////////////////////
|
//////////////////////
|
||||||
|
|
||||||
wxZlibInputStream::wxZlibInputStream(wxInputStream& stream, int flags)
|
wxZlibInputStream::wxZlibInputStream(wxInputStream& stream, int flags)
|
||||||
: wxFilterInputStream(stream)
|
: wxFilterInputStream(stream)
|
||||||
|
{
|
||||||
|
Init(flags);
|
||||||
|
}
|
||||||
|
|
||||||
|
wxZlibInputStream::wxZlibInputStream(wxInputStream *stream, int flags)
|
||||||
|
: wxFilterInputStream(stream)
|
||||||
|
{
|
||||||
|
Init(flags);
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxZlibInputStream::Init(int flags)
|
||||||
{
|
{
|
||||||
m_inflate = NULL;
|
m_inflate = NULL;
|
||||||
m_z_buffer = new unsigned char[ZSTREAM_BUFFER_SIZE];
|
m_z_buffer = new unsigned char[ZSTREAM_BUFFER_SIZE];
|
||||||
@@ -192,6 +269,19 @@ wxZlibOutputStream::wxZlibOutputStream(wxOutputStream& stream,
|
|||||||
int level,
|
int level,
|
||||||
int flags)
|
int flags)
|
||||||
: wxFilterOutputStream(stream)
|
: wxFilterOutputStream(stream)
|
||||||
|
{
|
||||||
|
Init(level, flags);
|
||||||
|
}
|
||||||
|
|
||||||
|
wxZlibOutputStream::wxZlibOutputStream(wxOutputStream *stream,
|
||||||
|
int level,
|
||||||
|
int flags)
|
||||||
|
: wxFilterOutputStream(stream)
|
||||||
|
{
|
||||||
|
Init(level, flags);
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxZlibOutputStream::Init(int level, int flags)
|
||||||
{
|
{
|
||||||
m_deflate = NULL;
|
m_deflate = NULL;
|
||||||
m_z_buffer = new unsigned char[ZSTREAM_BUFFER_SIZE];
|
m_z_buffer = new unsigned char[ZSTREAM_BUFFER_SIZE];
|
||||||
@@ -250,7 +340,8 @@ bool wxZlibOutputStream::Close()
|
|||||||
m_deflate = NULL;
|
m_deflate = NULL;
|
||||||
delete[] m_z_buffer;
|
delete[] m_z_buffer;
|
||||||
m_z_buffer = NULL;
|
m_z_buffer = NULL;
|
||||||
return IsOk();
|
|
||||||
|
return wxFilterOutputStream::Close() && IsOk();
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxZlibOutputStream::DoFlush(bool final)
|
void wxZlibOutputStream::DoFlush(bool final)
|
||||||
|
Reference in New Issue
Block a user