#if wxUSE_WCHAR_T
CPPUNIT_TEST( ConstructorsWithConversion );
CPPUNIT_TEST( Conversion );
-#endif
-#if wxUSE_UNICODE
CPPUNIT_TEST( ConversionUTF7 );
#endif
CPPUNIT_TEST( Extraction );
#if wxUSE_WCHAR_T
void ConstructorsWithConversion();
void Conversion();
-#endif
-#if wxUSE_UNICODE
void ConversionUTF7();
#endif
void Extraction();
CPPUNIT_ASSERT( s3 == sub );
CPPUNIT_ASSERT( s4 == sub );
+
+#if wxUSE_UNICODE
+ CPPUNIT_ASSERT ( wxString("\t[pl]open.format.Sformatuj dyskietkê=gfloppy %f",
+ wxConvUTF8) == wxT("") ); //should stop at pos 35
+#endif
}
void StringTestCase::Conversion()
CPPUNIT_ASSERT( memcmp(theBuffer.data(), "The\0String", 11) == 0 );
wxString szTheString2("The\0String", wxConvLocal, 10);
- CPPUNIT_ASSERT( wxMemcmp(szTheString2.c_str(), L"The\0String", 11) == 0 );
+ CPPUNIT_ASSERT( wxTmemcmp(szTheString2.c_str(), L"The\0String", 11) == 0 );
#else
wxString szTheString(wxT("TheString"));
szTheString.insert(3, 1, '\0');
CPPUNIT_ASSERT( memcmp(theLocalBuffer.data(), L"The\0String", 11 * sizeof(wchar_t)) == 0 );
#endif
}
-#endif // wxUSE_WCHAR_T
-#if wxUSE_UNICODE
void StringTestCase::ConversionUTF7()
{
- const wxChar wdata[] = { 0x00A3, 0x00A3, 0x00A3, 0x00A3, 0 }; // pound signs
+ const wchar_t data[] = { 0x00A3, 0x00A3, 0x00A3, 0x00A3, 0 }; // pound signs
+
+ //utf7 and utf7alt are equivelent
const char *utf7 = "+AKM-+AKM-+AKM-+AKM-";
- wxString str(wdata);
+ const char *utf7alt = "+AKMAowCjAKM-";
+
+#if wxUSE_UNICODE
+ wxString str(data);
wxCSConv conv(_T("utf-7"));
- CPPUNIT_ASSERT( strcmp(str.mb_str(conv), utf7) == 0 );
-}
+
+ wxCharBuffer theBuffer = str.mb_str(conv);
+
+ CPPUNIT_ASSERT( strcmp(theBuffer, utf7) == 0 || strcmp(theBuffer, utf7alt) == 0);
+#else //ANSI
+ wxString str(utf7);
+
+ wxCSConv conv(_T("utf-7"));
+
+ wxWCharBuffer theWBuffer = str.wc_str(conv);
+
+ CPPUNIT_ASSERT( wxWcslen(theWBuffer) == wxWcslen(data) );
+ CPPUNIT_ASSERT( memcmp(theWBuffer, data, wxWcslen(data) * sizeof(wchar_t)) == 0 );
+
+ wxString stralt(utf7alt);
+
+ wxWCharBuffer theWBufferAlt = stralt.wc_str(conv);
+
+ CPPUNIT_ASSERT( wxWcslen(theWBufferAlt) == wxWcslen(data) );
+ CPPUNIT_ASSERT( memcmp(theWBufferAlt, data, wxWcslen(data) * sizeof(wchar_t)) == 0 );
+
#endif // wxUSE_UNICODE
+}
+
+#endif // wxUSE_WCHAR_T
+
void StringTestCase::Extraction()
{