#ifndef __GTKCLIPBOARDH__
#define __GTKCLIPBOARDH__
-#ifdef __GNUG__
-#pragma interface
-#endif
-
-#include "wx/defs.h"
-
#if wxUSE_CLIPBOARD
#include "wx/object.h"
#include "wx/control.h"
#include "wx/module.h"
-//-----------------------------------------------------------------------------
-// classes
-//-----------------------------------------------------------------------------
-
-class wxClipboard;
-class wxClipboardModule;
-
-//-----------------------------------------------------------------------------
-// global data
-//-----------------------------------------------------------------------------
-
-extern wxClipboard* wxTheClipboard;
-
-//-----------------------------------------------------------------------------
+// ----------------------------------------------------------------------------
// wxClipboard
-//-----------------------------------------------------------------------------
+// ----------------------------------------------------------------------------
-class wxClipboard : public wxObject
+class WXDLLIMPEXP_CORE wxClipboard : public wxClipboardBase
{
- DECLARE_DYNAMIC_CLASS(wxClipboard)
-
public:
wxClipboard();
~wxClipboard();
// close the clipboard after SetData() and GetData()
virtual void Close();
+ // query whether the clipboard is opened
+ virtual bool IsOpened() const;
+
// set the clipboard data. all other formats will be deleted.
virtual bool SetData( wxDataObject *data );
virtual bool AddData( wxDataObject *data );
// ask if data in correct format is available
- virtual bool IsSupported( wxDataObject &data );
+ virtual bool IsSupported( const wxDataFormat& format );
// fill data with data on the clipboard (if available)
- virtual bool GetData( wxDataObject &data );
+ virtual bool GetData( wxDataObject& data );
// clears wxTheClipboard and the system's clipboard if possible
virtual void Clear();
- // implementation
-
+ // If primary == TRUE, use primary selection in all further ops,
+ // primary == FALSE resets it.
+ virtual void UsePrimarySelection(bool primary = TRUE)
+ { m_usePrimary = primary; }
+
+ // implementation from now on
bool m_open;
-
bool m_ownsClipboard;
bool m_ownsPrimarySelection;
+ wxDataObject *m_data;
- wxDataBroker *m_dataBroker;
- GtkWidget *m_clipboardWidget;
+ GtkWidget *m_clipboardWidget; /* for getting and offering data */
+ GtkWidget *m_targetsWidget; /* for getting list of supported formats */
+ bool m_waiting; /* querying data or formats is asynchronous */
bool m_formatSupported;
GdkAtom m_targetRequested;
+ bool m_usePrimary;
+ wxDataObject *m_receivedData;
- wxDataObject *m_receivedData;
-};
-
-//-----------------------------------------------------------------------------
-// wxClipboardModule
-//-----------------------------------------------------------------------------
-
-class wxClipboardModule: public wxModule
-{
- DECLARE_DYNAMIC_CLASS(wxClipboardModule)
-
-public:
- wxClipboardModule() {}
- bool OnInit();
- void OnExit();
+private:
+ DECLARE_DYNAMIC_CLASS(wxClipboard)
};
#endif
-
// wxUSE_CLIPBOARD
#endif