+// ---------------------------------------------------------------------------
+// wxPrivateDataObject is a specialization of wxDataObject for app specific
+// data (of some given kind, derive directly from wxDataObject if you wish to
+// efficiently support multiple formats)
+// ---------------------------------------------------------------------------
+
+class WXDLLEXPORT wxPrivateDataObject : public wxDataObject
+{
+ DECLARE_DYNAMIC_CLASS( wxPrivateDataObject )
+
+public:
+ wxPrivateDataObject();
+ virtual ~wxPrivateDataObject() { Free(); }
+
+ // get the format object - it is used to decide whether we support the
+ // given output format or not
+ wxDataFormat& GetFormat() { return m_format; }
+
+ // set data. will make copy of the data
+ void SetData( const void *data, size_t size );
+
+ // returns pointer to data
+ void *GetData() const { return m_data; }
+
+ // get the size of the data
+ virtual size_t GetSize() const;
+
+ // copy data to the given buffer
+ virtual void WriteData( void *dest ) const;
+
+ // these functions are provided for wxGTK compatibility, their usage is
+ // deprecated - use GetFormat().SetId() instead
+ void SetId( const wxString& id ) { m_format.SetId(id); }
+ wxString GetId() const { return m_format.GetId(); }
+
+ // implement the base class pure virtuals
+ virtual wxDataFormatId GetPreferredFormat() const
+ { return m_format; }
+ virtual bool IsSupportedFormat(wxDataFormat format) const
+ { return m_format == format; }
+ virtual size_t GetDataSize() const
+ { return m_size; }
+ virtual void GetDataHere(void *dest) const
+ { WriteData(dest); }
+
+protected:
+ // the function which really copies the data - called by WriteData() above
+ // and uses GetSize() to get the size of the data
+ //
+ // VZ: I really wonder why do we need it
+ void WriteData( const void *data, void *dest ) const;
+
+private:
+ // free the data
+ inline void Free();
+
+ // the data
+ size_t m_size;
+ void *m_data;
+
+ // the data format
+ wxDataFormat m_format;
+};
+
+