#elif defined(wxNEEDS_UTF16_FOR_TEXT_DATAOBJ)
-static wxMBConvUTF16 sUTF16Converter;
+namespace
+{
-static inline wxMBConv& GetConv(const wxDataFormat& format)
+inline wxMBConv& GetConv(const wxDataFormat& format)
{
- return
- format == wxDF_UNICODETEXT
- ? (wxMBConv&) sUTF16Converter
- : (wxMBConv&) wxConvLocal;
+ static wxMBConvUTF16 s_UTF16Converter;
+
+ return format == wxDF_UNICODETEXT ? static_cast<wxMBConv&>(s_UTF16Converter)
+ : static_cast<wxMBConv&>(wxConvLocal);
}
+} // anonymous namespace
+
size_t wxTextDataObject::GetDataSize(const wxDataFormat& format) const
{
- size_t len = GetConv(format).WC2MB( NULL, GetText().c_str(), 0 );
- len += (format == wxDF_UNICODETEXT ? 2 : 1);
-
- return len;
+ return GetConv(format).WC2MB(NULL, GetText().wc_str(), 0);
}
bool wxTextDataObject::GetDataHere(const wxDataFormat& format, void *buf) const
if ( buf == NULL )
return false;
- wxCharBuffer buffer = GetConv(format).cWX2MB( GetText().c_str() );
+ wxCharBuffer buffer(GetConv(format).cWX2MB(GetText().c_str()));
- size_t len = GetConv(format).WC2MB( NULL, GetText().c_str(), 0 );
- len += (format == wxDF_UNICODETEXT ? 2 : 1);
-
- // trailing (uni)char 0
- memcpy( (char*)buf, (const char*)buffer, len );
+ memcpy(buf, buffer.data(), buffer.length());
return true;
}
bool wxTextDataObject::SetData(const wxDataFormat& format,
- size_t WXUNUSED(len), const void *buf)
+ size_t WXUNUSED(len),
+ const void *buf)
{
if ( buf == NULL )
return false;
- wxWCharBuffer buffer = GetConv(format).cMB2WX( (const char*)buf );
-
- SetText( buffer );
+ SetText(GetConv(format).cMB2WX(static_cast<const char*>(buf)));
return true;
}