/////////////////////////////////////////////////////////////////////////////
-// Name: sckstrm.h
+// Name: wx/sckstrm.h
// Purpose: wxSocket*Stream
// Author: Guilhem Lavaux
// Modified by:
// Created: 17/07/97
-// RCS-ID: $Id$
// Copyright: (c)
// Licence: wxWindows licence
/////////////////////////////////////////////////////////////////////////////
#ifndef __SCK_STREAM_H__
#define __SCK_STREAM_H__
-#if defined(__GNUG__) && !defined(__APPLE__)
-#pragma interface
-#endif
-
#include "wx/stream.h"
#if wxUSE_SOCKETS && wxUSE_STREAMS
#include "wx/socket.h"
-class WXDLLIMPEXP_BASE wxSocketOutputStream : public wxOutputStream
+class WXDLLIMPEXP_NET wxSocketOutputStream : public wxOutputStream
{
- public:
- wxSocketOutputStream(wxSocketBase& s);
- ~wxSocketOutputStream();
+public:
+ wxSocketOutputStream(wxSocketBase& s);
+ virtual ~wxSocketOutputStream();
- off_t SeekO( off_t WXUNUSED(pos), wxSeekMode WXUNUSED(mode) )
- { return -1; }
- off_t 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; }
- DECLARE_NO_COPY_CLASS(wxSocketOutputStream)
+ wxDECLARE_NO_COPY_CLASS(wxSocketOutputStream);
};
-class WXDLLIMPEXP_BASE wxSocketInputStream : public wxInputStream
+class WXDLLIMPEXP_NET wxSocketInputStream : public wxInputStream
{
- public:
- wxSocketInputStream(wxSocketBase& s);
- ~wxSocketInputStream();
+public:
+ wxSocketInputStream(wxSocketBase& s);
+ virtual ~wxSocketInputStream();
- off_t SeekI( off_t WXUNUSED(pos), wxSeekMode WXUNUSED(mode) )
- { return -1; }
- off_t 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:
- DECLARE_NO_COPY_CLASS(wxSocketInputStream)
+ wxFileOffset OnSysTell() const
+ { return wxInvalidOffset; }
+ wxFileOffset OnSysSeek(wxFileOffset WXUNUSED(pos), wxSeekMode WXUNUSED(mode))
+ { return wxInvalidOffset; }
+
+ wxDECLARE_NO_COPY_CLASS(wxSocketInputStream);
};
-class WXDLLIMPEXP_BASE wxSocketStream : public wxSocketInputStream,
+class WXDLLIMPEXP_NET wxSocketStream : public wxSocketInputStream,
public wxSocketOutputStream
{
- public:
- wxSocketStream(wxSocketBase& s);
- ~wxSocketStream();
+public:
+ wxSocketStream(wxSocketBase& s);
+ virtual ~wxSocketStream();
+
+ wxDECLARE_NO_COPY_CLASS(wxSocketStream);
};
#endif