X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/dc86cb34c3a8f141686339f1285cf259dec5faaa..2dc1bdac6a37437e66e742122fb68f9c763f7d9e:/include/wx/gtk1/clipbrd.h?ds=sidebyside diff --git a/include/wx/gtk1/clipbrd.h b/include/wx/gtk1/clipbrd.h index aa46abbb00..5f7a92eead 100644 --- a/include/wx/gtk1/clipbrd.h +++ b/include/wx/gtk1/clipbrd.h @@ -18,21 +18,16 @@ #include "wx/defs.h" #include "wx/object.h" #include "wx/list.h" +#include "wx/dataobj.h" #include "wx/control.h" -#include "wx/dnd.h" // for wxDataObject +#include "wx/module.h" //----------------------------------------------------------------------------- // classes //----------------------------------------------------------------------------- class wxClipboard; - -//----------------------------------------------------------------------------- -// global functions -//----------------------------------------------------------------------------- - -void wxInitClipboard(); -void wxDoneClipboard(); +class wxClipboardModule; //----------------------------------------------------------------------------- // global data @@ -44,7 +39,7 @@ extern wxClipboard* wxTheClipboard; // wxClipboard //----------------------------------------------------------------------------- -class wxClipboard: public wxObject +class wxClipboard: public wxObject { DECLARE_DYNAMIC_CLASS(wxClipboard) @@ -53,19 +48,57 @@ public: wxClipboard(); ~wxClipboard(); - virtual void SetData( wxDataObject *data ); - virtual void *GetData( wxDataFormat format, size_t *length ); - virtual bool IsAvailable( wxDataFormat format ); + // open the clipboard before SetData() and GetData() + virtual bool Open(); + + // close the clipboard after SetData() and GetData() + virtual void Close(); + + // can be called several times + virtual bool SetData( wxDataObject *data ); + + // format available on the clipboard ? + // supply ID if private format, the same as wxPrivateDataObject::SetId() + virtual bool IsSupportedFormat( wxDataFormat format, const wxString &id = "" ); + + // fill data with data on the clipboard (if available) + virtual bool GetData( wxDataObject *data ); + + // clears wxTheClipboard and the system's clipboard if possible + virtual void Clear(); // implementation + + GdkAtom GetTargetAtom( wxDataFormat format, const wxString &id = "" ); + + bool m_open; - wxDataObject *m_data; - char *m_sentString, - *m_receivedString; - void *m_receivedTargets; - size_t m_receivedLength; - GtkWidget *m_clipboardWidget; + wxList m_dataObjects; + char *m_sentString, + *m_receivedString; + void *m_receivedTargets; + GtkWidget *m_clipboardWidget; + + bool m_formatSupported; + GdkAtom m_targetRequested; + + wxDataObject *m_receivedData; }; +//----------------------------------------------------------------------------- +// wxClipboardModule +//----------------------------------------------------------------------------- + +class wxClipboardModule: public wxModule +{ + DECLARE_DYNAMIC_CLASS(wxClipboardModule) + +public: + wxClipboardModule() {} + bool OnInit(); + void OnExit(); +}; + + #endif // __GTKCLIPBOARDH__