WXDLLEXPORT BSTR wxConvertStringToOle(const wxString& str)
{
-/*
- unsigned int len = strlen((const char*) str);
- unsigned short* s = new unsigned short[len*2+2];
- unsigned int i;
- memset(s, 0, len*2+2);
- for (i=0; i < len; i++)
- s[i*2] = str[i];
-*/
- wxBasicString bstr(str.mb_str());
- return bstr.Get();
+ return wxBasicString(str).Get();
}
WXDLLEXPORT wxString wxConvertStringFromOle(BSTR bStr)
{
+ // NULL BSTR is equivalent to an empty string (this is the convention used
+ // by VB and hence we must follow it)
+ if ( !bStr )
+ return wxString();
+
#if wxUSE_UNICODE
wxString str(bStr);
#else
// wxBasicString
// ----------------------------------------------------------------------------
-// ctor takes an ANSI string and transforms it to Unicode
-wxBasicString::wxBasicString(const char *sz)
+wxBasicString::wxBasicString(const wxString& str)
{
- Init(sz);
+ m_bstrBuf = SysAllocString(str.wc_str(*wxConvCurrent));
}
-// ctor takes an ANSI or Unicode string and transforms it to Unicode
-wxBasicString::wxBasicString(const wxString& str)
+wxBasicString::wxBasicString(const wxBasicString& src)
{
-#if wxUSE_UNICODE
- m_wzBuf = new OLECHAR[str.length() + 1];
- memcpy(m_wzBuf, str.c_str(), str.length()*2);
- m_wzBuf[str.length()] = L'\0';
-#else
- Init(str.c_str());
-#endif
+ m_bstrBuf = src.Get();
}
-// Takes an ANSI string and transforms it to Unicode
-void wxBasicString::Init(const char *sz)
+wxBasicString& wxBasicString::operator=(const wxBasicString& src)
{
- // get the size of required buffer
- UINT lenAnsi = strlen(sz);
-#ifdef __MWERKS__
- UINT lenWide = lenAnsi * 2 ;
-#else
- UINT lenWide = mbstowcs(NULL, sz, lenAnsi);
-#endif
-
- if ( lenWide > 0 ) {
- m_wzBuf = new OLECHAR[lenWide + 1];
- mbstowcs(m_wzBuf, sz, lenAnsi);
- m_wzBuf[lenWide] = L'\0';
- }
- else {
- m_wzBuf = NULL;
- }
+ SysReAllocString(&m_bstrBuf, src);
+ return *this;
}
-// dtor frees memory
wxBasicString::~wxBasicString()
{
- delete [] m_wzBuf;
+ SysFreeString(m_bstrBuf);
}
#if wxUSE_DATAOBJ