X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/427ff66291af2d8dd34ff5ee68c81436997144a1..6acba9a7194b30113636efb08e0b165f91011e79:/src/mac/dataobj.cpp diff --git a/src/mac/dataobj.cpp b/src/mac/dataobj.cpp index 5949c6300b..ebf1f0dbed 100644 --- a/src/mac/dataobj.cpp +++ b/src/mac/dataobj.cpp @@ -85,19 +85,21 @@ void wxDataFormat::SetType( wxDataFormatId Type ) else { 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 ) ; } @@ -107,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; @@ -122,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 ); }