X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/c220de0b393b5098c705c1a62ef7fc4698e2fa52..a7d354c6d75a32033f62b8ecadd837519b35b3ef:/src/common/clipcmn.cpp?ds=inline diff --git a/src/common/clipcmn.cpp b/src/common/clipcmn.cpp index afdd300f30..2781a967d7 100644 --- a/src/common/clipcmn.cpp +++ b/src/common/clipcmn.cpp @@ -29,6 +29,7 @@ #include "wx/clipbrd.h" #ifndef WX_PRECOMP + #include "wx/dataobj.h" #include "wx/module.h" #endif @@ -38,18 +39,28 @@ IMPLEMENT_DYNAMIC_CLASS(wxClipboardEvent,wxEvent) -DEFINE_EVENT_TYPE(wxEVT_CLIPBOARD_CHANGED) +wxDEFINE_EVENT( wxEVT_CLIPBOARD_CHANGED, wxClipboardEvent ); bool wxClipboardEvent::SupportsFormat( const wxDataFormat &format ) const -{ - wxVector::size_type n; - for (n = 0; n < m_formats.size(); n++) - { if (m_formats[n] == format) return true; } +{ +#ifdef __WXGTK20__ + for (wxVector::size_type n = 0; n < m_formats.size(); n++) + { + if (m_formats[n] == format) + return true; + } + return false; -} - -void wxClipboardEvent::AddFormat( const wxDataFormat &format ) -{ +#else + // All other ports just query the clipboard directly + // from here + wxClipboard* clipboard = (wxClipboard*) GetEventObject(); + return clipboard->IsSupported( format ); +#endif +} + +void wxClipboardEvent::AddFormat(const wxDataFormat& format) +{ m_formats.push_back( format ); } @@ -68,6 +79,19 @@ static wxClipboard *gs_clipboard = NULL; return gs_clipboard; } +bool wxClipboardBase::IsSupportedAsync( wxEvtHandler *sink ) +{ + // We just imitate an asynchronous API on most platforms. + // This method is overridden uner GTK. + wxClipboardEvent *event = new wxClipboardEvent(wxEVT_CLIPBOARD_CHANGED); + event->SetEventObject( this ); + + sink->QueueEvent( event ); + + return true; +} + + // ---------------------------------------------------------------------------- // wxClipboardModule: module responsible for destroying the global clipboard // object