X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/ee0995b09b0f91ceeaff41129ec7228d389d33ff..b00403b401b75f95b6984cf5d0f6d71492f0a1f9:/src/gtk/sockgtk.cpp diff --git a/src/gtk/sockgtk.cpp b/src/gtk/sockgtk.cpp index c8d449cfd8..e887cebb69 100644 --- a/src/gtk/sockgtk.cpp +++ b/src/gtk/sockgtk.cpp @@ -5,6 +5,7 @@ // Created: 1999 // RCS-ID: $Id$ // Copyright: (c) 1999, 2007 wxWidgets dev team +// (c) 2009 Vadim Zeitlin // Licence: wxWindows licence /////////////////////////////////////////////////////////////////////////////// @@ -13,14 +14,10 @@ #if wxUSE_SOCKETS -#include -#include +#include "wx/apptrait.h" +#include "wx/private/fdiomanager.h" #include -#include - -#include "wx/private/socket.h" -#include "wx/apptrait.h" extern "C" { static @@ -28,7 +25,7 @@ void wxSocket_GDK_Input(gpointer data, gint WXUNUSED(source), GdkInputCondition condition) { - wxSocketImplUnix * const handler = static_cast(data); + wxFDIOHandler * const handler = static_cast(data); if ( condition & GDK_INPUT_READ ) { @@ -37,7 +34,7 @@ void wxSocket_GDK_Input(gpointer data, // we could have lost connection while reading in which case we // shouldn't call OnWriteWaiting() as the socket is now closed and it // would assert - if ( handler->m_fd == INVALID_SOCKET ) + if ( !handler->IsOk() ) return; } @@ -46,29 +43,30 @@ void wxSocket_GDK_Input(gpointer data, } } -class GTKSocketManager : public wxSocketInputBasedManager +class GTKFDIOManager : public wxFDIOManager { public: - virtual int AddInput(wxSocketImplUnix *handler, int fd, SocketDir d) + virtual int AddInput(wxFDIOHandler *handler, int fd, Direction d) { return gdk_input_add ( fd, - d == FD_OUTPUT ? GDK_INPUT_WRITE : GDK_INPUT_READ, + d == OUTPUT ? GDK_INPUT_WRITE : GDK_INPUT_READ, wxSocket_GDK_Input, handler ); } - virtual void RemoveInput(int fd) + virtual void + RemoveInput(wxFDIOHandler* WXUNUSED(handler), int fd, Direction WXUNUSED(d)) { gdk_input_remove(fd); } }; -wxSocketManager *wxGUIAppTraits::GetSocketManager() +wxFDIOManager *wxGUIAppTraits::GetFDIOManager() { - static GTKSocketManager s_manager; + static GTKFDIOManager s_manager; return &s_manager; }