X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/e49f47aa77457548df1a86f74c285ea3226b3cce..9b61f868b597a84fd3c589b2e8539624c491f86b:/include/wx/datstrm.h diff --git a/include/wx/datstrm.h b/include/wx/datstrm.h index 8d5b759dcd..ee557221a2 100644 --- a/include/wx/datstrm.h +++ b/include/wx/datstrm.h @@ -9,8 +9,8 @@ // Licence: wxWindows license ///////////////////////////////////////////////////////////////////////////// -#ifndef __DATSTREAMH__ -#define __DATSTREAMH__ +#ifndef _WX_DATSTREAM_H_ +#define _WX_DATSTREAM_H_ #ifdef __GNUG__ #pragma interface "datstrm.h" @@ -18,31 +18,65 @@ #include -class wxDataInputStream: public wxFilterInputStream { +#if wxUSE_STREAMS + +class WXDLLEXPORT wxDataInputStream { public: wxDataInputStream(wxInputStream& s); - virtual ~wxDataInputStream(); + ~wxDataInputStream(); - unsigned long Read32(); - unsigned short Read16(); - unsigned char Read8(); + wxUint32 Read32(); + wxUint16 Read16(); + wxUint8 Read8(); double ReadDouble(); - wxString ReadLine(); wxString ReadString(); + + wxDataInputStream& operator>>(wxString& s); + wxDataInputStream& operator>>(wxInt8& c); + wxDataInputStream& operator>>(wxInt16& i); + wxDataInputStream& operator>>(wxInt32& i); + wxDataInputStream& operator>>(wxUint8& c); + wxDataInputStream& operator>>(wxUint16& i); + wxDataInputStream& operator>>(wxUint32& i); + wxDataInputStream& operator>>(double& i); + wxDataInputStream& operator>>(float& f); + + void BidEndianOrdered(bool be_order) { m_be_order = be_order; } + protected: + wxInputStream *m_input; + bool m_be_order; }; -class wxDataOutputStream: public wxFilterOutputStream { +class WXDLLEXPORT wxDataOutputStream { public: wxDataOutputStream(wxOutputStream& s); - virtual ~wxDataOutputStream(); + ~wxDataOutputStream(); - void Write32(unsigned long i); - void Write16(unsigned short i); - void Write8(unsigned char i); + void Write32(wxUint32 i); + void Write16(wxUint16 i); + void Write8(wxUint8 i); void WriteDouble(double d); - void WriteLine(const wxString& line); void WriteString(const wxString& string); + + wxDataOutputStream& operator<<(const wxChar *string); + wxDataOutputStream& operator<<(wxString& string); + wxDataOutputStream& operator<<(wxInt8 c); + wxDataOutputStream& operator<<(wxInt16 i); + wxDataOutputStream& operator<<(wxInt32 i); + wxDataOutputStream& operator<<(wxUint8 c); + wxDataOutputStream& operator<<(wxUint16 i); + wxDataOutputStream& operator<<(wxUint32 i); + wxDataOutputStream& operator<<(double f); + wxDataOutputStream& operator<<(float f); + + void BidEndianOrdered(bool be_order) { m_be_order = be_order; } + protected: + wxOutputStream *m_output; + bool m_be_order; }; #endif - // __DATSTREAMH__ + // wxUSE_STREAMS + +#endif + // _WX_DATSTREAM_H_