1 ///////////////////////////////////////////////////////////////////////////// 
   2 // Name:        samples/console/console.cpp 
   3 // Purpose:     A sample console (as opposed to GUI) program using wxWidgets 
   4 // Author:      Vadim Zeitlin 
   8 // Copyright:   (c) 1999 Vadim Zeitlin <zeitlin@dptmaths.ens-cachan.fr> 
   9 // Licence:     wxWindows license 
  10 ///////////////////////////////////////////////////////////////////////////// 
  12 // ============================================================================ 
  14 // ============================================================================ 
  16 // ---------------------------------------------------------------------------- 
  18 // ---------------------------------------------------------------------------- 
  24 #include "wx/string.h" 
  29 // without this pragma, the stupid compiler precompiles #defines below so that 
  30 // changing them doesn't "take place" later! 
  35 // ---------------------------------------------------------------------------- 
  36 // conditional compilation 
  37 // ---------------------------------------------------------------------------- 
  40    A note about all these conditional compilation macros: this file is used 
  41    both as a test suite for various non-GUI wxWidgets classes and as a 
  42    scratchpad for quick tests. So there are two compilation modes: if you 
  43    define TEST_ALL all tests are run, otherwise you may enable the individual 
  44    tests individually in the "#else" branch below. 
  47 // what to test (in alphabetic order)? Define TEST_ALL to 0 to do a single 
  48 // test, define it to 1 to do all tests. 
  63  //   #define TEST_FTP  --FIXME! (RN) 
  64     #define TEST_INFO_FUNCTIONS 
  74     #define TEST_SCOPEGUARD 
  76 //    #define TEST_SOCKETS  --FIXME! (RN) 
  77     #define TEST_STACKWALKER 
  80     #define TEST_TEXTSTREAM 
  83     // #define TEST_VCARD            -- don't enable this (VZ) 
  84 //    #define TEST_VOLUME   --FIXME! (RN) 
  91 // some tests are interactive, define this to run them 
  92 #ifdef TEST_INTERACTIVE 
  93     #undef TEST_INTERACTIVE 
  95     #define TEST_INTERACTIVE 1 
  97     #define TEST_INTERACTIVE 0 
 100 // ============================================================================ 
 102 // ============================================================================ 
 104 // ---------------------------------------------------------------------------- 
 106 // ---------------------------------------------------------------------------- 
 108 #if defined(TEST_SOCKETS) 
 110 // replace TABs with \t and CRs with \n 
 111 static wxString 
MakePrintable(const wxChar 
*s
) 
 114     (void)str
.Replace(_T("\t"), _T("\\t")); 
 115     (void)str
.Replace(_T("\n"), _T("\\n")); 
 116     (void)str
.Replace(_T("\r"), _T("\\r")); 
 121 #endif // MakePrintable() is used 
 123 // ---------------------------------------------------------------------------- 
 125 // ---------------------------------------------------------------------------- 
 129 #include "wx/cmdline.h" 
 130 #include "wx/datetime.h" 
 132 #if wxUSE_CMDLINE_PARSER 
 134 static void ShowCmdLine(const wxCmdLineParser
& parser
) 
 136     wxString s 
= _T("Input files: "); 
 138     size_t count 
= parser
.GetParamCount(); 
 139     for ( size_t param 
= 0; param 
< count
; param
++ ) 
 141         s 
<< parser
.GetParam(param
) << ' '; 
 145       << _T("Verbose:\t") << (parser
.Found(_T("v")) ? _T("yes") : _T("no")) << '\n' 
 146       << _T("Quiet:\t") << (parser
.Found(_T("q")) ? _T("yes") : _T("no")) << '\n'; 
 151     if ( parser
.Found(_T("o"), &strVal
) ) 
 152         s 
<< _T("Output file:\t") << strVal 
<< '\n'; 
 153     if ( parser
.Found(_T("i"), &strVal
) ) 
 154         s 
<< _T("Input dir:\t") << strVal 
<< '\n'; 
 155     if ( parser
.Found(_T("s"), &lVal
) ) 
 156         s 
<< _T("Size:\t") << lVal 
<< '\n'; 
 157     if ( parser
.Found(_T("d"), &dt
) ) 
 158         s 
<< _T("Date:\t") << dt
.FormatISODate() << '\n'; 
 159     if ( parser
.Found(_T("project_name"), &strVal
) ) 
 160         s 
<< _T("Project:\t") << strVal 
<< '\n'; 
 165 #endif // wxUSE_CMDLINE_PARSER 
 167 static void TestCmdLineConvert() 
 169     static const wxChar 
*cmdlines
[] = 
 172         _T("-a \"-bstring 1\" -c\"string 2\" \"string 3\""), 
 173         _T("literal \\\" and \"\""), 
 176     for ( size_t n 
= 0; n 
< WXSIZEOF(cmdlines
); n
++ ) 
 178         const wxChar 
*cmdline 
= cmdlines
[n
]; 
 179         wxPrintf(_T("Parsing: %s\n"), cmdline
); 
 180         wxArrayString args 
= wxCmdLineParser::ConvertStringToArgs(cmdline
); 
 182         size_t count 
= args
.GetCount(); 
 183         wxPrintf(_T("\targc = %u\n"), count
); 
 184         for ( size_t arg 
= 0; arg 
< count
; arg
++ ) 
 186             wxPrintf(_T("\targv[%u] = %s\n"), arg
, args
[arg
].c_str()); 
 191 #endif // TEST_CMDLINE 
 193 // ---------------------------------------------------------------------------- 
 195 // ---------------------------------------------------------------------------- 
 202     static const wxChar 
*ROOTDIR 
= _T("/"); 
 203     static const wxChar 
*TESTDIR 
= _T("/usr/local/share"); 
 204 #elif defined(__WXMSW__) || defined(__DOS__) 
 205     static const wxChar 
*ROOTDIR 
= _T("c:\\"); 
 206     static const wxChar 
*TESTDIR 
= _T("d:\\"); 
 208     #error "don't know where the root directory is" 
 211 static void TestDirEnumHelper(wxDir
& dir
, 
 212                               int flags 
= wxDIR_DEFAULT
, 
 213                               const wxString
& filespec 
= wxEmptyString
) 
 217     if ( !dir
.IsOpened() ) 
 220     bool cont 
= dir
.GetFirst(&filename
, filespec
, flags
); 
 223         wxPrintf(_T("\t%s\n"), filename
.c_str()); 
 225         cont 
= dir
.GetNext(&filename
); 
 228     wxPuts(wxEmptyString
); 
 231 static void TestDirEnum() 
 233     wxPuts(_T("*** Testing wxDir::GetFirst/GetNext ***")); 
 235     wxString cwd 
= wxGetCwd(); 
 236     if ( !wxDir::Exists(cwd
) ) 
 238         wxPrintf(_T("ERROR: current directory '%s' doesn't exist?\n"), cwd
.c_str()); 
 243     if ( !dir
.IsOpened() ) 
 245         wxPrintf(_T("ERROR: failed to open current directory '%s'.\n"), cwd
.c_str()); 
 249     wxPuts(_T("Enumerating everything in current directory:")); 
 250     TestDirEnumHelper(dir
); 
 252     wxPuts(_T("Enumerating really everything in current directory:")); 
 253     TestDirEnumHelper(dir
, wxDIR_DEFAULT 
| wxDIR_DOTDOT
); 
 255     wxPuts(_T("Enumerating object files in current directory:")); 
 256     TestDirEnumHelper(dir
, wxDIR_DEFAULT
, _T("*.o*")); 
 258     wxPuts(_T("Enumerating directories in current directory:")); 
 259     TestDirEnumHelper(dir
, wxDIR_DIRS
); 
 261     wxPuts(_T("Enumerating files in current directory:")); 
 262     TestDirEnumHelper(dir
, wxDIR_FILES
); 
 264     wxPuts(_T("Enumerating files including hidden in current directory:")); 
 265     TestDirEnumHelper(dir
, wxDIR_FILES 
| wxDIR_HIDDEN
); 
 269     wxPuts(_T("Enumerating everything in root directory:")); 
 270     TestDirEnumHelper(dir
, wxDIR_DEFAULT
); 
 272     wxPuts(_T("Enumerating directories in root directory:")); 
 273     TestDirEnumHelper(dir
, wxDIR_DIRS
); 
 275     wxPuts(_T("Enumerating files in root directory:")); 
 276     TestDirEnumHelper(dir
, wxDIR_FILES
); 
 278     wxPuts(_T("Enumerating files including hidden in root directory:")); 
 279     TestDirEnumHelper(dir
, wxDIR_FILES 
| wxDIR_HIDDEN
); 
 281     wxPuts(_T("Enumerating files in non existing directory:")); 
 282     wxDir 
dirNo(_T("nosuchdir")); 
 283     TestDirEnumHelper(dirNo
); 
 286 class DirPrintTraverser 
: public wxDirTraverser
 
 289     virtual wxDirTraverseResult 
OnFile(const wxString
& WXUNUSED(filename
)) 
 291         return wxDIR_CONTINUE
; 
 294     virtual wxDirTraverseResult 
OnDir(const wxString
& dirname
) 
 296         wxString path
, name
, ext
; 
 297         wxSplitPath(dirname
, &path
, &name
, &ext
); 
 300             name 
<< _T('.') << ext
; 
 303         for ( const wxChar 
*p 
= path
.c_str(); *p
; p
++ ) 
 305             if ( wxIsPathSeparator(*p
) ) 
 309         wxPrintf(_T("%s%s\n"), indent
.c_str(), name
.c_str()); 
 311         return wxDIR_CONTINUE
; 
 315 static void TestDirTraverse() 
 317     wxPuts(_T("*** Testing wxDir::Traverse() ***")); 
 321     size_t n 
= wxDir::GetAllFiles(TESTDIR
, &files
); 
 322     wxPrintf(_T("There are %u files under '%s'\n"), n
, TESTDIR
); 
 325         wxPrintf(_T("First one is '%s'\n"), files
[0u].c_str()); 
 326         wxPrintf(_T(" last one is '%s'\n"), files
[n 
- 1].c_str()); 
 329     // enum again with custom traverser 
 330     wxPuts(_T("Now enumerating directories:")); 
 332     DirPrintTraverser traverser
; 
 333     dir
.Traverse(traverser
, wxEmptyString
, wxDIR_DIRS 
| wxDIR_HIDDEN
); 
 336 static void TestDirExists() 
 338     wxPuts(_T("*** Testing wxDir::Exists() ***")); 
 340     static const wxChar 
*dirnames
[] = 
 343 #if defined(__WXMSW__) 
 346         _T("\\\\share\\file"), 
 350         _T("c:\\autoexec.bat"), 
 351 #elif defined(__UNIX__) 
 360     for ( size_t n 
= 0; n 
< WXSIZEOF(dirnames
); n
++ ) 
 362         wxPrintf(_T("%-40s: %s\n"), 
 364                  wxDir::Exists(dirnames
[n
]) ? _T("exists") 
 365                                             : _T("doesn't exist")); 
 371 // ---------------------------------------------------------------------------- 
 373 // ---------------------------------------------------------------------------- 
 377 #include "wx/dynlib.h" 
 379 static void TestDllLoad() 
 381 #if defined(__WXMSW__) 
 382     static const wxChar 
*LIB_NAME 
= _T("kernel32.dll"); 
 383     static const wxChar 
*FUNC_NAME 
= _T("lstrlenA"); 
 384 #elif defined(__UNIX__) 
 385     // weird: using just libc.so does *not* work! 
 386     static const wxChar 
*LIB_NAME 
= _T("/lib/libc.so.6"); 
 387     static const wxChar 
*FUNC_NAME 
= _T("strlen"); 
 389     #error "don't know how to test wxDllLoader on this platform" 
 392     wxPuts(_T("*** testing basic wxDynamicLibrary functions ***\n")); 
 394     wxDynamicLibrary 
lib(LIB_NAME
); 
 395     if ( !lib
.IsLoaded() ) 
 397         wxPrintf(_T("ERROR: failed to load '%s'.\n"), LIB_NAME
); 
 401         typedef int (wxSTDCALL 
*wxStrlenType
)(const char *); 
 402         wxStrlenType pfnStrlen 
= (wxStrlenType
)lib
.GetSymbol(FUNC_NAME
); 
 405             wxPrintf(_T("ERROR: function '%s' wasn't found in '%s'.\n"), 
 406                      FUNC_NAME
, LIB_NAME
); 
 410             wxPrintf(_T("Calling %s dynamically loaded from %s "), 
 411                      FUNC_NAME
, LIB_NAME
); 
 413             if ( pfnStrlen("foo") != 3 ) 
 415                 wxPrintf(_T("ERROR: loaded function is not wxStrlen()!\n")); 
 419                 wxPuts(_T("... ok")); 
 424         static const wxChar 
*FUNC_NAME_AW 
= _T("lstrlen"); 
 426         typedef int (wxSTDCALL 
*wxStrlenTypeAorW
)(const wxChar 
*); 
 428             pfnStrlenAorW 
= (wxStrlenTypeAorW
)lib
.GetSymbolAorW(FUNC_NAME_AW
); 
 429         if ( !pfnStrlenAorW 
) 
 431             wxPrintf(_T("ERROR: function '%s' wasn't found in '%s'.\n"), 
 432                      FUNC_NAME_AW
, LIB_NAME
); 
 436             if ( pfnStrlenAorW(_T("foobar")) != 6 ) 
 438                 wxPrintf(_T("ERROR: loaded function is not wxStrlen()!\n")); 
 445 #if defined(__WXMSW__) || defined(__UNIX__) 
 447 static void TestDllListLoaded() 
 449     wxPuts(_T("*** testing wxDynamicLibrary::ListLoaded() ***\n")); 
 451     puts("\nLoaded modules:"); 
 452     wxDynamicLibraryDetailsArray dlls 
= wxDynamicLibrary::ListLoaded(); 
 453     const size_t count 
= dlls
.GetCount(); 
 454     for ( size_t n 
= 0; n 
< count
; ++n 
) 
 456         const wxDynamicLibraryDetails
& details 
= dlls
[n
]; 
 457         printf("%-45s", details
.GetPath().mb_str()); 
 461         if ( details
.GetAddress(&addr
, &len
) ) 
 463             printf(" %08lx:%08lx", 
 464                    (unsigned long)addr
, (unsigned long)((char *)addr 
+ len
)); 
 467         printf(" %s\n", details
.GetVersion().mb_str()); 
 473 #endif // TEST_DYNLIB 
 475 // ---------------------------------------------------------------------------- 
 477 // ---------------------------------------------------------------------------- 
 481 #include "wx/utils.h" 
 483 static wxString 
MyGetEnv(const wxString
& var
) 
 486     if ( !wxGetEnv(var
, &val
) ) 
 489         val 
= wxString(_T('\'')) + val 
+ _T('\''); 
 494 static void TestEnvironment() 
 496     const wxChar 
*var 
= _T("wxTestVar"); 
 498     wxPuts(_T("*** testing environment access functions ***")); 
 500     wxPrintf(_T("Initially getenv(%s) = %s\n"), var
, MyGetEnv(var
).c_str()); 
 501     wxSetEnv(var
, _T("value for wxTestVar")); 
 502     wxPrintf(_T("After wxSetEnv: getenv(%s) = %s\n"),  var
, MyGetEnv(var
).c_str()); 
 503     wxSetEnv(var
, _T("another value")); 
 504     wxPrintf(_T("After 2nd wxSetEnv: getenv(%s) = %s\n"),  var
, MyGetEnv(var
).c_str()); 
 506     wxPrintf(_T("After wxUnsetEnv: getenv(%s) = %s\n"),  var
, MyGetEnv(var
).c_str()); 
 507     wxPrintf(_T("PATH = %s\n"),  MyGetEnv(_T("PATH")).c_str()); 
 510 #endif // TEST_ENVIRON 
 512 // ---------------------------------------------------------------------------- 
 514 // ---------------------------------------------------------------------------- 
 518 #include "wx/utils.h" 
 520 static void TestExecute() 
 522     wxPuts(_T("*** testing wxExecute ***")); 
 525     #define COMMAND "cat -n ../../Makefile" // "echo hi" 
 526     #define SHELL_COMMAND "echo hi from shell" 
 527     #define REDIRECT_COMMAND COMMAND // "date" 
 528 #elif defined(__WXMSW__) 
 529     #define COMMAND "command.com /c echo hi" 
 530     #define SHELL_COMMAND "echo hi" 
 531     #define REDIRECT_COMMAND COMMAND 
 533     #error "no command to exec" 
 536     wxPrintf(_T("Testing wxShell: ")); 
 538     if ( wxShell(_T(SHELL_COMMAND
)) ) 
 541         wxPuts(_T("ERROR.")); 
 543     wxPrintf(_T("Testing wxExecute: ")); 
 545     if ( wxExecute(_T(COMMAND
), true /* sync */) == 0 ) 
 548         wxPuts(_T("ERROR.")); 
 550 #if 0 // no, it doesn't work (yet?) 
 551     wxPrintf(_T("Testing async wxExecute: ")); 
 553     if ( wxExecute(COMMAND
) != 0 ) 
 554         wxPuts(_T("Ok (command launched).")); 
 556         wxPuts(_T("ERROR.")); 
 559     wxPrintf(_T("Testing wxExecute with redirection:\n")); 
 560     wxArrayString output
