X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/2e907fab47d506f5c8096b4a7675d9bd4216320e..19ff2a7bd5b0c567a8fa306d9021bc344e6fbe9b:/samples/console/console.cpp diff --git a/samples/console/console.cpp b/samples/console/console.cpp index 8cf63b91b8..f7079f20cb 100644 --- a/samples/console/console.cpp +++ b/samples/console/console.cpp @@ -44,7 +44,8 @@ //#define TEST_EXECUTE //#define TEST_FILE //#define TEST_FILECONF -#define TEST_FTP +//#define TEST_FILENAME +//#define TEST_FTP //#define TEST_HASH //#define TEST_LIST //#define TEST_LOG @@ -53,7 +54,7 @@ //#define TEST_INFO_FUNCTIONS //#define TEST_REGISTRY //#define TEST_SOCKETS -//#define TEST_STREAMS +#define TEST_STREAMS //#define TEST_STRINGS //#define TEST_THREADS //#define TEST_TIMER @@ -396,6 +397,7 @@ static void TestExecute() #ifdef TEST_FILE #include +#include #include static void TestFileRead() @@ -472,6 +474,55 @@ static void TestTextFileRead() puts(""); } +static void TestFileCopy() +{ + puts("*** Testing wxCopyFile ***"); + + static const wxChar *filename1 = _T("testdata.fc"); + static const wxChar *filename2 = _T("test2"); + if ( !wxCopyFile(filename1, filename2) ) + { + puts("ERROR: failed to copy file"); + } + else + { + wxFFile f1(filename1, "rb"), + f2(filename2, "rb"); + + if ( !f1.IsOpened() || !f2.IsOpened() ) + { + puts("ERROR: failed to open file(s)"); + } + else + { + wxString s1, s2; + if ( !f1.ReadAll(&s1) || !f2.ReadAll(&s2) ) + { + puts("ERROR: failed to read file(s)"); + } + else + { + if ( (s1.length() != s2.length()) || + (memcmp(s1.c_str(), s2.c_str(), s1.length()) != 0) ) + { + puts("ERROR: copy error!"); + } + else + { + puts("File was copied ok."); + } + } + } + } + + if ( !wxRemoveFile(filename2) ) + { + puts("ERROR: failed to remove the file"); + } + + puts(""); +} + #endif // TEST_FILE // ---------------------------------------------------------------------------- @@ -537,6 +588,95 @@ static void TestFileConfRead() #endif // TEST_FILECONF +// ---------------------------------------------------------------------------- +// wxFileName +// ---------------------------------------------------------------------------- + +#ifdef TEST_FILENAME + +#include + +static struct FileNameInfo +{ + const wxChar *fullname; + const wxChar *path; + const wxChar *name; + const wxChar *ext; +} filenames[] = +{ + { _T("/usr/bin/ls"), _T("/usr/bin"), _T("ls"), _T("") }, + { _T("/usr/bin/"), _T("/usr/bin"), _T(""), _T("") }, + { _T("~/.zshrc"), _T("~"), _T(".zshrc"), _T("") }, + { _T("../../foo"), _T("../.."), _T("foo"), _T("") }, + { _T("foo.bar"), _T(""), _T("foo"), _T("bar") }, + { _T("~/foo.bar"), _T("~"), _T("foo"), _T("bar") }, + { _T("Mahogany-0.60/foo.bar"), _T("Mahogany-0.60"), _T("foo"), _T("bar") }, + { _T("/tmp/wxwin.tar.bz"), _T("/tmp"), _T("wxwin.tar"), _T("bz") }, +}; + +static void TestFileNameConstruction() +{ + puts("*** testing wxFileName construction ***"); + + for ( size_t n = 0; n < WXSIZEOF(filenames); n++ ) + { + wxFileName fn(filenames[n].fullname, wxPATH_UNIX); + + printf("Filename: '%s'\t", fn.GetFullPath().c_str()); + if ( !fn.Normalize(wxPATH_NORM_ALL, _T(""), wxPATH_UNIX) ) + { + puts("ERROR (couldn't be normalized)"); + } + else + { + printf("normalized: '%s'\n", fn.GetFullPath().c_str()); + } + } + + puts(""); +} + +static void TestFileNameSplit() +{ + puts("*** testing wxFileName splitting ***"); + + for ( size_t n = 0; n < WXSIZEOF(filenames); n++ ) + { + const FileNameInfo &fni = filenames[n]; + wxString path, name, ext; + wxFileName::SplitPath(fni.fullname, &path, &name, &ext); + + printf("%s -> path = '%s', name = '%s', ext = '%s'", + fni.fullname, path.c_str(), name.c_str(), ext.c_str()); + if ( path != fni.path ) + printf(" (ERROR: path = '%s')", fni.path); + if ( name != fni.name ) + printf(" (ERROR: name = '%s')", fni.name); + if ( ext != fni.ext ) + printf(" (ERROR: ext = '%s')", fni.ext); + puts(""); + } + + puts(""); +} + +static void TestFileNameComparison() +{ + // TODO! +} + +static void TestFileNameOperations() +{ + // TODO! +} + +static void TestFileNameCwd() +{ + // TODO! +} + +#endif // TEST_FILENAME + // ---------------------------------------------------------------------------- // wxHashTable // ---------------------------------------------------------------------------- @@ -673,6 +813,8 @@ static wxMimeTypesManager g_mimeManager; static void TestMimeEnum() { + wxPuts(_T("*** Testing wxMimeTypesManager::EnumAllFileTypes() ***\n")); + wxArrayString mimetypes; size_t count = g_mimeManager.EnumAllFileTypes(mimetypes); @@ -768,24 +910,24 @@ static void TestMimeAssociate() { wxPuts(_T("*** Testing creation of filetype association ***\n")); - wxFileType *ft = g_mimeManager.Associate - ( - _T(".xyz"), - _T("application/x-xyz"), - _T("XYZFile"), // filetype (MSW only) - _T("XYZ File") // description (Unix only) - ); + wxFileTypeInfo ftInfo( + _T("application/x-xyz"), + _T("xyzview '%s'"), // open cmd + _T(""), // print cmd + _T("XYZ File") // description + _T(".xyz"), // extensions + NULL // end of extensions + ); + ftInfo.SetShortDesc(_T("XYZFile")); // used under Win32 only + + wxFileType *ft = g_mimeManager.Associate(ftInfo); if ( !ft ) { wxPuts(_T("ERROR: failed to create association!")); } else { - if ( !ft->SetOpenCommand(_T("myprogram")) ) - { - wxPuts(_T("ERROR: failed to set open command!")); - } - + // TODO: read it back delete ft; } } @@ -1366,85 +1508,78 @@ static void TestSocketClient() #endif // TEST_SOCKETS +// ---------------------------------------------------------------------------- +// FTP +// ---------------------------------------------------------------------------- + #ifdef TEST_FTP #include -static void TestProtocolFtp() +static wxFTP ftp; + +#define FTP_ANONYMOUS + +#ifdef FTP_ANONYMOUS + static const char *directory = "/pub"; + static const char *filename = "welcome.msg"; +#else + static const char *directory = "/etc"; + static const char *filename = "issue"; +#endif + +static bool TestFtpConnect() { - puts("*** Testing wxFTP download ***\n"); + puts("*** Testing FTP connect ***"); - wxFTP ftp; -#if 1 +#ifdef FTP_ANONYMOUS static const char *hostname = "ftp.wxwindows.org"; - static const char *directory = "pub"; printf("--- Attempting to connect to %s:21 anonymously...\n", hostname); -#else +#else // !FTP_ANONYMOUS static const char *hostname = "localhost"; - static const char *user = "zeitlin"; - static const char *directory = "/tmp"; + char user[256]; + fgets(user, WXSIZEOF(user), stdin); + user[strlen(user) - 1] = '\0'; // chop off '\n' ftp.SetUser(user); - ftp.SetPassword("password"); + + char password[256]; + printf("Password for %s: ", password); + fgets(password, WXSIZEOF(password), stdin); + password[strlen(password) - 1] = '\0'; // chop off '\n' + ftp.SetPassword(password); printf("--- Attempting to connect to %s:21 as %s...\n", hostname, user); -#endif +#endif // FTP_ANONYMOUS/!FTP_ANONYMOUS if ( !ftp.Connect(hostname) ) { printf("ERROR: failed to connect to %s\n", hostname); + + return FALSE; } else { printf("--- Connected to %s, current directory is '%s'\n", hostname, ftp.Pwd().c_str()); + } - // test CWD - if ( !ftp.ChDir(directory) ) - { - printf("ERROR: failed to cd to %s\n", directory); - } - - // test NLIST and LIST - wxArrayString files; - if ( !ftp.GetFilesList(files) ) - { - puts("ERROR: failed to get NLIST of files"); - } - else - { - printf("Brief list of files under '%s':\n", ftp.Pwd().c_str()); - size_t count = files.GetCount(); - for ( size_t n = 0; n < count; n++ ) - { - printf("\t%s\n", files[n].c_str()); - } - puts("End of the file list"); - } - - if ( !ftp.GetDirList(files) ) - { - puts("ERROR: failed to get LIST of files"); - } - else - { - printf("Detailed list of files under '%s':\n", ftp.Pwd().c_str()); - size_t count = files.GetCount(); - for ( size_t n = 0; n < count; n++ ) - { - printf("\t%s\n", files[n].c_str()); - } - puts("End of the file list"); - } - - if ( !ftp.ChDir(_T("..")) ) - { - puts("ERROR: failed to cd to .."); - } + return TRUE; +} - // test RETR - static const char *filename = "welcome.msg"; +// test (fixed?) wxFTP bug with wu-ftpd >= 2.6.0? +static void TestFtpWuFtpd() +{ + wxFTP ftp; + static const char *hostname = "ftp.eudora.com"; + if ( !ftp.Connect(hostname) ) + { + printf("ERROR: failed to connect to %s\n", hostname); + } + else + { + static const char *filename = "eudora/pubs/draft-gellens-submit-09.txt"; wxInputStream *in = ftp.GetInputStream(filename); if ( !in ) { @@ -1462,85 +1597,237 @@ static void TestProtocolFtp() } else { - printf("\nContents of %s:\n%s\n", filename, data); + printf("Successfully retrieved the file.\n"); } delete [] data; delete in; } + } +} + +static void TestFtpList() +{ + puts("*** Testing wxFTP file listing ***\n"); + + // test CWD + if ( !ftp.ChDir(directory) ) + { + printf("ERROR: failed to cd to %s\n", directory); + } + + printf("Current directory is '%s'\n", ftp.Pwd().c_str()); - // test some other FTP commands - if ( ftp.SendCommand("STAT") != '2' ) + // test NLIST and LIST + wxArrayString files; + if ( !ftp.GetFilesList(files) ) + { + puts("ERROR: failed to get NLIST of files"); + } + else + { + printf("Brief list of files under '%s':\n", ftp.Pwd().c_str()); + size_t count = files.GetCount(); + for ( size_t n = 0; n < count; n++ ) { - puts("ERROR: STAT failed"); + printf("\t%s\n", files[n].c_str()); } - else + puts("End of the file list"); + } + + if ( !ftp.GetDirList(files) ) + { + puts("ERROR: failed to get LIST of files"); + } + else + { + printf("Detailed list of files under '%s':\n", ftp.Pwd().c_str()); + size_t count = files.GetCount(); + for ( size_t n = 0; n < count; n++ ) { - printf("STAT returned:\n\n%s\n", ftp.GetLastResult().c_str()); + printf("\t%s\n", files[n].c_str()); } + puts("End of the file list"); + } + + if ( !ftp.ChDir(_T("..")) ) + { + puts("ERROR: failed to cd to .."); + } - if ( ftp.SendCommand("HELP SITE") != '2' ) + printf("Current directory is '%s'\n", ftp.Pwd().c_str()); +} + +static void TestFtpDownload() +{ + puts("*** Testing wxFTP download ***\n"); + + // test RETR + wxInputStream *in = ftp.GetInputStream(filename); + if ( !in ) + { + printf("ERROR: couldn't get input stream for %s\n", filename); + } + else + { + size_t size = in->StreamSize(); + printf("Reading file %s (%u bytes)...", filename, size); + fflush(stdout); + + char *data = new char[size]; + if ( !in->Read(data, size) ) { - puts("ERROR: HELP SITE failed"); + puts("ERROR: read error"); } else { - printf("The list of site-specific commands:\n\n%s\n", - ftp.GetLastResult().c_str()); + printf("\nContents of %s:\n%s\n", filename, data); } + + delete [] data; + delete in; } } -static void TestProtocolFtpUpload() +static void TestFtpFileSize() { - puts("*** Testing wxFTP uploading ***\n"); + puts("*** Testing FTP SIZE command ***"); - static const char *hostname = "localhost"; + if ( !ftp.ChDir(directory) ) + { + printf("ERROR: failed to cd to %s\n", directory); + } - printf("--- Attempting to connect to %s:21...\n", hostname); + printf("Current directory is '%s'\n", ftp.Pwd().c_str()); - wxFTP ftp; - ftp.SetUser("zeitlin"); - ftp.SetPassword("password"); - if ( !ftp.Connect(hostname) ) + if ( ftp.FileExists(filename) ) { - printf("ERROR: failed to connect to %s\n", hostname); + int size = ftp.GetFileSize(filename); + if ( size == -1 ) + printf("ERROR: couldn't get size of '%s'\n", filename); + else + printf("Size of '%s' is %d bytes.\n", filename, size); } else { - printf("--- Connected to %s, current directory is '%s'\n", - hostname, ftp.Pwd().c_str()); + printf("ERROR: '%s' doesn't exist\n", filename); + } +} - // upload a file - static const char *file1 = "test1"; - static const char *file2 = "test2"; - wxOutputStream *out = ftp.GetOutputStream(file1); - if ( out ) - { - printf("--- Uploading to %s ---\n", file1); - out->Write("First hello", 11); - delete out; - } +static void TestFtpMisc() +{ + puts("*** Testing miscellaneous wxFTP functions ***"); + + if ( ftp.SendCommand("STAT") != '2' ) + { + puts("ERROR: STAT failed"); + } + else + { + printf("STAT returned:\n\n%s\n", ftp.GetLastResult().c_str()); + } + + if ( ftp.SendCommand("HELP SITE") != '2' ) + { + puts("ERROR: HELP SITE failed"); + } + else + { + printf("The list of site-specific commands:\n\n%s\n", + ftp.GetLastResult().c_str()); + } +} + +static void TestFtpInteractive() +{ + puts("\n*** Interactive wxFTP test ***"); + + char buf[128]; + + for ( ;; ) + { + printf("Enter FTP command: "); + if ( !fgets(buf, WXSIZEOF(buf), stdin) ) + break; + + // kill the last '\n' + buf[strlen(buf) - 1] = 0; - // send a command to check the remote file - if ( ftp.SendCommand(wxString("STAT ") + file1) != '2' ) + // special handling of LIST and NLST as they require data connection + wxString start(buf, 4); + start.MakeUpper(); + if ( start == "LIST" || start == "NLST" ) { - printf("ERROR: STAT %s failed\n", file1); + wxString wildcard; + if ( strlen(buf) > 4 ) + wildcard = buf + 5; + + wxArrayString files; + if ( !ftp.GetList(files, wildcard, start == "LIST") ) + { + printf("ERROR: failed to get %s of files\n", start.c_str()); + } + else + { + printf("--- %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++ ) + { + printf("\t%s\n", files[n].c_str()); + } + puts("--- End of the file list"); + } } - else + else // !list { - printf("STAT %s returned:\n\n%s\n", - file1, ftp.GetLastResult().c_str()); - } + char ch = ftp.SendCommand(buf); + printf("Command %s", ch ? "succeeded" : "failed"); + if ( ch ) + { + printf(" (return code %c)", ch); + } - out = ftp.GetOutputStream(file2); - if ( out ) - { - printf("--- Uploading to %s ---\n", file1); - out->Write("Second hello", 12); - delete out; + printf(", server reply:\n%s\n\n", ftp.GetLastResult().c_str()); } } + + puts("\n*** done ***"); +} + +static void TestFtpUpload() +{ + puts("*** Testing wxFTP uploading ***\n"); + + // upload a file + static const char *file1 = "test1"; + static const char *file2 = "test2"; + wxOutputStream *out = ftp.GetOutputStream(file1); + if ( out ) + { + printf("--- Uploading to %s ---\n", file1); + out->Write("First hello", 11); + delete out; + } + + // send a command to check the remote file + if ( ftp.SendCommand(wxString("STAT ") + file1) != '2' ) + { + printf("ERROR: STAT %s failed\n", file1); + } + else + { + printf("STAT %s returned:\n\n%s\n", + file1, ftp.GetLastResult().c_str()); + } + + out = ftp.GetOutputStream(file2); + if ( out ) + { + printf("--- Uploading to %s ---\n", file1); + out->Write("Second hello", 12); + delete out; + } } #endif // TEST_FTP @@ -1551,8 +1838,34 @@ static void TestProtocolFtpUpload() #ifdef TEST_STREAMS +#include #include +static void TestFileStream() +{ + puts("*** Testing wxFileInputStream ***"); + + static const wxChar *filename = _T("testdata.fs"); + { + wxFileOutputStream fsOut(filename); + fsOut.Write("foo", 3); + } + + wxFileInputStream fsIn(filename); + printf("File stream size: %u\n", fsIn.GetSize()); + while ( !fsIn.Eof() ) + { + putchar(fsIn.GetC()); + } + + if ( !wxRemoveFile(filename) ) + { + printf("ERROR: failed to remove the file '%s'.\n", filename); + } + + puts("\n*** wxFileInputStream test done ***"); +} + static void TestMemoryStream() { puts("*** Testing wxMemoryInputStream ***"); @@ -1871,37 +2184,49 @@ static void TestVCardWrite() #ifdef TEST_WCHAR #include +#include +#include #include static void TestUtf8() { puts("*** Testing UTF8 support ***\n"); - wxString testString = "français"; -#if 0 -"************ French - Français ****************" -"Juste un petit exemple pour dire que les français aussi" -"ont à cœur de pouvoir utiliser tous leurs caractères ! :)"; -#endif - - wxWCharBuffer wchBuf = testString.wc_str(wxConvUTF8); - const wchar_t *pwz = (const wchar_t *)wchBuf; - wxString testString2(pwz, wxConvLocal); - - printf("Decoding '%s' => '%s'\n", testString.c_str(), testString2.c_str()); + static const char textInUtf8[] = + { + 208, 157, 208, 181, 209, 129, 208, 186, 208, 176, 208, 183, 208, 176, + 208, 189, 208, 189, 208, 190, 32, 208, 191, 208, 190, 209, 128, 208, + 176, 208, 180, 208, 190, 208, 178, 208, 176, 208, 187, 32, 208, 188, + 208, 181, 208, 189, 209, 143, 32, 209, 129, 208, 178, 208, 190, 208, + 181, 208, 185, 32, 208, 186, 209, 128, 209, 131, 209, 130, 208, 181, + 208, 185, 209, 136, 208, 181, 208, 185, 32, 208, 189, 208, 190, 208, + 178, 208, 190, 209, 129, 209, 130, 209, 140, 209, 142, 0 + }; - char *psz = "fran" "\xe7" "ais"; - size_t len = strlen(psz); - wchar_t *pwz2 = new wchar_t[len + 1]; - for ( size_t n = 0; n <= len; n++ ) + char buf[1024]; + wchar_t wbuf[1024]; + if ( wxConvUTF8.MB2WC(wbuf, textInUtf8, WXSIZEOF(textInUtf8)) <= 0 ) { - pwz2[n] = (wchar_t)(unsigned char)psz[n]; + puts("ERROR: UTF-8 decoding failed."); } + else + { + // using wxEncodingConverter +#if 0 + wxEncodingConverter ec; + ec.Init(wxFONTENCODING_UNICODE, wxFONTENCODING_KOI8); + ec.Convert(wbuf, buf); +#else // using wxCSConv + wxCSConv conv(_T("koi8-r")); + if ( conv.WC2MB(buf, wbuf, 0 /* not needed wcslen(wbuf) */) <= 0 ) + { + puts("ERROR: conversion to KOI8-R failed."); + } + else +#endif - wxString testString3(pwz2, wxConvUTF8); - delete [] pwz2; - - printf("Encoding '%s' -> '%s'\n", psz, testString3.c_str()); + printf("The resulting string (in koi8-r): %s\n", buf); + } } #endif // TEST_WCHAR @@ -2778,7 +3103,7 @@ static void TestTimeParse() } } -static void TestInteractive() +static void TestDateTimeInteractive() { puts("\n*** interactive wxDateTime tests ***"); @@ -3849,10 +4174,24 @@ int main(int argc, char **argv) #ifdef TEST_FILE if ( 0 ) + { TestFileRead(); - TestTextFileRead(); + TestTextFileRead(); + } + TestFileCopy(); #endif // TEST_FILE +#ifdef TEST_FILENAME + TestFileNameSplit(); + if ( 0 ) + { + TestFileNameConstruction(); + TestFileNameCwd(); + TestFileNameComparison(); + TestFileNameOperations(); + } +#endif // TEST_FILENAME + #ifdef TEST_THREADS int nCPUs = wxThread::GetCPUCount(); printf("This system has %d CPUs\n", nCPUs); @@ -3898,13 +4237,14 @@ int main(int argc, char **argv) #ifdef TEST_MIME wxLog::AddTraceMask(_T("mime")); - if ( 0 ) + if ( 1 ) { TestMimeEnum(); TestMimeOverride(); TestMimeFilename(); } - TestMimeAssociate(); + else + TestMimeAssociate(); #endif // TEST_MIME #ifdef TEST_INFO_FUNCTIONS @@ -3927,13 +4267,29 @@ int main(int argc, char **argv) #endif // TEST_SOCKETS #ifdef TEST_FTP - wxLog::AddTraceMask(_T("ftp")); - TestProtocolFtp(); + wxLog::AddTraceMask(FTP_TRACE_MASK); + if ( TestFtpConnect() ) + { + TestFtpFileSize(); + if ( 0 ) + { + TestFtpList(); + TestFtpDownload(); + TestFtpMisc(); + TestFtpUpload(); + } + if ( 0 ) + TestFtpInteractive(); + } + //else: connecting to the FTP server failed + if ( 0 ) - TestProtocolFtpUpload(); + TestFtpWuFtpd(); #endif // TEST_FTP #ifdef TEST_STREAMS + if ( 0 ) + TestFileStream(); TestMemoryStream(); #endif // TEST_STREAMS @@ -3942,7 +4298,7 @@ int main(int argc, char **argv) #endif // TEST_TIMER #ifdef TEST_DATETIME - if ( 0 ) + if ( 1 ) { TestTimeSet(); TestTimeStatic(); @@ -3962,7 +4318,7 @@ int main(int argc, char **argv) TestTimeZoneBug(); } if ( 0 ) - TestInteractive(); + TestDateTimeInteractive(); #endif // TEST_DATETIME #ifdef TEST_VCARD