///////////////////////////////////////////////////////////////////////////// // Name: samples/console/console.cpp // Purpose: A sample console (as opposed to GUI) program using wxWidgets // Author: Vadim Zeitlin // Modified by: // Created: 04.10.99 // RCS-ID: $Id$ // Copyright: (c) 1999 Vadim Zeitlin // Licence: wxWindows license ///////////////////////////////////////////////////////////////////////////// // IMPORTANT NOTE FOR WXWIDGETS USERS: // If you're a wxWidgets user and you're looking at this file to learn how to // structure a wxWidgets console application, then you don't have much to learn. // This application is used more for testing rather than as sample but // basically the following simple block is enough for you to start your // own console application: /* int main(int argc, char **argv) { wxApp::CheckBuildOptions(WX_BUILD_OPTIONS_SIGNATURE, "program"); wxInitializer initializer; if ( !initializer ) { fprintf(stderr, "Failed to initialize the wxWidgets library, aborting."); return -1; } static const wxCmdLineEntryDesc cmdLineDesc[] = { { wxCMD_LINE_SWITCH, "h", "help", "show this help message", wxCMD_LINE_VAL_NONE, wxCMD_LINE_OPTION_HELP }, // ... your other command line options here... { wxCMD_LINE_NONE } }; wxCmdLineParser parser(cmdLineDesc, argc, wxArgv); switch ( parser.Parse() ) { case -1: wxLogMessage(wxT("Help was given, terminating.")); break; case 0: // everything is ok; proceed break; default: wxLogMessage(wxT("Syntax error detected, aborting.")); break; } // do something useful here return 0; } */ // ============================================================================ // declarations // ============================================================================ // ---------------------------------------------------------------------------- // headers // ---------------------------------------------------------------------------- #include "wx/defs.h" #include #include "wx/string.h" #include "wx/file.h" #include "wx/filename.h" #include "wx/app.h" #include "wx/log.h" #include "wx/apptrait.h" #include "wx/platinfo.h" #include "wx/wxchar.h" // without this pragma, the stupid compiler precompiles #defines below so that // changing them doesn't "take place" later! #ifdef __VISUALC__ #pragma hdrstop #endif // ---------------------------------------------------------------------------- // conditional compilation // ---------------------------------------------------------------------------- /* A note about all these conditional compilation macros: this file is used both as a test suite for various non-GUI wxWidgets classes and as a scratchpad for quick tests. So there are two compilation modes: if you define TEST_ALL all tests are run, otherwise you may enable the individual tests individually in the "#else" branch below. */ // what to test (in alphabetic order)? Define TEST_ALL to 0 to do a single // test, define it to 1 to do all tests. #define TEST_ALL 0 #if TEST_ALL #define TEST_CMDLINE #define TEST_DATETIME #define TEST_DIR #define TEST_DYNLIB #define TEST_ENVIRON #define TEST_FILE #define TEST_FILECONF #define TEST_FILENAME #define TEST_FILETIME #define TEST_FTP #define TEST_INFO_FUNCTIONS #define TEST_LOCALE #define TEST_LOG #define TEST_MIME #define TEST_MODULE #define TEST_PATHLIST #define TEST_PRINTF #define TEST_REGCONF #define TEST_REGEX #define TEST_REGISTRY #define TEST_SCOPEGUARD #define TEST_SNGLINST // #define TEST_SOCKETS --FIXME! (RN) #define TEST_STACKWALKER #define TEST_STDPATHS #else // #if TEST_ALL #define TEST_DATETIME #define TEST_VOLUME #endif // some tests are interactive, define this to run them #ifdef TEST_INTERACTIVE #undef TEST_INTERACTIVE #define TEST_INTERACTIVE 1 #else #define TEST_INTERACTIVE 1 #endif // ============================================================================ // implementation // ============================================================================ // ---------------------------------------------------------------------------- // helper functions // ---------------------------------------------------------------------------- #if defined(TEST_SOCKETS) // replace TABs with \t and CRs with \n static wxString MakePrintable(const wxChar *s) { wxString str(s); (void)str.Replace(wxT("\t"), wxT("\\t")); (void)str.Replace(wxT("\n"), wxT("\\n")); (void)str.Replace(wxT("\r"), wxT("\\r")); return str; } #endif // MakePrintable() is used // ---------------------------------------------------------------------------- // wxCmdLineParser // ---------------------------------------------------------------------------- #ifdef TEST_CMDLINE #include "wx/cmdline.h" #include "wx/datetime.h" #if wxUSE_CMDLINE_PARSER static void ShowCmdLine(const wxCmdLineParser& parser) { wxString s = wxT("Command line parsed successfully:\nInput files: "); size_t count = parser.GetParamCount(); for ( size_t param = 0; param < count; param++ ) { s << parser.GetParam(param) << ' '; } s << '\n' << wxT("Verbose:\t") << (parser.Found(wxT("v")) ? wxT("yes") : wxT("no")) << '\n' << wxT("Quiet:\t") << (parser.Found(wxT("q")) ? wxT("yes") : wxT("no")) << '\n'; wxString strVal; long lVal; double dVal; wxDateTime dt; if ( parser.Found(wxT("o"), &strVal) ) s << wxT("Output file:\t") << strVal << '\n'; if ( parser.Found(wxT("i"), &strVal) ) s << wxT("Input dir:\t") << strVal << '\n'; if ( parser.Found(wxT("s"), &lVal) ) s << wxT("Size:\t") << lVal << '\n'; if ( parser.Found(wxT("f"), &dVal) ) s << wxT("Double:\t") << dVal << '\n'; if ( parser.Found(wxT("d"), &dt) ) s << wxT("Date:\t") << dt.FormatISODate() << '\n'; if ( parser.Found(wxT("project_name"), &strVal) ) s << wxT("Project:\t") << strVal << '\n'; wxLogMessage(s); } #endif // wxUSE_CMDLINE_PARSER static void TestCmdLineConvert() { static const wxChar *cmdlines[] = { wxT("arg1 arg2"), wxT("-a \"-bstring 1\" -c\"string 2\" \"string 3\""), wxT("literal \\\" and \"\""), }; for ( size_t n = 0; n < WXSIZEOF(cmdlines); n++ ) { const wxChar *cmdline = cmdlines[n]; wxPrintf(wxT("Parsing: %s\n"), cmdline); wxArrayString args = wxCmdLineParser::ConvertStringToArgs(cmdline); size_t count = args.GetCount(); wxPrintf(wxT("\targc = %u\n"), count); for ( size_t arg = 0; arg < count; arg++ ) { wxPrintf(wxT("\targv[%u] = %s\n"), arg, args[arg].c_str()); } } } #endif // TEST_CMDLINE // ---------------------------------------------------------------------------- // wxDir // ---------------------------------------------------------------------------- #ifdef TEST_DIR #include "wx/dir.h" #ifdef __UNIX__ static const wxChar *ROOTDIR = wxT("/"); static const wxChar *TESTDIR = wxT("/usr/local/share"); #elif defined(__WXMSW__) || defined(__DOS__) || defined(__OS2__) static const wxChar *ROOTDIR = wxT("c:\\"); static const wxChar *TESTDIR = wxT("d:\\"); #else #error "don't know where the root directory is" #endif static void TestDirEnumHelper(wxDir& dir, int flags = wxDIR_DEFAULT, const wxString& filespec = wxEmptyString) { wxString filename; if ( !dir.IsOpened() ) return; bool cont = dir.GetFirst(&filename, filespec, flags); while ( cont ) { wxPrintf(wxT("\t%s\n"), filename.c_str()); cont = dir.GetNext(&filename); } wxPuts(wxEmptyString); } #if TEST_ALL static void TestDirEnum() { wxPuts(wxT("*** Testing wxDir::GetFirst/GetNext ***")); wxString cwd = wxGetCwd(); if ( !wxDir::Exists(cwd) ) { wxPrintf(wxT("ERROR: current directory '%s' doesn't exist?\n"), cwd.c_str()); return; } wxDir dir(cwd); if ( !dir.IsOpened() ) { wxPrintf(wxT("ERROR: failed to open current directory '%s'.\n"), cwd.c_str()); return; } wxPuts(wxT("Enumerating everything in current directory:")); TestDirEnumHelper(dir); wxPuts(wxT("Enumerating really everything in current directory:")); TestDirEnumHelper(dir, wxDIR_DEFAULT | wxDIR_DOTDOT); wxPuts(wxT("Enumerating object files in current directory:")); TestDirEnumHelper(dir, wxDIR_DEFAULT, wxT("*.o*")); wxPuts(wxT("Enumerating directories in current directory:")); TestDirEnumHelper(dir, wxDIR_DIRS); wxPuts(wxT("Enumerating files in current directory:")); TestDirEnumHelper(dir, wxDIR_FILES); wxPuts(wxT("Enumerating files including hidden in current directory:")); TestDirEnumHelper(dir, wxDIR_FILES | wxDIR_HIDDEN); dir.Open(ROOTDIR); wxPuts(wxT("Enumerating everything in root directory:")); TestDirEnumHelper(dir, wxDIR_DEFAULT); wxPuts(wxT("Enumerating directories in root directory:")); TestDirEnumHelper(dir, wxDIR_DIRS); wxPuts(wxT("Enumerating files in root directory:")); TestDirEnumHelper(dir, wxDIR_FILES); wxPuts(wxT("Enumerating files including hidden in root directory:")); TestDirEnumHelper(dir, wxDIR_FILES | wxDIR_HIDDEN); wxPuts(wxT("Enumerating files in non existing directory:")); wxDir dirNo(wxT("nosuchdir")); TestDirEnumHelper(dirNo); } #endif // TEST_ALL class DirPrintTraverser : public wxDirTraverser { public: virtual wxDirTraverseResult OnFile(const wxString& WXUNUSED(filename)) { return wxDIR_CONTINUE; } virtual wxDirTraverseResult OnDir(const wxString& dirname) { wxString path, name, ext; wxFileName::SplitPath(dirname, &path, &name, &ext); if ( !ext.empty() ) name << wxT('.') << ext; wxString indent; for ( const wxChar *p = path.c_str(); *p; p++ ) { if ( wxIsPathSeparator(*p) ) indent += wxT(" "); } wxPrintf(wxT("%s%s\n"), indent.c_str(), name.c_str()); return wxDIR_CONTINUE; } }; static void TestDirTraverse() { wxPuts(wxT("*** Testing wxDir::Traverse() ***")); // enum all files wxArrayString files; size_t n = wxDir::GetAllFiles(TESTDIR, &files); wxPrintf(wxT("There are %u files under '%s'\n"), n, TESTDIR); if ( n > 1 ) { wxPrintf(wxT("First one is '%s'\n"), files[0u].c_str()); wxPrintf(wxT(" last one is '%s'\n"), files[n - 1].c_str()); } // enum again with custom traverser wxPuts(wxT("Now enumerating directories:")); wxDir dir(TESTDIR); DirPrintTraverser traverser; dir.Traverse(traverser, wxEmptyString, wxDIR_DIRS | wxDIR_HIDDEN); } #if TEST_ALL static void TestDirExists() { wxPuts(wxT("*** Testing wxDir::Exists() ***")); static const wxChar *dirnames[] = { wxT("."), #if defined(__WXMSW__) wxT("c:"), wxT("c:\\"), wxT("\\\\share\\file"), wxT("c:\\dos"), wxT("c:\\dos\\"), wxT("c:\\dos\\\\"), wxT("c:\\autoexec.bat"), #elif defined(__UNIX__) wxT("/"), wxT("//"), wxT("/usr/bin"), wxT("/usr//bin"), wxT("/usr///bin"), #endif }; for ( size_t n = 0; n < WXSIZEOF(dirnames); n++ ) { wxPrintf(wxT("%-40s: %s\n"), dirnames[n], wxDir::Exists(dirnames[n]) ? wxT("exists") : wxT("doesn't exist")); } } #endif // TEST_ALL #endif // TEST_DIR // ---------------------------------------------------------------------------- // wxDllLoader // ---------------------------------------------------------------------------- #ifdef TEST_DYNLIB #include "wx/dynlib.h" static void TestDllLoad() { #if defined(__WXMSW__) static const wxChar *LIB_NAME = wxT("kernel32.dll"); static const wxChar *FUNC_NAME = wxT("lstrlenA"); #elif defined(__UNIX__) // weird: using just libc.so does *not* work! static const wxChar *LIB_NAME = wxT("/lib/libc.so.6"); static const wxChar *FUNC_NAME = wxT("strlen"); #else #error "don't know how to test wxDllLoader on this platform" #endif wxPuts(wxT("*** testing basic wxDynamicLibrary functions ***\n")); wxDynamicLibrary lib(LIB_NAME); if ( !lib.IsLoaded() ) { wxPrintf(wxT("ERROR: failed to load '%s'.\n"), LIB_NAME); } else { typedef int (wxSTDCALL *wxStrlenType)(const char *); wxStrlenType pfnStrlen = (wxStrlenType)lib.GetSymbol(FUNC_NAME); if ( !pfnStrlen ) { wxPrintf(wxT("ERROR: function '%s' wasn't found in '%s'.\n"), FUNC_NAME, LIB_NAME); } else { wxPrintf(wxT("Calling %s dynamically loaded from %s "), FUNC_NAME, LIB_NAME); if ( pfnStrlen("foo") != 3 ) { wxPrintf(wxT("ERROR: loaded function is not wxStrlen()!\n")); } else { wxPuts(wxT("... ok")); } } #ifdef __WXMSW__ static const wxChar *FUNC_NAME_AW = wxT("lstrlen"); typedef int (wxSTDCALL *wxStrlenTypeAorW)(const wxChar *); wxStrlenTypeAorW pfnStrlenAorW = (wxStrlenTypeAorW)lib.GetSymbolAorW(FUNC_NAME_AW); if ( !pfnStrlenAorW ) { wxPrintf(wxT("ERROR: function '%s' wasn't found in '%s'.\n"), FUNC_NAME_AW, LIB_NAME); } else { if ( pfnStrlenAorW(wxT("foobar")) != 6 ) { wxPrintf(wxT("ERROR: loaded function is not wxStrlen()!\n")); } } #endif // __WXMSW__ } } #if defined(__WXMSW__) || defined(__UNIX__) static void TestDllListLoaded() { wxPuts(wxT("*** testing wxDynamicLibrary::ListLoaded() ***\n")); puts("\nLoaded modules:"); wxDynamicLibraryDetailsArray dlls = wxDynamicLibrary::ListLoaded(); const size_t count = dlls.GetCount(); for ( size_t n = 0; n < count; ++n ) { const wxDynamicLibraryDetails& details = dlls[n]; printf("%-45s", (const char *)details.GetPath().mb_str()); void *addr wxDUMMY_INITIALIZE(NULL); size_t len wxDUMMY_INITIALIZE(0); if ( details.GetAddress(&addr, &len) ) { printf(" %08lx:%08lx", (unsigned long)addr, (unsigned long)((char *)addr + len)); } printf(" %s\n", (const char *)details.GetVersion().mb_str()); } } #endif #endif // TEST_DYNLIB // ---------------------------------------------------------------------------- // wxGet/SetEnv // ---------------------------------------------------------------------------- #ifdef TEST_ENVIRON #include "wx/utils.h" static wxString MyGetEnv(const wxString& var) { wxString val; if ( !wxGetEnv(var, &val) ) val = wxT(""); else val = wxString(wxT('\'')) + val + wxT('\''); return val; } static void TestEnvironment() { const wxChar *var = wxT("wxTestVar"); wxPuts(wxT("*** testing environment access functions ***")); wxPrintf(wxT("Initially getenv(%s) = %s\n"), var, MyGetEnv(var).c_str()); wxSetEnv(var, wxT("value for wxTestVar")); wxPrintf(wxT("After wxSetEnv: getenv(%s) = %s\n"), var, MyGetEnv(var).c_str()); wxSetEnv(var, wxT("another value")); wxPrintf(wxT("After 2nd wxSetEnv: getenv(%s) = %s\n"), var, MyGetEnv(var).c_str()); wxUnsetEnv(var); wxPrintf(wxT("After wxUnsetEnv: getenv(%s) = %s\n"), var, MyGetEnv(var).c_str()); wxPrintf(wxT("PATH = %s\n"), MyGetEnv(wxT("PATH")).c_str()); } #endif // TEST_ENVIRON // ---------------------------------------------------------------------------- // file // ---------------------------------------------------------------------------- #ifdef TEST_FILE #include "wx/file.h" #include "wx/ffile.h" #include "wx/textfile.h" static void TestFileRead() { wxPuts(wxT("*** wxFile read test ***")); wxFile file(wxT("testdata.fc")); if ( file.IsOpened() ) { wxPrintf(wxT("File length: %lu\n"), file.Length()); wxPuts(wxT("File dump:\n----------")); static const size_t len = 1024; wxChar buf[len]; for ( ;; ) { size_t nRead = file.Read(buf, len); if ( nRead == (size_t)wxInvalidOffset ) { wxPrintf(wxT("Failed to read the file.")); break; } fwrite(buf, nRead, 1, stdout); if ( nRead < len ) break; } wxPuts(wxT("----------")); } else { wxPrintf(wxT("ERROR: can't open test file.\n")); } wxPuts(wxEmptyString); } static void TestTextFileRead() { wxPuts(wxT("*** wxTextFile read test ***")); wxTextFile file(wxT("testdata.fc")); if ( file.Open() ) { wxPrintf(wxT("Number of lines: %u\n"), file.GetLineCount()); wxPrintf(wxT("Last line: '%s'\n"), file.GetLastLine().c_str()); wxString s; wxPuts(wxT("\nDumping the entire file:")); for ( s = file.GetFirstLine(); !file.Eof(); s = file.GetNextLine() ) { wxPrintf(wxT("%6u: %s\n"), file.GetCurrentLine() + 1, s.c_str()); } wxPrintf(wxT("%6u: %s\n"), file.GetCurrentLine() + 1, s.c_str()); wxPuts(wxT("\nAnd now backwards:")); for ( s = file.GetLastLine(); file.GetCurrentLine() != 0; s = file.GetPrevLine() ) { wxPrintf(wxT("%6u: %s\n"), file.GetCurrentLine() + 1, s.c_str()); } wxPrintf(wxT("%6u: %s\n"), file.GetCurrentLine() + 1, s.c_str()); } else { wxPrintf(wxT("ERROR: can't open '%s'\n"), file.GetName()); } wxPuts(wxEmptyString); } static void TestFileCopy() { wxPuts(wxT("*** Testing wxCopyFile ***")); static const wxChar *filename1 = wxT("testdata.fc"); static const wxChar *filename2 = wxT("test2"); if ( !wxCopyFile(filename1, filename2) ) { wxPuts(wxT("ERROR: failed to copy file")); } else { wxFFile f1(filename1, wxT("rb")), f2(filename2, wxT("rb")); if ( !f1.IsOpened() || !f2.IsOpened() ) { wxPuts(wxT("ERROR: failed to open file(s)")); } else { wxString s1, s2; if ( !f1.ReadAll(&s1) || !f2.ReadAll(&s2) ) { wxPuts(wxT("ERROR: failed to read file(s)")); } else { if ( (s1.length() != s2.length()) || (memcmp(s1.c_str(), s2.c_str(), s1.length()) != 0) ) { wxPuts(wxT("ERROR: copy error!")); } else { wxPuts(wxT("File was copied ok.")); } } } } if ( !wxRemoveFile(filename2) ) { wxPuts(wxT("ERROR: failed to remove the file")); } wxPuts(wxEmptyString); } static void TestTempFile() { wxPuts(wxT("*** wxTempFile test ***")); wxTempFile tmpFile; if ( tmpFile.Open(wxT("test2")) && tmpFile.Write(wxT("the answer is 42")) ) { if ( tmpFile.Commit() ) wxPuts(wxT("File committed.")); else wxPuts(wxT("ERROR: could't commit temp file.")); wxRemoveFile(wxT("test2")); } wxPuts(wxEmptyString); } #endif // TEST_FILE // ---------------------------------------------------------------------------- // wxFileConfig // ---------------------------------------------------------------------------- #ifdef TEST_FILECONF #include "wx/confbase.h" #include "wx/fileconf.h" static const struct FileConfTestData { const wxChar *name; // value name const wxChar *value; // the value from the file } fcTestData[] = { { wxT("value1"), wxT("one") }, { wxT("value2"), wxT("two") }, { wxT("novalue"), wxT("default") }, }; static void TestFileConfRead() { wxPuts(wxT("*** testing wxFileConfig loading/reading ***")); wxFileConfig fileconf(wxT("test"), wxEmptyString, wxT("testdata.fc"), wxEmptyString, wxCONFIG_USE_RELATIVE_PATH); // test simple reading wxPuts(wxT("\nReading config file:")); wxString defValue(wxT("default")), value; for ( size_t n = 0; n < WXSIZEOF(fcTestData); n++ ) { const FileConfTestData& data = fcTestData[n]; value = fileconf.Read(data.name, defValue); wxPrintf(wxT("\t%s = %s "), data.name, value.c_str()); if ( value == data.value ) { wxPuts(wxT("(ok)")); } else { wxPrintf(wxT("(ERROR: should be %s)\n"), data.value); } } // test enumerating the entries wxPuts(wxT("\nEnumerating all root entries:")); long dummy; wxString name; bool cont = fileconf.GetFirstEntry(name, dummy); while ( cont ) { wxPrintf(wxT("\t%s = %s\n"), name.c_str(), fileconf.Read(name.c_str(), wxT("ERROR")).c_str()); cont = fileconf.GetNextEntry(name, dummy); } static const wxChar *testEntry = wxT("TestEntry"); wxPrintf(wxT("\nTesting deletion of newly created \"Test\" entry: ")); fileconf.Write(testEntry, wxT("A value")); fileconf.DeleteEntry(testEntry); wxPrintf(fileconf.HasEntry(testEntry) ? wxT("ERROR\n") : wxT("ok\n")); } #endif // TEST_FILECONF // ---------------------------------------------------------------------------- // wxFileName // ---------------------------------------------------------------------------- #ifdef TEST_FILENAME #include "wx/filename.h" #if 0 static void DumpFileName(const wxChar *desc, const wxFileName& fn) { wxPuts(desc); wxString full = fn.GetFullPath(); wxString vol, path, name, ext; wxFileName::SplitPath(full, &vol, &path, &name, &ext); wxPrintf(wxT("'%s'-> vol '%s', path '%s', name '%s', ext '%s'\n"), full.c_str(), vol.c_str(), path.c_str(), name.c_str(), ext.c_str()); wxFileName::SplitPath(full, &path, &name, &ext); wxPrintf(wxT("or\t\t-> path '%s', name '%s', ext '%s'\n"), path.c_str(), name.c_str(), ext.c_str()); wxPrintf(wxT("path is also:\t'%s'\n"), fn.GetPath().c_str()); wxPrintf(wxT("with volume: \t'%s'\n"), fn.GetPath(wxPATH_GET_VOLUME).c_str()); wxPrintf(wxT("with separator:\t'%s'\n"), fn.GetPath(wxPATH_GET_SEPARATOR).c_str()); wxPrintf(wxT("with both: \t'%s'\n"), fn.GetPath(wxPATH_GET_SEPARATOR | wxPATH_GET_VOLUME).c_str()); wxPuts(wxT("The directories in the path are:")); wxArrayString dirs = fn.GetDirs(); size_t count = dirs.GetCount(); for ( size_t n = 0; n < count; n++ ) { wxPrintf(wxT("\t%u: %s\n"), n, dirs[n].c_str()); } } #endif static void TestFileNameTemp() { wxPuts(wxT("*** testing wxFileName temp file creation ***")); static const wxChar *tmpprefixes[] = { wxT(""), wxT("foo"), wxT(".."), wxT("../bar"), #ifdef __UNIX__ wxT("/tmp/foo"), wxT("/tmp/foo/bar"), // this one must be an error #endif // __UNIX__ }; for ( size_t n = 0; n < WXSIZEOF(tmpprefixes); n++ ) { wxString path = wxFileName::CreateTempFileName(tmpprefixes[n]); if ( path.empty() ) { // "error" is not in upper case because it may be ok wxPrintf(wxT("Prefix '%s'\t-> error\n"), tmpprefixes[n]); } else { wxPrintf(wxT("Prefix '%s'\t-> temp file '%s'\n"), tmpprefixes[n], path.c_str()); if ( !wxRemoveFile(path) ) { wxLogWarning(wxT("Failed to remove temp file '%s'"), path.c_str()); } } } } static void TestFileNameDirManip() { // TODO: test AppendDir(), RemoveDir(), ... } static void TestFileNameComparison() { // TODO! } static void TestFileNameOperations() { // TODO! } static void TestFileNameCwd() { // TODO! } #endif // TEST_FILENAME // ---------------------------------------------------------------------------- // wxFileName time functions // ---------------------------------------------------------------------------- #ifdef TEST_FILETIME #include "wx/filename.h" #include "wx/datetime.h" static void TestFileGetTimes() { wxFileName fn(wxT("testdata.fc")); wxDateTime dtAccess, dtMod, dtCreate; if ( !fn.GetTimes(&dtAccess, &dtMod, &dtCreate) ) { wxPrintf(wxT("ERROR: GetTimes() failed.\n")); } else { static const wxChar *fmt = wxT("%Y-%b-%d %H:%M:%S"); wxPrintf(wxT("File times for '%s':\n"), fn.GetFullPath().c_str()); wxPrintf(wxT("Creation: \t%s\n"), dtCreate.Format(fmt).c_str()); wxPrintf(wxT("Last read: \t%s\n"), dtAccess.Format(fmt).c_str()); wxPrintf(wxT("Last write: \t%s\n"), dtMod.Format(fmt).c_str()); } } #if 0 static void TestFileSetTimes() { wxFileName fn(wxT("testdata.fc")); if ( !fn.Touch() ) { wxPrintf(wxT("ERROR: Touch() failed.\n")); } } #endif #endif // TEST_FILETIME // ---------------------------------------------------------------------------- // wxLocale // ---------------------------------------------------------------------------- #ifdef TEST_LOCALE #include "wx/intl.h" #include "wx/utils.h" // for wxSetEnv static wxLocale gs_localeDefault; // NOTE: don't init it here as it needs a wxAppTraits object // and thus must be init-ed after creation of the wxInitializer // class in the main() // find the name of the language from its value static const wxChar *GetLangName(int lang) { static const wxChar *languageNames[] = { wxT("DEFAULT"), wxT("UNKNOWN"), wxT("ABKHAZIAN"), wxT("AFAR"), wxT("AFRIKAANS"), wxT("ALBANIAN"), wxT("AMHARIC"), wxT("ARABIC"), wxT("ARABIC_ALGERIA"), wxT("ARABIC_BAHRAIN"), wxT("ARABIC_EGYPT"), wxT("ARABIC_IRAQ"), wxT("ARABIC_JORDAN"), wxT("ARABIC_KUWAIT"), wxT("ARABIC_LEBANON"), wxT("ARABIC_LIBYA"), wxT("ARABIC_MOROCCO"), wxT("ARABIC_OMAN"), wxT("ARABIC_QATAR"), wxT("ARABIC_SAUDI_ARABIA"), wxT("ARABIC_SUDAN"), wxT("ARABIC_SYRIA"), wxT("ARABIC_TUNISIA"), wxT("ARABIC_UAE"), wxT("ARABIC_YEMEN"), wxT("ARMENIAN"), wxT("ASSAMESE"), wxT("AYMARA"), wxT("AZERI"), wxT("AZERI_CYRILLIC"), wxT("AZERI_LATIN"), wxT("BASHKIR"), wxT("BASQUE"), wxT("BELARUSIAN"), wxT("BENGALI"), wxT("BHUTANI"), wxT("BIHARI"), wxT("BISLAMA"), wxT("BRETON"), wxT("BULGARIAN"), wxT("BURMESE"), wxT("CAMBODIAN"), wxT("CATALAN"), wxT("CHINESE"), wxT("CHINESE_SIMPLIFIED"), wxT("CHINESE_TRADITIONAL"), wxT("CHINESE_HONGKONG"), wxT("CHINESE_MACAU"), wxT("CHINESE_SINGAPORE"), wxT("CHINESE_TAIWAN"), wxT("CORSICAN"), wxT("CROATIAN"), wxT("CZECH"), wxT("DANISH"), wxT("DUTCH"), wxT("DUTCH_BELGIAN"), wxT("ENGLISH"), wxT("ENGLISH_UK"), wxT("ENGLISH_US"), wxT("ENGLISH_AUSTRALIA"), wxT("ENGLISH_BELIZE"), wxT("ENGLISH_BOTSWANA"), wxT("ENGLISH_CANADA"), wxT("ENGLISH_CARIBBEAN"), wxT("ENGLISH_DENMARK"), wxT("ENGLISH_EIRE"), wxT("ENGLISH_JAMAICA"), wxT("ENGLISH_NEW_ZEALAND"), wxT("ENGLISH_PHILIPPINES"), wxT("ENGLISH_SOUTH_AFRICA"), wxT("ENGLISH_TRINIDAD"), wxT("ENGLISH_ZIMBABWE"), wxT("ESPERANTO"), wxT("ESTONIAN"), wxT("FAEROESE"), wxT("FARSI"), wxT("FIJI"), wxT("FINNISH"), wxT("FRENCH"), wxT("FRENCH_BELGIAN"), wxT("FRENCH_CANADIAN"), wxT("FRENCH_LUXEMBOURG"), wxT("FRENCH_MONACO"), wxT("FRENCH_SWISS"), wxT("FRISIAN"), wxT("GALICIAN"), wxT("GEORGIAN"), wxT("GERMAN"), wxT("GERMAN_AUSTRIAN"), wxT("GERMAN_BELGIUM"), wxT("GERMAN_LIECHTENSTEIN"), wxT("GERMAN_LUXEMBOURG"), wxT("GERMAN_SWISS"), wxT("GREEK"), wxT("GREENLANDIC"), wxT("GUARANI"), wxT("GUJARATI"), wxT("HAUSA"), wxT("HEBREW"), wxT("HINDI"), wxT("HUNGARIAN"), wxT("ICELANDIC"), wxT("INDONESIAN"), wxT("INTERLINGUA"), wxT("INTERLINGUE"), wxT("INUKTITUT"), wxT("INUPIAK"), wxT("IRISH"), wxT("ITALIAN"), wxT("ITALIAN_SWISS"), wxT("JAPANESE"), wxT("JAVANESE"), wxT("KANNADA"), wxT("KASHMIRI"), wxT("KASHMIRI_INDIA"), wxT("KAZAKH"), wxT("KERNEWEK"), wxT("KINYARWANDA"), wxT("KIRGHIZ"), wxT("KIRUNDI"), wxT("KONKANI"), wxT("KOREAN"), wxT("KURDISH"), wxT("LAOTHIAN"), wxT("LATIN"), wxT("LATVIAN"), wxT("LINGALA"), wxT("LITHUANIAN"), wxT("MACEDONIAN"), wxT("MALAGASY"), wxT("MALAY"), wxT("MALAYALAM"), wxT("MALAY_BRUNEI_DARUSSALAM"), wxT("MALAY_MALAYSIA"), wxT("MALTESE"), wxT("MANIPURI"), wxT("MAORI"), wxT("MARATHI"), wxT("MOLDAVIAN"), wxT("MONGOLIAN"), wxT("NAURU"), wxT("NEPALI"), wxT("NEPALI_INDIA"), wxT("NORWEGIAN_BOKMAL"), wxT("NORWEGIAN_NYNORSK"), wxT("OCCITAN"), wxT("ORIYA"), wxT("OROMO"), wxT("PASHTO"), wxT("POLISH"), wxT("PORTUGUESE"), wxT("PORTUGUESE_BRAZILIAN"), wxT("PUNJABI"), wxT("QUECHUA"), wxT("RHAETO_ROMANCE"), wxT("ROMANIAN"), wxT("RUSSIAN"), wxT("RUSSIAN_UKRAINE"), wxT("SAMOAN"), wxT("SANGHO"), wxT("SANSKRIT"), wxT("SCOTS_GAELIC"), wxT("SERBIAN"), wxT("SERBIAN_CYRILLIC"), wxT("SERBIAN_LATIN"), wxT("SERBO_CROATIAN"), wxT("SESOTHO"), wxT("SETSWANA"), wxT("SHONA"), wxT("SINDHI"), wxT("SINHALESE"), wxT("SISWATI"), wxT("SLOVAK"), wxT("SLOVENIAN"), wxT("SOMALI"), wxT("SPANISH"), wxT("SPANISH_ARGENTINA"), wxT("SPANISH_BOLIVIA"), wxT("SPANISH_CHILE"), wxT("SPANISH_COLOMBIA"), wxT("SPANISH_COSTA_RICA"), wxT("SPANISH_DOMINICAN_REPUBLIC"), wxT("SPANISH_ECUADOR"), wxT("SPANISH_EL_SALVADOR"), wxT("SPANISH_GUATEMALA"), wxT("SPANISH_HONDURAS"), wxT("SPANISH_MEXICAN"), wxT("SPANISH_MODERN"), wxT("SPANISH_NICARAGUA"), wxT("SPANISH_PANAMA"), wxT("SPANISH_PARAGUAY"), wxT("SPANISH_PERU"), wxT("SPANISH_PUERTO_RICO"), wxT("SPANISH_URUGUAY"), wxT("SPANISH_US"), wxT("SPANISH_VENEZUELA"), wxT("SUNDANESE"), wxT("SWAHILI"), wxT("SWEDISH"), wxT("SWEDISH_FINLAND"), wxT("TAGALOG"), wxT("TAJIK"), wxT("TAMIL"), wxT("TATAR"), wxT("TELUGU"), wxT("THAI"), wxT("TIBETAN"), wxT("TIGRINYA"), wxT("TONGA"), wxT("TSONGA"), wxT("TURKISH"), wxT("TURKMEN"), wxT("TWI"), wxT("UIGHUR"), wxT("UKRAINIAN"), wxT("URDU"), wxT("URDU_INDIA"), wxT("URDU_PAKISTAN"), wxT("UZBEK"), wxT("UZBEK_CYRILLIC"), wxT("UZBEK_LATIN"), wxT("VIETNAMESE"), wxT("VOLAPUK"), wxT("WELSH"), wxT("WOLOF"), wxT("XHOSA"), wxT("YIDDISH"), wxT("YORUBA"), wxT("ZHUANG"), wxT("ZULU"), }; if ( (size_t)lang < WXSIZEOF(languageNames) ) return languageNames[lang]; else return wxT("INVALID"); } static void TestDefaultLang() { wxPuts(wxT("*** Testing wxLocale::GetSystemLanguage ***")); gs_localeDefault.Init(wxLANGUAGE_ENGLISH); static const wxChar *langStrings[] = { NULL, // system default wxT("C"), wxT("fr"), wxT("fr_FR"), wxT("en"), wxT("en_GB"), wxT("en_US"), wxT("de_DE.iso88591"), wxT("german"), wxT("?"), // invalid lang spec wxT("klingonese"), // I bet on some systems it does exist... }; wxPrintf(wxT("The default system encoding is %s (%d)\n"), wxLocale::GetSystemEncodingName().c_str(), wxLocale::GetSystemEncoding()); for ( size_t n = 0; n < WXSIZEOF(langStrings); n++ ) { const wxChar *langStr = langStrings[n]; if ( langStr ) { // FIXME: this doesn't do anything at all under Windows, we need // to create a new wxLocale! wxSetEnv(wxT("LC_ALL"), langStr); } int lang = gs_localeDefault.GetSystemLanguage(); wxPrintf(wxT("Locale for '%s' is %s.\n"), langStr ? langStr : wxT("system default"), GetLangName(lang)); } } #endif // TEST_LOCALE // ---------------------------------------------------------------------------- // MIME types // ---------------------------------------------------------------------------- #ifdef TEST_MIME #include "wx/mimetype.h" static void TestMimeEnum() { wxPuts(wxT("*** Testing wxMimeTypesManager::EnumAllFileTypes() ***\n")); wxArrayString mimetypes; size_t count = wxTheMimeTypesManager->EnumAllFileTypes(mimetypes); wxPrintf(wxT("*** All %u known filetypes: ***\n"), count); wxArrayString exts; wxString desc; for ( size_t n = 0; n < count; n++ ) { wxFileType *filetype = wxTheMimeTypesManager->GetFileTypeFromMimeType(mimetypes[n]); if ( !filetype ) { wxPrintf(wxT("nothing known about the filetype '%s'!\n"), mimetypes[n].c_str()); continue; } filetype->GetDescription(&desc); filetype->GetExtensions(exts); filetype->GetIcon(NULL); wxString extsAll; for ( size_t e = 0; e < exts.GetCount(); e++ ) { if ( e > 0 ) extsAll << wxT(", "); extsAll += exts[e]; } wxPrintf(wxT("\t%s: %s (%s)\n"), mimetypes[n].c_str(), desc.c_str(), extsAll.c_str()); } wxPuts(wxEmptyString); } static void TestMimeFilename() { wxPuts(wxT("*** Testing MIME type from filename query ***\n")); static const wxChar *filenames[] = { wxT("readme.txt"), wxT("document.pdf"), wxT("image.gif"), wxT("picture.jpeg"), }; for ( size_t n = 0; n < WXSIZEOF(filenames); n++ ) { const wxString fname = filenames[n]; wxString ext = fname.AfterLast(wxT('.')); wxFileType *ft = wxTheMimeTypesManager->GetFileTypeFromExtension(ext); if ( !ft ) { wxPrintf(wxT("WARNING: extension '%s' is unknown.\n"), ext.c_str()); } else { wxString desc; if ( !ft->GetDescription(&desc) ) desc = wxT(""); wxString cmd; if ( !ft->GetOpenCommand(&cmd, wxFileType::MessageParameters(fname, wxEmptyString)) ) cmd = wxT(""); else cmd = wxString(wxT('"')) + cmd + wxT('"'); wxPrintf(wxT("To open %s (%s) do %s.\n"), fname.c_str(), desc.c_str(), cmd.c_str()); delete ft; } } wxPuts(wxEmptyString); } // these tests were broken by wxMimeTypesManager changes, temporarily disabling #if 0 static void TestMimeOverride() { wxPuts(wxT("*** Testing wxMimeTypesManager additional files loading ***\n")); static const wxChar *mailcap = wxT("/tmp/mailcap"); static const wxChar *mimetypes = wxT("/tmp/mime.types"); if ( wxFile::Exists(mailcap) ) wxPrintf(wxT("Loading mailcap from '%s': %s\n"), mailcap, wxTheMimeTypesManager->ReadMailcap(mailcap) ? wxT("ok") : wxT("ERROR")); else wxPrintf(wxT("WARN: mailcap file '%s' doesn't exist, not loaded.\n"), mailcap); if ( wxFile::Exists(mimetypes) ) wxPrintf(wxT("Loading mime.types from '%s': %s\n"), mimetypes, wxTheMimeTypesManager->ReadMimeTypes(mimetypes) ? wxT("ok") : wxT("ERROR")); else wxPrintf(wxT("WARN: mime.types file '%s' doesn't exist, not loaded.\n"), mimetypes); wxPuts(wxEmptyString); } static void TestMimeAssociate() { wxPuts(wxT("*** Testing creation of filetype association ***\n")); wxFileTypeInfo ftInfo( wxT("application/x-xyz"), wxT("xyzview '%s'"), // open cmd wxT(""), // print cmd wxT("XYZ File"), // description wxT(".xyz"), // extensions wxNullPtr // end of extensions ); ftInfo.SetShortDesc(wxT("XYZFile")); // used under Win32 only wxFileType *ft = wxTheMimeTypesManager->Associate(ftInfo); if ( !ft ) { wxPuts(wxT("ERROR: failed to create association!")); } else { // TODO: read it back delete ft; } wxPuts(wxEmptyString); } #endif // 0 #endif // TEST_MIME // ---------------------------------------------------------------------------- // module dependencies feature // ---------------------------------------------------------------------------- #ifdef TEST_MODULE #include "wx/module.h" class wxTestModule : public wxModule { protected: virtual bool OnInit() { wxPrintf(wxT("Load module: %s\n"), GetClassInfo()->GetClassName()); return true; } virtual void OnExit() { wxPrintf(wxT("Unload module: %s\n"), GetClassInfo()->GetClassName()); } }; class wxTestModuleA : public wxTestModule { public: wxTestModuleA(); private: DECLARE_DYNAMIC_CLASS(wxTestModuleA) }; class wxTestModuleB : public wxTestModule { public: wxTestModuleB(); private: DECLARE_DYNAMIC_CLASS(wxTestModuleB) }; class wxTestModuleC : public wxTestModule { public: wxTestModuleC(); private: DECLARE_DYNAMIC_CLASS(wxTestModuleC) }; class wxTestModuleD : public wxTestModule { public: wxTestModuleD(); private: DECLARE_DYNAMIC_CLASS(wxTestModuleD) }; IMPLEMENT_DYNAMIC_CLASS(wxTestModuleC, wxModule) wxTestModuleC::wxTestModuleC() { AddDependency(CLASSINFO(wxTestModuleD)); } IMPLEMENT_DYNAMIC_CLASS(wxTestModuleA, wxModule) wxTestModuleA::wxTestModuleA() { AddDependency(CLASSINFO(wxTestModuleB)); AddDependency(CLASSINFO(wxTestModuleD)); } IMPLEMENT_DYNAMIC_CLASS(wxTestModuleD, wxModule) wxTestModuleD::wxTestModuleD() { } IMPLEMENT_DYNAMIC_CLASS(wxTestModuleB, wxModule) wxTestModuleB::wxTestModuleB() { AddDependency(CLASSINFO(wxTestModuleD)); AddDependency(CLASSINFO(wxTestModuleC)); } #endif // TEST_MODULE // ---------------------------------------------------------------------------- // misc information functions // ---------------------------------------------------------------------------- #ifdef TEST_INFO_FUNCTIONS #include "wx/utils.h" #if TEST_INTERACTIVE static void TestDiskInfo() { wxPuts(wxT("*** Testing wxGetDiskSpace() ***")); for ( ;; ) { wxChar pathname[128]; wxPrintf(wxT("\nEnter a directory name: ")); if ( !wxFgets(pathname, WXSIZEOF(pathname), stdin) ) break; // kill the last '\n' pathname[wxStrlen(pathname) - 1] = 0; wxLongLong total, free; if ( !wxGetDiskSpace(pathname, &total, &free) ) { wxPuts(wxT("ERROR: wxGetDiskSpace failed.")); } else { wxPrintf(wxT("%sKb total, %sKb free on '%s'.\n"), (total / 1024).ToString().c_str(), (free / 1024).ToString().c_str(), pathname); } } } #endif // TEST_INTERACTIVE static void TestOsInfo() { wxPuts(wxT("*** Testing OS info functions ***\n")); int major, minor; wxGetOsVersion(&major, &minor); wxPrintf(wxT("Running under: %s, version %d.%d\n"), wxGetOsDescription().c_str(), major, minor); wxPrintf(wxT("%ld free bytes of memory left.\n"), wxGetFreeMemory().ToLong()); wxPrintf(wxT("Host name is %s (%s).\n"), wxGetHostName().c_str(), wxGetFullHostName().c_str()); wxPuts(wxEmptyString); } static void TestPlatformInfo() { wxPuts(wxT("*** Testing wxPlatformInfo functions ***\n")); // get this platform wxPlatformInfo plat; wxPrintf(wxT("Operating system family name is: %s\n"), plat.GetOperatingSystemFamilyName().c_str()); wxPrintf(wxT("Operating system name is: %s\n"), plat.GetOperatingSystemIdName().c_str()); wxPrintf(wxT("Port ID name is: %s\n"), plat.GetPortIdName().c_str()); wxPrintf(wxT("Port ID short name is: %s\n"), plat.GetPortIdShortName().c_str()); wxPrintf(wxT("Architecture is: %s\n"), plat.GetArchName().c_str()); wxPrintf(wxT("Endianness is: %s\n"), plat.GetEndiannessName().c_str()); wxPuts(wxEmptyString); } static void TestUserInfo() { wxPuts(wxT("*** Testing user info functions ***\n")); wxPrintf(wxT("User id is:\t%s\n"), wxGetUserId().c_str()); wxPrintf(wxT("User name is:\t%s\n"), wxGetUserName().c_str()); wxPrintf(wxT("Home dir is:\t%s\n"), wxGetHomeDir().c_str()); wxPrintf(wxT("Email address:\t%s\n"), wxGetEmailAddress().c_str()); wxPuts(wxEmptyString); } #endif // TEST_INFO_FUNCTIONS // ---------------------------------------------------------------------------- // path list // ---------------------------------------------------------------------------- #ifdef TEST_PATHLIST #ifdef __UNIX__ #define CMD_IN_PATH wxT("ls") #else #define CMD_IN_PATH wxT("command.com") #endif static void TestPathList() { wxPuts(wxT("*** Testing wxPathList ***\n")); wxPathList pathlist; pathlist.AddEnvList(wxT("PATH")); wxString path = pathlist.FindValidPath(CMD_IN_PATH); if ( path.empty() ) { wxPrintf(wxT("ERROR: command not found in the path.\n")); } else { wxPrintf(wxT("Command found in the path as '%s'.\n"), path.c_str()); } } #endif // TEST_PATHLIST // ---------------------------------------------------------------------------- // regular expressions // ---------------------------------------------------------------------------- #if defined TEST_REGEX && TEST_INTERACTIVE #include "wx/regex.h" static void TestRegExInteractive() { wxPuts(wxT("*** Testing RE interactively ***")); for ( ;; ) { wxChar pattern[128]; wxPrintf(wxT("\nEnter a pattern: ")); if ( !wxFgets(pattern, WXSIZEOF(pattern), stdin) ) break; // kill the last '\n' pattern[wxStrlen(pattern) - 1] = 0; wxRegEx re; if ( !re.Compile(pattern) ) { continue; } wxChar text[128]; for ( ;; ) { wxPrintf(wxT("Enter text to match: ")); if ( !wxFgets(text, WXSIZEOF(text), stdin) ) break; // kill the last '\n' text[wxStrlen(text) - 1] = 0; if ( !re.Matches(text) ) { wxPrintf(wxT("No match.\n")); } else { wxPrintf(wxT("Pattern matches at '%s'\n"), re.GetMatch(text).c_str()); size_t start, len; for ( size_t n = 1; ; n++ ) { if ( !re.GetMatch(&start, &len, n) ) { break; } wxPrintf(wxT("Subexpr %u matched '%s'\n"), n, wxString(text + start, len).c_str()); } } } } } #endif // TEST_REGEX // ---------------------------------------------------------------------------- // printf() tests // ---------------------------------------------------------------------------- /* NB: this stuff was taken from the glibc test suite and modified to build in wxWidgets: if I read the copyright below properly, this shouldn't be a problem */ #ifdef TEST_PRINTF #ifdef wxTEST_PRINTF // use our functions from wxchar.cpp #undef wxPrintf #undef wxSprintf // NB: do _not_ use WX_ATTRIBUTE_PRINTF here, we have some invalid formats // in the tests below int wxPrintf( const wxChar *format, ... ); int wxSprintf( wxChar *str, const wxChar *format, ... ); #endif #include "wx/longlong.h" #include static void rfg1 (void); static void rfg2 (void); static void fmtchk (const wxChar *fmt) { (void) wxPrintf(wxT("%s:\t`"), fmt); (void) wxPrintf(fmt, 0x12); (void) wxPrintf(wxT("'\n")); } static void fmtst1chk (const wxChar *fmt) { (void) wxPrintf(wxT("%s:\t`"), fmt); (void) wxPrintf(fmt, 4, 0x12); (void) wxPrintf(wxT("'\n")); } static void fmtst2chk (const wxChar *fmt) { (void) wxPrintf(wxT("%s:\t`"), fmt); (void) wxPrintf(fmt, 4, 4, 0x12); (void) wxPrintf(wxT("'\n")); } /* This page is covered by the following copyright: */ /* (C) Copyright C E Chew * * Feel free to copy, use and distribute this software provided: * * 1. you do not pretend that you wrote it * 2. you leave this copyright notice intact. */ /* * Extracted from exercise.c for glibc-1.05 bug report by Bruce Evans. */ #define DEC -123 #define INT 255 #define UNS (~0) /* Formatted Output Test * * This exercises the output formatting code. */ wxChar *PointerNull = NULL; static void fp_test (void) { int i, j, k, l; wxChar buf[7]; wxChar *prefix = buf; wxChar tp[20]; wxPuts(wxT("\nFormatted output test")); wxPrintf(wxT("prefix 6d 6o 6x 6X 6u\n")); wxStrcpy(prefix, wxT("%")); for (i = 0; i < 2; i++) { for (j = 0; j < 2; j++) { for (k = 0; k < 2; k++) { for (l = 0; l < 2; l++) { wxStrcpy(prefix, wxT("%")); if (i == 0) wxStrcat(prefix, wxT("-")); if (j == 0) wxStrcat(prefix, wxT("+")); if (k == 0) wxStrcat(prefix, wxT("#")); if (l == 0) wxStrcat(prefix, wxT("0")); wxPrintf(wxT("%5s |"), prefix); wxStrcpy(tp, prefix); wxStrcat(tp, wxT("6d |")); wxPrintf(tp, DEC); wxStrcpy(tp, prefix); wxStrcat(tp, wxT("6o |")); wxPrintf(tp, INT); wxStrcpy(tp, prefix); wxStrcat(tp, wxT("6x |")); wxPrintf(tp, INT); wxStrcpy(tp, prefix); wxStrcat(tp, wxT("6X |")); wxPrintf(tp, INT); wxStrcpy(tp, prefix); wxStrcat(tp, wxT("6u |")); wxPrintf(tp, UNS); wxPrintf(wxT("\n")); } } } } wxPrintf(wxT("%10s\n"), PointerNull); wxPrintf(wxT("%-10s\n"), PointerNull); } static void TestPrintf() { static wxChar shortstr[] = wxT("Hi, Z."); static wxChar longstr[] = wxT("Good morning, Doctor Chandra. This is Hal. \ I am ready for my first lesson today."); int result = 0; wxString test_format; fmtchk(wxT("%.4x")); fmtchk(wxT("%04x")); fmtchk(wxT("%4.4x")); fmtchk(wxT("%04.4x")); fmtchk(wxT("%4.3x")); fmtchk(wxT("%04.3x")); fmtst1chk(wxT("%.*x")); fmtst1chk(wxT("%0*x")); fmtst2chk(wxT("%*.*x")); fmtst2chk(wxT("%0*.*x")); wxString bad_format = wxT("bad format:\t\"%b\"\n"); wxPrintf(bad_format.c_str()); wxPrintf(wxT("nil pointer (padded):\t\"%10p\"\n"), (void *) NULL); wxPrintf(wxT("decimal negative:\t\"%d\"\n"), -2345); wxPrintf(wxT("octal negative:\t\"%o\"\n"), -2345); wxPrintf(wxT("hex negative:\t\"%x\"\n"), -2345); wxPrintf(wxT("long decimal number:\t\"%ld\"\n"), -123456L); wxPrintf(wxT("long octal negative:\t\"%lo\"\n"), -2345L); wxPrintf(wxT("long unsigned decimal number:\t\"%lu\"\n"), -123456L); wxPrintf(wxT("zero-padded LDN:\t\"%010ld\"\n"), -123456L); test_format = wxT("left-adjusted ZLDN:\t\"%-010ld\"\n"); wxPrintf(test_format.c_str(), -123456); wxPrintf(wxT("space-padded LDN:\t\"%10ld\"\n"), -123456L); wxPrintf(wxT("left-adjusted SLDN:\t\"%-10ld\"\n"), -123456L); test_format = wxT("zero-padded string:\t\"%010s\"\n"); wxPrintf(test_format.c_str(), shortstr); test_format = wxT("left-adjusted Z string:\t\"%-010s\"\n"); wxPrintf(test_format.c_str(), shortstr); wxPrintf(wxT("space-padded string:\t\"%10s\"\n"), shortstr); wxPrintf(wxT("left-adjusted S string:\t\"%-10s\"\n"), shortstr); wxPrintf(wxT("null string:\t\"%s\"\n"), PointerNull); wxPrintf(wxT("limited string:\t\"%.22s\"\n"), longstr); wxPrintf(wxT("e-style >= 1:\t\"%e\"\n"), 12.34); wxPrintf(wxT("e-style >= .1:\t\"%e\"\n"), 0.1234); wxPrintf(wxT("e-style < .1:\t\"%e\"\n"), 0.001234); wxPrintf(wxT("e-style big:\t\"%.60e\"\n"), 1e20); wxPrintf(wxT("e-style == .1:\t\"%e\"\n"), 0.1); wxPrintf(wxT("f-style >= 1:\t\"%f\"\n"), 12.34); wxPrintf(wxT("f-style >= .1:\t\"%f\"\n"), 0.1234); wxPrintf(wxT("f-style < .1:\t\"%f\"\n"), 0.001234); wxPrintf(wxT("g-style >= 1:\t\"%g\"\n"), 12.34); wxPrintf(wxT("g-style >= .1:\t\"%g\"\n"), 0.1234); wxPrintf(wxT("g-style < .1:\t\"%g\"\n"), 0.001234); wxPrintf(wxT("g-style big:\t\"%.60g\"\n"), 1e20); wxPrintf (wxT(" %6.5f\n"), .099999999860301614); wxPrintf (wxT(" %6.5f\n"), .1); wxPrintf (wxT("x%5.4fx\n"), .5); wxPrintf (wxT("%#03x\n"), 1); //wxPrintf (wxT("something really insane: %.10000f\n"), 1.0); { double d = FLT_MIN; int niter = 17; while (niter-- != 0) wxPrintf (wxT("%.17e\n"), d / 2); fflush (stdout); } #ifndef __WATCOMC__ // Open Watcom cause compiler error here // Error! E173: col(24) floating-point constant too small to represent wxPrintf (wxT("%15.5e\n"), 4.9406564584124654e-324); #endif #define FORMAT wxT("|%12.4f|%12.4e|%12.4g|\n") wxPrintf (FORMAT, 0.0, 0.0, 0.0); wxPrintf (FORMAT, 1.0, 1.0, 1.0); wxPrintf (FORMAT, -1.0, -1.0, -1.0); wxPrintf (FORMAT, 100.0, 100.0, 100.0); wxPrintf (FORMAT, 1000.0, 1000.0, 1000.0); wxPrintf (FORMAT, 10000.0, 10000.0, 10000.0); wxPrintf (FORMAT, 12345.0, 12345.0, 12345.0); wxPrintf (FORMAT, 100000.0, 100000.0, 100000.0); wxPrintf (FORMAT, 123456.0, 123456.0, 123456.0); #undef FORMAT { wxChar buf[20]; int rc = wxSnprintf (buf, WXSIZEOF(buf), wxT("%30s"), wxT("foo")); wxPrintf(wxT("snprintf (\"%%30s\", \"foo\") == %d, \"%.*s\"\n"), rc, WXSIZEOF(buf), buf); #if 0 wxChar buf2[512]; wxPrintf ("snprintf (\"%%.999999u\", 10)\n", wxSnprintf(buf2, WXSIZEOFbuf2), "%.999999u", 10)); #endif } fp_test (); wxPrintf (wxT("%e should be 1.234568e+06\n"), 1234567.8); wxPrintf (wxT("%f should be 1234567.800000\n"), 1234567.8); wxPrintf (wxT("%g should be 1.23457e+06\n"), 1234567.8); wxPrintf (wxT("%g should be 123.456\n"), 123.456); wxPrintf (wxT("%g should be 1e+06\n"), 1000000.0); wxPrintf (wxT("%g should be 10\n"), 10.0); wxPrintf (wxT("%g should be 0.02\n"), 0.02); { double x=1.0; wxPrintf(wxT("%.17f\n"),(1.0/x/10.0+1.0)*x-x); } { wxChar buf[200]; wxSprintf(buf,wxT("%*s%*s%*s"),-1,wxT("one"),-20,wxT("two"),-30,wxT("three")); result |= wxStrcmp (buf, wxT("onetwo three ")); wxPuts (result != 0 ? wxT("Test failed!") : wxT("Test ok.")); } #ifdef wxLongLong_t { wxChar buf[200]; wxSprintf(buf, "%07" wxLongLongFmtSpec "o", wxLL(040000000000)); #if 0 // for some reason below line fails under Borland wxPrintf (wxT("sprintf (buf, \"%%07Lo\", 040000000000ll) = %s"), buf); #endif if (wxStrcmp (buf, wxT("40000000000")) != 0) { result = 1; wxPuts (wxT("\tFAILED")); } wxUnusedVar(result); wxPuts (wxEmptyString); } #endif // wxLongLong_t wxPrintf (wxT("printf (\"%%hhu\", %u) = %hhu\n"), UCHAR_MAX + 2, UCHAR_MAX + 2); wxPrintf (wxT("printf (\"%%hu\", %u) = %hu\n"), USHRT_MAX + 2, USHRT_MAX + 2); wxPuts (wxT("--- Should be no further output. ---")); rfg1 (); rfg2 (); #if 0 { wxChar bytes[7]; wxChar buf[20]; memset (bytes, '\xff', sizeof bytes); wxSprintf (buf, wxT("foo%hhn\n"), &bytes[3]); if (bytes[0] != '\xff' || bytes[1] != '\xff' || bytes[2] != '\xff' || bytes[4] != '\xff' || bytes[5] != '\xff' || bytes[6] != '\xff') { wxPuts (wxT("%hhn overwrite more bytes")); result = 1; } if (bytes[3] != 3) { wxPuts (wxT("%hhn wrote incorrect value")); result = 1; } } #endif } static void rfg1 (void) { wxChar buf[100]; wxSprintf (buf, wxT("%5.s"), wxT("xyz")); if (wxStrcmp (buf, wxT(" ")) != 0) wxPrintf (wxT("got: '%s', expected: '%s'\n"), buf, wxT(" ")); wxSprintf (buf, wxT("%5.f"), 33.3); if (wxStrcmp (buf, wxT(" 33")) != 0) wxPrintf (wxT("got: '%s', expected: '%s'\n"), buf, wxT(" 33")); wxSprintf (buf, wxT("%8.e"), 33.3e7); if (wxStrcmp (buf, wxT(" 3e+08")) != 0) wxPrintf (wxT("got: '%s', expected: '%s'\n"), buf, wxT(" 3e+08")); wxSprintf (buf, wxT("%8.E"), 33.3e7); if (wxStrcmp (buf, wxT(" 3E+08")) != 0) wxPrintf (wxT("got: '%s', expected: '%s'\n"), buf, wxT(" 3E+08")); wxSprintf (buf, wxT("%.g"), 33.3); if (wxStrcmp (buf, wxT("3e+01")) != 0) wxPrintf (wxT("got: '%s', expected: '%s'\n"), buf, wxT("3e+01")); wxSprintf (buf, wxT("%.G"), 33.3); if (wxStrcmp (buf, wxT("3E+01")) != 0) wxPrintf (wxT("got: '%s', expected: '%s'\n"), buf, wxT("3E+01")); } static void rfg2 (void) { int prec; wxChar buf[100]; wxString test_format; prec = 0; wxSprintf (buf, wxT("%.*g"), prec, 3.3); if (wxStrcmp (buf, wxT("3")) != 0) wxPrintf (wxT("got: '%s', expected: '%s'\n"), buf, wxT("3")); prec = 0; wxSprintf (buf, wxT("%.*G"), prec, 3.3); if (wxStrcmp (buf, wxT("3")) != 0) wxPrintf (wxT("got: '%s', expected: '%s'\n"), buf, wxT("3")); prec = 0; wxSprintf (buf, wxT("%7.*G"), prec, 3.33); if (wxStrcmp (buf, wxT(" 3")) != 0) wxPrintf (wxT("got: '%s', expected: '%s'\n"), buf, wxT(" 3")); prec = 3; test_format = wxT("%04.*o"); wxSprintf (buf, test_format.c_str(), prec, 33); if (wxStrcmp (buf, wxT(" 041")) != 0) wxPrintf (wxT("got: '%s', expected: '%s'\n"), buf, wxT(" 041")); prec = 7; test_format = wxT("%09.*u"); wxSprintf (buf, test_format.c_str(), prec, 33); if (wxStrcmp (buf, wxT(" 0000033")) != 0) wxPrintf (wxT("got: '%s', expected: '%s'\n"), buf, wxT(" 0000033")); prec = 3; test_format = wxT("%04.*x"); wxSprintf (buf, test_format.c_str(), prec, 33); if (wxStrcmp (buf, wxT(" 021")) != 0) wxPrintf (wxT("got: '%s', expected: '%s'\n"), buf, wxT(" 021")); prec = 3; test_format = wxT("%04.*X"); wxSprintf (buf, test_format.c_str(), prec, 33); if (wxStrcmp (buf, wxT(" 021")) != 0) wxPrintf (wxT("got: '%s', expected: '%s'\n"), buf, wxT(" 021")); } #endif // TEST_PRINTF // ---------------------------------------------------------------------------- // registry and related stuff // ---------------------------------------------------------------------------- // this is for MSW only #ifndef __WXMSW__ #undef TEST_REGCONF #undef TEST_REGISTRY #endif #ifdef TEST_REGCONF #include "wx/confbase.h" #include "wx/msw/regconf.h" #if 0 static void TestRegConfWrite() { wxConfig *config = new wxConfig(wxT("myapp")); config->SetPath(wxT("/group1")); config->Write(wxT("entry1"), wxT("foo")); config->SetPath(wxT("/group2")); config->Write(wxT("entry1"), wxT("bar")); } #endif static void TestRegConfRead() { wxRegConfig *config = new wxRegConfig(wxT("myapp")); wxString str; long dummy; config->SetPath(wxT("/")); wxPuts(wxT("Enumerating / subgroups:")); bool bCont = config->GetFirstGroup(str, dummy); while(bCont) { wxPuts(str); bCont = config->GetNextGroup(str, dummy); } } #endif // TEST_REGCONF #ifdef TEST_REGISTRY #include "wx/msw/registry.h" // I chose this one because I liked its name, but it probably only exists under // NT static const wxChar *TESTKEY = wxT("HKEY_LOCAL_MACHINE\\SYSTEM\\ControlSet001\\Control\\CrashControl"); static void TestRegistryRead() { wxPuts(wxT("*** testing registry reading ***")); wxRegKey key(TESTKEY); wxPrintf(wxT("The test key name is '%s'.\n"), key.GetName().c_str()); if ( !key.Open() ) { wxPuts(wxT("ERROR: test key can't be opened, aborting test.")); return; } size_t nSubKeys, nValues; if ( key.GetKeyInfo(&nSubKeys, NULL, &nValues, NULL) ) { wxPrintf(wxT("It has %u subkeys and %u values.\n"), nSubKeys, nValues); } wxPrintf(wxT("Enumerating values:\n")); long dummy; wxString value; bool cont = key.GetFirstValue(value, dummy); while ( cont ) { wxPrintf(wxT("Value '%s': type "), value.c_str()); switch ( key.GetValueType(value) ) { case wxRegKey::Type_None: wxPrintf(wxT("ERROR (none)")); break; case wxRegKey::Type_String: wxPrintf(wxT("SZ")); break; case wxRegKey::Type_Expand_String: wxPrintf(wxT("EXPAND_SZ")); break; case wxRegKey::Type_Binary: wxPrintf(wxT("BINARY")); break; case wxRegKey::Type_Dword: wxPrintf(wxT("DWORD")); break; case wxRegKey::Type_Multi_String: wxPrintf(wxT("MULTI_SZ")); break; default: wxPrintf(wxT("other (unknown)")); break; } wxPrintf(wxT(", value = ")); if ( key.IsNumericValue(value) ) { long val; key.QueryValue(value, &val); wxPrintf(wxT("%ld"), val); } else // string { wxString val; key.QueryValue(value, val); wxPrintf(wxT("'%s'"), val.c_str()); key.QueryRawValue(value, val); wxPrintf(wxT(" (raw value '%s')"), val.c_str()); } wxPutchar('\n'); cont = key.GetNextValue(value, dummy); } } static void TestRegistryAssociation() { /* The second call to deleteself genertaes an error message, with a messagebox saying .flo is crucial to system operation, while the .ddf call also fails, but with no error message */ wxRegKey key; key.SetName(wxT("HKEY_CLASSES_ROOT\\.ddf") ); key.Create(); key = wxT("ddxf_auto_file") ; key.SetName(wxT("HKEY_CLASSES_ROOT\\.flo") ); key.Create(); key = wxT("ddxf_auto_file") ; key.SetName(wxT("HKEY_CLASSES_ROOT\\ddxf_auto_file\\DefaultIcon")); key.Create(); key = wxT("program,0") ; key.SetName(wxT("HKEY_CLASSES_ROOT\\ddxf_auto_file\\shell\\open\\command")); key.Create(); key = wxT("program \"%1\"") ; key.SetName(wxT("HKEY_CLASSES_ROOT\\.ddf") ); key.DeleteSelf(); key.SetName(wxT("HKEY_CLASSES_ROOT\\.flo") ); key.DeleteSelf(); key.SetName(wxT("HKEY_CLASSES_ROOT\\ddxf_auto_file\\DefaultIcon")); key.DeleteSelf(); key.SetName(wxT("HKEY_CLASSES_ROOT\\ddxf_auto_file\\shell\\open\\command")); key.DeleteSelf(); } #endif // TEST_REGISTRY // ---------------------------------------------------------------------------- // scope guard // ---------------------------------------------------------------------------- #ifdef TEST_SCOPEGUARD #include "wx/scopeguard.h" static void function0() { puts("function0()"); } static void function1(int n) { printf("function1(%d)\n", n); } static void function2(double x, char c) { printf("function2(%g, %c)\n", x, c); } struct Object { void method0() { printf("method0()\n"); } void method1(int n) { printf("method1(%d)\n", n); } void method2(double x, char c) { printf("method2(%g, %c)\n", x, c); } }; static void TestScopeGuard() { wxON_BLOCK_EXIT0(function0); wxON_BLOCK_EXIT1(function1, 17); wxON_BLOCK_EXIT2(function2, 3.14, 'p'); Object obj; wxON_BLOCK_EXIT_OBJ0(obj, Object::method0); wxON_BLOCK_EXIT_OBJ1(obj, Object::method1, 7); wxON_BLOCK_EXIT_OBJ2(obj, Object::method2, 2.71, 'e'); wxScopeGuard dismissed = wxMakeGuard(function0); dismissed.Dismiss(); } #endif // ---------------------------------------------------------------------------- // sockets // ---------------------------------------------------------------------------- #ifdef TEST_SOCKETS #include "wx/socket.h" #include "wx/protocol/protocol.h" #include "wx/protocol/http.h" static void TestSocketServer() { wxPuts(wxT("*** Testing wxSocketServer ***\n")); static const int PORT = 3000; wxIPV4address addr; addr.Service(PORT); wxSocketServer *server = new wxSocketServer(addr); if ( !server->Ok() ) { wxPuts(wxT("ERROR: failed to bind")); return; } bool quit = false; while ( !quit ) { wxPrintf(wxT("Server: waiting for connection on port %d...\n"), PORT); wxSocketBase *socket = server->Accept(); if ( !socket ) { wxPuts(wxT("ERROR: wxSocketServer::Accept() failed.")); break; } wxPuts(wxT("Server: got a client.")); server->SetTimeout(60); // 1 min bool close = false; while ( !close && socket->IsConnected() ) { wxString s; wxChar ch = wxT('\0'); for ( ;; ) { if ( socket->Read(&ch, sizeof(ch)).Error() ) { // don't log error if the client just close the connection if ( socket->IsConnected() ) { wxPuts(wxT("ERROR: in wxSocket::Read.")); } break; } if ( ch == '\r' ) continue; if ( ch == '\n' ) break; s += ch; } if ( ch != '\n' ) { break; } wxPrintf(wxT("Server: got '%s'.\n"), s.c_str()); if ( s == wxT("close") ) { wxPuts(wxT("Closing connection")); close = true; } else if ( s == wxT("quit") ) { close = quit = true; wxPuts(wxT("Shutting down the server")); } else // not a special command { socket->Write(s.MakeUpper().c_str(), s.length()); socket->Write("\r\n", 2); wxPrintf(wxT("Server: wrote '%s'.\n"), s.c_str()); } } if ( !close ) { wxPuts(wxT("Server: lost a client unexpectedly.")); } socket->Destroy(); } // same as "delete server" but is consistent with GUI programs server->Destroy(); } static void TestSocketClient() { wxPuts(wxT("*** Testing wxSocketClient ***\n")); static const wxChar *hostname = wxT("www.wxwidgets.org"); wxIPV4address addr; addr.Hostname(hostname); addr.Service(80); wxPrintf(wxT("--- Attempting to connect to %s:80...\n"), hostname); wxSocketClient client; if ( !client.Connect(addr) ) { wxPrintf(wxT("ERROR: failed to connect to %s\n"), hostname); } else { wxPrintf(wxT("--- Connected to %s:%u...\n"), addr.Hostname().c_str(), addr.Service()); wxChar buf[8192]; // could use simply "GET" here I suppose wxString cmdGet = wxString::Format(wxT("GET http://%s/\r\n"), hostname); client.Write(cmdGet, cmdGet.length()); wxPrintf(wxT("--- Sent command '%s' to the server\n"), MakePrintable(cmdGet).c_str()); client.Read(buf, WXSIZEOF(buf)); wxPrintf(wxT("--- Server replied:\n%s"), buf); } } #endif // TEST_SOCKETS // ---------------------------------------------------------------------------- // FTP // ---------------------------------------------------------------------------- #ifdef TEST_FTP #include "wx/protocol/ftp.h" #include "wx/protocol/log.h" #define FTP_ANONYMOUS static wxFTP *ftp; #ifdef FTP_ANONYMOUS static const wxChar *directory = wxT("/pub"); static const wxChar *filename = wxT("welcome.msg"); #else static const wxChar *directory = wxT("/etc"); static const wxChar *filename = wxT("issue"); #endif static bool TestFtpConnect() { wxPuts(wxT("*** Testing FTP connect ***")); #ifdef FTP_ANONYMOUS static const wxChar *hostname = wxT("ftp.wxwidgets.org"); wxPrintf(wxT("--- Attempting to connect to %s:21 anonymously...\n"), hostname); #else // !FTP_ANONYMOUS static const wxChar *hostname = "localhost"; wxChar user[256]; wxFgets(user, WXSIZEOF(user), stdin); user[wxStrlen(user) - 1] = '\0'; // chop off '\n' ftp->SetUser(user); wxChar password[256]; wxPrintf(wxT("Password for %s: "), password); wxFgets(password, WXSIZEOF(password), stdin); password[wxStrlen(password) - 1] = '\0'; // chop off '\n' ftp->SetPassword(password); wxPrintf(wxT("--- Attempting to connect to %s:21 as %s...\n"), hostname, user); #endif // FTP_ANONYMOUS/!FTP_ANONYMOUS if ( !ftp->Connect(hostname) ) { wxPrintf(wxT("ERROR: failed to connect to %s\n"), hostname); return false; } else { wxPrintf(wxT("--- Connected to %s, current directory is '%s'\n"), hostname, ftp->Pwd().c_str()); ftp->Close(); } return true; } static void TestFtpList() { wxPuts(wxT("*** Testing wxFTP file listing ***\n")); // test CWD if ( !ftp->ChDir(directory) ) { wxPrintf(wxT("ERROR: failed to cd to %s\n"), directory); } wxPrintf(wxT("Current directory is '%s'\n"), ftp->Pwd().c_str()); // test NLIST and LIST wxArrayString files; if ( !ftp->GetFilesList(files) ) { wxPuts(wxT("ERROR: failed to get NLIST of files")); } else { wxPrintf(wxT("Brief list of files under '%s':\n"), ftp->Pwd().c_str()); size_t count = files.GetCount(); for ( size_t n = 0; n < count; n++ ) { wxPrintf(wxT("\t%s\n"), files[n].c_str()); } wxPuts(wxT("End of the file list")); } if ( !ftp->GetDirList(files) ) { wxPuts(wxT("ERROR: failed to get LIST of files")); } else { wxPrintf(wxT("Detailed list of files under '%s':\n"), ftp->Pwd().c_str()); size_t count = files.GetCount(); for ( size_t n = 0; n < count; n++ ) { wxPrintf(wxT("\t%s\n"), files[n].c_str()); } wxPuts(wxT("End of the file list")); } if ( !ftp->ChDir(wxT("..")) ) { wxPuts(wxT("ERROR: failed to cd to ..")); } wxPrintf(wxT("Current directory is '%s'\n"), ftp->Pwd().c_str()); } static void TestFtpDownload() { wxPuts(wxT("*** Testing wxFTP download ***\n")); // test RETR wxInputStream *in = ftp->GetInputStream(filename); if ( !in ) { wxPrintf(wxT("ERROR: couldn't get input stream for %s\n"), filename); } else { size_t size = in->GetSize(); wxPrintf(wxT("Reading file %s (%u bytes)..."), filename, size); fflush(stdout); wxChar *data = new wxChar[size]; if ( !in->Read(data, size) ) { wxPuts(wxT("ERROR: read error")); } else { wxPrintf(wxT("\nContents of %s:\n%s\n"), filename, data); } delete [] data; delete in; } } static void TestFtpFileSize() { wxPuts(wxT("*** Testing FTP SIZE command ***")); if ( !ftp->ChDir(directory) ) { wxPrintf(wxT("ERROR: failed to cd to %s\n"), directory); } wxPrintf(wxT("Current directory is '%s'\n"), ftp->Pwd().c_str()); if ( ftp->FileExists(filename) ) { int size = ftp->GetFileSize(filename); if ( size == -1 ) wxPrintf(wxT("ERROR: couldn't get size of '%s'\n"), filename); else wxPrintf(wxT("Size of '%s' is %d bytes.\n"), filename, size); } else { wxPrintf(wxT("ERROR: '%s' doesn't exist\n"), filename); } } static void TestFtpMisc() { wxPuts(wxT("*** Testing miscellaneous wxFTP functions ***")); if ( ftp->SendCommand(wxT("STAT")) != '2' ) { wxPuts(wxT("ERROR: STAT failed")); } else { wxPrintf(wxT("STAT returned:\n\n%s\n"), ftp->GetLastResult().c_str()); } if ( ftp->SendCommand(wxT("HELP SITE")) != '2' ) { wxPuts(wxT("ERROR: HELP SITE failed")); } else { wxPrintf(wxT("The list of site-specific commands:\n\n%s\n"), ftp->GetLastResult().c_str()); } } #if TEST_INTERACTIVE static void TestFtpInteractive() { wxPuts(wxT("\n*** Interactive wxFTP test ***")); wxChar buf[128]; for ( ;; ) { wxPrintf(wxT("Enter FTP command: ")); if ( !wxFgets(buf, WXSIZEOF(buf), stdin) ) break; // kill the last '\n' buf[wxStrlen(buf) - 1] = 0; // special handling of LIST and NLST as they require data connection wxString start(buf, 4); start.MakeUpper(); if ( start == wxT("LIST") || start == wxT("NLST") ) { wxString wildcard; if ( wxStrlen(buf) > 4 ) wildcard = buf + 5; wxArrayString files; if ( !ftp->GetList(files, wildcard, start == wxT("LIST")) ) { wxPrintf(wxT("ERROR: failed to get %s of files\n"), start.c_str()); } else { wxPrintf(wxT("--- %s of '%s' under '%s':\n"), start.c_str(), wildcard.c_str(), ftp->Pwd().c_str()); size_t count = files.GetCount(); for ( size_t n = 0; n < count; n++ ) { wxPrintf(wxT("\t%s\n"), files[n].c_str()); } wxPuts(wxT("--- End of the file list")); } } else // !list { wxChar ch = ftp->SendCommand(buf); wxPrintf(wxT("Command %s"), ch ? wxT("succeeded") : wxT("failed")); if ( ch ) { wxPrintf(wxT(" (return code %c)"), ch); } wxPrintf(wxT(", server reply:\n%s\n\n"), ftp->GetLastResult().c_str()); } } wxPuts(wxT("\n*** done ***")); } #endif // TEST_INTERACTIVE static void TestFtpUpload() { wxPuts(wxT("*** Testing wxFTP uploading ***\n")); // upload a file static const wxChar *file1 = wxT("test1"); static const wxChar *file2 = wxT("test2"); wxOutputStream *out = ftp->GetOutputStream(file1); if ( out ) { wxPrintf(wxT("--- Uploading to %s ---\n"), file1); out->Write("First hello", 11); delete out; } // send a command to check the remote file if ( ftp->SendCommand(wxString(wxT("STAT ")) + file1) != '2' ) { wxPrintf(wxT("ERROR: STAT %s failed\n"), file1); } else { wxPrintf(wxT("STAT %s returned:\n\n%s\n"), file1, ftp->GetLastResult().c_str()); } out = ftp->GetOutputStream(file2); if ( out ) { wxPrintf(wxT("--- Uploading to %s ---\n"), file1); out->Write("Second hello", 12); delete out; } } #endif // TEST_FTP // ---------------------------------------------------------------------------- // stack backtrace // ---------------------------------------------------------------------------- #ifdef TEST_STACKWALKER #if wxUSE_STACKWALKER #include "wx/stackwalk.h" class StackDump : public wxStackWalker { public: StackDump(const char *argv0) : wxStackWalker(argv0) { } virtual void Walk(size_t skip = 1, size_t maxdepth = wxSTACKWALKER_MAX_DEPTH) { wxPuts(wxT("Stack dump:")); wxStackWalker::Walk(skip, maxdepth); } protected: virtual void OnStackFrame(const wxStackFrame& frame) { printf("[%2d] ", (int) frame.GetLevel()); wxString name = frame.GetName(); if ( !name.empty() ) { printf("%-20.40s", (const char*)name.mb_str()); } else { printf("0x%08lx", (unsigned long)frame.GetAddress()); } if ( frame.HasSourceLocation() ) { printf("\t%s:%d", (const char*)frame.GetFileName().mb_str(), (int)frame.GetLine()); } puts(""); wxString type, val; for ( size_t n = 0; frame.GetParam(n, &type, &name, &val); n++ ) { printf("\t%s %s = %s\n", (const char*)type.mb_str(), (const char*)name.mb_str(), (const char*)val.mb_str()); } } }; static void TestStackWalk(const char *argv0) { wxPuts(wxT("*** Testing wxStackWalker ***\n")); StackDump dump(argv0); dump.Walk(); } #endif // wxUSE_STACKWALKER #endif // TEST_STACKWALKER // ---------------------------------------------------------------------------- // standard paths // ---------------------------------------------------------------------------- #ifdef TEST_STDPATHS #include "wx/stdpaths.h" #include "wx/wxchar.h" // wxPrintf static void TestStandardPaths() { wxPuts(wxT("*** Testing wxStandardPaths ***\n")); wxTheApp->SetAppName(wxT("console")); wxStandardPathsBase& stdp = wxStandardPaths::Get(); wxPrintf(wxT("Config dir (sys):\t%s\n"), stdp.GetConfigDir().c_str()); wxPrintf(wxT("Config dir (user):\t%s\n"), stdp.GetUserConfigDir().c_str()); wxPrintf(wxT("Data dir (sys):\t\t%s\n"), stdp.GetDataDir().c_str()); wxPrintf(wxT("Data dir (sys local):\t%s\n"), stdp.GetLocalDataDir().c_str()); wxPrintf(wxT("Data dir (user):\t%s\n"), stdp.GetUserDataDir().c_str()); wxPrintf(wxT("Data dir (user local):\t%s\n"), stdp.GetUserLocalDataDir().c_str()); wxPrintf(wxT("Documents dir:\t\t%s\n"), stdp.GetDocumentsDir().c_str()); wxPrintf(wxT("Executable path:\t%s\n"), stdp.GetExecutablePath().c_str()); wxPrintf(wxT("Plugins dir:\t\t%s\n"), stdp.GetPluginsDir().c_str()); wxPrintf(wxT("Resources dir:\t\t%s\n"), stdp.GetResourcesDir().c_str()); wxPrintf(wxT("Localized res. dir:\t%s\n"), stdp.GetLocalizedResourcesDir(wxT("fr")).c_str()); wxPrintf(wxT("Message catalogs dir:\t%s\n"), stdp.GetLocalizedResourcesDir ( wxT("fr"), wxStandardPaths::ResourceCat_Messages ).c_str()); } #endif // TEST_STDPATHS // ---------------------------------------------------------------------------- // wxVolume tests // ---------------------------------------------------------------------------- #if !defined(__WIN32__) || !wxUSE_FSVOLUME #undef TEST_VOLUME #endif #ifdef TEST_VOLUME #include "wx/volume.h" static const wxChar *volumeKinds[] = { wxT("floppy"), wxT("hard disk"), wxT("CD-ROM"), wxT("DVD-ROM"), wxT("network volume"), wxT("other volume"), }; static void TestFSVolume() { wxPuts(wxT("*** Testing wxFSVolume class ***")); wxArrayString volumes = wxFSVolume::GetVolumes(); size_t count = volumes.GetCount(); if ( !count ) { wxPuts(wxT("ERROR: no mounted volumes?")); return; } wxPrintf(wxT("%u mounted volumes found:\n"), count); for ( size_t n = 0; n < count; n++ ) { wxFSVolume vol(volumes[n]); if ( !vol.IsOk() ) { wxPuts(wxT("ERROR: couldn't create volume")); continue; } wxPrintf(wxT("%u: %s (%s), %s, %s, %s\n"), n + 1, vol.GetDisplayName().c_str(), vol.GetName().c_str(), volumeKinds[vol.GetKind()], vol.IsWritable() ? wxT("rw") : wxT("ro"), vol.GetFlags() & wxFS_VOL_REMOVABLE ? wxT("removable") : wxT("fixed")); } } #endif // TEST_VOLUME // ---------------------------------------------------------------------------- // date time // ---------------------------------------------------------------------------- #ifdef TEST_DATETIME #include "wx/math.h" #include "wx/datetime.h" #if TEST_INTERACTIVE static void TestDateTimeInteractive() { wxPuts(wxT("\n*** interactive wxDateTime tests ***")); wxChar buf[128]; for ( ;; ) { wxPrintf(wxT("Enter a date: ")); if ( !wxFgets(buf, WXSIZEOF(buf), stdin) ) break; // kill the last '\n' buf[wxStrlen(buf) - 1] = 0; wxDateTime dt; const wxChar *p = dt.ParseDate(buf); if ( !p ) { wxPrintf(wxT("ERROR: failed to parse the date '%s'.\n"), buf); continue; } else if ( *p ) { wxPrintf(wxT("WARNING: parsed only first %u characters.\n"), p - buf); } wxPrintf(wxT("%s: day %u, week of month %u/%u, week of year %u\n"), dt.Format(wxT("%b %d, %Y")).c_str(), dt.GetDayOfYear(), dt.GetWeekOfMonth(wxDateTime::Monday_First), dt.GetWeekOfMonth(wxDateTime::Sunday_First), dt.GetWeekOfYear(wxDateTime::Monday_First)); } wxPuts(wxT("\n*** done ***")); } #endif // TEST_INTERACTIVE #endif // TEST_DATETIME // ---------------------------------------------------------------------------- // entry point // ---------------------------------------------------------------------------- #ifdef TEST_SNGLINST #include "wx/snglinst.h" #endif // TEST_SNGLINST int main(int argc, char **argv) { #if wxUSE_UNICODE wxChar **wxArgv = new wxChar *[argc + 1]; { int n; for (n = 0; n < argc; n++ ) { wxMB2WXbuf warg = wxConvertMB2WX(argv[n]); wxArgv[n] = wxStrdup(warg); } wxArgv[n] = NULL; } #else // !wxUSE_UNICODE #define wxArgv argv #endif // wxUSE_UNICODE/!wxUSE_UNICODE wxApp::CheckBuildOptions(WX_BUILD_OPTIONS_SIGNATURE, "program"); wxInitializer initializer; if ( !initializer ) { fprintf(stderr, "Failed to initialize the wxWidgets library, aborting."); return -1; } #ifdef TEST_SNGLINST wxSingleInstanceChecker checker; if ( checker.Create(wxT(".wxconsole.lock")) ) { if ( checker.IsAnotherRunning() ) { wxPrintf(wxT("Another instance of the program is running, exiting.\n")); return 1; } // wait some time to give time to launch another instance wxPrintf(wxT("Press \"Enter\" to continue...")); wxFgetc(stdin); } else // failed to create { wxPrintf(wxT("Failed to init wxSingleInstanceChecker.\n")); } #endif // TEST_SNGLINST #ifdef TEST_CMDLINE TestCmdLineConvert(); #if wxUSE_CMDLINE_PARSER static const wxCmdLineEntryDesc cmdLineDesc[] = { { wxCMD_LINE_SWITCH, "h", "help", "show this help message", wxCMD_LINE_VAL_NONE, wxCMD_LINE_OPTION_HELP }, { wxCMD_LINE_SWITCH, "v", "verbose", "be verbose" }, { wxCMD_LINE_SWITCH, "q", "quiet", "be quiet" }, { wxCMD_LINE_OPTION, "o", "output", "output file" }, { wxCMD_LINE_OPTION, "i", "input", "input dir" }, { wxCMD_LINE_OPTION, "s", "size", "output block size", wxCMD_LINE_VAL_NUMBER }, { wxCMD_LINE_OPTION, "d", "date", "output file date", wxCMD_LINE_VAL_DATE }, { wxCMD_LINE_OPTION, "f", "double", "output double", wxCMD_LINE_VAL_DOUBLE }, { wxCMD_LINE_PARAM, NULL, NULL, "input file", wxCMD_LINE_VAL_STRING, wxCMD_LINE_PARAM_MULTIPLE }, { wxCMD_LINE_NONE } }; wxCmdLineParser parser(cmdLineDesc, argc, wxArgv); parser.AddOption(wxT("project_name"), wxT(""), wxT("full path to project file"), wxCMD_LINE_VAL_STRING, wxCMD_LINE_OPTION_MANDATORY | wxCMD_LINE_NEEDS_SEPARATOR); switch ( parser.Parse() ) { case -1: wxLogMessage(wxT("Help was given, terminating.")); break; case 0: ShowCmdLine(parser); break; default: wxLogMessage(wxT("Syntax error detected, aborting.")); break; } #endif // wxUSE_CMDLINE_PARSER #endif // TEST_CMDLINE #ifdef TEST_DIR #if TEST_ALL TestDirExists(); TestDirEnum(); #endif TestDirTraverse(); #endif // TEST_DIR #ifdef TEST_DYNLIB TestDllLoad(); TestDllListLoaded(); #endif // TEST_DYNLIB #ifdef TEST_ENVIRON TestEnvironment(); #endif // TEST_ENVIRON #ifdef TEST_FILECONF TestFileConfRead(); #endif // TEST_FILECONF #ifdef TEST_LOCALE TestDefaultLang(); #endif // TEST_LOCALE #ifdef TEST_LOG wxPuts(wxT("*** Testing wxLog ***")); wxString s; for ( size_t n = 0; n < 8000; n++ ) { s << (wxChar)(wxT('A') + (n % 26)); } wxLogWarning(wxT("The length of the string is %lu"), (unsigned long)s.length()); wxString msg; msg.Printf(wxT("A very very long message: '%s', the end!\n"), s.c_str()); // this one shouldn't be truncated wxPrintf(msg); // but this one will because log functions use fixed size buffer // (note that it doesn't need '\n' at the end neither - will be added // by wxLog anyhow) wxLogMessage(wxT("A very very long message 2: '%s', the end!"), s.c_str()); #endif // TEST_LOG #ifdef TEST_FILE TestFileRead(); TestTextFileRead(); TestFileCopy(); TestTempFile(); #endif // TEST_FILE #ifdef TEST_FILENAME TestFileNameTemp(); TestFileNameCwd(); TestFileNameDirManip(); TestFileNameComparison(); TestFileNameOperations(); #endif // TEST_FILENAME #ifdef TEST_FILETIME TestFileGetTimes(); #if 0 TestFileSetTimes(); #endif #endif // TEST_FILETIME #ifdef TEST_FTP wxLog::AddTraceMask(FTP_TRACE_MASK); // wxFTP cannot be a static variable as its ctor needs to access // wxWidgets internals after it has been initialized ftp = new wxFTP; ftp->SetLog(new wxProtocolLog(FTP_TRACE_MASK)); if ( TestFtpConnect() ) { #if TEST_ALL TestFtpList(); TestFtpDownload(); TestFtpMisc(); TestFtpFileSize(); TestFtpUpload(); #endif // TEST_ALL #if TEST_INTERACTIVE //TestFtpInteractive(); #endif } //else: connecting to the FTP server failed delete ftp; #endif // TEST_FTP #ifdef TEST_MIME //wxLog::AddTraceMask(wxT("mime")); TestMimeEnum(); #if 0 TestMimeOverride(); TestMimeAssociate(); #endif TestMimeFilename(); #endif // TEST_MIME #ifdef TEST_INFO_FUNCTIONS TestOsInfo(); TestPlatformInfo(); TestUserInfo(); #if TEST_INTERACTIVE TestDiskInfo(); #endif #endif // TEST_INFO_FUNCTIONS #ifdef TEST_PATHLIST TestPathList(); #endif // TEST_PATHLIST #ifdef TEST_PRINTF TestPrintf(); #endif // TEST_PRINTF #ifdef TEST_REGCONF #if 0 TestRegConfWrite(); #endif TestRegConfRead(); #endif // TEST_REGCONF #if defined TEST_REGEX && TEST_INTERACTIVE TestRegExInteractive(); #endif // defined TEST_REGEX && TEST_INTERACTIVE #ifdef TEST_REGISTRY TestRegistryRead(); TestRegistryAssociation(); #endif // TEST_REGISTRY #ifdef TEST_SOCKETS TestSocketServer(); TestSocketClient(); #endif // TEST_SOCKETS #ifdef TEST_DATETIME #if TEST_INTERACTIVE TestDateTimeInteractive(); #endif #endif // TEST_DATETIME #ifdef TEST_SCOPEGUARD TestScopeGuard(); #endif #ifdef TEST_STACKWALKER #if wxUSE_STACKWALKER TestStackWalk(argv[0]); #endif #endif // TEST_STACKWALKER #ifdef TEST_STDPATHS TestStandardPaths(); #endif #ifdef TEST_USLEEP wxPuts(wxT("Sleeping for 3 seconds... z-z-z-z-z...")); wxUsleep(3000); #endif // TEST_USLEEP #ifdef TEST_VOLUME TestFSVolume(); #endif // TEST_VOLUME #if wxUSE_UNICODE { for ( int n = 0; n < argc; n++ ) free(wxArgv[n]); delete [] wxArgv; } #endif // wxUSE_UNICODE wxUnusedVar(argc); wxUnusedVar(argv); return 0; }