]> git.saurik.com Git - wxWidgets.git/blobdiff - include/wx/unix/private/epolldispatcher.h
use bool expression rather than implicit conversion
[wxWidgets.git] / include / wx / unix / private / epolldispatcher.h
index f76cf6e8d71971db850b526eb4aa3c5a528c91a9..e32df9cce661d747f65fa843fcb65d083e6433e1 100644 (file)
@@ -17,7 +17,9 @@
 
 #include "wx/private/fdiodispatcher.h"
 
-class WXDLLIMPEXP_CORE wxEpollDispatcher : public wxFDIODispatcher
+struct epoll_event;
+
+class WXDLLIMPEXP_BASE wxEpollDispatcher : public wxFDIODispatcher
 {
 public:
     // create a new instance of this class, can return NULL if
@@ -26,16 +28,24 @@ public:
     // the caller should delete the returned pointer
     static wxEpollDispatcher *Create();
 
+    virtual ~wxEpollDispatcher();
+
     // implement base class pure virtual methods
     virtual bool RegisterFD(int fd, wxFDIOHandler* handler, int flags = wxFDIO_ALL);
     virtual bool ModifyFD(int fd, wxFDIOHandler* handler, int flags = wxFDIO_ALL);
     virtual bool UnregisterFD(int fd);
-    virtual void Dispatch(int timeout = TIMEOUT_INFINITE);
+    virtual bool HasPending() const;
+    virtual int Dispatch(int timeout = TIMEOUT_INFINITE);
 
 private:
     // ctor is private, use Create()
     wxEpollDispatcher(int epollDescriptor);
 
+    // common part of HasPending() and Dispatch(): calls epoll_wait() with the
+    // given timeout
+    int DoPoll(epoll_event *events, int numEvents, int timeout) const;
+
+
     int m_epollDescriptor;
 };