#ifndef _WX_GTK_DATAFORM_H
#define _WX_GTK_DATAFORM_H
-class wxDataFormat
+class WXDLLIMPEXP_CORE wxDataFormat
{
public:
// the clipboard formats under GDK are GdkAtoms
wxDataFormat();
wxDataFormat( wxDataFormatId type );
- wxDataFormat( const wxString &id );
- wxDataFormat( const wxChar *id );
wxDataFormat( NativeFormat format );
+ // we have to provide all the overloads to allow using strings instead of
+ // data formats (as a lot of existing code does)
+ wxDataFormat( const wxString& id ) { InitFromString(id); }
+ wxDataFormat( const char *id ) { InitFromString(id); }
+ wxDataFormat( const wchar_t *id ) { InitFromString(id); }
+ wxDataFormat( const wxCStrData& id ) { InitFromString(id); }
+
+ wxDataFormat& operator=(const wxDataFormat& format)
+ {
+ if (&format != this)
+ {
+ m_type = format.m_type;
+ m_format = format.m_format;
+ }
+ return *this;
+ }
wxDataFormat& operator=(NativeFormat format)
{ SetId(format); return *this; }
{ return m_format == (NativeFormat)format; }
bool operator!=(NativeFormat format) const
{ return m_format != (NativeFormat)format; }
+ bool operator==(wxDataFormatId format) const
+ { return m_type == (wxDataFormatId)format; }
+ bool operator!=(wxDataFormatId format) const
+ { return m_type != (wxDataFormatId)format; }
// explicit and implicit conversions to NativeFormat which is one of
// standard data types (implicit conversion is useful for preserving the
// string ids are used for custom types - this SetId() must be used for
// application-specific formats
wxString GetId() const;
- void SetId( const wxChar *id );
+ void SetId( const wxString& id );
// implementation
wxDataFormatId GetType() const;
+ void SetType( wxDataFormatId type );
private:
+ // common part of ctors from format name
+ void InitFromString(const wxString& id);
+
wxDataFormatId m_type;
NativeFormat m_format;
void PrepareFormats();
- void SetType( wxDataFormatId type );
};
#endif // _WX_GTK_DATAFORM_H