+ DoTestConversion(d.str, d.wcs, wxConvUTF8);
+ }
+}
+
+void UnicodeTestCase::ConversionUTF16()
+{
+ static const StringConversionData utf16data[] =
+ {
+#ifdef wxHAVE_U_ESCAPE
+ { "\x04\x1f\x04\x40\x04\x38\x04\x32\x04\x35\x04\x42\0\0",
+ L"\u041f\u0440\u0438\u0432\u0435\u0442" },
+ { "\x01\0\0b\x01\0\0a\x01\0\0r\0\0", L"\u0100b\u0100a\u0100r" },
+#endif
+ { "\0f\0o\0o\0\0", L"foo" },
+ };
+
+ wxCSConv conv(wxFONTENCODING_UTF16BE);
+ for ( size_t n = 0; n < WXSIZEOF(utf16data); n++ )
+ {
+ const StringConversionData& d = utf16data[n];
+ DoTestConversion(d.str, d.wcs, conv);
+ }
+
+ // special case: this string has consecutive NULs inside it which don't
+ // terminate the string, this exposed a bug in our conversion code which
+ // got confused in this case
+ size_t len;
+ wxWCharBuffer wbuf(conv.cMB2WC("\x01\0\0B\0C" /* A macron BC */, 6, &len));
+ CPPUNIT_ASSERT_EQUAL( (size_t)3, len );
+}
+
+void UnicodeTestCase::ConversionUTF32()
+{
+ static const StringConversionData utf32data[] =
+ {
+#ifdef wxHAVE_U_ESCAPE
+ {
+ "\0\0\x04\x1f\0\0\x04\x40\0\0\x04\x38\0\0\x04\x32\0\0\x04\x35\0\0\x04\x42\0\0\0\0",
+ L"\u041f\u0440\u0438\u0432\u0435\u0442" },
+#endif
+ { "\0\0\0f\0\0\0o\0\0\0o\0\0\0\0", L"foo" },
+ };
+
+ wxCSConv conv(wxFONTENCODING_UTF32BE);
+ for ( size_t n = 0; n < WXSIZEOF(utf32data); n++ )
+ {
+ const StringConversionData& d = utf32data[n];
+ DoTestConversion(d.str, d.wcs, conv);