X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/dbd300df5c4abfd161e3cc233e87a0a71f544cbe..c32cfa3641288eea409ee54b99baa9ff176dc64b:/include/wx/socket.h diff --git a/include/wx/socket.h b/include/wx/socket.h index 1b23f7c075..762e01c863 100644 --- a/include/wx/socket.h +++ b/include/wx/socket.h @@ -24,15 +24,16 @@ // wxSocket headers (generic) // --------------------------------------------------------------------------- #ifdef WXPREC - #include "wx/wxprec.h" +# include #else - #include "wx/event.h" - #include "wx/string.h" +# include +# include #endif -#include "wx/sckaddr.h" -#include "gsocket.h" +#include +#include "wx/gsocket.h" +class WXDLLEXPORT wxTimer; class WXDLLEXPORT wxSocketEvent; class WXDLLEXPORT wxSocketBase : public wxEvtHandler { @@ -43,7 +44,7 @@ public: typedef int wxSockFlags; // Type of request - enum wxSockType { SOCK_CLIENT, SOCK_SERVER, SOCK_INTERNAL, SOCK_UNINIT }; + enum wxSockType { SOCK_CLIENT, SOCK_SERVER, SOCK_INTERNAL, SOCK_UNINIT }; typedef void (*wxSockCbk)(wxSocketBase& sock,GSocketEvent evt,char *cdata); protected: @@ -65,14 +66,16 @@ protected: bool m_notify_state; // Notify state int m_id; // Socket id (for event handler) + // Defering variables enum { DEFER_READ, DEFER_WRITE, NO_DEFER - } m_defering; // Defering state + } m_defering; // Defering state char *m_defer_buffer; // Defering target buffer size_t m_defer_nbytes; // Defering buffer size + wxTimer *m_defer_timer; // Timer for defering mode wxList m_states; // Stack of states - + public: wxSocketBase(); virtual ~wxSocketBase(); @@ -102,7 +105,7 @@ public: inline size_t LastCount() const { return m_lcount; } inline GSocketError LastError() const { return GSocket_GetError(m_socket); } inline wxSockType GetType() const { return m_type; } - + void SetFlags(wxSockFlags _flags); wxSockFlags GetFlags() const; inline void SetTimeout(unsigned long sec) { m_timeout = sec; } @@ -114,7 +117,7 @@ public: bool WaitForRead(long seconds = -1, long microseconds = 0); bool WaitForWrite(long seconds = -1, long microseconds = 0); bool WaitForLost(long seconds = -1, long microseconds = 0); - + // Save the current state of Socket void SaveState(); void RestoreState(); @@ -125,7 +128,7 @@ public: // Setup event handler void SetEventHandler(wxEvtHandler& evt_hdlr, int id = -1); - + // Method called when it happens something on the socket void SetNotify(GSocketEventFlags flags); virtual void OnRequest(GSocketEvent req_evt); @@ -159,13 +162,13 @@ public: #ifdef __SALFORDC__ protected: #endif - + bool _Wait(long seconds, long microseconds, int type); int DeferRead(char *buffer, size_t nbytes); int DeferWrite(const char *buffer, size_t nbytes); void DoDefer(GSocketEvent evt); - + // Pushback library size_t GetPushback(char *buffer, size_t size, bool peek); };