X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/79c3e0e1aeebb64da2ac893e6ed7b27edca01a64..43cf637fac1894db167f0ed34d1958107a48ea85:/include/wx/mstream.h diff --git a/include/wx/mstream.h b/include/wx/mstream.h index 641c0d4244..97d6f5e00b 100644 --- a/include/wx/mstream.h +++ b/include/wx/mstream.h @@ -1,5 +1,5 @@ ///////////////////////////////////////////////////////////////////////////// -// Name: mstream.h +// Name: wx/mstream.h // Purpose: Memory stream classes // Author: Guilhem Lavaux // Modified by: @@ -8,71 +8,102 @@ // Copyright: (c) Guilhem Lavaux // Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// -#ifndef __WXMMSTREAM_H__ -#define __WXMMSTREAM_H__ -#include +#ifndef _WX_WXMMSTREAM_H__ +#define _WX_WXMMSTREAM_H__ -class wxMemoryStreamBase { - protected: - wxMemoryStreamBase(); - virtual ~wxMemoryStreamBase(); +#include "wx/defs.h" - bool ChangeBufferSize(size_t new_length); +#if wxUSE_STREAMS - protected: - bool m_persistent; - size_t m_length; - char *m_buffer; - int m_iolimit; -}; +#include "wx/stream.h" -class wxMemoryInputStream: virtual public wxMemoryStreamBase, public wxInputStream { - DECLARE_CLASS(wxMemoryInputStream) - public: - wxMemoryInputStream(const char *data, size_t length); - virtual ~wxMemoryInputStream(); - - wxInputStream& Read(void *buffer, size_t size); - off_t SeekI(off_t pos, wxSeekMode mode); - off_t TellI() const { return m_position_i; } - - bool Eof() const { return m_eof; } - size_t LastRead() const { return m_lastread; } - - protected: - bool m_eof; - off_t m_position_i; - size_t m_lastread; -}; +class WXDLLIMPEXP_FWD_BASE wxMemoryOutputStream; + +class WXDLLIMPEXP_BASE wxMemoryInputStream : public wxInputStream +{ +public: + wxMemoryInputStream(const void *data, size_t length); + wxMemoryInputStream(const wxMemoryOutputStream& stream); + wxMemoryInputStream(wxInputStream& stream, + wxFileOffset lenFile = wxInvalidOffset) + { + InitFromStream(stream, lenFile); + } + wxMemoryInputStream(wxMemoryInputStream& stream) + { + InitFromStream(stream, wxInvalidOffset); + } + + virtual ~wxMemoryInputStream(); + virtual wxFileOffset GetLength() const { return m_length; } + virtual bool IsSeekable() const { return true; } -class wxMemoryOutputStream: virtual public wxMemoryStreamBase, public wxOutputStream { - DECLARE_CLASS(wxMemoryOutputStream) - public: - wxMemoryOutputStream(char *data = NULL, size_t length = 0); - virtual ~wxMemoryOutputStream(); + virtual char Peek(); + virtual bool CanRead() const; - wxOutputStream& Write(const void *buffer, size_t size); - off_t SeekO(off_t pos, wxSeekMode mode); - off_t TellO() const { return m_position_o; } + wxStreamBuffer *GetInputStreamBuffer() const { return m_i_streambuf; } - bool Bad() const { return m_bad; } - size_t LastWrite() const { return m_lastwrite; } +#if WXWIN_COMPATIBILITY_2_6 + // deprecated, compatibility only + wxDEPRECATED( wxStreamBuffer *InputStreamBuffer() const ); +#endif // WXWIN_COMPATIBILITY_2_6 - char *GetData() { return m_buffer; } - size_t GetLength() { return m_length; } +protected: + wxStreamBuffer *m_i_streambuf; - protected: - bool m_bad; - off_t m_position_o; - size_t m_lastwrite; + size_t OnSysRead(void *buffer, size_t nbytes); + wxFileOffset OnSysSeek(wxFileOffset pos, wxSeekMode mode); + wxFileOffset OnSysTell() const; + +private: + // common part of ctors taking wxInputStream + void InitFromStream(wxInputStream& stream, wxFileOffset lenFile); + + size_t m_length; + + // copy ctor is implemented above: it copies the other stream in this one + DECLARE_ABSTRACT_CLASS(wxMemoryInputStream) + DECLARE_NO_ASSIGN_CLASS(wxMemoryInputStream) }; -class wxMemoryStream: public wxMemoryInputStream, public wxMemoryOutputStream { - DECLARE_CLASS(wxMemoryStream) - public: - wxMemoryStream(char *data = NULL, size_t length = 0); - virtual ~wxMemoryStream(); +class WXDLLIMPEXP_BASE wxMemoryOutputStream : public wxOutputStream +{ +public: + // if data is !NULL it must be allocated with malloc() + wxMemoryOutputStream(void *data = NULL, size_t length = 0); + virtual ~wxMemoryOutputStream(); + virtual wxFileOffset GetLength() const { return m_o_streambuf->GetLastAccess(); } + virtual bool IsSeekable() const { return true; } + + size_t CopyTo(void *buffer, size_t len) const; + + wxStreamBuffer *GetOutputStreamBuffer() const { return m_o_streambuf; } + +#if WXWIN_COMPATIBILITY_2_6 + // deprecated, compatibility only + wxDEPRECATED( wxStreamBuffer *OutputStreamBuffer() const ); +#endif // WXWIN_COMPATIBILITY_2_6 + +protected: + wxStreamBuffer *m_o_streambuf; + +protected: + size_t OnSysWrite(const void *buffer, size_t nbytes); + wxFileOffset OnSysSeek(wxFileOffset pos, wxSeekMode mode); + wxFileOffset OnSysTell() const; + + DECLARE_DYNAMIC_CLASS(wxMemoryOutputStream) + DECLARE_NO_COPY_CLASS(wxMemoryOutputStream) }; +#if WXWIN_COMPATIBILITY_2_6 + inline wxStreamBuffer *wxMemoryInputStream::InputStreamBuffer() const { return m_i_streambuf; } + inline wxStreamBuffer *wxMemoryOutputStream::OutputStreamBuffer() const { return m_o_streambuf; } +#endif // WXWIN_COMPATIBILITY_2_6 + +#endif + // wxUSE_STREAMS + #endif + // _WX_WXMMSTREAM_H__