#pragma interface
#endif
+#include "wx/defs.h"
+
#if wxUSE_SOCKETS
-#include <wx/object.h>
-#include <wx/list.h>
-#include <wx/socket.h>
-#include <wx/thread.h>
+#include "wx/object.h"
+#include "wx/list.h"
+#include "wx/socket.h"
+#include "wx/thread.h"
// Socket state
class SocketState
wxSocketInternal *m_internal;
int m_fd;
};
+#endif
-class SocketRequester: public wxThread {
+class SocketRequester
+#if wxUSE_THREADS
+ : public wxThread
+#endif
+ {
public:
SocketRequester(wxSocketBase *socket, wxSocketInternal *internal);
~SocketRequester();
bool WaitFor(wxSocketBase::wxRequestNotify req, int millisec);
+#if wxUSE_THREADS
// Thread Entry point
// ---
virtual void *Entry();
+#endif
public:
wxSocketBase *m_socket;
wxSocketInternal *m_internal;
int m_fd;
};
-#endif
- // wxUSE_THREADS
class wxSocketInternal {
public:
void ReleaseFD();
int GetFD() { return m_fd; }
+ void SetFD(int fd) { m_fd = fd; }
void ResumeWaiter();
void StopWaiter();
void QueueRequest(SockRequest *request, bool async);
void WaitForEnd(SockRequest *request);
+ // Used by SocketRequester
SockRequest *WaitForReq();
void EndRequest(SockRequest *req);
public:
wxMutex m_socket_locker, m_fd_locker, m_request_locker, m_end_requester;
wxCondition m_socket_cond;
SocketWaiter *m_thread_waiter;
- SocketRequester *m_thread_requester;
#endif
+ SocketRequester *m_thread_requester;
wxList m_requests;
int m_fd;
bool m_invalid_requester;