]> git.saurik.com Git - wxWidgets.git/blobdiff - src/common/clipcmn.cpp
introduce wxBG_STYLE_{ERASE,PAINT} and implement their documented semantics in wxGTK
[wxWidgets.git] / src / common / clipcmn.cpp
index bbb7b68c6761df4e1051f8440e8db39fbf70d641..133c18967a10edd0ab8c9524dcfb87a7021896bf 100644 (file)
@@ -1,5 +1,5 @@
 /////////////////////////////////////////////////////////////////////////////
 /////////////////////////////////////////////////////////////////////////////
-// Name:        common/clipcmn.cpp
+// Name:        src/common/clipcmn.cpp
 // Purpose:     common (to all ports) wxClipboard functions
 // Author:      Robert Roebling
 // Modified by:
 // Purpose:     common (to all ports) wxClipboard functions
 // Author:      Robert Roebling
 // Modified by:
 // headers
 // ----------------------------------------------------------------------------
 
 // headers
 // ----------------------------------------------------------------------------
 
-#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA)
-    #pragma implementation "clipboardbase.h"
-#endif
-
 // For compilers that support precompilation, includes "wx.h".
 #include "wx/wxprec.h"
 
 // For compilers that support precompilation, includes "wx.h".
 #include "wx/wxprec.h"
 
     #pragma hdrstop
 #endif
 
     #pragma hdrstop
 #endif
 
+#if wxUSE_CLIPBOARD
+
 #include "wx/clipbrd.h"
 #include "wx/clipbrd.h"
-#include "wx/module.h"
 
 
-#if wxUSE_CLIPBOARD
+#ifndef WX_PRECOMP
+    #include "wx/dataobj.h"
+    #include "wx/module.h"
+#endif
 
 
-// ----------------------------------------------------------------------------
-// wxClipboardModule: module responsible for initializing the global clipboard
-// object
-// ----------------------------------------------------------------------------
+// ---------------------------------------------------------
+// wxClipboardEvent
+// ---------------------------------------------------------
 
 
-class wxClipboardModule : public wxModule
+IMPLEMENT_DYNAMIC_CLASS(wxClipboardEvent,wxEvent)
+
+wxDEFINE_EVENT( wxEVT_CLIPBOARD_CHANGED, wxClipboardEvent );
+
+// notice that ctors are defined here and not inline to avoid having to include
+// wx/dataobj.h from wx/clipbrd.h
+wxClipboardEvent::wxClipboardEvent(wxEventType evtType)
+    : wxEvent(0, evtType)
 {
 {
-public:
-    bool OnInit();
-    void OnExit();
+}
 
 
-private:
-    DECLARE_DYNAMIC_CLASS(wxClipboardModule)
-};
+wxClipboardEvent::wxClipboardEvent(const wxClipboardEvent& event)
+    : wxEvent(event),
+      m_formats(event.m_formats)
+{
+}
 
 
-// ----------------------------------------------------------------------------
-// global data defined here
-// ----------------------------------------------------------------------------
+wxEvent* wxClipboardEvent::Clone() const
+{
+    return new wxClipboardEvent(*this);
+}
 
 
-IMPLEMENT_DYNAMIC_CLASS(wxClipboardModule, wxModule)
+bool wxClipboardEvent::SupportsFormat( const wxDataFormat &format ) const
+{
+#ifdef __WXGTK20__
+    // GTK has an asynchronous API which reports the supported formats one by
+    // one. We may have to add X11 and Motif later.
+    for (wxVector<wxDataFormat>::size_type 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)
+{
+    m_formats.push_back( format );
+}
 
 
-wxClipboard* wxTheClipboard = (wxClipboard *)NULL;
+// ---------------------------------------------------------
+// wxClipboardBase
+// ---------------------------------------------------------
 
 
-// ----------------------------------------------------------------------------
-// implementation
-// ----------------------------------------------------------------------------
+static wxClipboard *gs_clipboard = NULL;
 
 
-wxClipboardBase::wxClipboardBase()
+/*static*/ wxClipboard *wxClipboardBase::Get()
 {
 {
+    if ( !gs_clipboard )
+    {
+        gs_clipboard = new wxClipboard;
+    }
+    return gs_clipboard;
 }
 
 }
 
-bool wxClipboardModule::OnInit()
+bool wxClipboardBase::IsSupportedAsync( wxEvtHandler *sink )
 {
 {
-    wxTheClipboard = new wxClipboard;
+    // 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 );
 
 
-    return TRUE;
+    sink->QueueEvent( event );
+
+    return true;
 }
 
 }
 
-void wxClipboardModule::OnExit()
+
+// ----------------------------------------------------------------------------
+// wxClipboardModule: module responsible for destroying the global clipboard
+// object
+// ----------------------------------------------------------------------------
+
+class wxClipboardModule : public wxModule
 {
 {
-    delete wxTheClipboard;
+public:
+    bool OnInit() { return true; }
+    void OnExit() { wxDELETE(gs_clipboard); }
 
 
-    wxTheClipboard = (wxClipboard *)NULL;
-}
+private:
+    DECLARE_DYNAMIC_CLASS(wxClipboardModule)
+};
+
+IMPLEMENT_DYNAMIC_CLASS(wxClipboardModule, wxModule)
 
 #endif // wxUSE_CLIPBOARD
 
 #endif // wxUSE_CLIPBOARD