X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/42b1f941b010bee7e5e82b12c1096dce094553d4..1540e053dd87095c23c1d9a42db4f395621af240:/samples/console/console.cpp?ds=sidebyside diff --git a/samples/console/console.cpp b/samples/console/console.cpp index 3bf7de87f0..59d0bda4c0 100644 --- a/samples/console/console.cpp +++ b/samples/console/console.cpp @@ -44,8 +44,8 @@ //#define TEST_EXECUTE //#define TEST_FILE //#define TEST_FILECONF -#define TEST_FILENAME -//#define TEST_FTP +//#define TEST_FILENAME +#define TEST_FTP //#define TEST_HASH //#define TEST_LIST //#define TEST_LOG @@ -596,14 +596,22 @@ static void TestFileConfRead() #include -static const wxChar *filenames[] = +static struct FileNameInfo { - _T("/usr/bin/ls"), - _T("/usr/bin/"), - _T("~/.zshrc"), - _T("../../foo"), - _T("~/foo.bar"), - _T("/tmp/wxwin.tar.bz"), + 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() @@ -612,7 +620,7 @@ static void TestFileNameConstruction() for ( size_t n = 0; n < WXSIZEOF(filenames); n++ ) { - wxFileName fn(filenames[n], wxPATH_UNIX); + wxFileName fn(filenames[n].fullname, wxPATH_UNIX); printf("Filename: '%s'\t", fn.GetFullPath().c_str()); if ( !fn.Normalize(wxPATH_NORM_ALL, _T(""), wxPATH_UNIX) ) @@ -634,10 +642,19 @@ static void TestFileNameSplit() for ( size_t n = 0; n < WXSIZEOF(filenames); n++ ) { + const FileNameInfo &fni = filenames[n]; wxString path, name, ext; - wxFileName::SplitPath(filenames[n], &path, &name, &ext); - printf("%s -> path = '%s', name = '%s', ext = '%s'\n", - filenames[n], path.c_str(), name.c_str(), ext.c_str()); + 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(""); @@ -796,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); @@ -891,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; } } @@ -1489,17 +1508,70 @@ 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; +#ifdef FTP_ANONYMOUS + static const char *hostname = "ftp.wxwindows.org"; + + printf("--- Attempting to connect to %s:21 anonymously...\n", hostname); +#else // !FTP_ANONYMOUS + static const char *hostname = "localhost"; + + char user[256]; + fgets(user, WXSIZEOF(user), stdin); + user[strlen(user) - 1] = '\0'; // chop off '\n' + ftp.SetUser(user); + + char password[256]; + printf("Password for %s: ", password); + fgets(password, WXSIZEOF(password), stdin); + password[strlen(password) - 1] = '\0'; // chop off '\n' + ftp.SetPassword(password); -#ifdef TEST_WUFTPD // test (fixed?) wxFTP bug with wu-ftpd >= 2.6.0? + printf("--- Attempting to connect to %s:21 as %s...\n", hostname, user); +#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()); + } + + return TRUE; +} + +// 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) ) { @@ -1532,174 +1604,229 @@ static void TestProtocolFtp() delete in; } } -#else // !TEST_WUFTPD - -#if 1 - static const char *hostname = "ftp.wxwindows.org"; - static const char *directory = "pub"; - static const char *filename = "welcome.msg"; +} - printf("--- Attempting to connect to %s:21 anonymously...\n", hostname); -#else - static const char *hostname = "localhost"; - static const char *user = "zeitlin"; - static const char *directory = "/tmp"; +static void TestFtpList() +{ + puts("*** Testing wxFTP file listing ***\n"); - ftp.SetUser(user); - ftp.SetPassword("password"); + // test CWD + if ( !ftp.ChDir(directory) ) + { + printf("ERROR: failed to cd to %s\n", directory); + } - printf("--- Attempting to connect to %s:21 as %s...\n", hostname, user); -#endif + printf("Current directory is '%s'\n", ftp.Pwd().c_str()); - if ( !ftp.Connect(hostname) ) + // test NLIST and LIST + wxArrayString files; + if ( !ftp.GetFilesList(files) ) { - printf("ERROR: failed to connect to %s\n", hostname); + puts("ERROR: failed to get NLIST of files"); } else { - printf("--- Connected to %s, current directory is '%s'\n", - hostname, ftp.Pwd().c_str()); - - // test CWD - if ( !ftp.ChDir(directory) ) + 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("ERROR: failed to cd to %s\n", directory); + printf("\t%s\n", files[n].c_str()); } + puts("End of the file list"); + } - // test NLIST and LIST - wxArrayString files; - if ( !ftp.GetFilesList(files) ) - { - puts("ERROR: failed to get NLIST of files"); - } - else + 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("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"); + printf("\t%s\n", files[n].c_str()); } + puts("End of the file list"); + } - if ( !ftp.GetDirList(files) ) + if ( !ftp.ChDir(_T("..")) ) + { + puts("ERROR: failed to cd to .."); + } + + 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: failed to get LIST of files"); + puts("ERROR: read error"); } 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"); + printf("\nContents of %s:\n%s\n", filename, data); } - if ( !ftp.ChDir(_T("..")) ) - { - puts("ERROR: failed to cd to .."); - } + delete [] data; + delete in; + } +} - // test RETR - wxInputStream *in = ftp.GetInputStream(filename); - if ( !in ) - { - printf("ERROR: couldn't get input stream for %s\n", filename); - } +static void TestFtpFileSize() +{ + puts("*** Testing FTP SIZE command ***"); + + if ( !ftp.ChDir(directory) ) + { + printf("ERROR: failed to cd to %s\n", directory); + } + + printf("Current directory is '%s'\n", ftp.Pwd().c_str()); + + if ( ftp.FileExists(filename) ) + { + 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("ERROR: '%s' doesn't exist\n", filename); + } +} + +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; + + // special handling of LIST and NLST as they require data connection + wxString start(buf, 4); + start.MakeUpper(); + if ( start == "LIST" || start == "NLST" ) { - size_t size = in->StreamSize(); - printf("Reading file %s (%u bytes)...", filename, size); + wxString wildcard; + if ( strlen(buf) > 4 ) + wildcard = buf + 5; - char *data = new char[size]; - if ( !in->Read(data, size) ) + wxArrayString files; + if ( !ftp.GetList(files, wildcard, start == "LIST") ) { - puts("ERROR: read error"); + printf("ERROR: failed to get %s of files\n", start.c_str()); } else { - printf("\nContents of %s:\n%s\n", filename, data); + 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"); } - - delete [] data; - delete in; - } - - // test some other FTP commands - if ( ftp.SendCommand("STAT") != '2' ) - { - puts("ERROR: STAT failed"); } - else + else // !list { - printf("STAT returned:\n\n%s\n", ftp.GetLastResult().c_str()); - } + char ch = ftp.SendCommand(buf); + printf("Command %s", ch ? "succeeded" : "failed"); + if ( ch ) + { + printf(" (return code %c)", ch); + } - 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()); + printf(", server reply:\n%s\n\n", ftp.GetLastResult().c_str()); } } -#endif // TEST_WUFTPD/!TEST_WUFTPD + + puts("\n*** done ***"); } -static void TestProtocolFtpUpload() +static void TestFtpUpload() { puts("*** Testing wxFTP uploading ***\n"); - static const char *hostname = "localhost"; - - printf("--- Attempting to connect to %s:21...\n", hostname); + // 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; + } - wxFTP ftp; - ftp.SetUser("zeitlin"); - ftp.SetPassword("password"); - if ( !ftp.Connect(hostname) ) + // send a command to check the remote file + if ( ftp.SendCommand(wxString("STAT ") + file1) != '2' ) { - printf("ERROR: failed to connect to %s\n", hostname); + printf("ERROR: STAT %s failed\n", file1); } else { - printf("--- Connected to %s, current directory is '%s'\n", - hostname, ftp.Pwd().c_str()); - - // 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()); - } + 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; - } + out = ftp.GetOutputStream(file2); + if ( out ) + { + printf("--- Uploading to %s ---\n", file1); + out->Write("Second hello", 12); + delete out; } } @@ -2938,7 +3065,7 @@ static void TestTimeParse() } } -static void TestInteractive() +static void TestDateTimeInteractive() { puts("\n*** interactive wxDateTime tests ***"); @@ -4072,13 +4199,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 @@ -4101,10 +4229,24 @@ 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 @@ -4136,7 +4278,7 @@ int main(int argc, char **argv) TestTimeZoneBug(); } if ( 0 ) - TestInteractive(); + TestDateTimeInteractive(); #endif // TEST_DATETIME #ifdef TEST_VCARD