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; }
- char Peek();
+ virtual char Peek();
+ virtual bool CanRead() const;
wxStreamBuffer *GetInputStreamBuffer() const { return m_i_streambuf; }
+#if WXWIN_COMPATIBILITY_2_6
// deprecated, compatibility only
- wxStreamBuffer *InputStreamBuffer() const { return m_i_streambuf; }
+ wxDEPRECATED( wxStreamBuffer *InputStreamBuffer() const );
+#endif // WXWIN_COMPATIBILITY_2_6
protected:
wxStreamBuffer *m_i_streambuf;
wxFileOffset OnSysTell() const;
private:
+ // common part of ctors taking wxInputStream
+ void InitFromStream(wxInputStream& stream, wxFileOffset lenFile);
+
size_t m_length;
- DECLARE_NO_COPY_CLASS(wxMemoryInputStream)
+ // copy ctor is implemented above: it copies the other stream in this one
+ DECLARE_NO_ASSIGN_CLASS(wxMemoryInputStream)
};
class WXDLLIMPEXP_BASE wxMemoryOutputStream : public wxOutputStream
wxStreamBuffer *GetOutputStreamBuffer() const { return m_o_streambuf; }
+#if WXWIN_COMPATIBILITY_2_6
// deprecated, compatibility only
- wxStreamBuffer *OutputStreamBuffer() const { return m_o_streambuf; }
+ wxDEPRECATED( wxStreamBuffer *OutputStreamBuffer() const );
+#endif // WXWIN_COMPATIBILITY_2_6
protected:
wxStreamBuffer *m_o_streambuf;
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__
-