1 /////////////////////////////////////////////////////////////////////////////
2 // Name: wx/private/fdiodispatcher.h
3 // Purpose: classes for dispatching IO notifications for file descriptors
4 // Authors: Lukasz Michalski
5 // Created: December 2006
6 // Copyright: (c) Lukasz Michalski
8 // Licence: wxWindows licence
9 /////////////////////////////////////////////////////////////////////////////
11 #ifndef _WX_PRIVATE_FDIODISPATCHER_H_
12 #define _WX_PRIVATE_FDIODISPATCHER_H_
14 #include "wx/hashmap.h"
16 // handler used to process events on descriptors
20 // called when descriptor is available for non-blocking read
21 virtual void OnReadWaiting() = 0;
23 // called when descriptor is available for non-blocking write
24 virtual void OnWriteWaiting() = 0;
26 // called when there is exception on descriptor
27 virtual void OnExceptionWaiting() = 0;
29 // virtual dtor for the base class
30 virtual ~wxFDIOHandler() { }
33 // those flags describes sets where descriptor should be added
34 enum wxFDIODispatcherEntryFlags
39 wxFDIO_ALL
= wxFDIO_INPUT
| wxFDIO_OUTPUT
| wxFDIO_EXCEPTION
42 struct wxFDIOHandlerEntry
48 wxFDIOHandlerEntry(wxFDIOHandler
*handler_
, int flags_
)
54 wxFDIOHandler
*handler
;
58 // this hash is used to map file descriptors to their handlers
67 // base class for wxSelectDispatcher and wxEpollDispatcher
69 // notice that all pure virtual functions for FD management have implementation
70 // in the base class and should be called from the derived classes
71 class WXDLLIMPEXP_BASE wxFDIODispatcher
74 enum { TIMEOUT_INFINITE
= -1 };
76 // find the handler for the given fd, return NULL if none
77 wxFDIOHandler
*FindHandler(int fd
) const;
79 // register handler for the given descriptor with the dispatcher, return
80 // true on success or false on error
81 virtual bool RegisterFD(int fd
, wxFDIOHandler
*handler
, int flags
) = 0;
83 // modify descriptor flags or handler, return true on success
84 virtual bool ModifyFD(int fd
, wxFDIOHandler
*handler
, int flags
) = 0;
86 // unregister descriptor previously registered with RegisterFD(), the
87 // caller is responsible for deleting the returned handler pointer if
89 virtual wxFDIOHandler
*UnregisterFD(int fd
, int flags
) = 0;
91 // loops waiting for an event to happen on any of the descriptors
92 virtual void RunLoop(int timeout
) = 0;
94 virtual ~wxFDIODispatcher() { }
97 // the fd -> handler map containing all the registered handlers
98 wxFDIOHandlerMap m_handlers
;
101 #endif // _WX_PRIVATE_FDIODISPATCHER_H_