; 
 561     if ( wxExecute(_T(REDIRECT_COMMAND
), output
) != 0 ) 
 563         wxPuts(_T("ERROR.")); 
 567         size_t count 
= output
.GetCount(); 
 568         for ( size_t n 
= 0; n 
< count
; n
++ ) 
 570             wxPrintf(_T("\t%s\n"), output
[n
].c_str()); 
 577 #endif // TEST_EXECUTE 
 579 // ---------------------------------------------------------------------------- 
 581 // ---------------------------------------------------------------------------- 
 586 #include "wx/ffile.h" 
 587 #include "wx/textfile.h" 
 589 static void TestFileRead() 
 591     wxPuts(_T("*** wxFile read test ***")); 
 593     wxFile 
file(_T("testdata.fc")); 
 594     if ( file
.IsOpened() ) 
 596         wxPrintf(_T("File length: %lu\n"), file
.Length()); 
 598         wxPuts(_T("File dump:\n----------")); 
 600         static const size_t len 
= 1024; 
 604             size_t nRead 
= file
.Read(buf
, len
); 
 605             if ( nRead 
== (size_t)wxInvalidOffset 
) 
 607                 wxPrintf(_T("Failed to read the file.")); 
 611             fwrite(buf
, nRead
, 1, stdout
); 
 617         wxPuts(_T("----------")); 
 621         wxPrintf(_T("ERROR: can't open test file.\n")); 
 624     wxPuts(wxEmptyString
); 
 627 static void TestTextFileRead() 
 629     wxPuts(_T("*** wxTextFile read test ***")); 
 631     wxTextFile 
file(_T("testdata.fc")); 
 634         wxPrintf(_T("Number of lines: %u\n"), file
.GetLineCount()); 
 635         wxPrintf(_T("Last line: '%s'\n"), file
.GetLastLine().c_str()); 
 639         wxPuts(_T("\nDumping the entire file:")); 
 640         for ( s 
= file
.GetFirstLine(); !file
.Eof(); s 
= file
.GetNextLine() ) 
 642             wxPrintf(_T("%6u: %s\n"), file
.GetCurrentLine() + 1, s
.c_str()); 
 644         wxPrintf(_T("%6u: %s\n"), file
.GetCurrentLine() + 1, s
.c_str()); 
 646         wxPuts(_T("\nAnd now backwards:")); 
 647         for ( s 
= file
.GetLastLine(); 
 648               file
.GetCurrentLine() != 0; 
 649               s 
= file
.GetPrevLine() ) 
 651             wxPrintf(_T("%6u: %s\n"), file
.GetCurrentLine() + 1, s
.c_str()); 
 653         wxPrintf(_T("%6u: %s\n"), file
.GetCurrentLine() + 1, s
.c_str()); 
 657         wxPrintf(_T("ERROR: can't open '%s'\n"), file
.GetName()); 
 660     wxPuts(wxEmptyString
); 
 663 static void TestFileCopy() 
 665     wxPuts(_T("*** Testing wxCopyFile ***")); 
 667     static const wxChar 
*filename1 
= _T("testdata.fc"); 
 668     static const wxChar 
*filename2 
= _T("test2"); 
 669     if ( !wxCopyFile(filename1
, filename2
) ) 
 671         wxPuts(_T("ERROR: failed to copy file")); 
 675         wxFFile 
f1(filename1
, _T("rb")), 
 676                 f2(filename2
, _T("rb")); 
 678         if ( !f1
.IsOpened() || !f2
.IsOpened() ) 
 680             wxPuts(_T("ERROR: failed to open file(s)")); 
 685             if ( !f1
.ReadAll(&s1
) || !f2
.ReadAll(&s2
) ) 
 687                 wxPuts(_T("ERROR: failed to read file(s)")); 
 691                 if ( (s1
.length() != s2
.length()) || 
 692                      (memcmp(s1
.c_str(), s2
.c_str(), s1
.length()) != 0) ) 
 694                     wxPuts(_T("ERROR: copy error!")); 
 698                     wxPuts(_T("File was copied ok.")); 
 704     if ( !wxRemoveFile(filename2
) ) 
 706         wxPuts(_T("ERROR: failed to remove the file")); 
 709     wxPuts(wxEmptyString
); 
 714 // ---------------------------------------------------------------------------- 
 716 // ---------------------------------------------------------------------------- 
 720 #include "wx/confbase.h" 
 721 #include "wx/fileconf.h" 
 723 static const struct FileConfTestData
 
 725     const wxChar 
*name
;      // value name 
 726     const wxChar 
*value
;     // the value from the file 
 729     { _T("value1"),                       _T("one") }, 
 730     { _T("value2"),                       _T("two") }, 
 731     { _T("novalue"),                      _T("default") }, 
 734 static void TestFileConfRead() 
 736     wxPuts(_T("*** testing wxFileConfig loading/reading ***")); 
 738     wxFileConfig 
fileconf(_T("test"), wxEmptyString
, 
 739                           _T("testdata.fc"), wxEmptyString
, 
 740                           wxCONFIG_USE_RELATIVE_PATH
); 
 742     // test simple reading 
 743     wxPuts(_T("\nReading config file:")); 
 744     wxString 
defValue(_T("default")), value
; 
 745     for ( size_t n 
= 0; n 
< WXSIZEOF(fcTestData
); n
++ ) 
 747         const FileConfTestData
& data 
= fcTestData
[n
]; 
 748         value 
= fileconf
.Read(data
.name
, defValue
); 
 749         wxPrintf(_T("\t%s = %s "), data
.name
, value
.c_str()); 
 750         if ( value 
== data
.value 
) 
 756             wxPrintf(_T("(ERROR: should be %s)\n"), data
.value
); 
 760     // test enumerating the entries 
 761     wxPuts(_T("\nEnumerating all root entries:")); 
 764     bool cont 
= fileconf
.GetFirstEntry(name
, dummy
); 
 767         wxPrintf(_T("\t%s = %s\n"), 
 769                fileconf
.Read(name
.c_str(), _T("ERROR")).c_str()); 
 771         cont 
= fileconf
.GetNextEntry(name
, dummy
); 
 774     static const wxChar 
*testEntry 
= _T("TestEntry"); 
 775     wxPrintf(_T("\nTesting deletion of newly created \"Test\" entry: ")); 
 776     fileconf
.Write(testEntry
, _T("A value")); 
 777     fileconf
.DeleteEntry(testEntry
); 
 778     wxPrintf(fileconf
.HasEntry(testEntry
) ? _T("ERROR\n") : _T("ok\n")); 
 781 #endif // TEST_FILECONF 
 783 // ---------------------------------------------------------------------------- 
 785 // ---------------------------------------------------------------------------- 
 789 #include "wx/filename.h" 
 792 static void DumpFileName(const wxChar 
*desc
, const wxFileName
& fn
) 
 796     wxString full 
= fn
.GetFullPath(); 
 798     wxString vol
, path
, name
, ext
; 
 799     wxFileName::SplitPath(full
, &vol
, &path
, &name
, &ext
); 
 801     wxPrintf(_T("'%s'-> vol '%s', path '%s', name '%s', ext '%s'\n"), 
 802              full
.c_str(), vol
.c_str(), path
.c_str(), name
.c_str(), ext
.c_str()); 
 804     wxFileName::SplitPath(full
, &path
, &name
, &ext
); 
 805     wxPrintf(_T("or\t\t-> path '%s', name '%s', ext '%s'\n"), 
 806              path
.c_str(), name
.c_str(), ext
.c_str()); 
 808     wxPrintf(_T("path is also:\t'%s'\n"), fn
.GetPath().c_str()); 
 809     wxPrintf(_T("with volume: \t'%s'\n"), 
 810              fn
.GetPath(wxPATH_GET_VOLUME
).c_str()); 
 811     wxPrintf(_T("with separator:\t'%s'\n"), 
 812              fn
.GetPath(wxPATH_GET_SEPARATOR
).c_str()); 
 813     wxPrintf(_T("with both:   \t'%s'\n"), 
 814              fn
.GetPath(wxPATH_GET_SEPARATOR 
| wxPATH_GET_VOLUME
).c_str()); 
 816     wxPuts(_T("The directories in the path are:")); 
 817     wxArrayString dirs 
= fn
.GetDirs(); 
 818     size_t count 
= dirs
.GetCount(); 
 819     for ( size_t n 
= 0; n 
< count
; n
++ ) 
 821         wxPrintf(_T("\t%u: %s\n"), n
, dirs
[n
].c_str()); 
 826 static void TestFileNameTemp() 
 828     wxPuts(_T("*** testing wxFileName temp file creation ***")); 
 830     static const wxChar 
*tmpprefixes
[] = 
 838         _T("/tmp/foo/bar"), // this one must be an error 
 842     for ( size_t n 
= 0; n 
< WXSIZEOF(tmpprefixes
); n
++ ) 
 844         wxString path 
