X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/34138703c3997ce676a1e713d9ff9eb020640da7..12ed316d02733e7111a6967f6ae41e2c0ceaa57a:/include/wx/mstream.h?ds=sidebyside diff --git a/include/wx/mstream.h b/include/wx/mstream.h index a07ce80ceb..bdb4a65997 100644 --- a/include/wx/mstream.h +++ b/include/wx/mstream.h @@ -8,64 +8,60 @@ // Copyright: (c) Guilhem Lavaux // Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// + #ifndef _WX_WXMMSTREAM_H__ #define _WX_WXMMSTREAM_H__ -#include +#include "wx/stream.h" -class wxMemoryStreamBase { - protected: - wxMemoryStreamBase(); - virtual ~wxMemoryStreamBase(); +#if wxUSE_STREAMS - bool ChangeBufferSize(size_t new_length); +class WXDLLEXPORT wxMemoryInputStream : public wxInputStream +{ +public: + wxMemoryInputStream(const char *data, size_t length); + virtual ~wxMemoryInputStream(); + virtual size_t GetSize() const { return m_length; } + virtual bool Eof() const; - protected: - bool m_persistent; - size_t m_length; - char *m_buffer; - int m_iolimit; -}; + char Peek(); -class wxMemoryInputStream: virtual public wxMemoryStreamBase, public wxInputStream { - public: - wxMemoryInputStream(const char *data, size_t length); - virtual ~wxMemoryInputStream(); + wxStreamBuffer *InputStreamBuffer() const { return m_i_streambuf; } - char Peek(); +protected: + wxStreamBuffer *m_i_streambuf; - protected: - - size_t DoRead(void *buffer, size_t size); - off_t DoSeekInput(off_t pos, wxSeekMode mode); - off_t DoTellInput() const { return m_position_i; } + size_t OnSysRead(void *buffer, size_t nbytes); + off_t OnSysSeek(off_t pos, wxSeekMode mode); + off_t OnSysTell() const; - protected: - off_t m_position_i; +private: + size_t m_length; }; -class wxMemoryOutputStream: virtual public wxMemoryStreamBase, public wxOutputStream { - public: - wxMemoryOutputStream(char *data = NULL, size_t length = 0); - virtual ~wxMemoryOutputStream(); +class WXDLLEXPORT wxMemoryOutputStream : public wxOutputStream +{ +public: + wxMemoryOutputStream(char *data = NULL, size_t length = 0); + virtual ~wxMemoryOutputStream(); + virtual size_t GetSize() const { return m_o_streambuf->GetLastAccess(); } - char *GetData() { Sync(); return m_buffer; } - size_t GetLength() { Sync(); return m_length; } + wxStreamBuffer *OutputStreamBuffer() const { return m_o_streambuf; } - protected: + size_t CopyTo(char *buffer, size_t len) const; - size_t DoWrite(const void *buffer, size_t size); - off_t DoSeekOutput(off_t pos, wxSeekMode mode); - off_t DoTellOutput() const { return m_position_o; } +protected: + wxStreamBuffer *m_o_streambuf; - protected: - off_t m_position_o; +protected: + size_t OnSysWrite(const void *buffer, size_t nbytes); + off_t OnSysSeek(off_t pos, wxSeekMode mode); + off_t OnSysTell() const; }; -class wxMemoryStream: public wxMemoryInputStream, public wxMemoryOutputStream { - public: - wxMemoryStream(char *data = NULL, size_t length = 0); - virtual ~wxMemoryStream(); -}; +#endif + // wxUSE_STREAMS #endif + // _WX_WXMMSTREAM_H__ +