X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/493ac0b8b5b3bcfcd3da44ad259ea55e05cf1803..917be7ed065337e8a7a67615969ecaade9eea809:/src/mac/carbon/dataobj.cpp diff --git a/src/mac/carbon/dataobj.cpp b/src/mac/carbon/dataobj.cpp index ed8f00717d..bec4f2bd60 100644 --- a/src/mac/carbon/dataobj.cpp +++ b/src/mac/carbon/dataobj.cpp @@ -34,7 +34,7 @@ #include "wx/mstream.h" #include "wx/image.h" #include "wx/mac/private.h" -#include "Scrap.h" +#include // ---------------------------------------------------------------------------- // functions @@ -84,21 +84,22 @@ void wxDataFormat::SetType( wxDataFormatId Type ) m_format = kDragFlavorTypeHFS ; else { - m_format = '????' ; wxFAIL_MSG( wxT("invalid dataformat") ); - } -} -wxDataFormatId wxDataFormat::GetType() const -{ - return m_type; + // this is '????' but it can't be used in the code because ??' is + // parsed as a trigraph! + m_format = 0x3f3f3f3f; + } } wxString wxDataFormat::GetId() const { - char text[5] ; - strncpy( text , (char*) &m_format , 4 ) ; - text[4] = 0 ; + // note that m_format is not a pointer to string, it *is* itself a 4 + // character string + char text[5] ; + strncpy( text , (char*) &m_format , 4 ) ; + text[4] = 0 ; + return wxString::FromAscii( text ) ; } @@ -108,14 +109,11 @@ void wxDataFormat::SetId( NativeFormat format ) if (m_format == kScrapFlavorTypeText) m_type = wxDF_TEXT; - else - if (m_format == kScrapFlavorTypeUnicode ) + else if (m_format == kScrapFlavorTypeUnicode ) m_type = wxDF_UNICODETEXT; - else - if (m_format == kScrapFlavorTypePicture) + else if (m_format == kScrapFlavorTypePicture) m_type = wxDF_BITMAP; - else - if (m_format == kDragFlavorTypeHFS ) + else if (m_format == kDragFlavorTypeHFS ) m_type = wxDF_FILENAME; else m_type = wxDF_PRIVATE; @@ -123,8 +121,6 @@ void wxDataFormat::SetId( NativeFormat format ) void wxDataFormat::SetId( const wxChar* zId ) { - wxString tmp(zId); - m_type = wxDF_PRIVATE; m_format = 0;// TODO: get the format gdk_atom_intern( wxMBSTRINGCAST tmp.mbc_str(), FALSE ); } @@ -170,6 +166,19 @@ bool wxDataObject::IsSupportedFormat( } } +// ---------------------------------------------------------------------------- +// wxTextDataObject +// ---------------------------------------------------------------------------- + +#if wxUSE_UNICODE +void wxTextDataObject::GetAllFormats(wxDataFormat *formats, wxDataObjectBase::Direction dir) const +{ + *formats++ = wxDataFormat( wxDF_TEXT ); + *formats = wxDataFormat( wxDF_UNICODETEXT ); +} + +#endif + // ---------------------------------------------------------------------------- // wxFileDataObject // ---------------------------------------------------------------------------- @@ -210,7 +219,10 @@ bool wxFileDataObject::SetData( { m_filenames.Empty(); - AddFile(wxString::FromAscii((char*)pBuf)); + // only add if this is not an empty string + // we can therefore clear the list by just setting an empty string + if ( (*(char*)pBuf) != 0 ) + AddFile(wxString::FromAscii((char*)pBuf)); return TRUE; }