X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/1cd53e884b78da17408bc80567574bb1c212a9a6..dd05139a8023fd3e30476409fafbe04221c6d627:/tests/strings/strings.cpp diff --git a/tests/strings/strings.cpp b/tests/strings/strings.cpp index 322735ee38..42db733cb5 100644 --- a/tests/strings/strings.cpp +++ b/tests/strings/strings.cpp @@ -11,7 +11,7 @@ // headers // ---------------------------------------------------------------------------- -#include "wx/wxprec.h" +#include "testprec.h" #ifdef __BORLANDC__ #pragma hdrstop @@ -21,10 +21,6 @@ #include "wx/wx.h" #endif // WX_PRECOMP -#include "wx/tokenzr.h" - -#include "wx/cppunit.h" - // ---------------------------------------------------------------------------- // test class // ---------------------------------------------------------------------------- @@ -41,11 +37,16 @@ private: CPPUNIT_TEST( Format ); CPPUNIT_TEST( Constructors ); CPPUNIT_TEST( Extraction ); + CPPUNIT_TEST( Trim ); CPPUNIT_TEST( Find ); - CPPUNIT_TEST( Tokenizer ); CPPUNIT_TEST( Replace ); CPPUNIT_TEST( Match ); - CPPUNIT_TEST( Std ); + CPPUNIT_TEST( CaseChanges ); + CPPUNIT_TEST( Compare ); + CPPUNIT_TEST( CompareNoCase ); + CPPUNIT_TEST( ToLong ); + CPPUNIT_TEST( ToULong ); + CPPUNIT_TEST( ToDouble ); CPPUNIT_TEST_SUITE_END(); void String(); @@ -53,11 +54,16 @@ private: void Format(); void Constructors(); void Extraction(); + void Trim(); void Find(); - void Tokenizer(); void Replace(); void Match(); - void Std(); + void CaseChanges(); + void Compare(); + void CompareNoCase(); + void ToLong(); + void ToULong(); + void ToDouble(); DECLARE_NO_COPY_CLASS(StringTestCase) }; @@ -117,6 +123,15 @@ void StringTestCase::Format() CPPUNIT_ASSERT( s1 == wxString::Format(_T("%03d"), 18) ); s2.Printf(_T("Number 18: %s\n"), s1.c_str()); CPPUNIT_ASSERT( s2 == wxString::Format(_T("Number 18: %s\n"), s1.c_str()) ); + + static const size_t lengths[] = { 1, 512, 1024, 1025, 2048, 4096, 4097 }; + for ( size_t n = 0; n < WXSIZEOF(lengths); n++ ) + { + const size_t len = lengths[n]; + + wxString s(_T('Z'), len); + CPPUNIT_ASSERT_EQUAL( len, wxString::Format(_T("%s"), s.c_str()).length()); + } } void StringTestCase::Constructors() @@ -137,6 +152,7 @@ void StringTestCase::Constructors() TEST_CTOR((start, end), _T("really")); } + void StringTestCase::Extraction() { wxString s(_T("Hello, world!")); @@ -151,11 +167,10 @@ void StringTestCase::Extraction() wxString rest; - #define TEST_STARTS_WITH( prefix , correct_rest, result ) \ - CPPUNIT_ASSERT( \ - ( s.StartsWith( prefix, &rest ) == result ) && \ - ( ( result == false ) || ( wxStrcmp( correct_rest , rest ) == 0 ) ) \ - ) + #define TEST_STARTS_WITH(prefix, correct_rest, result) \ + CPPUNIT_ASSERT_EQUAL(result, s.StartsWith(prefix, &rest)); \ + if ( result ) \ + CPPUNIT_ASSERT_EQUAL(wxString(correct_rest), rest) TEST_STARTS_WITH( _T("Hello"), _T(", world!"), true ); TEST_STARTS_WITH( _T("Hello, "), _T("world!"), true ); @@ -166,6 +181,41 @@ void StringTestCase::Extraction() TEST_STARTS_WITH( _T("Hi"), _T(""), false ); #undef TEST_STARTS_WITH + + #define TEST_ENDS_WITH(suffix, correct_rest, result) \ + CPPUNIT_ASSERT_EQUAL(result, s.EndsWith(suffix, &rest)); \ + if ( result ) \ + CPPUNIT_ASSERT_EQUAL(wxString(correct_rest), rest) + + TEST_ENDS_WITH( _T(""), _T("Hello, world!"), true ); + TEST_ENDS_WITH( _T("!"), _T("Hello, world"), true ); + TEST_ENDS_WITH( _T(", world!"), _T("Hello"), true ); + TEST_ENDS_WITH( _T("ello, world!"), _T("H"), true ); + TEST_ENDS_WITH( _T("Hello, world!"), _T(""), true ); + TEST_ENDS_WITH( _T("very long string"), _T(""), false ); + TEST_ENDS_WITH( _T("?"), _T(""), false ); + TEST_ENDS_WITH( _T("Hello, world"), _T(""), false ); + TEST_ENDS_WITH( _T("Gello, world!"), _T(""), false ); + + #undef TEST_ENDS_WITH +} + +void StringTestCase::Trim() +{ + #define TEST_TRIM( str , dir , result ) \ + CPPUNIT_ASSERT( wxString(str).Trim(dir) == result ) + + TEST_TRIM( _T(" Test "), true, _T(" Test") ); + TEST_TRIM( _T(" "), true, _T("") ); + TEST_TRIM( _T(" "), true, _T("") ); + TEST_TRIM( _T(""), true, _T("") ); + + TEST_TRIM( _T(" Test "), false, _T("Test ") ); + TEST_TRIM( _T(" "), false, _T("") ); + TEST_TRIM( _T(" "), false, _T("") ); + TEST_TRIM( _T(""), false, _T("") ); + + #undef TEST_TRIM } void StringTestCase::Find() @@ -180,62 +230,6 @@ void StringTestCase::Find() #undef TEST_FIND } -void StringTestCase::Tokenizer() -{ - #define TEST_TOKENIZER( str , delims, count , mode ) \ - { \ - wxStringTokenizer tkz( str, delims, mode); \ - CPPUNIT_ASSERT( tkz.CountTokens() == count ); \ - \ - wxChar *buf, *s = NULL, *last; \ - \ - if ( tkz.GetMode() == wxTOKEN_STRTOK ) \ - { \ - buf = new wxChar[wxStrlen(str) + 1]; \ - wxStrcpy(buf, str); \ - s = wxStrtok(buf, delims, &last); \ - } \ - else \ - { \ - buf = NULL; \ - } \ - \ - size_t count2 = 0; \ - while ( tkz.HasMoreTokens() ) \ - { \ - wxString token = tkz.GetNextToken(); \ - if ( buf ) \ - { \ - CPPUNIT_ASSERT( token == s ); \ - s = wxStrtok(NULL, delims, &last); \ - } \ - count2++; \ - } \ - \ - CPPUNIT_ASSERT( count2 == count ); \ - if ( buf ) \ - { \ - delete [] buf; \ - } \ - } - - TEST_TOKENIZER( _T(""), _T(" "), 0, wxTOKEN_DEFAULT ); - TEST_TOKENIZER( _T("Hello, world"), _T(" "), 2, wxTOKEN_DEFAULT ); - TEST_TOKENIZER( _T("Hello, world "), _T(" "), 2, wxTOKEN_DEFAULT ); - TEST_TOKENIZER( _T("Hello, world"), _T(","), 2, wxTOKEN_DEFAULT ); - TEST_TOKENIZER( _T("Hello, world!"), _T(",!"), 2, wxTOKEN_DEFAULT ); - TEST_TOKENIZER( _T("Hello,, world!"), _T(",!"), 3, wxTOKEN_DEFAULT ); - TEST_TOKENIZER( _T("Hello, world!"), _T(",!"), 3, wxTOKEN_RET_EMPTY_ALL ); - TEST_TOKENIZER( _T("username:password:uid:gid:gecos:home:shell"), _T(":"), 7, wxTOKEN_DEFAULT ); - TEST_TOKENIZER( _T("1 \t3\t4 6 "), wxDEFAULT_DELIMITERS, 4, wxTOKEN_DEFAULT ); - TEST_TOKENIZER( _T("1 \t3\t4 6 "), wxDEFAULT_DELIMITERS, 6, wxTOKEN_RET_EMPTY ); - TEST_TOKENIZER( _T("1 \t3\t4 6 "), wxDEFAULT_DELIMITERS, 9, wxTOKEN_RET_EMPTY_ALL ); - TEST_TOKENIZER( _T("01/02/99"), _T("/-"), 3, wxTOKEN_DEFAULT ); - TEST_TOKENIZER( _T("01-02/99"), _T("/-"), 3, wxTOKEN_RET_DELIMS ); - - #undef TEST_TOKENIZER -} - void StringTestCase::Replace() { #define TEST_REPLACE( original , pos , len , replacement , result ) \ @@ -251,6 +245,32 @@ void StringTestCase::Replace() TEST_REPLACE( _T("foobar"), 3, 0, _T("-"), _T("foo-bar") ); TEST_REPLACE( _T("barfoo"), 0, 6, _T("foobar"), _T("foobar") ); + + #define TEST_NULLCHARREPLACE( o , olen, pos , len , replacement , r, rlen ) \ + { \ + wxString s(o,olen); \ + s.replace( pos , len , replacement ); \ + CPPUNIT_ASSERT( s == wxString(r,rlen) ); \ + } + + TEST_NULLCHARREPLACE( _T("null\0char"), 9, 5, 1, _T("d"), + _T("null\0dhar"), 9 ); + + #define TEST_WXREPLACE( o , olen, olds, news, all, r, rlen ) \ + { \ + wxString s(o,olen); \ + s.Replace( olds, news, all ); \ + CPPUNIT_ASSERT( s == wxString(r,rlen) ); \ + } + + TEST_WXREPLACE( _T("null\0char"), 9, _T("c"), _T("de"), true, + _T("null\0dehar"), 10 ); + + TEST_WXREPLACE( _T("null\0dehar"), 10, _T("de"), _T("c"), true, + _T("null\0char"), 9 ); + + #undef TEST_WXREPLACE + #undef TEST_NULLCHARREPLACE #undef TEST_REPLACE } @@ -274,256 +294,210 @@ void StringTestCase::Match() #undef TEST_MATCH } -void StringTestCase::Std() + +void StringTestCase::CaseChanges() +{ + wxString s1(_T("Hello!")); + wxString s1u(s1); + wxString s1l(s1); + s1u.MakeUpper(); + s1l.MakeLower(); + wxString s2u, s2l; + s2u.MakeUpper(); + s2l.MakeLower(); + + CPPUNIT_ASSERT( s1u == _T("HELLO!") ); + CPPUNIT_ASSERT( s1l == _T("hello!") ); + CPPUNIT_ASSERT( s2u == wxEmptyString ); + CPPUNIT_ASSERT( s2l == wxEmptyString ); + +#if !wxUSE_UNICODE + wxLocale locRu(wxLANGUAGE_RUSSIAN, 0 /* flags */); + if ( locRu.IsOk() ) + { + // try upper casing 8bit strings + const wchar_t capital_ya[] = { 0x42f, 0 }, + small_ya[] = { 0x44f, 0 }; + + wxString sUpper(wxConvLibc.cWC2MB(capital_ya)), + sLower(wxConvLibc.cWC2MB(small_ya)); + + CPPUNIT_ASSERT( sUpper.Lower() == sLower ); + CPPUNIT_ASSERT( sLower.Upper() == sUpper ); + } +#endif // !wxUSE_UNICODE +} + +void StringTestCase::Compare() { - wxString s1(_T("abcdefgh")), - s2(_T("abcdefghijklm"), 8), - s3(_T("abcdefghijklm")), - s4(8, _T('a')); - wxString s5(s1), - s6(s3, 0, 8), - s7(s3.begin(), s3.begin() + 8); - wxString s8(s1, 4, 8), s9, s10, s11; - - CPPUNIT_ASSERT( s1 == _T("abcdefgh") ); - CPPUNIT_ASSERT( s2 == s1 ); - CPPUNIT_ASSERT( s4 == _T("aaaaaaaa") ); - CPPUNIT_ASSERT( s5 == _T("abcdefgh") ); - CPPUNIT_ASSERT( s6 == s1 ); - CPPUNIT_ASSERT( s7 == s1 ); - CPPUNIT_ASSERT( s8 == _T("efgh") ); - - // test append - s1 = s2 = s3 = s4 = s5 = s6 = s7 = s8 = _T("abc"); - s1.append(_T("def")); - s2.append(_T("defgh"), 3); - s3.append(wxString(_T("abcdef")), 3, 6); - s4.append(s1); - s5.append(3, _T('a')); - s6.append(s1.begin() + 3, s1.end()); - - CPPUNIT_ASSERT( s1 == _T("abcdef") ); - CPPUNIT_ASSERT( s2 == _T("abcdef") ); - CPPUNIT_ASSERT( s3 == _T("abcdef") ); - CPPUNIT_ASSERT( s4 == _T("abcabcdef") ); - CPPUNIT_ASSERT( s5 == _T("abcaaa") ); - CPPUNIT_ASSERT( s6 == _T("abcdef") ); - - // test assign - s1 = s2 = s3 = s4 = s5 = s6 = s7 = s8 = _T("abc"); - s1.assign(_T("def")); - s2.assign(_T("defgh"), 3); - s3.assign(wxString(_T("abcdef")), 3, 6); - s4.assign(s1); - s5.assign(3, _T('a')); - s6.assign(s1.begin() + 1, s1.end()); - - CPPUNIT_ASSERT( s1 == _T("def") ); - CPPUNIT_ASSERT( s2 == _T("def") ); - CPPUNIT_ASSERT( s3 == _T("def") ); - CPPUNIT_ASSERT( s4 == _T("def") ); - CPPUNIT_ASSERT( s5 == _T("aaa") ); - CPPUNIT_ASSERT( s6 == _T("ef") ); - - // test compare - s1 = _T("abcdefgh"); - s2 = _T("abcdefgh"); - s3 = _T("abc"); - s4 = _T("abcdefghi"); - s5 = _T("aaa"); - s6 = _T("zzz"); - s7 = _T("zabcdefg"); - - CPPUNIT_ASSERT( s1.compare(s2) == 0 ); - CPPUNIT_ASSERT( s1.compare(s3) > 0 ); - CPPUNIT_ASSERT( s1.compare(s4) < 0 ); - CPPUNIT_ASSERT( s1.compare(s5) > 0 ); - CPPUNIT_ASSERT( s1.compare(s6) < 0 ); - CPPUNIT_ASSERT( s1.compare(1, 12, s1) > 0); - CPPUNIT_ASSERT( s1.compare(_T("abcdefgh")) == 0); - CPPUNIT_ASSERT( s1.compare(1, 7, _T("bcdefgh")) == 0); - CPPUNIT_ASSERT( s1.compare(1, 7, _T("bcdefgh"), 7) == 0); - - // test erase - s1.erase(1, 1); - s2.erase(4, 12); - wxString::iterator it = s3.erase(s3.begin() + 1); - wxString::iterator it2 = s4.erase(s4.begin() + 4, s4.begin() + 6); - wxString::iterator it3 = s7.erase(s7.begin() + 4, s7.begin() + 8); - - CPPUNIT_ASSERT( s1 == _T("acdefgh") ); - CPPUNIT_ASSERT( s2 == _T("abcd") ); - CPPUNIT_ASSERT( s3 == _T("ac") ); - CPPUNIT_ASSERT( s4 == _T("abcdghi") ); - CPPUNIT_ASSERT( s7 == _T("zabc") ); - CPPUNIT_ASSERT( *it == _T('c') ); - CPPUNIT_ASSERT( *it2 == _T('g') ); - CPPUNIT_ASSERT( it3 == s7.end() ); - - // find - // 0 1 2 - // 01234567890123456789012345 - s1 = _T("abcdefgABCDEFGabcABCabcABC"); - s2 = _T("gAB"); - - CPPUNIT_ASSERT( s1.find(_T('A')) == 7u ); - CPPUNIT_ASSERT( s1.find(_T('A'), 7) == 7u ); - CPPUNIT_ASSERT( s1.find(_T('Z')) == wxString::npos ); - CPPUNIT_ASSERT( s1.find(_T('C'), 22) == 25u ); - - CPPUNIT_ASSERT( s1.find(_T("gAB")) == 6u ); - CPPUNIT_ASSERT( s1.find(_T("gAB"), 7) == wxString::npos ); - CPPUNIT_ASSERT( s1.find(_T("gAB"), 6) == 6u ); - - CPPUNIT_ASSERT( s1.find(_T("gABZZZ"), 2, 3) == 6u ); - CPPUNIT_ASSERT( s1.find(_T("gABZZZ"), 7, 3) == wxString::npos ); - - CPPUNIT_ASSERT( s1.find(s2) == 6u ); - CPPUNIT_ASSERT( s1.find(s2, 7) == wxString::npos ); - CPPUNIT_ASSERT( s1.find(s2, 6) == 6u ); - - // find_first_not_of - // 0 1 2 3 - // 01234567890123456789012345678901234 - s1 = _T("aaaaaabcdefghlkjiaaaaaabcdbcdbcdbcd"); - s2 = _T("aaaaaa"); - - CPPUNIT_ASSERT( s1.find_first_not_of(_T('a')) == 6u ); - CPPUNIT_ASSERT( s1.find_first_not_of(_T('a'), 7) == 7u ); - CPPUNIT_ASSERT( s2.find_first_not_of(_T('a')) == wxString::npos ); - - CPPUNIT_ASSERT( s1.find_first_not_of(_T("abde"), 4) == 7u ); - CPPUNIT_ASSERT( s1.find_first_not_of(_T("abde"), 7) == 7u ); - CPPUNIT_ASSERT( s1.find_first_not_of(_T("abcdefghijkl")) == wxString::npos ); - - CPPUNIT_ASSERT( s1.find_first_not_of(_T("abcdefghi"), 0, 4) == 9u ); - - // find_first_of - CPPUNIT_ASSERT( s1.find_first_of(_T('c')) == 7u ); - CPPUNIT_ASSERT( s1.find_first_of(_T('v')) == wxString::npos ); - CPPUNIT_ASSERT( s1.find_first_of(_T('c'), 10) == 24u ); - - CPPUNIT_ASSERT( s1.find_first_of(_T("ijkl")) == 13u ); - CPPUNIT_ASSERT( s1.find_first_of(_T("ddcfg"), 17) == 24u ); - CPPUNIT_ASSERT( s1.find_first_of(_T("ddcfga"), 17, 5) == 24u ); - - // find_last_not_of - // 0 1 2 3 - // 01234567890123456789012345678901234 - s1 = _T("aaaaaabcdefghlkjiaaaaaabcdbcdbcdbcd"); - s2 = _T("aaaaaa"); - - CPPUNIT_ASSERT( s2.find_last_not_of(_T('a')) == wxString::npos ); - CPPUNIT_ASSERT( s1.find_last_not_of(_T('d')) == 33u ); - CPPUNIT_ASSERT( s1.find_last_not_of(_T('d'), 25) == 24u ); - - CPPUNIT_ASSERT( s1.find_last_not_of(_T("bcd")) == 22u ); - CPPUNIT_ASSERT( s1.find_last_not_of(_T("abc"), 24) == 16u ); - - CPPUNIT_ASSERT( s1.find_last_not_of(_T("abcdefghijklmnopqrstuv"), 24, 3) == 16u ); - - // find_last_of - CPPUNIT_ASSERT( s2.find_last_of(_T('c')) == wxString::npos ); - CPPUNIT_ASSERT( s1.find_last_of(_T('a')) == 22u ); - CPPUNIT_ASSERT( s1.find_last_of(_T('b'), 24) == 23u ); - - CPPUNIT_ASSERT( s1.find_last_of(_T("ijklm")) == 16u ); - CPPUNIT_ASSERT( s1.find_last_of(_T("ijklma"), 33, 4) == 16u ); - CPPUNIT_ASSERT( s1.find_last_of(_T("a"), 17) == 17u ); - - // test insert - s1 = s2 = s3 = s4 = s5 = s6 = s7 = s8 = _T("aaaa"); - s9 = s10 = _T("cdefg"); - - s1.insert(1, _T("cc") ); - s2.insert(2, _T("cdef"), 3); - s3.insert(2, s10); - s4.insert(2, s10, 3, 7); - s5.insert(1, 2, _T('c')); - it = s6.insert(s6.begin() + 3, _T('X')); - s7.insert(s7.begin(), s9.begin(), s9.end() - 1); - s8.insert(s8.begin(), 2, _T('c')); - - CPPUNIT_ASSERT( s1 == _T("accaaa") ); - CPPUNIT_ASSERT( s2 == _T("aacdeaa") ); - CPPUNIT_ASSERT( s3 == _T("aacdefgaa") ); - CPPUNIT_ASSERT( s4 == _T("aafgaa") ); - CPPUNIT_ASSERT( s5 == _T("accaaa") ); - CPPUNIT_ASSERT( s6 == _T("aaaXa") ); - CPPUNIT_ASSERT( s7 == _T("cdefaaaa") ); - CPPUNIT_ASSERT( s8 == _T("ccaaaa") ); - - s1 = s2 = s3 = _T("aaaa"); - s1.insert(0, _T("ccc"), 2); - s2.insert(4, _T("ccc"), 2); - - CPPUNIT_ASSERT( s1 == _T("ccaaaa") ); - CPPUNIT_ASSERT( s2 == _T("aaaacc") ); - - // test replace - s1 = s2 = s3 = s4 = s5 = s6 = s7 = s8 = _T("QWERTYUIOP"); - s9 = s10 = _T("werty"); - - s1.replace(3, 4, _T("rtyu")); - s1.replace(8, 7, _T("opopop")); - s2.replace(10, 12, _T("WWWW")); - s3.replace(1, 5, s9); - s4.replace(1, 4, s9, 0, 4); - s5.replace(1, 2, s9, 1, 12); - s6.replace(0, 123, s9, 0, 123); - s7.replace(2, 7, s9); - - CPPUNIT_ASSERT( s1 == _T("QWErtyuIopopop") ); - CPPUNIT_ASSERT( s2 == _T("QWERTYUIOPWWWW") ); - CPPUNIT_ASSERT( s3 == _T("QwertyUIOP") ); - CPPUNIT_ASSERT( s4 == _T("QwertYUIOP") ); - CPPUNIT_ASSERT( s5 == _T("QertyRTYUIOP") ); - CPPUNIT_ASSERT( s6 == s9); - CPPUNIT_ASSERT( s7 == _T("QWwertyP") ); - - // rfind - // 0 1 2 - // 01234567890123456789012345 - s1 = _T("abcdefgABCDEFGabcABCabcABC"); - s2 = _T("gAB"); - s3 = _T("ab"); - - CPPUNIT_ASSERT( s1.rfind(_T('A')) == 23u ); - CPPUNIT_ASSERT( s1.rfind(_T('A'), 7) == 7u ); - CPPUNIT_ASSERT( s1.rfind(_T('Z')) == wxString::npos ); - CPPUNIT_ASSERT( s1.rfind(_T('C'), 22) == 19u ); - - CPPUNIT_ASSERT( s1.rfind(_T("cAB")) == 22u ); - CPPUNIT_ASSERT( s1.rfind(_T("cAB"), 15) == wxString::npos ); - CPPUNIT_ASSERT( s1.rfind(_T("cAB"), 21) == 16u ); - - CPPUNIT_ASSERT( s1.rfind(_T("gABZZZ"), 7, 3) == 6u ); - CPPUNIT_ASSERT( s1.rfind(_T("gABZZZ"), 5, 3) == wxString::npos ); - - CPPUNIT_ASSERT( s1.rfind(s2) == 6u ); - CPPUNIT_ASSERT( s1.rfind(s2, 5) == wxString::npos ); - CPPUNIT_ASSERT( s1.rfind(s2, 6) == 6u ); - CPPUNIT_ASSERT( s1.rfind(s3, 1) == 0u ); - - // resize - s1 = s2 = s3 = s4 = _T("abcABCdefDEF"); - - s1.resize( 12 ); - s2.resize( 10 ); - s3.resize( 14, _T(' ') ); - s4.resize( 14, _T('W') ); - - CPPUNIT_ASSERT( s1 == _T("abcABCdefDEF") ); - CPPUNIT_ASSERT( s2 == _T("abcABCdefD") ); - CPPUNIT_ASSERT( s3 == _T("abcABCdefDEF ") ); - CPPUNIT_ASSERT( s4 == _T("abcABCdefDEFWW") ); - - // substr - s1 = _T("abcdefgABCDEFG"); - - CPPUNIT_ASSERT( s1.substr( 0, 14 ) == s1 ); - CPPUNIT_ASSERT( s1.substr( 1, 13 ) == _T("bcdefgABCDEFG") ); - CPPUNIT_ASSERT( s1.substr( 1, 20 ) == _T("bcdefgABCDEFG") ); - CPPUNIT_ASSERT( s1.substr( 14, 30 ) == _T("") ); + wxString s1 = wxT("AHH"); + wxString eq = wxT("AHH"); + wxString neq1 = wxT("HAH"); + wxString neq2 = wxT("AH"); + wxString neq3 = wxT("AHHH"); + wxString neq4 = wxT("AhH"); + + CPPUNIT_ASSERT( s1 == eq ); + CPPUNIT_ASSERT( s1 != neq1 ); + CPPUNIT_ASSERT( s1 != neq2 ); + CPPUNIT_ASSERT( s1 != neq3 ); + CPPUNIT_ASSERT( s1 != neq4 ); + +// wxString _s1 = wxT("A\0HH"); +// wxString _eq = wxT("A\0HH"); +// wxString _neq1 = wxT("H\0AH"); +// wxString _neq2 = wxT("A\0H"); +// wxString _neq3 = wxT("A\0HHH"); +// wxString _neq4 = wxT("A\0hH"); + s1.insert(1,1,'\0'); + eq.insert(1,1,'\0'); + neq1.insert(1,1,'\0'); + neq2.insert(1,1,'\0'); + neq3.insert(1,1,'\0'); + neq4.insert(1,1,'\0'); + + CPPUNIT_ASSERT( s1 == eq ); + CPPUNIT_ASSERT( s1 != neq1 ); + CPPUNIT_ASSERT( s1 != neq2 ); + CPPUNIT_ASSERT( s1 != neq3 ); + CPPUNIT_ASSERT( s1 != neq4 ); } +void StringTestCase::CompareNoCase() +{ + wxString s1 = wxT("AHH"); + wxString eq = wxT("AHH"); + wxString eq2 = wxT("AhH"); + wxString eq3 = wxT("ahh"); + wxString neq = wxT("HAH"); + wxString neq2 = wxT("AH"); + wxString neq3 = wxT("AHHH"); + + #define CPPUNIT_CNCEQ_ASSERT(s1, s2) CPPUNIT_ASSERT( s1.CmpNoCase(s2) == 0) + #define CPPUNIT_CNCNEQ_ASSERT(s1, s2) CPPUNIT_ASSERT( s1.CmpNoCase(s2) != 0) + + CPPUNIT_CNCEQ_ASSERT( s1, eq ); + CPPUNIT_CNCEQ_ASSERT( s1, eq2 ); + CPPUNIT_CNCEQ_ASSERT( s1, eq3 ); + + CPPUNIT_CNCNEQ_ASSERT( s1, neq ); + CPPUNIT_CNCNEQ_ASSERT( s1, neq2 ); + CPPUNIT_CNCNEQ_ASSERT( s1, neq3 ); + + +// wxString _s1 = wxT("A\0HH"); +// wxString _eq = wxT("A\0HH"); +// wxString _eq2 = wxT("A\0hH"); +// wxString _eq3 = wxT("a\0hh"); +// wxString _neq = wxT("H\0AH"); +// wxString _neq2 = wxT("A\0H"); +// wxString _neq3 = wxT("A\0HHH"); + + s1.insert(1,1,'\0'); + eq.insert(1,1,'\0'); + eq2.insert(1,1,'\0'); + eq3.insert(1,1,'\0'); + neq.insert(1,1,'\0'); + neq2.insert(1,1,'\0'); + neq3.insert(1,1,'\0'); + + CPPUNIT_CNCEQ_ASSERT( s1, eq ); + CPPUNIT_CNCEQ_ASSERT( s1, eq2 ); + CPPUNIT_CNCEQ_ASSERT( s1, eq3 ); + + CPPUNIT_CNCNEQ_ASSERT( s1, neq ); + CPPUNIT_CNCNEQ_ASSERT( s1, neq2 ); + CPPUNIT_CNCNEQ_ASSERT( s1, neq3 ); +} + +void StringTestCase::ToLong() +{ + long l; + static const struct ToLongData + { + const wxChar *str; + long value; + bool ok; + } longData[] = + { + { _T("1"), 1, true }, + { _T("0"), 0, true }, + { _T("a"), 0, false }, + { _T("12345"), 12345, true }, + { _T("-1"), -1, true }, + { _T("--1"), 0, false }, + }; + + size_t n; + for ( n = 0; n < WXSIZEOF(longData); n++ ) + { + const ToLongData& ld = longData[n]; + CPPUNIT_ASSERT_EQUAL( ld.ok, wxString(ld.str).ToLong(&l) ); + if ( ld.ok ) + CPPUNIT_ASSERT_EQUAL( ld.value, l ); + } +} + +void StringTestCase::ToULong() +{ + unsigned long ul; + static const struct ToULongData + { + const wxChar *str; + unsigned long value; + bool ok; + } ulongData[] = + { + { _T("1"), 1, true }, + { _T("0"), 0, true }, + { _T("a"), 0, false }, + { _T("12345"), 12345, true }, + // this is surprizing but consistent with strtoul() behaviour + { _T("-1"), ULONG_MAX, true }, + }; + + size_t n; + for ( n = 0; n < WXSIZEOF(ulongData); n++ ) + { + const ToULongData& uld = ulongData[n]; + CPPUNIT_ASSERT_EQUAL( uld.ok, wxString(uld.str).ToULong(&ul) ); + if ( uld.ok ) + CPPUNIT_ASSERT_EQUAL( uld.value, ul ); + } +} + +void StringTestCase::ToDouble() +{ + double d; + static const struct ToDoubleData + { + const wxChar *str; + double value; + bool ok; + } doubleData[] = + { + { _T("1"), 1, true }, + { _T("1.23"), 1.23, true }, + { _T(".1"), .1, true }, + { _T("1."), 1, true }, + { _T("1.."), 0, false }, + { _T("0"), 0, true }, + { _T("a"), 0, false }, + { _T("12345"), 12345, true }, + { _T("-1"), -1, true }, + { _T("--1"), 0, false }, + }; + + // we need to use decimal point, not comma or whatever is its value for the + // current locale + wxSetlocale(LC_ALL, _T("C")); + + size_t n; + for ( n = 0; n < WXSIZEOF(doubleData); n++ ) + { + const ToDoubleData& ld = doubleData[n]; + CPPUNIT_ASSERT_EQUAL( ld.ok, wxString(ld.str).ToDouble(&d) ); + if ( ld.ok ) + CPPUNIT_ASSERT_EQUAL( ld.value, d ); + } +}