= wxFileName::CreateTempFileName(tmpprefixes
[n
]); 
 847             // "error" is not in upper case because it may be ok 
 848             wxPrintf(_T("Prefix '%s'\t-> error\n"), tmpprefixes
[n
]); 
 852             wxPrintf(_T("Prefix '%s'\t-> temp file '%s'\n"), 
 853                    tmpprefixes
[n
], path
.c_str()); 
 855             if ( !wxRemoveFile(path
) ) 
 857                 wxLogWarning(_T("Failed to remove temp file '%s'"), 
 864 static void TestFileNameDirManip() 
 866     // TODO: test AppendDir(), RemoveDir(), ... 
 869 static void TestFileNameComparison() 
 874 static void TestFileNameOperations() 
 879 static void TestFileNameCwd() 
 884 #endif // TEST_FILENAME 
 886 // ---------------------------------------------------------------------------- 
 887 // wxFileName time functions 
 888 // ---------------------------------------------------------------------------- 
 892 #include <wx/filename.h> 
 893 #include <wx/datetime.h> 
 895 static void TestFileGetTimes() 
 897     wxFileName 
fn(_T("testdata.fc")); 
 899     wxDateTime dtAccess
, dtMod
, dtCreate
; 
 900     if ( !fn
.GetTimes(&dtAccess
, &dtMod
, &dtCreate
) ) 
 902         wxPrintf(_T("ERROR: GetTimes() failed.\n")); 
 906         static const wxChar 
*fmt 
= _T("%Y-%b-%d %H:%M:%S"); 
 908         wxPrintf(_T("File times for '%s':\n"), fn
.GetFullPath().c_str()); 
 909         wxPrintf(_T("Creation:    \t%s\n"), dtCreate
.Format(fmt
).c_str()); 
 910         wxPrintf(_T("Last read:   \t%s\n"), dtAccess
.Format(fmt
).c_str()); 
 911         wxPrintf(_T("Last write:  \t%s\n"), dtMod
.Format(fmt
).c_str()); 
 916 static void TestFileSetTimes() 
 918     wxFileName 
fn(_T("testdata.fc")); 
 922         wxPrintf(_T("ERROR: Touch() failed.\n")); 
 927 #endif // TEST_FILETIME 
 929 // ---------------------------------------------------------------------------- 
 931 // ---------------------------------------------------------------------------- 
 936 #include "wx/utils.h"   // for wxSetEnv 
 938 static wxLocale 
gs_localeDefault(wxLANGUAGE_ENGLISH
); 
 940 // find the name of the language from its value 
 941 static const wxChar 
*GetLangName(int lang
) 
 943     static const wxChar 
*languageNames
[] = 
 953         _T("ARABIC_ALGERIA"), 
 954         _T("ARABIC_BAHRAIN"), 
 959         _T("ARABIC_LEBANON"), 
 961         _T("ARABIC_MOROCCO"), 
 964         _T("ARABIC_SAUDI_ARABIA"), 
 967         _T("ARABIC_TUNISIA"), 
 974         _T("AZERI_CYRILLIC"), 
 989         _T("CHINESE_SIMPLIFIED"), 
 990         _T("CHINESE_TRADITIONAL"), 
 991         _T("CHINESE_HONGKONG"), 
 993         _T("CHINESE_SINGAPORE"), 
 994         _T("CHINESE_TAIWAN"), 
1000         _T("DUTCH_BELGIAN"), 
1004         _T("ENGLISH_AUSTRALIA"), 
1005         _T("ENGLISH_BELIZE"), 
1006         _T("ENGLISH_BOTSWANA"), 
1007         _T("ENGLISH_CANADA"), 
1008         _T("ENGLISH_CARIBBEAN"), 
1009         _T("ENGLISH_DENMARK"), 
1011         _T("ENGLISH_JAMAICA"), 
1012         _T("ENGLISH_NEW_ZEALAND"), 
1013         _T("ENGLISH_PHILIPPINES"), 
1014         _T("ENGLISH_SOUTH_AFRICA"), 
1015         _T("ENGLISH_TRINIDAD"), 
1016         _T("ENGLISH_ZIMBABWE"), 
1024         _T("FRENCH_BELGIAN"), 
1025         _T("FRENCH_CANADIAN"), 
1026         _T("FRENCH_LUXEMBOURG"), 
1027         _T("FRENCH_MONACO"), 
1033         _T("GERMAN_AUSTRIAN"), 
1034         _T("GERMAN_BELGIUM"), 
1035         _T("GERMAN_LIECHTENSTEIN"), 
1036         _T("GERMAN_LUXEMBOURG"), 
1054         _T("ITALIAN_SWISS"), 
1059         _T("KASHMIRI_INDIA"), 
1077         _T("MALAY_BRUNEI_DARUSSALAM"), 
1078         _T("MALAY_MALAYSIA"), 
1088         _T("NORWEGIAN_BOKMAL"), 
1089         _T("NORWEGIAN_NYNORSK"), 
1096         _T("PORTUGUESE_BRAZILIAN"), 
1099         _T("RHAETO_ROMANCE"), 
1102         _T("RUSSIAN_UKRAINE"), 
1108         _T("SERBIAN_CYRILLIC"), 
1109         _T("SERBIAN_LATIN"), 
1110         _T("SERBO_CROATIAN"), 
1121         _T("SPANISH_ARGENTINA"), 
1122         _T("SPANISH_BOLIVIA"), 
1123         _T("SPANISH_CHILE"), 
1124         _T("SPANISH_COLOMBIA"), 
1125         _T("SPANISH_COSTA_RICA"), 
1126         _T("SPANISH_DOMINICAN_REPUBLIC"), 
1127         _T("SPANISH_ECUADOR"), 
1128         _T("SPANISH_EL_SALVADOR"), 
1129         _T("SPANISH_GUATEMALA"), 
1130         _T("SPANISH_HONDURAS"), 
1131         _T("SPANISH_MEXICAN"), 
1132         _T("SPANISH_MODERN"), 
1133         _T("SPANISH_NICARAGUA"), 
1134         _T("SPANISH_PANAMA"), 
1135         _T("SPANISH_PARAGUAY"), 
1137         _T("SPANISH_PUERTO_RICO"), 
1138         _T("SPANISH_URUGUAY"), 
1140         _T("SPANISH_VENEZUELA"), 
1144         _T("SWEDISH_FINLAND"), 
1162         _T("URDU_PAKISTAN"), 
1164         _T("UZBEK_CYRILLIC"), 
1177     if ( (size_t)lang 
< WXSIZEOF(languageNames
) ) 
1178         return languageNames
[lang
]; 
1180         return _T("INVALID"); 
1183 static void TestDefaultLang() 
1185     wxPuts(_T("*** Testing wxLocale::GetSystemLanguage ***")); 
1187     static const wxChar 
*langStrings
[] = 
1189         NULL
,               // system default 
1196         _T("de_DE.iso88591"), 
1198         _T("?"),            // invalid lang spec 
1199         _T("klingonese"),   // I bet on some systems it does exist... 
1202     wxPrintf(_T("The default system encoding is %s (%d)\n"), 
1203              wxLocale::GetSystemEncodingName().c_str(), 
1204              wxLocale::GetSystemEncoding()); 
1206     for ( size_t n 
= 0; n 
< WXSIZEOF(langStrings
); n
++ ) 
1208         const wxChar 
*langStr 
= langStrings
[n
]; 
1211             // FIXME: this doesn't do anything at all under Windows, we need 
1212             //        to create a new wxLocale! 
1213             wxSetEnv(_T("LC_ALL"), langStr
); 
1216         int lang 
= gs_localeDefault
.GetSystemLanguage(); 
1217         wxPrintf(_T("Locale for '%s' is %s.\n"), 
1218                  langStr 
? langStr 
: _T("system default"), GetLangName(lang
)); 
1222 #endif // TEST_LOCALE 
1224 // ---------------------------------------------------------------------------- 
1226 // ---------------------------------------------------------------------------- 
1230 #include "wx/mimetype.h" 
1232 static void TestMimeEnum() 
1234     wxPuts(_T("*** Testing wxMimeTypesManager::EnumAllFileTypes() ***\n")); 
1236     wxArrayString mimetypes
; 
1238     size_t count 
= wxTheMimeTypesManager
->EnumAllFileTypes(mimetypes
); 
1240     wxPrintf(_T("*** All %u known filetypes: ***\n"), count
); 
1245     for ( size_t n 
= 0; n 
< count
; n
++ ) 
1247         wxFileType 
*filetype 
= 
1248             wxTheMimeTypesManager
->GetFileTypeFromMimeType(mimetypes
[n
]); 
1251             wxPrintf(_T("nothing known about the filetype '%s'!\n"), 
1252                    mimetypes
[n
].c_str()); 
1256         filetype
->GetDescription(&desc
); 
1257         filetype
->GetExtensions(exts
); 
1259         filetype
->GetIcon(NULL
); 
1262         for ( size_t e 
= 0; e 
< exts
.GetCount(); e
++ ) 
1265                 extsAll 
<< _T(", "); 
1269         wxPrintf(_T("\t%s: %s (%s)\n"), 
1270                mimetypes
[n
].c_str(), desc
.c_str(), extsAll
.c_str()); 
1273     wxPuts(wxEmptyString
); 
1276 static void TestMimeOverride() 
1278     wxPuts(_T("*** Testing wxMimeTypesManager additional files loading ***\n")); 
1280     static const wxChar 
*mailcap 
= _T("/tmp/mailcap"); 
1281     static const wxChar 
*mimetypes 
= _T("/tmp/mime.types"); 
1283     if ( wxFile::Exists(mailcap
) ) 
1284         wxPrintf(_T("Loading mailcap from '%s': %s\n"), 
1286                  wxTheMimeTypesManager
->ReadMailcap(mailcap
) ? _T("ok") : _T("ERROR")); 
1288         wxPrintf(_T("WARN: mailcap file '%s' doesn't exist, not loaded.\n"), 
1291     if ( wxFile::Exists(mimetypes
) ) 
1292         wxPrintf(_T("Loading mime.types from '%s': %s\n"), 
1294                  wxTheMimeTypesManager
->ReadMimeTypes(mimetypes
) ? _T("ok") : _T("ERROR")); 
1296         wxPrintf(_T("WARN: mime.types file '%s' doesn't exist, not loaded.\n"), 
1299     wxPuts(wxEmptyString
); 
1302 static void TestMimeFilename() 
1304     wxPuts(_T("*** Testing MIME type from filename query ***\n")); 
1306     static const wxChar 
*filenames
[] = 
1314     for ( size_t n 
= 0; n 
< WXSIZEOF(filenames
); n
++ ) 
1316         const wxString fname 
= filenames
[n
]; 
1317         wxString ext 
= fname
.AfterLast(_T('.')); 
1318         wxFileType 
*ft 
= wxTheMimeTypesManager
->GetFileTypeFromExtension(ext
); 
1321             wxPrintf(_T("WARNING: extension '%s' is unknown.\n"), ext
.c_str()); 
1326             if ( !ft
->GetDescription(&desc
) ) 
1327                 desc 
= _T("<no description>"); 
1330             if ( !ft
->GetOpenCommand(&cmd
, 
1331                                      wxFileType::MessageParameters(fname
, wxEmptyString
)) ) 
1332                 cmd 
= _T("<no command available>"); 
1334                 cmd 
= wxString(_T('"')) + cmd 
+ _T('"'); 
1336             wxPrintf(_T("To open %s (%s) do %s.\n"), 
1337                      fname
.c_str(), desc
.c_str(), cmd
.c_str()); 
1343     wxPuts(wxEmptyString
); 
1346 static void TestMimeAssociate() 
1348     wxPuts(_T("*** Testing creation of filetype association ***\n")); 
1350     wxFileTypeInfo 
ftInfo( 
1351                             _T("application/x-xyz"), 
1352                             _T("xyzview '%s'"), // open cmd 
1353                             _T(""),             // print cmd 
1354                             _T("XYZ File"),     // description 
1355                             _T(".xyz"),         // extensions 
1356                             NULL                
// end of extensions 
1358     ftInfo
.SetShortDesc(_T("XYZFile")); // used under Win32 only 
1360     wxFileType 
*ft 
= wxTheMimeTypesManager
->Associate(ftInfo
); 
1363         wxPuts(_T("ERROR: failed to create association!")); 
1367         // TODO: read it back 
1371     wxPuts(wxEmptyString
); 
1376 // ---------------------------------------------------------------------------- 
1377 // misc information functions 
1378 // ---------------------------------------------------------------------------- 
1380 #ifdef TEST_INFO_FUNCTIONS 
1382 #include "wx/utils.h" 
1384 static void TestDiskInfo() 
1386     wxPuts(_T("*** Testing wxGetDiskSpace() ***")); 
1390         wxChar pathname
[128]; 
1391         wxPrintf(_T("\nEnter a directory name: ")); 
1392         if ( !wxFgets(pathname
, WXSIZEOF(pathname
), stdin
) ) 
1395         // kill the last '\n' 
1396         pathname
[wxStrlen(pathname
) - 1] = 0; 
1398         wxLongLong total
, free
; 
1399         if ( !wxGetDiskSpace(pathname
, &total
, &free
) ) 
1401             wxPuts(_T("ERROR: wxGetDiskSpace failed.")); 
1405             wxPrintf(_T("%sKb total, %sKb free on '%s'.\n"), 
1406                     (total 
/ 1024).ToString().c_str(), 
1407                     (free 
/ 1024).ToString().c_str(), 
1413 static void TestOsInfo() 
1415     wxPuts(_T("*** Testing OS info functions ***\n")); 
1418     wxGetOsVersion(&major
, &minor
); 
1419     wxPrintf(_T("Running under: %s, version %d.%d\n"), 
1420             wxGetOsDescription().c_str(), major
, minor
); 
1422     wxPrintf(_T("%ld free bytes of memory left.\n"), wxGetFreeMemory()); 
1424     wxPrintf(_T("Host name is %s (%s).\n"), 
1425            wxGetHostName().c_str(), wxGetFullHostName().c_str()); 
1427     wxPuts(wxEmptyString
); 
1430 static void TestUserInfo() 
1432     wxPuts(_T("*** Testing user info functions ***\n")); 
1434     wxPrintf(_T("User id is:\t%s\n"), wxGetUserId().c_str()); 
1435     wxPrintf(_T("User name is:\t%s\n"), wxGetUserName().c_str()); 
1436     wxPrintf(_T("Home dir is:\t%s\n"), wxGetHomeDir().c_str()); 
1437     wxPrintf(_T("Email address:\t%s\n"), wxGetEmailAddress().c_str()); 
1439     wxPuts(wxEmptyString
); 
1442 #endif // TEST_INFO_FUNCTIONS 
1444 // ---------------------------------------------------------------------------- 
1446 // ---------------------------------------------------------------------------- 
1448 #ifdef TEST_PATHLIST 
1451     #define CMD_IN_PATH _T("ls") 
1453     #define CMD_IN_PATH _T("command.com") 
1456 static void TestPathList() 
1458     wxPuts(_T("*** Testing wxPathList ***\n")); 
1460     wxPathList pathlist
; 
1461     pathlist
.AddEnvList(_T("PATH")); 
1462     wxString path 
= pathlist
.FindValidPath(CMD_IN_PATH
); 
1465         wxPrintf(_T("ERROR: command not found in the path.\n")); 
1469         wxPrintf(_T("Command found in the path as '%s'.\n"), path
.c_str()); 
1473 #endif // TEST_PATHLIST 
1475 // ---------------------------------------------------------------------------- 
1476 // regular expressions 
1477 // ---------------------------------------------------------------------------- 
1481 #include "wx/regex.h" 
1483 static void TestRegExInteractive() 
1485     wxPuts(_T("*** Testing RE interactively ***")); 
1489         wxChar pattern
[128]; 
1490         wxPrintf(_T("\nEnter a pattern: ")); 
1491         if ( !wxFgets(pattern
, WXSIZEOF(pattern
), stdin
) ) 
1494         // kill the last '\n' 
1495         pattern
[wxStrlen(pattern
) - 1] = 0; 
1498         if ( !re
.Compile(pattern
) ) 
1506             wxPrintf(_T("Enter text to match: ")); 
1507             if ( !wxFgets(text
, WXSIZEOF(text
), stdin
) ) 
1510             // kill the last '\n' 
1511             text
[wxStrlen(text
) - 1] = 0; 
1513             if ( !re
.Matches(text
) ) 
1515                 wxPrintf(_T("No match.\n")); 
1519                 wxPrintf(_T("Pattern matches at '%s'\n"), re
.GetMatch(text
).c_str()); 
1522                 for ( size_t n 
= 1; ; n
++ ) 
1524                     if ( !re
.GetMatch(&start
, &len
, n
) ) 
1529                     wxPrintf(_T("Subexpr %u matched '%s'\n"), 
1530                              n
, wxString(text 
+ start
, len
).c_str()); 
1537 #endif // TEST_REGEX 
1539 // ---------------------------------------------------------------------------- 
1541 // ---------------------------------------------------------------------------- 
1551 static void TestDbOpen() 
1559 // ---------------------------------------------------------------------------- 
1561 // ---------------------------------------------------------------------------- 
1564    NB: this stuff was taken from the glibc test suite and modified to build 
1565        in wxWidgets: if I read the copyright below properly, this shouldn't 
1571 #ifdef wxTEST_PRINTF 
1572     // use our functions from wxchar.cpp 
1576     // NB: do _not_ use ATTRIBUTE_PRINTF here, we have some invalid formats 
1577     //     in the tests below 
1578     int wxPrintf( const wxChar 
*format
, ... ); 
1579     int wxSprintf( wxChar 
*str
, const wxChar 
*format
, ... ); 
1582 #include "wx/longlong.h" 
1586 static void rfg1 (void); 
1587 static void rfg2 (void); 
1591 fmtchk (const wxChar 
*fmt
) 
1593   (void) wxPrintf(_T("%s:\t`"), fmt
); 
1594   (void) wxPrintf(fmt
, 0x12); 
1595   (void) wxPrintf(_T("'\n")); 
1599 fmtst1chk (const wxChar 
*fmt
) 
1601   (void) wxPrintf(_T("%s:\t`"), fmt
); 
1602   (void) wxPrintf(fmt
, 4, 0x12); 
1603   (void) wxPrintf(_T("'\n")); 
1607 fmtst2chk (const wxChar 
*fmt
) 
1609   (void) wxPrintf(_T("%s:\t`"), fmt
); 
1610   (void) wxPrintf(fmt
, 4, 4, 0x12); 
1611   (void) wxPrintf(_T("'\n")); 
1614 /* This page is covered by the following copyright: */ 
1616 /* (C) Copyright C E Chew 
1618  * Feel free to copy, use and distribute this software provided: 
1620  *        1. you do not pretend that you wrote it 
1621  *        2. you leave this copyright notice intact. 
1625  * Extracted from exercise.c for glibc-1.05 bug report by Bruce Evans. 
1632 /* Formatted Output Test 
1634  * This exercises the output formatting code. 
1637 wxChar 
*PointerNull 
= NULL
; 
1644   wxChar 
*prefix 
= buf
; 
1647   wxPuts(_T("\nFormatted output test")); 
1648   wxPrintf(_T("prefix  6d      6o      6x      6X      6u\n")); 
1649   wxStrcpy(prefix
, _T("%")); 
1650   for (i 
= 0; i 
< 2; i
++) { 
1651     for (j 
= 0; j 
< 2; j
++) { 
1652       for (k 
= 0; k 
< 2; k
++) { 
1653         for (l 
= 0; l 
< 2; l
++) { 
1654           wxStrcpy(prefix
, _T("%")); 
1655           if (i 
== 0) wxStrcat(prefix
, _T("-")); 
1656           if (j 
== 0) wxStrcat(prefix
, _T("+")); 
1657           if (k 
== 0) wxStrcat(prefix
, _T("#")); 
1658           if (l 
== 0) wxStrcat(prefix
, _T("0")); 
1659           wxPrintf(_T("%5s |"), prefix
); 
1660           wxStrcpy(tp
, prefix
); 
1661           wxStrcat(tp
, _T("6d |")); 
1663           wxStrcpy(tp
, prefix
); 
1664           wxStrcat(tp
, _T("6o |")); 
1666           wxStrcpy(tp
, prefix
); 
1667           wxStrcat(tp
, _T("6x |")); 
1669           wxStrcpy(tp
, prefix
); 
1670           wxStrcat(tp
, _T("6X |")); 
1672           wxStrcpy(tp
, prefix
); 
1673           wxStrcat(tp
, _T("6u |")); 
1680   wxPrintf(_T("%10s\n"), PointerNull
); 
1681   wxPrintf(_T("%-10s\n"), PointerNull
); 
1684 static void TestPrintf() 
1686   static wxChar shortstr
[] = _T("Hi, Z."); 
1687   static wxChar longstr
[] = _T("Good morning, Doctor Chandra.  This is Hal.  \ 
1688 I am ready for my first lesson today."); 
1690   wxString test_format
; 
1694   fmtchk(_T("%4.4x")); 
1695   fmtchk(_T("%04.4x")); 
1696   fmtchk(_T("%4.3x")); 
1697   fmtchk(_T("%04.3x")); 
1699   fmtst1chk(_T("%.*x")); 
1700   fmtst1chk(_T("%0*x")); 
1701   fmtst2chk(_T("%*.*x")); 
1702   fmtst2chk(_T("%0*.*x")); 
1704   wxString bad_format 
= _T("bad format:\t\"%b\"\n"); 
1705   wxPrintf(bad_format
.c_str()); 
1706   wxPrintf(_T("nil pointer (padded):\t\"%10p\"\n"), (void *) NULL
); 
1708   wxPrintf(_T("decimal negative:\t\"%d\"\n"), -2345); 
1709   wxPrintf(_T("octal negative:\t\"%o\"\n"), -2345); 
1710   wxPrintf(_T("hex negative:\t\"%x\"\n"), -2345); 
1711   wxPrintf(_T("long decimal number:\t\"%ld\"\n"), -123456L); 
1712   wxPrintf(_T("long octal negative:\t\"%lo\"\n"), -2345L); 
1713   wxPrintf(_T("long unsigned decimal number:\t\"%lu\"\n"), -123456L); 
1714   wxPrintf(_T("zero-padded LDN:\t\"%010ld\"\n"), -123456L); 
1715   test_format 
= _T("left-adjusted ZLDN:\t\"%-010ld\"\n"); 
1716   wxPrintf(test_format
.c_str(), -123456); 
1717   wxPrintf(_T("space-padded LDN:\t\"%10ld\"\n"), -123456L); 
1718   wxPrintf(_T("left-adjusted SLDN:\t\"%-10ld\"\n"), -123456L); 
1720   test_format 
= _T("zero-padded string:\t\"%010s\"\n"); 
1721   wxPrintf(test_format
.c_str(), shortstr
); 
1722   test_format 
= _T("left-adjusted Z string:\t\"%-010s\"\n"); 
1723   wxPrintf(test_format
.c_str(), shortstr
); 
1724   wxPrintf(_T("space-padded string:\t\"%10s\"\n"), shortstr
); 
1725   wxPrintf(_T("left-adjusted S string:\t\"%-10s\"\n"), shortstr
); 
1726   wxPrintf(_T("null string:\t\"%s\"\n"), PointerNull
); 
1727   wxPrintf(_T("limited string:\t\"%.22s\"\n"), longstr
); 
1729   wxPrintf(_T("e-style >= 1:\t\"%e\"\n"), 12.34); 
1730   wxPrintf(_T("e-style >= .1:\t\"%e\"\n"), 0.1234); 
1731   wxPrintf(_T("e-style < .1:\t\"%e\"\n"), 0.001234); 
1732   wxPrintf(_T("e-style big:\t\"%.60e\"\n"), 1e20
); 
1733   wxPrintf(_T("e-style == .1:\t\"%e\"\n"), 0.1); 
1734   wxPrintf(_T("f-style >= 1:\t\"%f\"\n"), 12.34); 
1735   wxPrintf(_T("f-style >= .1:\t\"%f\"\n"), 0.1234); 
1736   wxPrintf(_T("f-style < .1:\t\"%f\"\n"), 0.001234); 
1737   wxPrintf(_T("g-style >= 1:\t\"%g\"\n"), 12.34); 
1738   wxPrintf(_T("g-style >= .1:\t\"%g\"\n"), 0.1234); 
1739   wxPrintf(_T("g-style < .1:\t\"%g\"\n"), 0.001234); 
1740   wxPrintf(_T("g-style big:\t\"%.60g\"\n"), 1e20
); 
1742   wxPrintf (_T(" %6.5f\n"), .099999999860301614); 
1743   wxPrintf (_T(" %6.5f\n"), .1); 
1744   wxPrintf (_T("x%5.4fx\n"), .5); 
1746   wxPrintf (_T("%#03x\n"), 1); 
1748   //wxPrintf (_T("something really insane: %.10000f\n"), 1.0); 
1754     while (niter
-- != 0) 
1755       wxPrintf (_T("%.17e\n"), d 
/ 2); 
1760   // Open Watcom cause compiler error here 
1761   // Error! E173: col(24) floating-point constant too small to represent 
1762   wxPrintf (_T("%15.5e\n"), 4.9406564584124654e-324); 
1765 #define FORMAT _T("|%12.4f|%12.4e|%12.4g|\n") 
1766   wxPrintf (FORMAT
, 0.0, 0.0, 0.0); 
1767   wxPrintf (FORMAT
, 1.0, 1.0, 1.0); 
1768   wxPrintf (FORMAT
, -1.0, -1.0, -1.0); 
1769   wxPrintf (FORMAT
, 100.0, 100.0, 100.0); 
1770   wxPrintf (FORMAT
, 1000.0, 1000.0, 1000.0); 
1771   wxPrintf (FORMAT
, 10000.0, 10000.0, 10000.0); 
1772   wxPrintf (FORMAT
, 12345.0, 12345.0, 12345.0); 
1773   wxPrintf (FORMAT
, 100000.0, 100000.0, 100000.0); 
1774   wxPrintf (FORMAT
, 123456.0, 123456.0, 123456.0); 
1779     int rc 
= wxSnprintf (buf
, WXSIZEOF(buf
), _T("%30s"), _T("foo")); 
1781     wxPrintf(_T("snprintf (\"%%30s\", \"foo\") == %d, \"%.*s\"\n"), 
1782              rc
, WXSIZEOF(buf
), buf
); 
1785     wxPrintf ("snprintf (\"%%.999999u\", 10)\n", 
1786             wxSnprintf(buf2
, WXSIZEOFbuf2
), "%.999999u", 10)); 
1792   wxPrintf (_T("%e should be 1.234568e+06\n"), 1234567.8); 
1793   wxPrintf (_T("%f should be 1234567.800000\n"), 1234567.8); 
1794   wxPrintf (_T("%g should be 1.23457e+06\n"), 1234567.8); 
1795   wxPrintf (_T("%g should be 123.456\n"), 123.456); 
1796   wxPrintf (_T("%g should be 1e+06\n"), 1000000.0); 
1797   wxPrintf (_T("%g should be 10\n"), 10.0); 
1798   wxPrintf (_T("%g should be 0.02\n"), 0.02); 
1802     wxPrintf(_T("%.17f\n"),(1.0/x
/10.0+1.0)*x
-x
); 
1808     wxSprintf(buf
,_T("%*s%*s%*s"),-1,_T("one"),-20,_T("two"),-30,_T("three")); 
1810     result 
|= wxStrcmp (buf
, 
1811                       _T("onetwo                 three                         ")); 
1813     wxPuts (result 
!= 0 ? _T("Test failed!") : _T("Test ok.")); 
1820       wxSprintf(buf
, _T("%07") wxLongLongFmtSpec 
_T("o"), wxLL(040000000000)); 
1822         // for some reason below line fails under Borland 
1823       wxPrintf (_T("sprintf (buf, \"%%07Lo\", 040000000000ll) = %s"), buf
); 
1826       if (wxStrcmp (buf
, _T("40000000000")) != 0) 
1829           wxPuts (_T("\tFAILED")); 
1831       wxUnusedVar(result
); 
1832       wxPuts (wxEmptyString
); 
1834 #endif // wxLongLong_t 
1836   wxPrintf (_T("printf (\"%%hhu\", %u) = %hhu\n"), UCHAR_MAX 
+ 2, UCHAR_MAX 
+ 2); 
1837   wxPrintf (_T("printf (\"%%hu\", %u) = %hu\n"), USHRT_MAX 
+ 2, USHRT_MAX 
+ 2); 
1839   wxPuts (_T("--- Should be no further output. ---")); 
1848     memset (bytes
, '\xff', sizeof bytes
); 
1849     wxSprintf (buf
, _T("foo%hhn\n"), &bytes
[3]); 
1850     if (bytes
[0] != '\xff' || bytes
[1] != '\xff' || bytes
[2] != '\xff' 
1851         || bytes
[4] != '\xff' || bytes
[5] != '\xff' || bytes
[6] != '\xff') 
1853         wxPuts (_T("%hhn overwrite more bytes")); 
1858         wxPuts (_T("%hhn wrote incorrect value")); 
1870   wxSprintf (buf
, _T("%5.s"), _T("xyz")); 
1871   if (wxStrcmp (buf
, _T("     ")) != 0) 
1872     wxPrintf (_T("got: '%s', expected: '%s'\n"), buf
, _T("     ")); 
1873   wxSprintf (buf
, _T("%5.f"), 33.3); 
1874   if (wxStrcmp (buf
, _T("   33")) != 0) 
1875     wxPrintf (_T("got: '%s', expected: '%s'\n"), buf
, _T("   33")); 
1876   wxSprintf (buf
, _T("%8.e"), 33.3e7
); 
1877   if (wxStrcmp (buf
, _T("   3e+08")) != 0) 
1878     wxPrintf (_T("got: '%s', expected: '%s'\n"), buf
, _T("   3e+08")); 
1879   wxSprintf (buf
, _T("%8.E"), 33.3e7
); 
1880   if (wxStrcmp (buf
, _T("   3E+08")) != 0) 
1881     wxPrintf (_T("got: '%s', expected: '%s'\n"), buf
, _T("   3E+08")); 
1882   wxSprintf (buf
, _T("%.g"), 33.3); 
1883   if (wxStrcmp (buf
, _T("3e+01")) != 0) 
1884     wxPrintf (_T("got: '%s', expected: '%s'\n"), buf
, _T("3e+01")); 
1885   wxSprintf (buf
, _T("%.G"), 33.3); 
1886   if (wxStrcmp (buf
, _T("3E+01")) != 0) 
1887     wxPrintf (_T("got: '%s', expected: '%s'\n"), buf
, _T("3E+01")); 
1895   wxString test_format
; 
1898   wxSprintf (buf
, _T("%.*g"), prec
, 3.3); 
1899   if (wxStrcmp (buf
, _T("3")) != 0) 
1900     wxPrintf (_T("got: '%s', expected: '%s'\n"), buf
, _T("3")); 
1902   wxSprintf (buf
, _T("%.*G"), prec
, 3.3); 
1903   if (wxStrcmp (buf
, _T("3")) != 0) 
1904     wxPrintf (_T("got: '%s', expected: '%s'\n"), buf
, _T("3")); 
1906   wxSprintf (buf
, _T("%7.*G"), prec
, 3.33); 
1907   if (wxStrcmp (buf
, _T("      3")) != 0) 
1908     wxPrintf (_T("got: '%s', expected: '%s'\n"), buf
, _T("      3")); 
1910   test_format 
= _T("%04.*o"); 
1911   wxSprintf (buf
, test_format
.c_str(), prec
, 33); 
1912   if (wxStrcmp (buf
, _T(" 041")) != 0) 
1913     wxPrintf (_T("got: '%s', expected: '%s'\n"), buf
, _T(" 041")); 
1915   test_format 
= _T("%09.*u"); 
1916   wxSprintf (buf
, test_format
.c_str(), prec
, 33); 
1917   if (wxStrcmp (buf
, _T("  0000033")) != 0) 
1918     wxPrintf (_T("got: '%s', expected: '%s'\n"), buf
, _T("  0000033")); 
1920   test_format 
= _T("%04.*x"); 
1921   wxSprintf (buf
, test_format
.c_str(), prec
, 33); 
1922   if (wxStrcmp (buf
, _T(" 021")) != 0) 
1923     wxPrintf (_T("got: '%s', expected: '%s'\n"), buf
, _T(" 021")); 
1925   test_format 
= _T("%04.*X"); 
1926   wxSprintf (buf
, test_format
.c_str(), prec
, 33); 
1927   if (wxStrcmp (buf
, _T(" 021")) != 0) 
1928     wxPrintf (_T("got: '%s', expected: '%s'\n"), buf
, _T(" 021")); 
1931 #endif // TEST_PRINTF 
1933 // ---------------------------------------------------------------------------- 
1934 // registry and related stuff 
1935 // ---------------------------------------------------------------------------- 
1937 // this is for MSW only 
1940     #undef TEST_REGISTRY 
1945 #include "wx/confbase.h" 
1946 #include "wx/msw/regconf.h" 
1949 static void TestRegConfWrite() 
1951     wxConfig 
*config 
= new wxConfig(_T("myapp")); 
1952     config
->SetPath(_T("/group1")); 
1953     config
->Write(_T("entry1"), _T("foo")); 
1954     config
->SetPath(_T("/group2")); 
1955     config
->Write(_T("entry1"), _T("bar")); 
1959 static void TestRegConfRead() 
1961     wxConfig 
*config 
= new wxConfig(_T("myapp")); 
1965     config
->SetPath(_T("/")); 
1966     wxPuts(_T("Enumerating / subgroups:")); 
1967     bool bCont 
= config
->GetFirstGroup(str
, dummy
); 
1971         bCont 
= config
->GetNextGroup(str
, dummy
); 
1975 #endif // TEST_REGCONF 
1977 #ifdef TEST_REGISTRY 
1979 #include "wx/msw/registry.h" 
1981 // I chose this one because I liked its name, but it probably only exists under 
1983 static const wxChar 
*TESTKEY 
= 
1984     _T("HKEY_LOCAL_MACHINE\\SYSTEM\\ControlSet001\\Control\\CrashControl"); 
1986 static void TestRegistryRead() 
1988     wxPuts(_T("*** testing registry reading ***")); 
1990     wxRegKey 
key(TESTKEY
); 
1991     wxPrintf(_T("The test key name is '%s'.\n"), key
.GetName().c_str()); 
1994         wxPuts(_T("ERROR: test key can't be opened, aborting test.")); 
1999     size_t nSubKeys
, nValues
; 
2000     if ( key
.GetKeyInfo(&nSubKeys
, NULL
, &nValues
, NULL
) ) 
2002         wxPrintf(_T("It has %u subkeys and %u values.\n"), nSubKeys
, nValues
); 
2005     wxPrintf(_T("Enumerating values:\n")); 
2009     bool cont 
= key
.GetFirstValue(value
, dummy
); 
2012         wxPrintf(_T("Value '%s': type "), value
.c_str()); 
2013         switch ( key
.GetValueType(value
) ) 
2015             case wxRegKey::Type_None
:   wxPrintf(_T("ERROR (none)")); break; 
2016             case wxRegKey::Type_String
: wxPrintf(_T("SZ")); break; 
2017             case wxRegKey::Type_Expand_String
: wxPrintf(_T("EXPAND_SZ")); break; 
2018             case wxRegKey::Type_Binary
: wxPrintf(_T("BINARY")); break; 
2019             case wxRegKey::Type_Dword
: wxPrintf(_T("DWORD")); break; 
2020             case wxRegKey::Type_Multi_String
: wxPrintf(_T("MULTI_SZ")); break; 
2021             default: wxPrintf(_T("other (unknown)")); break; 
2024         wxPrintf(_T(", value = ")); 
2025         if ( key
.IsNumericValue(value
) ) 
2028             key
.QueryValue(value
, &val
); 
2029             wxPrintf(_T("%ld"), val
); 
2034             key
.QueryValue(value
, val
); 
2035             wxPrintf(_T("'%s'"), val
.c_str()); 
2037             key
.QueryRawValue(value
, val
); 
2038             wxPrintf(_T(" (raw value '%s')"), val
.c_str()); 
2043         cont 
= key
.GetNextValue(value
, dummy
); 
2047 static void TestRegistryAssociation() 
2050        The second call to deleteself genertaes an error message, with a 
2051        messagebox saying .flo is crucial to system operation, while the .ddf 
2052        call also fails, but with no error message 
2057     key
.SetName(_T("HKEY_CLASSES_ROOT\\.ddf") ); 
2059     key 
= _T("ddxf_auto_file") ; 
2060     key
.SetName(_T("HKEY_CLASSES_ROOT\\.flo") ); 
2062     key 
= _T("ddxf_auto_file") ; 
2063     key
.SetName(_T("HKEY_CLASSES_ROOT\\ddxf_auto_file\\DefaultIcon")); 
2065     key 
= _T("program,0") ; 
2066     key
.SetName(_T("HKEY_CLASSES_ROOT\\ddxf_auto_file\\shell\\open\\command")); 
2068     key 
= _T("program \"%1\"") ; 
2070     key
.SetName(_T("HKEY_CLASSES_ROOT\\.ddf") ); 
2072     key
.SetName(_T("HKEY_CLASSES_ROOT\\.flo") ); 
2074     key
.SetName(_T("HKEY_CLASSES_ROOT\\ddxf_auto_file\\DefaultIcon")); 
2076     key
.SetName(_T("HKEY_CLASSES_ROOT\\ddxf_auto_file\\shell\\open\\command")); 
2080 #endif // TEST_REGISTRY 
2082 // ---------------------------------------------------------------------------- 
2084 // ---------------------------------------------------------------------------- 
2086 #ifdef TEST_SCOPEGUARD 
2088 #include "wx/scopeguard.h" 
2090 static void function0() { puts("function0()"); } 
2091 static void function1(int n
) { printf("function1(%d)\n", n
); } 
2092 static void function2(double x
, char c
) { printf("function2(%g, %c)\n", x
, c
); } 
2096     void method0() { printf("method0()\n"); } 
2097     void method1(int n
) { printf("method1(%d)\n", n
); } 
2098     void method2(double x
, char c
) { printf("method2(%g, %c)\n", x
, c
); } 
2101 static void TestScopeGuard() 
2103     wxON_BLOCK_EXIT0(function0
); 
2104     wxON_BLOCK_EXIT1(function1
, 17); 
2105     wxON_BLOCK_EXIT2(function2
, 3.14, 'p'); 
2108     wxON_BLOCK_EXIT_OBJ0(obj
, &Object::method0
); 
2109     wxON_BLOCK_EXIT_OBJ1(obj
, &Object::method1
, 7); 
2110     wxON_BLOCK_EXIT_OBJ2(obj
, &Object::method2
, 2.71, 'e'); 
2112     wxScopeGuard dismissed 
= wxMakeGuard(function0
); 
2113     dismissed
.Dismiss(); 
2118 // ---------------------------------------------------------------------------- 
2120 // ---------------------------------------------------------------------------- 
2124 #include "wx/socket.h" 
2125 #include "wx/protocol/protocol.h" 
2126 #include "wx/protocol/http.h" 
2128 static void TestSocketServer() 
2130     wxPuts(_T("*** Testing wxSocketServer ***\n")); 
2132     static const int PORT 
= 3000; 
2137     wxSocketServer 
*server 
= new wxSocketServer(addr
); 
2138     if ( !server
->Ok() ) 
2140         wxPuts(_T("ERROR: failed to bind")); 
2148         wxPrintf(_T("Server: waiting for connection on port %d...\n"), PORT
); 
2150         wxSocketBase 
*socket 
= server
->Accept(); 
2153             wxPuts(_T("ERROR: wxSocketServer::Accept() failed.")); 
2157         wxPuts(_T("Server: got a client.")); 
2159         server
->SetTimeout(60); // 1 min 
2162         while ( !close 
&& socket
->IsConnected() ) 
2165             wxChar ch 
= _T('\0'); 
2168                 if ( socket
->Read(&ch
, sizeof(ch
)).Error() ) 
2170                     // don't log error if the client just close the connection 
2171                     if ( socket
->IsConnected() ) 
2173                         wxPuts(_T("ERROR: in wxSocket::Read.")); 
2193             wxPrintf(_T("Server: got '%s'.\n"), s
.c_str()); 
2194             if ( s 
== _T("close") ) 
2196                 wxPuts(_T("Closing connection")); 
2200             else if ( s 
== _T("quit") ) 
2205                 wxPuts(_T("Shutting down the server")); 
2207             else // not a special command 
2209                 socket
->Write(s
.MakeUpper().c_str(), s
.length()); 
2210                 socket
->Write("\r\n", 2); 
2211                 wxPrintf(_T("Server: wrote '%s'.\n"), s
.c_str()); 
2217             wxPuts(_T("Server: lost a client unexpectedly.")); 
2223     // same as "delete server" but is consistent with GUI programs 
2227 static void TestSocketClient() 
2229     wxPuts(_T("*** Testing wxSocketClient ***\n")); 
2231     static const wxChar 
*hostname 
= _T("www.wxwidgets.org"); 
2234     addr
.Hostname(hostname
); 
2237     wxPrintf(_T("--- Attempting to connect to %s:80...\n"), hostname
); 
2239     wxSocketClient client
; 
2240     if ( !client
.Connect(addr
) ) 
2242         wxPrintf(_T("ERROR: failed to connect to %s\n"), hostname
); 
2246         wxPrintf(_T("--- Connected to %s:%u...\n"), 
2247                addr
.Hostname().c_str(), addr
.Service()); 
2251         // could use simply "GET" here I suppose 
2253             wxString::Format(_T("GET http://%s/\r\n"), hostname
); 
2254         client
.Write(cmdGet
, cmdGet
.length()); 
2255         wxPrintf(_T("--- Sent command '%s' to the server\n"), 
2256                MakePrintable(cmdGet
).c_str()); 
2257         client
.Read(buf
, WXSIZEOF(buf
)); 
2258         wxPrintf(_T("--- Server replied:\n%s"), buf
); 
2262 #endif // TEST_SOCKETS 
2264 // ---------------------------------------------------------------------------- 
2266 // ---------------------------------------------------------------------------- 
2270 #include "wx/protocol/ftp.h" 
2274 #define FTP_ANONYMOUS 
2276 #ifdef FTP_ANONYMOUS 
2277     static const wxChar 
*directory 
= _T("/pub"); 
2278     static const wxChar 
*filename 
= _T("welcome.msg"); 
2280     static const wxChar 
*directory 
= _T("/etc"); 
2281     static const wxChar 
*filename 
= _T("issue"); 
2284 static bool TestFtpConnect() 
2286     wxPuts(_T("*** Testing FTP connect ***")); 
2288 #ifdef FTP_ANONYMOUS 
2289     static const wxChar 
*hostname 
= _T("ftp.wxwidgets.org"); 
2291     wxPrintf(_T("--- Attempting to connect to %s:21 anonymously...\n"), hostname
); 
2292 #else // !FTP_ANONYMOUS 
2293     static const wxChar 
*hostname 
= "localhost"; 
2296     wxFgets(user
, WXSIZEOF(user
), stdin
); 
2297     user
[wxStrlen(user
) - 1] = '\0'; // chop off '\n' 
2300     wxChar password
[256]; 
2301     wxPrintf(_T("Password for %s: "), password
); 
2302     wxFgets(password
, WXSIZEOF(password
), stdin
); 
2303     password
[wxStrlen(password
) - 1] = '\0'; // chop off '\n' 
2304     ftp
.SetPassword(password
); 
2306     wxPrintf(_T("--- Attempting to connect to %s:21 as %s...\n"), hostname
, user
); 
2307 #endif // FTP_ANONYMOUS/!FTP_ANONYMOUS 
2309     if ( !ftp
.Connect(hostname
) ) 
2311         wxPrintf(_T("ERROR: failed to connect to %s\n"), hostname
); 
2317         wxPrintf(_T("--- Connected to %s, current directory is '%s'\n"), 
2318                  hostname
, ftp
.Pwd().c_str()); 
2325 // test (fixed?) wxFTP bug with wu-ftpd >= 2.6.0? 
2326 static void TestFtpWuFtpd() 
2329     static const wxChar 
*hostname 
= _T("ftp.eudora.com"); 
2330     if ( !ftp
.Connect(hostname
) ) 
2332         wxPrintf(_T("ERROR: failed to connect to %s\n"), hostname
); 
2336         static const wxChar 
*filename 
= _T("eudora/pubs/draft-gellens-submit-09.txt"); 
2337         wxInputStream 
*in 
= ftp
.GetInputStream(filename
); 
2340             wxPrintf(_T("ERROR: couldn't get input stream for %s\n"), filename
); 
2344             size_t size 
= in
->GetSize(); 
2345             wxPrintf(_T("Reading file %s (%u bytes)..."), filename
, size
); 
2347             wxChar 
*data 
= new wxChar
[size
]; 
2348             if ( !in
->Read(data
, size
) ) 
2350                 wxPuts(_T("ERROR: read error")); 
2354                 wxPrintf(_T("Successfully retrieved the file.\n")); 
2363 static void TestFtpList() 
2365     wxPuts(_T("*** Testing wxFTP file listing ***\n")); 
2368     if ( !ftp
.ChDir(directory
) ) 
2370         wxPrintf(_T("ERROR: failed to cd to %s\n"), directory
); 
2373     wxPrintf(_T("Current directory is '%s'\n"), ftp
.Pwd().c_str()); 
2375     // test NLIST and LIST 
2376     wxArrayString files
; 
2377     if ( !ftp
.GetFilesList(files
) ) 
2379         wxPuts(_T("ERROR: failed to get NLIST of files")); 
2383         wxPrintf(_T("Brief list of files under '%s':\n"), ftp
.Pwd().c_str()); 
2384         size_t count 
= files
.GetCount(); 
2385         for ( size_t n 
= 0; n 
< count
; n
++ ) 
2387             wxPrintf(_T("\t%s\n"), files
[n
].c_str()); 
2389         wxPuts(_T("End of the file list")); 
2392     if ( !ftp
.GetDirList(files
) ) 
2394         wxPuts(_T("ERROR: failed to get LIST of files")); 
2398         wxPrintf(_T("Detailed list of files under '%s':\n"), ftp
.Pwd().c_str()); 
2399         size_t count 
= files
.GetCount(); 
2400         for ( size_t n 
= 0; n 
< count
; n
++ ) 
2402             wxPrintf(_T("\t%s\n"), files
[n
].c_str()); 
2404         wxPuts(_T("End of the file list")); 
2407     if ( !ftp
.ChDir(_T("..")) ) 
2409         wxPuts(_T("ERROR: failed to cd to ..")); 
2412     wxPrintf(_T("Current directory is '%s'\n"), ftp
.Pwd().c_str()); 
2415 static void TestFtpDownload() 
2417     wxPuts(_T("*** Testing wxFTP download ***\n")); 
2420     wxInputStream 
*in 
= ftp
.GetInputStream(filename
); 
2423         wxPrintf(_T("ERROR: couldn't get input stream for %s\n"), filename
); 
2427         size_t size 
= in
->GetSize(); 
2428         wxPrintf(_T("Reading file %s (%u bytes)..."), filename
, size
); 
2431         wxChar 
*data 
= new wxChar
[size
]; 
2432         if ( !in
->Read(data
, size
) ) 
2434             wxPuts(_T("ERROR: read error")); 
2438             wxPrintf(_T("\nContents of %s:\n%s\n"), filename
, data
); 
2446 static void TestFtpFileSize() 
2448     wxPuts(_T("*** Testing FTP SIZE command ***")); 
2450     if ( !ftp
.ChDir(directory
) ) 
2452         wxPrintf(_T("ERROR: failed to cd to %s\n"), directory
); 
2455     wxPrintf(_T("Current directory is '%s'\n"), ftp
.Pwd().c_str()); 
2457     if ( ftp
.FileExists(filename
) ) 
2459         int size 
= ftp
.GetFileSize(filename
); 
2461             wxPrintf(_T("ERROR: couldn't get size of '%s'\n"), filename
); 
2463             wxPrintf(_T("Size of '%s' is %d bytes.\n"), filename
, size
); 
2467         wxPrintf(_T("ERROR: '%s' doesn't exist\n"), filename
); 
2471 static void TestFtpMisc() 
2473     wxPuts(_T("*** Testing miscellaneous wxFTP functions ***")); 
2475     if ( ftp
.SendCommand(_T("STAT")) != '2' ) 
2477         wxPuts(_T("ERROR: STAT failed")); 
2481         wxPrintf(_T("STAT returned:\n\n%s\n"), ftp
.GetLastResult().c_str()); 
2484     if ( ftp
.SendCommand(_T("HELP SITE")) != '2' ) 
2486         wxPuts(_T("ERROR: HELP SITE failed")); 
2490         wxPrintf(_T("The list of site-specific commands:\n\n%s\n"), 
2491                ftp
.GetLastResult().c_str()); 
2495 static void TestFtpInteractive() 
2497     wxPuts(_T("\n*** Interactive wxFTP test ***")); 
2503         wxPrintf(_T("Enter FTP command: ")); 
2504         if ( !wxFgets(buf
, WXSIZEOF(buf
), stdin
) ) 
2507         // kill the last '\n' 
2508         buf
[wxStrlen(buf
) - 1] = 0; 
2510         // special handling of LIST and NLST as they require data connection 
2511         wxString 
start(buf
, 4); 
2513         if ( start 
== _T("LIST") || start 
== _T("NLST") ) 
2516             if ( wxStrlen(buf
) > 4 ) 
2519             wxArrayString files
; 
2520             if ( !ftp
.GetList(files
, wildcard
, start 
== _T("LIST")) ) 
2522                 wxPrintf(_T("ERROR: failed to get %s of files\n"), start
.c_str()); 
2526                 wxPrintf(_T("--- %s of '%s' under '%s':\n"), 
2527                        start
.c_str(), wildcard
.c_str(), ftp
.Pwd().c_str()); 
2528                 size_t count 
= files
.GetCount(); 
2529                 for ( size_t n 
= 0; n 
< count
; n
++ ) 
2531                     wxPrintf(_T("\t%s\n"), files
[n
].c_str()); 
2533                 wxPuts(_T("--- End of the file list")); 
2538             wxChar ch 
= ftp
.SendCommand(buf
); 
2539             wxPrintf(_T("Command %s"), ch 
? _T("succeeded") : _T("failed")); 
2542                 wxPrintf(_T(" (return code %c)"), ch
); 
2545             wxPrintf(_T(", server reply:\n%s\n\n"), ftp
.GetLastResult().c_str()); 
2549     wxPuts(_T("\n*** done ***")); 
2552 static void TestFtpUpload() 
2554     wxPuts(_T("*** Testing wxFTP uploading ***\n")); 
2557     static const wxChar 
*file1 
= _T("test1"); 
2558     static const wxChar 
*file2 
= _T("test2"); 
2559     wxOutputStream 
*out 
= ftp
.GetOutputStream(file1
); 
2562         wxPrintf(_T("--- Uploading to %s ---\n"), file1
); 
2563         out
->Write("First hello", 11); 
2567     // send a command to check the remote file 
2568     if ( ftp
.SendCommand(wxString(_T("STAT ")) + file1
) != '2' ) 
2570         wxPrintf(_T("ERROR: STAT %s failed\n"), file1
); 
2574         wxPrintf(_T("STAT %s returned:\n\n%s\n"), 
2575                file1
, ftp
.GetLastResult().c_str()); 
2578     out 
= ftp
.GetOutputStream(file2
); 
2581         wxPrintf(_T("--- Uploading to %s ---\n"), file1
); 
2582         out
->Write("Second hello", 12); 
2589 // ---------------------------------------------------------------------------- 
2591 // ---------------------------------------------------------------------------- 
2593 #ifdef TEST_STACKWALKER 
2595 #if wxUSE_STACKWALKER 
2597 #include "wx/stackwalk.h" 
2599 class StackDump 
: public wxStackWalker
 
2602     StackDump(const char *argv0
) 
2603         : wxStackWalker(argv0
) 
2607     virtual void Walk(size_t skip 
= 1) 
2609         wxPuts(_T("Stack dump:")); 
2611         wxStackWalker::Walk(skip
); 
2615     virtual void OnStackFrame(const wxStackFrame
& frame
) 
2617         printf("[%2d] ", frame
.GetLevel()); 
2619         wxString name 
= frame
.GetName(); 
2620         if ( !name
.empty() ) 
2622             printf("%-20.40s", name
.mb_str()); 
2626             printf("0x%08lx", (unsigned long)frame
.GetAddress()); 
2629         if ( frame
.HasSourceLocation() ) 
2632                    frame
.GetFileName().mb_str(), 
2639         for ( size_t n 
= 0; frame
.GetParam(n
, &type
, &name
, &val
); n
++ ) 
2641             printf("\t%s %s = %s\n", type
.mb_str(), name
.mb_str(), val
.mb_str()); 
2646 static void TestStackWalk(const char *argv0
) 
2648     wxPuts(_T("*** Testing wxStackWalker ***\n")); 
2650     StackDump 
dump(argv0
); 
2654 #endif // wxUSE_STACKWALKER 
2656 #endif // TEST_STACKWALKER 
2658 // ---------------------------------------------------------------------------- 
2660 // ---------------------------------------------------------------------------- 
2662 #ifdef TEST_STDPATHS 
2664 #include "wx/stdpaths.h" 
2666 static void TestStandardPaths() 
2668     wxPuts(_T("*** Testing wxStandardPaths ***\n")); 
2670     wxTheApp
->SetAppName(_T("console")); 
2672     wxStandardPathsBase
& stdp 
= wxStandardPaths::Get(); 
2673     wxPrintf(_T("Config dir (sys):\t%s\n"), stdp
.GetConfigDir().c_str()); 
2674     wxPrintf(_T("Config dir (user):\t%s\n"), stdp
.GetUserConfigDir().c_str()); 
2675     wxPrintf(_T("Data dir (sys):\t\t%s\n"), stdp
.GetDataDir().c_str()); 
2676     wxPrintf(_T("Data dir (sys local):\t%s\n"), stdp
.GetLocalDataDir().c_str()); 
2677     wxPrintf(_T("Data dir (user):\t%s\n"), stdp
.GetUserDataDir().c_str()); 
2678     wxPrintf(_T("Data dir (user local):\t%s\n"), stdp
.GetUserLocalDataDir().c_str()); 
2679     wxPrintf(_T("Plugins dir:\t\t%s\n"), stdp
.GetPluginsDir().c_str()); 
2682 #endif // TEST_STDPATHS 
2684 // ---------------------------------------------------------------------------- 
2686 // ---------------------------------------------------------------------------- 
2690 #include "wx/wfstream.h" 
2691 #include "wx/mstream.h" 
2693 static void TestFileStream() 
2695     wxPuts(_T("*** Testing wxFileInputStream ***")); 
2697     static const wxString filename 
= _T("testdata.fs"); 
2699         wxFileOutputStream 
fsOut(filename
); 
2700         fsOut
.Write("foo", 3); 
2703     wxFileInputStream 
fsIn(filename
); 
2704     wxPrintf(_T("File stream size: %u\n"), fsIn
.GetSize()); 
2705     while ( !fsIn
.Eof() ) 
2707         wxPutchar(fsIn
.GetC()); 
2710     if ( !wxRemoveFile(filename
) ) 
2712         wxPrintf(_T("ERROR: failed to remove the file '%s'.\n"), filename
.c_str()); 
2715     wxPuts(_T("\n*** wxFileInputStream test done ***")); 
2718 static void TestMemoryStream() 
2720     wxPuts(_T("*** Testing wxMemoryOutputStream ***")); 
2722     wxMemoryOutputStream memOutStream
; 
2723     wxPrintf(_T("Initially out stream offset: %lu\n"), 
2724              (unsigned long)memOutStream
.TellO()); 
2726     for ( const wxChar 
*p 
= _T("Hello, stream!"); *p
; p
++ ) 
2728         memOutStream
.PutC(*p
); 
2731     wxPrintf(_T("Final out stream offset: %lu\n"), 
2732              (unsigned long)memOutStream
.TellO()); 
2734     wxPuts(_T("*** Testing wxMemoryInputStream ***")); 
2737     size_t len 
= memOutStream
.CopyTo(buf
, WXSIZEOF(buf
)); 
2739     wxMemoryInputStream 
memInpStream(buf
, len
); 
2740     wxPrintf(_T("Memory stream size: %u\n"), memInpStream
.GetSize()); 
2741     while ( !memInpStream
.Eof() ) 
2743         wxPutchar(memInpStream
.GetC()); 
2746     wxPuts(_T("\n*** wxMemoryInputStream test done ***")); 
2749 #endif // TEST_STREAMS 
2751 // ---------------------------------------------------------------------------- 
2753 // ---------------------------------------------------------------------------- 
2757 #include "wx/stopwatch.h" 
2758 #include "wx/utils.h" 
2760 static void TestStopWatch() 
2762     wxPuts(_T("*** Testing wxStopWatch ***\n")); 
2766     wxPrintf(_T("Initially paused, after 2 seconds time is...")); 
2769     wxPrintf(_T("\t%ldms\n"), sw
.Time()); 
2771     wxPrintf(_T("Resuming stopwatch and sleeping 3 seconds...")); 
2775     wxPrintf(_T("\telapsed time: %ldms\n"), sw
.Time()); 
2778     wxPrintf(_T("Pausing agan and sleeping 2 more seconds...")); 
2781     wxPrintf(_T("\telapsed time: %ldms\n"), sw
.Time()); 
2784     wxPrintf(_T("Finally resuming and sleeping 2 more seconds...")); 
2787     wxPrintf(_T("\telapsed time: %ldms\n"), sw
.Time()); 
2790     wxPuts(_T("\nChecking for 'backwards clock' bug...")); 
2791     for ( size_t n 
= 0; n 
< 70; n
++ ) 
2795         for ( size_t m 
= 0; m 
< 100000; m
++ ) 
2797             if ( sw
.Time() < 0 || sw2
.Time() < 0 ) 
2799                 wxPuts(_T("\ntime is negative - ERROR!")); 
2807     wxPuts(_T(", ok.")); 
2810 #endif // TEST_TIMER 
2812 // ---------------------------------------------------------------------------- 
2814 // ---------------------------------------------------------------------------- 
2818 #include "wx/vcard.h" 
2820 static void DumpVObject(size_t level
, const wxVCardObject
& vcard
) 
2823     wxVCardObject 
*vcObj 
= vcard
.GetFirstProp(&cookie
); 
2826         wxPrintf(_T("%s%s"), 
2827                wxString(_T('\t'), level
).c_str(), 
2828                vcObj
->GetName().c_str()); 
2831         switch ( vcObj
->GetType() ) 
2833             case wxVCardObject::String
: 
2834             case wxVCardObject::UString
: 
2837                     vcObj
->GetValue(&val
); 
2838                     value 
<< _T('"') << val 
<< _T('"'); 
2842             case wxVCardObject::Int
: 
2845                     vcObj
->GetValue(&i
); 
2846                     value
.Printf(_T("%u"), i
); 
2850             case wxVCardObject::Long
: 
2853                     vcObj
->GetValue(&l
); 
2854                     value
.Printf(_T("%lu"), l
); 
2858             case wxVCardObject::None
: 
2861             case wxVCardObject::Object
: 
2862                 value 
= _T("<node>"); 
2866                 value 
= _T("<unknown value type>"); 
2870             wxPrintf(_T(" = %s"), value
.c_str()); 
2873         DumpVObject(level 
+ 1, *vcObj
); 
2876         vcObj 
= vcard
.GetNextProp(&cookie
); 
2880 static void DumpVCardAddresses(const wxVCard
& vcard
) 
2882     wxPuts(_T("\nShowing all addresses from vCard:\n")); 
2886     wxVCardAddress 
*addr 
= vcard
.GetFirstAddress(&cookie
); 
2890         int flags 
= addr
->GetFlags(); 
2891         if ( flags 
& wxVCardAddress::Domestic 
) 
2893             flagsStr 
<< _T("domestic "); 
2895         if ( flags 
& wxVCardAddress::Intl 
) 
2897             flagsStr 
<< _T("international "); 
2899         if ( flags 
& wxVCardAddress::Postal 
) 
2901             flagsStr 
<< _T("postal "); 
2903         if ( flags 
& wxVCardAddress::Parcel 
) 
2905             flagsStr 
<< _T("parcel "); 
2907         if ( flags 
& wxVCardAddress::Home 
) 
2909             flagsStr 
<< _T("home "); 
2911         if ( flags 
& wxVCardAddress::Work 
) 
2913             flagsStr 
<< _T("work "); 
2916         wxPrintf(_T("Address %u:\n") 
2918                "\tvalue = %s;%s;%s;%s;%s;%s;%s\n", 
2921                addr
->GetPostOffice().c_str(), 
2922                addr
->GetExtAddress().c_str(), 
2923                addr
->GetStreet().c_str(), 
2924                addr
->GetLocality().c_str(), 
2925                addr
->GetRegion().c_str(), 
2926                addr
->GetPostalCode().c_str(), 
2927                addr
->GetCountry().c_str() 
2931         addr 
= vcard
.GetNextAddress(&cookie
); 
2935 static void DumpVCardPhoneNumbers(const wxVCard
& vcard
) 
2937     wxPuts(_T("\nShowing all phone numbers from vCard:\n")); 
2941     wxVCardPhoneNumber 
*phone 
= vcard
.GetFirstPhoneNumber(&cookie
); 
2945         int flags 
= phone
->GetFlags(); 
2946         if ( flags 
& wxVCardPhoneNumber::Voice 
) 
2948             flagsStr 
<< _T("voice "); 
2950         if ( flags 
& wxVCardPhoneNumber::Fax 
) 
2952             flagsStr 
<< _T("fax "); 
2954         if ( flags 
& wxVCardPhoneNumber::Cellular 
) 
2956             flagsStr 
<< _T("cellular "); 
2958         if ( flags 
& wxVCardPhoneNumber::Modem 
) 
2960             flagsStr 
<< _T("modem "); 
2962         if ( flags 
& wxVCardPhoneNumber::Home 
) 
2964             flagsStr 
<< _T("home "); 
2966         if ( flags 
& wxVCardPhoneNumber::Work 
) 
2968             flagsStr 
<< _T("work "); 
2971         wxPrintf(_T("Phone number %u:\n") 
2976                phone
->GetNumber().c_str() 
2980         phone 
= vcard
.GetNextPhoneNumber(&cookie
); 
2984 static void TestVCardRead() 
2986     wxPuts(_T("*** Testing wxVCard reading ***\n")); 
2988     wxVCard 
vcard(_T("vcard.vcf")); 
2989     if ( !vcard
.IsOk() ) 
2991         wxPuts(_T("ERROR: couldn't load vCard.")); 
2995         // read individual vCard properties 
2996         wxVCardObject 
*vcObj 
= vcard
.GetProperty("FN"); 
3000             vcObj
->GetValue(&value
); 
3005             value 
= _T("<none>"); 
3008         wxPrintf(_T("Full name retrieved directly: %s\n"), value
.c_str()); 
3011         if ( !vcard
.GetFullName(&value
) ) 
3013             value 
= _T("<none>"); 
3016         wxPrintf(_T("Full name from wxVCard API: %s\n"), value
.c_str()); 
3018         // now show how to deal with multiply occurring properties 
3019         DumpVCardAddresses(vcard
); 
3020         DumpVCardPhoneNumbers(vcard
); 
3022         // and finally show all 
3023         wxPuts(_T("\nNow dumping the entire vCard:\n") 
3024              "-----------------------------\n"); 
3026         DumpVObject(0, vcard
); 
3030 static void TestVCardWrite() 
3032     wxPuts(_T("*** Testing wxVCard writing ***\n")); 
3035     if ( !vcard
.IsOk() ) 
3037         wxPuts(_T("ERROR: couldn't create vCard.")); 
3042         vcard
.SetName("Zeitlin", "Vadim"); 
3043         vcard
.SetFullName("Vadim Zeitlin"); 
3044         vcard
.SetOrganization("wxWidgets", "R&D"); 
3046         // just dump the vCard back 
3047         wxPuts(_T("Entire vCard follows:\n")); 
3048         wxPuts(vcard
.Write()); 
3052 #endif // TEST_VCARD 
3054 // ---------------------------------------------------------------------------- 
3056 // ---------------------------------------------------------------------------- 
3058 #if !defined(__WIN32__) || !wxUSE_FSVOLUME 
3064 #include "wx/volume.h" 
3066 static const wxChar 
*volumeKinds
[] = 
3072     _T("network volume"), 
3076 static void TestFSVolume() 
3078     wxPuts(_T("*** Testing wxFSVolume class ***")); 
3080     wxArrayString volumes 
= wxFSVolume::GetVolumes(); 
3081     size_t count 
= volumes
.GetCount(); 
3085         wxPuts(_T("ERROR: no mounted volumes?")); 
3089     wxPrintf(_T("%u mounted volumes found:\n"), count
); 
3091     for ( size_t n 
= 0; n 
< count
; n
++ ) 
3093         wxFSVolume 
vol(volumes
[n
]); 
3096             wxPuts(_T("ERROR: couldn't create volume")); 
3100         wxPrintf(_T("%u: %s (%s), %s, %s, %s\n"), 
3102                  vol
.GetDisplayName().c_str(), 
3103                  vol
.GetName().c_str(), 
3104                  volumeKinds
[vol
.GetKind()], 
3105                  vol
.IsWritable() ? _T("rw") : _T("ro"), 
3106                  vol
.GetFlags() & wxFS_VOL_REMOVABLE 
? _T("removable") 
3111 #endif // TEST_VOLUME 
3113 // ---------------------------------------------------------------------------- 
3114 // wide char and Unicode support 
3115 // ---------------------------------------------------------------------------- 
3119 #include "wx/strconv.h" 
3120 #include "wx/fontenc.h" 
3121 #include "wx/encconv.h" 
3122 #include "wx/buffer.h" 
3124 static const unsigned char utf8koi8r
[] = 
3126     208, 157, 208, 181, 209, 129, 208, 186, 208, 176, 208, 183, 208, 176, 
3127     208, 189, 208, 189, 208, 190, 32, 208, 191, 208, 190, 209, 128, 208, 
3128     176, 208, 180, 208, 190, 208, 178, 208, 176, 208, 187, 32, 208, 188, 
3129     208, 181, 208, 189, 209, 143, 32, 209, 129, 208, 178, 208, 190, 208, 
3130     181, 208, 185, 32, 208, 186, 209, 128, 209, 131, 209, 130, 208, 181, 
3131     208, 185, 209, 136, 208, 181, 208, 185, 32, 208, 189, 208, 190, 208, 
3132     178, 208, 190, 209, 129, 209, 130, 209, 140, 209, 142, 0 
3135 static const unsigned char utf8iso8859_1
[] = 
3137     0x53, 0x79, 0x73, 0x74, 0xc3, 0xa8, 0x6d, 0x65, 0x73, 0x20, 0x49, 0x6e, 
3138     0x74, 0xc3, 0xa9, 0x67, 0x72, 0x61, 0x62, 0x6c, 0x65, 0x73, 0x20, 0x65, 
3139     0x6e, 0x20, 0x4d, 0xc3, 0xa9, 0x63, 0x61, 0x6e, 0x69, 0x71, 0x75, 0x65, 
3140     0x20, 0x43, 0x6c, 0x61, 0x73, 0x73, 0x69, 0x71, 0x75, 0x65, 0x20, 0x65, 
3141     0x74, 0x20, 0x51, 0x75, 0x61, 0x6e, 0x74, 0x69, 0x71, 0x75, 0x65, 0 
3144 static const unsigned char utf8Invalid
[] = 
3146     0x3c, 0x64, 0x69, 0x73, 0x70, 0x6c, 0x61, 0x79, 0x3e, 0x32, 0x30, 0x30, 
3147     0x32, 0xe5, 0xb9, 0xb4, 0x30, 0x39, 0xe6, 0x9c, 0x88, 0x32, 0x35, 0xe6, 
3148     0x97, 0xa5, 0x20, 0x30, 0x37, 0xe6, 0x99, 0x82, 0x33, 0x39, 0xe5, 0x88, 
3149     0x86, 0x35, 0x37, 0xe7, 0xa7, 0x92, 0x3c, 0x2f, 0x64, 0x69, 0x73, 0x70, 
3153 static const struct Utf8Data
 
3155     const unsigned char *text
; 
3157     const wxChar 
*charset
; 
3158     wxFontEncoding encoding
; 
3161     { utf8Invalid
, WXSIZEOF(utf8Invalid
), _T("iso8859-1"), wxFONTENCODING_ISO8859_1 
}, 
3162     { utf8koi8r
, WXSIZEOF(utf8koi8r
), _T("koi8-r"), wxFONTENCODING_KOI8 
}, 
3163     { utf8iso8859_1
, WXSIZEOF(utf8iso8859_1
), _T("iso8859-1"), wxFONTENCODING_ISO8859_1 
}, 
3166 static void TestUtf8() 
3168     wxPuts(_T("*** Testing UTF8 support ***\n")); 
3173     for ( size_t n 
= 0; n 
< WXSIZEOF(utf8data
); n
++ ) 
3175         const Utf8Data
& u8d 
= utf8data
[n
]; 
3176         if ( wxConvUTF8
.MB2WC(wbuf
, (const char *)u8d
.text
, 
3177                               WXSIZEOF(wbuf
)) == (size_t)-1 ) 
3179             wxPuts(_T("ERROR: UTF-8 decoding failed.")); 
3183             wxCSConv 
conv(u8d
.charset
); 
3184             if ( conv
.WC2MB(buf
, wbuf
, WXSIZEOF(buf
)) == (size_t)-1 ) 
3186                 wxPrintf(_T("ERROR: conversion to %s failed.\n"), u8d
.charset
); 
3190                 wxPrintf(_T("String in %s: %s\n"), u8d
.charset
, buf
); 
3194         wxString 
s(wxConvUTF8
.cMB2WC((const char *)u8d
.text
)); 
3196             s 
= _T("<< conversion failed >>"); 
3197         wxPrintf(_T("String in current cset: %s\n"), s
.c_str()); 
3201     wxPuts(wxEmptyString
); 
3204 static void TestEncodingConverter() 
3206     wxPuts(_T("*** Testing wxEncodingConverter ***\n")); 
3208     // using wxEncodingConverter should give the same result as above 
3211     if ( wxConvUTF8
.MB2WC(wbuf
, (const char *)utf8koi8r
, 
3212                           WXSIZEOF(utf8koi8r
)) == (size_t)-1 ) 
3214         wxPuts(_T("ERROR: UTF-8 decoding failed.")); 
3218         wxEncodingConverter ec
; 
3219         ec
.Init(wxFONTENCODING_UNICODE
, wxFONTENCODING_KOI8
); 
3220         ec
.Convert(wbuf
, buf
); 
3221         wxPrintf(_T("The same KOI8-R string using wxEC: %s\n"), buf
); 
3224     wxPuts(wxEmptyString
); 
3227 #endif // TEST_WCHAR 
3229 // ---------------------------------------------------------------------------- 
3231 // ---------------------------------------------------------------------------- 
3235 #include "wx/filesys.h" 
3236 #include "wx/fs_zip.h" 
3237 #include "wx/zipstrm.h" 
3239 static const wxChar 
*TESTFILE_ZIP 
= _T("testdata.zip"); 
3241 static void TestZipStreamRead() 
3243     wxPuts(_T("*** Testing ZIP reading ***\n")); 
3245     static const wxString filename 
= _T("foo"); 
3246     wxZipInputStream 
istr(TESTFILE_ZIP
, filename
); 
3247     wxPrintf(_T("Archive size: %u\n"), istr
.GetSize()); 
3249     wxPrintf(_T("Dumping the file '%s':\n"), filename
.c_str()); 
3250     while ( !istr
.Eof() ) 
3252         wxPutchar(istr
.GetC()); 
3256     wxPuts(_T("\n----- done ------")); 
3259 static void DumpZipDirectory(wxFileSystem
& fs
, 
3260                              const wxString
& dir
, 
3261                              const wxString
& indent
) 
3263     wxString prefix 
= wxString::Format(_T("%s#zip:%s"), 
3264                                          TESTFILE_ZIP
, dir
.c_str()); 
3265     wxString wildcard 
= prefix 
+ _T("/*"); 
3267     wxString dirname 
= fs
.FindFirst(wildcard
, wxDIR
); 
3268     while ( !dirname
.empty() ) 
3270         if ( !dirname
.StartsWith(prefix 
+ _T('/'), &dirname
) ) 
3272             wxPrintf(_T("ERROR: unexpected wxFileSystem::FindNext result\n")); 
3277         wxPrintf(_T("%s%s\n"), indent
.c_str(), dirname
.c_str()); 
3279         DumpZipDirectory(fs
, dirname
, 
3280                          indent 
+ wxString(_T(' '), 4)); 
3282         dirname 
= fs
.FindNext(); 
3285     wxString filename 
= fs
.FindFirst(wildcard
, wxFILE
); 
3286     while ( !filename
.empty() ) 
3288         if ( !filename
.StartsWith(prefix
, &filename
) ) 
3290             wxPrintf(_T("ERROR: unexpected wxFileSystem::FindNext result\n")); 
3295         wxPrintf(_T("%s%s\n"), indent
.c_str(), filename
.c_str()); 
3297         filename 
= fs
.FindNext(); 
3301 static void TestZipFileSystem() 
3303     wxPuts(_T("*** Testing ZIP file system ***\n")); 
3305     wxFileSystem::AddHandler(new wxZipFSHandler
); 
3307     wxPrintf(_T("Dumping all files in the archive %s:\n"), TESTFILE_ZIP
); 
3309     DumpZipDirectory(fs
, _T(""), wxString(_T(' '), 4)); 
3314 // ---------------------------------------------------------------------------- 
3316 // ---------------------------------------------------------------------------- 
3318 #ifdef TEST_DATETIME 
3320 #include "wx/math.h" 
3321 #include "wx/datetime.h" 
3323 // this test miscellaneous static wxDateTime functions 
3327 static void TestTimeStatic() 
3329     wxPuts(_T("\n*** wxDateTime static methods test ***")); 
3331     // some info about the current date 
3332     int year 
= wxDateTime::GetCurrentYear(); 
3333     wxPrintf(_T("Current year %d is %sa leap one and has %d days.\n"), 
3335            wxDateTime::IsLeapYear(year
) ? "" : "not ", 
3336            wxDateTime::GetNumberOfDays(year
)); 
3338     wxDateTime::Month month 
= wxDateTime::GetCurrentMonth(); 
3339     wxPrintf(_T("Current month is '%s' ('%s') and it has %d days\n"), 
3340            wxDateTime::GetMonthName(month
, wxDateTime::Name_Abbr
).c_str(), 
3341            wxDateTime::GetMonthName(month
).c_str(), 
3342            wxDateTime::GetNumberOfDays(month
)); 
3345 // test time zones stuff 
3346 static void TestTimeZones() 
3348     wxPuts(_T("\n*** wxDateTime timezone test ***")); 
3350     wxDateTime now 
= wxDateTime::Now(); 
3352     wxPrintf(_T("Current GMT time:\t%s\n"), now
.Format(_T("%c"), wxDateTime::GMT0
).c_str()); 
3353     wxPrintf(_T("Unix epoch (GMT):\t%s\n"), wxDateTime((time_t)0).Format(_T("%c"), wxDateTime::GMT0
).c_str()); 
3354     wxPrintf(_T("Unix epoch (EST):\t%s\n"), wxDateTime((time_t)0).Format(_T("%c"), wxDateTime::EST
).c_str()); 
3355     wxPrintf(_T("Current time in Paris:\t%s\n"), now
.Format(_T("%c"), wxDateTime::CET
).c_str()); 
3356     wxPrintf(_T("               Moscow:\t%s\n"), now
.Format(_T("%c"), wxDateTime::MSK
).c_str()); 
3357     wxPrintf(_T("             New York:\t%s\n"), now
.Format(_T("%c"), wxDateTime::EST
).c_str()); 
3359     wxPrintf(_T("%s\n"), wxDateTime::Now().Format(_T("Our timezone is %Z")).c_str()); 
3361     wxDateTime::Tm tm 
= now
.GetTm(); 
3362     if ( wxDateTime(tm
) != now 
) 
3364         wxPrintf(_T("ERROR: got %s instead of %s\n"), 
3365                  wxDateTime(tm
).Format().c_str(), now
.Format().c_str()); 
3369 // test some minimal support for the dates outside the standard range 
3370 static void TestTimeRange() 
3372     wxPuts(_T("\n*** wxDateTime out-of-standard-range dates test ***")); 
3374     static const wxChar 
*fmt 
= _T("%d-%b-%Y %H:%M:%S"); 
3376     wxPrintf(_T("Unix epoch:\t%s\n"), 
3377              wxDateTime(2440587.5).Format(fmt
).c_str()); 
3378     wxPrintf(_T("Feb 29, 0: \t%s\n"), 
3379              wxDateTime(29, wxDateTime::Feb
, 0).Format(fmt
).c_str()); 
3380     wxPrintf(_T("JDN 0:     \t%s\n"), 
3381              wxDateTime(0.0).Format(fmt
).c_str()); 
3382     wxPrintf(_T("Jan 1, 1AD:\t%s\n"), 
3383              wxDateTime(1, wxDateTime::Jan
, 1).Format(fmt
).c_str()); 
3384     wxPrintf(_T("May 29, 2099:\t%s\n"), 
3385              wxDateTime(29, wxDateTime::May
, 2099).Format(fmt
).c_str()); 
3388 // test DST calculations 
3389 static void TestTimeDST() 
3391     wxPuts(_T("\n*** wxDateTime DST test ***")); 
3393     wxPrintf(_T("DST is%s in effect now.\n\n"), 
3394              wxDateTime::Now().IsDST() ? wxEmptyString 
: _T(" not")); 
3396     for ( int year 
= 1990; year 
< 2005; year
++ ) 
3398         wxPrintf(_T("DST period in Europe for year %d: from %s to %s\n"), 
3400                  wxDateTime::GetBeginDST(year
, wxDateTime::Country_EEC
).Format().c_str(), 
3401                  wxDateTime::GetEndDST(year
, wxDateTime::Country_EEC
).Format().c_str()); 
3407 #if TEST_INTERACTIVE 
3409 static void TestDateTimeInteractive() 
3411     wxPuts(_T("\n*** interactive wxDateTime tests ***")); 
3417         wxPrintf(_T("Enter a date: ")); 
3418         if ( !wxFgets(buf
, WXSIZEOF(buf
), stdin
) ) 
3421         // kill the last '\n' 
3422         buf
[wxStrlen(buf
) - 1] = 0; 
3425         const wxChar 
*p 
= dt
.ParseDate(buf
); 
3428             wxPrintf(_T("ERROR: failed to parse the date '%s'.\n"), buf
); 
3434             wxPrintf(_T("WARNING: parsed only first %u characters.\n"), p 
- buf
); 
3437         wxPrintf(_T("%s: day %u, week of month %u/%u, week of year %u\n"), 
3438                  dt
.Format(_T("%b %d, %Y")).c_str(), 
3440                  dt
.GetWeekOfMonth(wxDateTime::Monday_First
), 
3441                  dt
.GetWeekOfMonth(wxDateTime::Sunday_First
), 
3442                  dt
.GetWeekOfYear(wxDateTime::Monday_First
)); 
3445     wxPuts(_T("\n*** done ***")); 
3448 #endif // TEST_INTERACTIVE 
3452 static void TestTimeMS() 
3454     wxPuts(_T("*** testing millisecond-resolution support in wxDateTime ***")); 
3456     wxDateTime dt1 
= wxDateTime::Now(), 
3457                dt2 
= wxDateTime::UNow(); 
3459     wxPrintf(_T("Now = %s\n"), dt1
.Format(_T("%H:%M:%S:%l")).c_str()); 
3460     wxPrintf(_T("UNow = %s\n"), dt2
.Format(_T("%H:%M:%S:%l")).c_str()); 
3461     wxPrintf(_T("Dummy loop: ")); 
3462     for ( int i 
= 0; i 
< 6000; i
++ ) 
3464         //for ( int j = 0; j < 10; j++ ) 
3467             s
.Printf(_T("%g"), sqrt((float)i
)); 
3473     wxPuts(_T(", done")); 
3476     dt2 
= wxDateTime::UNow(); 
3477     wxPrintf(_T("UNow = %s\n"), dt2
.Format(_T("%H:%M:%S:%l")).c_str()); 
3479     wxPrintf(_T("Loop executed in %s ms\n"), (dt2 
- dt1
).Format(_T("%l")).c_str()); 
3481     wxPuts(_T("\n*** done ***")); 
3484 static void TestTimeHolidays() 
3486     wxPuts(_T("\n*** testing wxDateTimeHolidayAuthority ***\n")); 
3488     wxDateTime::Tm tm 
= wxDateTime(29, wxDateTime::May
, 2000).GetTm(); 
3489     wxDateTime 
dtStart(1, tm
.mon
, tm
.year
), 
3490                dtEnd 
= dtStart
.GetLastMonthDay(); 
3492     wxDateTimeArray hol
; 
3493     wxDateTimeHolidayAuthority::GetHolidaysInRange(dtStart
, dtEnd
, hol
); 
3495     const wxChar 
*format 
= _T("%d-%b-%Y (%a)"); 
3497     wxPrintf(_T("All holidays between %s and %s:\n"), 
3498            dtStart
.Format(format
).c_str(), dtEnd
.Format(format
).c_str()); 
3500     size_t count 
= hol
.GetCount(); 
3501     for ( size_t n 
= 0; n 
< count
; n
++ ) 
3503         wxPrintf(_T("\t%s\n"), hol
[n
].Format(format
).c_str()); 
3506     wxPuts(wxEmptyString
); 
3509 static void TestTimeZoneBug() 
3511     wxPuts(_T("\n*** testing for DST/timezone bug ***\n")); 
3513     wxDateTime date 
= wxDateTime(1, wxDateTime::Mar
, 2000); 
3514     for ( int i 
= 0; i 
< 31; i
++ ) 
3516         wxPrintf(_T("Date %s: week day %s.\n"), 
3517                date
.Format(_T("%d-%m-%Y")).c_str(), 
3518                date
.GetWeekDayName(date
.GetWeekDay()).c_str()); 
3520         date 
+= wxDateSpan::Day(); 
3523     wxPuts(wxEmptyString
); 
3526 static void TestTimeSpanFormat() 
3528     wxPuts(_T("\n*** wxTimeSpan tests ***")); 
3530     static const wxChar 
*formats
[] = 
3532         _T("(default) %H:%M:%S"), 
3533         _T("%E weeks and %D days"), 
3534         _T("%l milliseconds"), 
3535         _T("(with ms) %H:%M:%S:%l"), 
3536         _T("100%% of minutes is %M"),       // test "%%" 
3537         _T("%D days and %H hours"), 
3538         _T("or also %S seconds"), 
3541     wxTimeSpan 
ts1(1, 2, 3, 4), 
3543     for ( size_t n 
= 0; n 
< WXSIZEOF(formats
); n
++ ) 
3545         wxPrintf(_T("ts1 = %s\tts2 = %s\n"), 
3546                ts1
.Format(formats
[n
]).c_str(), 
3547                ts2
.Format(formats
[n
]).c_str()); 
3550     wxPuts(wxEmptyString
); 
3555 #endif // TEST_DATETIME 
3557 // ---------------------------------------------------------------------------- 
3558 // wxTextInput/OutputStream 
3559 // ---------------------------------------------------------------------------- 
3561 #ifdef TEST_TEXTSTREAM 
3563 #include "wx/txtstrm.h" 
3564 #include "wx/wfstream.h" 
3566 static void TestTextInputStream() 
3568     wxPuts(_T("\n*** wxTextInputStream test ***")); 
3570     wxString filename 
= _T("testdata.fc"); 
3571     wxFileInputStream 
fsIn(filename
); 
3574         wxPuts(_T("ERROR: couldn't open file.")); 
3578         wxTextInputStream 
tis(fsIn
); 
3583             const wxString s 
= tis
.ReadLine(); 
3585             // line could be non empty if the last line of the file isn't 
3586             // terminated with EOL 
3587             if ( fsIn
.Eof() && s
.empty() ) 
3590             wxPrintf(_T("Line %d: %s\n"), line
++, s
.c_str()); 
3595 #endif // TEST_TEXTSTREAM 
3597 // ---------------------------------------------------------------------------- 
3599 // ---------------------------------------------------------------------------- 
3603 #include "wx/thread.h" 
3605 static size_t gs_counter 
= (size_t)-1; 
3606 static wxCriticalSection gs_critsect
; 
3607 static wxSemaphore gs_cond
; 
3609 class MyJoinableThread 
: public wxThread
 
3612     MyJoinableThread(size_t n
) : wxThread(wxTHREAD_JOINABLE
) 
3613         { m_n 
= n
; Create(); } 
3615     // thread execution starts here 
3616     virtual ExitCode 
Entry(); 
3622 wxThread::ExitCode 
MyJoinableThread::Entry() 
3624     unsigned long res 
= 1; 
3625     for ( size_t n 
= 1; n 
< m_n
; n
++ ) 
3629         // it's a loooong calculation :-) 
3633     return (ExitCode
)res
; 
3636 class MyDetachedThread 
: public wxThread
 
3639     MyDetachedThread(size_t n
, wxChar ch
) 
3643         m_cancelled 
= false; 
3648     // thread execution starts here 
3649     virtual ExitCode 
Entry(); 
3652     virtual void OnExit(); 
3655     size_t m_n
; // number of characters to write 
3656     wxChar m_ch
;  // character to write 
3658     bool m_cancelled
;   // false if we exit normally 
3661 wxThread::ExitCode 
MyDetachedThread::Entry() 
3664         wxCriticalSectionLocker 
lock(gs_critsect
); 
3665         if ( gs_counter 
== (size_t)-1 ) 
3671     for ( size_t n 
= 0; n 
< m_n
; n
++ ) 
3673         if ( TestDestroy() ) 
3683         wxThread::Sleep(100); 
3689 void MyDetachedThread::OnExit() 
3691     wxLogTrace(_T("thread"), _T("Thread %ld is in OnExit"), GetId()); 
3693     wxCriticalSectionLocker 
lock(gs_critsect
); 
3694     if ( !--gs_counter 
&& !m_cancelled 
) 
3698 static void TestDetachedThreads() 
3700     wxPuts(_T("\n*** Testing detached threads ***")); 
3702     static const size_t nThreads 
= 3; 
3703     MyDetachedThread 
*threads
[nThreads
]; 
3705     for ( n 
= 0; n 
< nThreads
; n
++ ) 
3707         threads
[n
] = new MyDetachedThread(10, 'A' + n
); 
3710     threads
[0]->SetPriority(WXTHREAD_MIN_PRIORITY
); 
3711     threads
[1]->SetPriority(WXTHREAD_MAX_PRIORITY
); 
3713     for ( n 
= 0; n 
< nThreads
; n
++ ) 
3718     // wait until all threads terminate 
3721     wxPuts(wxEmptyString
); 
3724 static void TestJoinableThreads() 
3726     wxPuts(_T("\n*** Testing a joinable thread (a loooong calculation...) ***")); 
3728     // calc 10! in the background 
3729     MyJoinableThread 
thread(10); 
3732     wxPrintf(_T("\nThread terminated with exit code %lu.\n"), 
3733              (unsigned long)thread
.Wait()); 
3736 static void TestThreadSuspend() 
3738     wxPuts(_T("\n*** Testing thread suspend/resume functions ***")); 
3740     MyDetachedThread 
*thread 
= new MyDetachedThread(15, 'X'); 
3744     // this is for this demo only, in a real life program we'd use another 
3745     // condition variable which would be signaled from wxThread::Entry() to 
3746     // tell us that the thread really started running - but here just wait a 
3747     // bit and hope that it will be enough (the problem is, of course, that 
3748     // the thread might still not run when we call Pause() which will result 
3750     wxThread::Sleep(300); 
3752     for ( size_t n 
= 0; n 
< 3; n
++ ) 
3756         wxPuts(_T("\nThread suspended")); 
3759             // don't sleep but resume immediately the first time 
3760             wxThread::Sleep(300); 
3762         wxPuts(_T("Going to resume the thread")); 
3767     wxPuts(_T("Waiting until it terminates now")); 
3769     // wait until the thread terminates 
3772     wxPuts(wxEmptyString
); 
3775 static void TestThreadDelete() 
3777     // As above, using Sleep() is only for testing here - we must use some 
3778     // synchronisation object instead to ensure that the thread is still 
3779     // running when we delete it - deleting a detached thread which already 
3780     // terminated will lead to a crash! 
3782     wxPuts(_T("\n*** Testing thread delete function ***")); 
3784     MyDetachedThread 
*thread0 
= new MyDetachedThread(30, 'W'); 
3788     wxPuts(_T("\nDeleted a thread which didn't start to run yet.")); 
3790     MyDetachedThread 
*thread1 
= new MyDetachedThread(30, 'Y'); 
3794     wxThread::Sleep(300); 
3798     wxPuts(_T("\nDeleted a running thread.")); 
3800     MyDetachedThread 
*thread2 
= new MyDetachedThread(30, 'Z'); 
3804     wxThread::Sleep(300); 
3810     wxPuts(_T("\nDeleted a sleeping thread.")); 
3812     MyJoinableThread 
thread3(20); 
3817     wxPuts(_T("\nDeleted a joinable thread.")); 
3819     MyJoinableThread 
thread4(2); 
3822     wxThread::Sleep(300); 
3826     wxPuts(_T("\nDeleted a joinable thread which already terminated.")); 
3828     wxPuts(wxEmptyString
); 
3831 class MyWaitingThread 
: public wxThread
 
3834     MyWaitingThread( wxMutex 
*mutex
, wxCondition 
*condition 
) 
3837         m_condition 
= condition
; 
3842     virtual ExitCode 
Entry() 
3844         wxPrintf(_T("Thread %lu has started running.\n"), GetId()); 
3849         wxPrintf(_T("Thread %lu starts to wait...\n"), GetId()); 
3853         m_condition
->Wait(); 
3856         wxPrintf(_T("Thread %lu finished to wait, exiting.\n"), GetId()); 
3864     wxCondition 
*m_condition
; 
3867 static void TestThreadConditions() 
3870     wxCondition 
condition(mutex
); 
3872     // otherwise its difficult to understand which log messages pertain to 
3874     //wxLogTrace(_T("thread"), _T("Local condition var is %08x, gs_cond = %08x"), 
3875     //           condition.GetId(), gs_cond.GetId()); 
3877     // create and launch threads 
3878     MyWaitingThread 
*threads
[10]; 
3881     for ( n 
= 0; n 
< WXSIZEOF(threads
); n
++ ) 
3883         threads
[n
] = new MyWaitingThread( &mutex
, &condition 
); 
3886     for ( n 
= 0; n 
< WXSIZEOF(threads
); n
++ ) 
3891     // wait until all threads run 
3892     wxPuts(_T("Main thread is waiting for the other threads to start")); 
3895     size_t nRunning 
= 0; 
3896     while ( nRunning 
< WXSIZEOF(threads
) ) 
3902         wxPrintf(_T("Main thread: %u already running\n"), nRunning
); 
3906     wxPuts(_T("Main thread: all threads started up.")); 
3909     wxThread::Sleep(500); 
3912     // now wake one of them up 
3913     wxPrintf(_T("Main thread: about to signal the condition.\n")); 
3918     wxThread::Sleep(200); 
3920     // wake all the (remaining) threads up, so that they can exit 
3921     wxPrintf(_T("Main thread: about to broadcast the condition.\n")); 
3923     condition
.Broadcast(); 
3925     // give them time to terminate (dirty!) 
3926     wxThread::Sleep(500); 
3929 #include "wx/utils.h" 
3931 class MyExecThread 
: public wxThread
 
3934     MyExecThread(const wxString
& command
) : wxThread(wxTHREAD_JOINABLE
), 
3940     virtual ExitCode 
Entry() 
3942         return (ExitCode
)wxExecute(m_command
, wxEXEC_SYNC
); 
3949 static void TestThreadExec() 
3951     wxPuts(_T("*** Testing wxExecute interaction with threads ***\n")); 
3953     MyExecThread 
thread(_T("true")); 
3956     wxPrintf(_T("Main program exit code: %ld.\n"), 
3957              wxExecute(_T("false"), wxEXEC_SYNC
)); 
3959     wxPrintf(_T("Thread exit code: %ld.\n"), (long)thread
.Wait()); 
3963 #include "wx/datetime.h" 
3965 class MySemaphoreThread 
: public wxThread
 
3968     MySemaphoreThread(int i
, wxSemaphore 
*sem
) 
3969         : wxThread(wxTHREAD_JOINABLE
), 
3976     virtual ExitCode 
Entry() 
3978         wxPrintf(_T("%s: Thread #%d (%ld) starting to wait for semaphore...\n"), 
3979                  wxDateTime::Now().FormatTime().c_str(), m_i
, (long)GetId()); 
3983         wxPrintf(_T("%s: Thread #%d (%ld) acquired the semaphore.\n"), 
3984                  wxDateTime::Now().FormatTime().c_str(), m_i
, (long)GetId()); 
3988         wxPrintf(_T("%s: Thread #%d (%ld) releasing the semaphore.\n"), 
3989                  wxDateTime::Now().FormatTime().c_str(), m_i
, (long)GetId()); 
4001 WX_DEFINE_ARRAY_PTR(wxThread 
*, ArrayThreads
); 
4003 static void TestSemaphore() 
4005     wxPuts(_T("*** Testing wxSemaphore class. ***")); 
4007     static const int SEM_LIMIT 
= 3; 
4009     wxSemaphore 
sem(SEM_LIMIT
, SEM_LIMIT
); 
4010     ArrayThreads threads
; 
4012     for ( int i 
= 0; i 
< 3*SEM_LIMIT
; i
++ ) 
4014         threads
.Add(new MySemaphoreThread(i
, &sem
)); 
4015         threads
.Last()->Run(); 
4018     for ( size_t n 
= 0; n 
< threads
.GetCount(); n
++ ) 
4025 #endif // TEST_THREADS 
4027 // ---------------------------------------------------------------------------- 
4029 // ---------------------------------------------------------------------------- 
4031 #ifdef TEST_SNGLINST 
4032     #include "wx/snglinst.h" 
4033 #endif // TEST_SNGLINST 
4035 int main(int argc
, char **argv
) 
4038     wxChar 
**wxArgv 
= new wxChar 
*[argc 
+ 1]; 
4043         for (n 
= 0; n 
< argc
; n
++ ) 
4045             wxMB2WXbuf warg 
= wxConvertMB2WX(argv
[n
]); 
4046             wxArgv
[n
] = wxStrdup(warg
); 
4051 #else // !wxUSE_UNICODE 
4053 #endif // wxUSE_UNICODE/!wxUSE_UNICODE 
4055     wxApp::CheckBuildOptions(WX_BUILD_OPTIONS_SIGNATURE
, "program"); 
4057     wxInitializer initializer
; 
4060         fprintf(stderr
, "Failed to initialize the wxWidgets library, aborting."); 
4065 #ifdef TEST_SNGLINST 
4066     wxSingleInstanceChecker checker
; 
4067     if ( checker
.Create(_T(".wxconsole.lock")) ) 
4069         if ( checker
.IsAnotherRunning() ) 
4071             wxPrintf(_T("Another instance of the program is running, exiting.\n")); 
4076         // wait some time to give time to launch another instance 
4077         wxPrintf(_T("Press \"Enter\" to continue...")); 
4080     else // failed to create 
4082         wxPrintf(_T("Failed to init wxSingleInstanceChecker.\n")); 
4084 #endif // TEST_SNGLINST 
4087     TestCmdLineConvert(); 
4089 #if wxUSE_CMDLINE_PARSER 
4090     static const wxCmdLineEntryDesc cmdLineDesc
[] = 
4092         { wxCMD_LINE_SWITCH
, _T("h"), _T("help"), _T("show this help message"), 
4093             wxCMD_LINE_VAL_NONE
, wxCMD_LINE_OPTION_HELP 
}, 
4094         { wxCMD_LINE_SWITCH
, _T("v"), _T("verbose"), _T("be verbose") }, 
4095         { wxCMD_LINE_SWITCH
, _T("q"), _T("quiet"),   _T("be quiet") }, 
4097         { wxCMD_LINE_OPTION
, _T("o"), _T("output"),  _T("output file") }, 
4098         { wxCMD_LINE_OPTION
, _T("i"), _T("input"),   _T("input dir") }, 
4099         { wxCMD_LINE_OPTION
, _T("s"), _T("size"),    _T("output block size"), 
4100             wxCMD_LINE_VAL_NUMBER 
}, 
4101         { wxCMD_LINE_OPTION
, _T("d"), _T("date"),    _T("output file date"), 
4102             wxCMD_LINE_VAL_DATE 
}, 
4104         { wxCMD_LINE_PARAM
,  NULL
, NULL
, _T("input file"), 
4105             wxCMD_LINE_VAL_STRING
, wxCMD_LINE_PARAM_MULTIPLE 
}, 
4110     wxCmdLineParser 
parser(cmdLineDesc
, argc
, wxArgv
); 
4112     parser
.AddOption(_T("project_name"), _T(""), _T("full path to project file"), 
4113                      wxCMD_LINE_VAL_STRING
, 
4114                      wxCMD_LINE_OPTION_MANDATORY 
| wxCMD_LINE_NEEDS_SEPARATOR
); 
4116     switch ( parser
.Parse() ) 
4119             wxLogMessage(_T("Help was given, terminating.")); 
4123             ShowCmdLine(parser
); 
4127             wxLogMessage(_T("Syntax error detected, aborting.")); 
4130 #endif // wxUSE_CMDLINE_PARSER 
4132 #endif // TEST_CMDLINE 
4144     TestDllListLoaded(); 
4145 #endif // TEST_DYNLIB 
4149 #endif // TEST_ENVIRON 
4153 #endif // TEST_EXECUTE 
4155 #ifdef TEST_FILECONF 
4157 #endif // TEST_FILECONF 
4161 #endif // TEST_LOCALE 
4164     wxPuts(_T("*** Testing wxLog ***")); 
4167     for ( size_t n 
= 0; n 
< 8000; n
++ ) 
4169         s 
<< (wxChar
)(_T('A') + (n 
% 26)); 
4172     wxLogWarning(_T("The length of the string is %lu"), 
4173                  (unsigned long)s
.length()); 
4176     msg
.Printf(_T("A very very long message: '%s', the end!\n"), s
.c_str()); 
4178     // this one shouldn't be truncated 
4181     // but this one will because log functions use fixed size buffer 
4182     // (note that it doesn't need '\n' at the end neither - will be added 
4184     wxLogMessage(_T("A very very long message 2: '%s', the end!"), s
.c_str()); 
4193 #ifdef TEST_FILENAME 
4196     TestFileNameDirManip(); 
4197     TestFileNameComparison(); 
4198     TestFileNameOperations(); 
4199 #endif // TEST_FILENAME 
4201 #ifdef TEST_FILETIME 
4206 #endif // TEST_FILETIME 
4209     wxLog::AddTraceMask(FTP_TRACE_MASK
); 
4210     if ( TestFtpConnect() ) 
4220         #if TEST_INTERACTIVE 
4221             TestFtpInteractive(); 
4224     //else: connecting to the FTP server failed 
4232     wxLog::AddTraceMask(_T("mime")); 
4236         TestMimeAssociate(); 
4241 #ifdef TEST_INFO_FUNCTIONS 
4246         #if TEST_INTERACTIVE 
4250 #endif // TEST_INFO_FUNCTIONS 
4252 #ifdef TEST_PATHLIST 
4254 #endif // TEST_PATHLIST 
4262 #endif // TEST_PRINTF 
4269 #endif // TEST_REGCONF 
4271 #if defined TEST_REGEX && TEST_INTERACTIVE 
4272     TestRegExInteractive(); 
4273 #endif // defined TEST_REGEX && TEST_INTERACTIVE 
4275 #ifdef TEST_REGISTRY 
4277     TestRegistryAssociation(); 
4278 #endif // TEST_REGISTRY 
4283 #endif // TEST_SOCKETS 
4290 #endif // TEST_STREAMS 
4292 #ifdef TEST_TEXTSTREAM 
4293     TestTextInputStream(); 
4294 #endif // TEST_TEXTSTREAM 
4297     int nCPUs 
= wxThread::GetCPUCount(); 
4298     wxPrintf(_T("This system has %d CPUs\n"), nCPUs
); 
4300         wxThread::SetConcurrency(nCPUs
); 
4302         TestJoinableThreads(); 
4305         TestJoinableThreads(); 
4306         TestDetachedThreads(); 
4307         TestThreadSuspend(); 
4309         TestThreadConditions(); 
4313 #endif // TEST_THREADS 
4317 #endif // TEST_TIMER 
4319 #ifdef TEST_DATETIME 
4326         TestTimeSpanFormat(); 
4332     #if TEST_INTERACTIVE 
4333         TestDateTimeInteractive(); 
4335 #endif // TEST_DATETIME 
4337 #ifdef TEST_SCOPEGUARD 
4341 #ifdef TEST_STACKWALKER 
4342 #if wxUSE_STACKWALKER 
4343     TestStackWalk(argv
[0]); 
4345 #endif // TEST_STACKWALKER 
4347 #ifdef TEST_STDPATHS 
4348     TestStandardPaths(); 
4352     wxPuts(_T("Sleeping for 3 seconds... z-z-z-z-z...")); 
4354 #endif // TEST_USLEEP 
4359 #endif // TEST_VCARD 
4363 #endif // TEST_VOLUME 
4367     TestEncodingConverter(); 
4368 #endif // TEST_WCHAR 
4371     TestZipStreamRead(); 
4372     TestZipFileSystem(); 
4377         for ( int n 
= 0; n 
< argc
; n
++ ) 
4382 #endif // wxUSE_UNICODE