class WXDLLIMPEXP_NET wxSocketOutputStream : public wxOutputStream
{
- public:
- wxSocketOutputStream(wxSocketBase& s);
- virtual ~wxSocketOutputStream();
+public:
+ wxSocketOutputStream(wxSocketBase& s);
+ virtual ~wxSocketOutputStream();
- wxFileOffset SeekO( wxFileOffset WXUNUSED(pos), wxSeekMode WXUNUSED(mode) )
- { return -1; }
- wxFileOffset TellO() const
- { return -1; }
+protected:
+ wxSocketBase *m_o_socket;
- protected:
- wxSocketBase *m_o_socket;
+ size_t OnSysWrite(const void *buffer, size_t bufsize);
- size_t OnSysWrite(const void *buffer, size_t bufsize);
+ // socket streams are both un-seekable and size-less streams:
+ wxFileOffset OnSysTell() const
+ { return wxInvalidOffset; }
+ wxFileOffset OnSysSeek(wxFileOffset WXUNUSED(pos), wxSeekMode WXUNUSED(mode))
+ { return wxInvalidOffset; }
wxDECLARE_NO_COPY_CLASS(wxSocketOutputStream);
};
class WXDLLIMPEXP_NET wxSocketInputStream : public wxInputStream
{
- public:
- wxSocketInputStream(wxSocketBase& s);
- virtual ~wxSocketInputStream();
+public:
+ wxSocketInputStream(wxSocketBase& s);
+ virtual ~wxSocketInputStream();
- wxFileOffset SeekI( wxFileOffset WXUNUSED(pos), wxSeekMode WXUNUSED(mode) )
- { return -1; }
- wxFileOffset TellI() const
- { return -1; }
+protected:
+ wxSocketBase *m_i_socket;
- protected:
- wxSocketBase *m_i_socket;
+ size_t OnSysRead(void *buffer, size_t bufsize);
- size_t OnSysRead(void *buffer, size_t bufsize);
+ // socket streams are both un-seekable and size-less streams:
+
+ wxFileOffset OnSysTell() const
+ { return wxInvalidOffset; }
+ wxFileOffset OnSysSeek(wxFileOffset WXUNUSED(pos), wxSeekMode WXUNUSED(mode))
+ { return wxInvalidOffset; }
wxDECLARE_NO_COPY_CLASS(wxSocketInputStream);
};
class WXDLLIMPEXP_NET wxSocketStream : public wxSocketInputStream,
public wxSocketOutputStream
{
- public:
- wxSocketStream(wxSocketBase& s);
- virtual ~wxSocketStream();
+public:
+ wxSocketStream(wxSocketBase& s);
+ virtual ~wxSocketStream();
- wxDECLARE_NO_COPY_CLASS(wxSocketStream);
+ wxDECLARE_NO_COPY_CLASS(wxSocketStream);
};
#endif
int iSel = wxNOT_FOUND;
// remember how many bytes we read from the stream:
- wxFileOffset offset = sizeof(IconDir);
+ wxFileOffset alreadySeeked = sizeof(IconDir);
for (unsigned int i = 0; i < nIcons; i++ )
{
- offset += stream.Read(pCurrentEntry, sizeof(ICONDIRENTRY)).LastRead();
+ alreadySeeked += stream.Read(pCurrentEntry, sizeof(ICONDIRENTRY)).LastRead();
// bHeight and bColorCount are wxUint8
if ( pCurrentEntry->bWidth >= wMax )
// NOTE: seeking a positive amount in wxFromCurrent mode allows us to
// load even non-seekable streams (see wxInputStream::SeekI docs)!
- if (stream.SeekI(wxUINT32_SWAP_ON_BE(pCurrentEntry->dwImageOffset) - offset,
- wxFromCurrent) == wxInvalidOffset)
+ wxFileOffset offset = wxUINT32_SWAP_ON_BE(pCurrentEntry->dwImageOffset) - alreadySeeked;
+ if (offset != 0 && stream.SeekI(offset, wxFromCurrent) == wxInvalidOffset)
return false;
bResult = LoadDib(image, stream, true, IsBmp);