X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/01fc49320e42f2738d398e5fc9be0cb79f2b0053..c363ead1e206e599d6564ac939ac7342d165e0e3:/src/common/clipcmn.cpp diff --git a/src/common/clipcmn.cpp b/src/common/clipcmn.cpp index 09a62dc496..f8134784e0 100644 --- a/src/common/clipcmn.cpp +++ b/src/common/clipcmn.cpp @@ -43,10 +43,20 @@ DEFINE_EVENT_TYPE(wxEVT_CLIPBOARD_CHANGED) bool wxClipboardEvent::SupportsFormat( const wxDataFormat &format ) const { +#ifdef __WXGTK20__ + // GTK has an asynchronnous API which reports + // the supported formats one by one. + // We may have to add X11 and Motif later. wxVector::size_type n; for (n = 0; n < m_formats.size(); n++) { if (m_formats[n] == format) return true; } return false; +#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 ) @@ -69,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