X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/6b8ef0b35d674bc262eb2005ac1321762c831d31..0d28a1f9271606b5a38b4b7b2a78bd869bb7d520:/src/unix/evtloopunix.cpp diff --git a/src/unix/evtloopunix.cpp b/src/unix/evtloopunix.cpp index b082984019..453f1c354a 100644 --- a/src/unix/evtloopunix.cpp +++ b/src/unix/evtloopunix.cpp @@ -30,6 +30,7 @@ #include #include "wx/apptrait.h" +#include "wx/scopedptr.h" #include "wx/thread.h" #include "wx/module.h" #include "wx/unix/pipe.h" @@ -37,6 +38,10 @@ #include "wx/unix/private/epolldispatcher.h" #include "wx/private/selectdispatcher.h" +#if wxUSE_EVENTLOOP_SOURCE + #include "wx/evtloopsrc.h" +#endif // wxUSE_EVENTLOOP_SOURCE + #define TRACE_EVENTS wxT("events") // =========================================================================== @@ -220,36 +225,40 @@ protected: wxEventLoopSourceHandler* m_impl; }; -bool wxConsoleEventLoop::DoAddSource(wxAbstractEventLoopSource* src) +wxEventLoopSource * +wxConsoleEventLoop::AddSourceForFD(int fd, + wxEventLoopSourceHandler *handler, + int flags) { - Source* source = dynamic_cast(src); - wxCHECK_MSG( source, false, "Invalid source type" ); + wxCHECK_MSG( fd != -1, NULL, "can't monitor invalid fd" ); wxLogTrace(wxTRACE_EVT_SOURCE, - "wxConsoleEventLoop::AddSource() source=%d", - source->GetResource()); + "Adding event loop source for fd=%d", fd); - // translating into wxFDIOHandler - // XXX this is a memory leak of course, but this is really temporary, so - // we are not creating another map of handlers - wxFDIOHandler* h = new wxFDIOEventLoopSourceHandler(source->GetHandler()); + // we need a bridge to wxFDIODispatcher + // + // TODO: refactor the code so that only wxEventLoopSourceHandler is used + wxScopedPtr + fdioHandler(new wxFDIOEventLoopSourceHandler(handler)); - return m_dispatcher->RegisterFD(source->GetResource(), h, - source->GetFlags()); + if ( !m_dispatcher->RegisterFD(fd, fdioHandler.get(), flags) ) + return NULL; + + return new wxUnixEventLoopSource(m_dispatcher, fdioHandler.release(), + fd, handler, flags); } -bool wxConsoleEventLoop::DoRemoveSource(wxAbstractEventLoopSource* src) +wxUnixEventLoopSource::~wxUnixEventLoopSource() { - Source* source = dynamic_cast(src); - wxCHECK_MSG( source, false, "Invalid source type" ); - wxLogTrace(wxTRACE_EVT_SOURCE, - "wxConsoleEventLoop::RemoveSource() source=%d", - source->GetResource()); + "Removing event loop source for fd=%d", m_fd); - return m_dispatcher->UnregisterFD(source->GetResource()); + m_dispatcher->UnregisterFD(m_fd); + + delete m_fdioHandler; } -#endif + +#endif // wxUSE_EVENTLOOP_SOURCE //----------------------------------------------------------------------------- // events dispatch and loop handling