X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/8e7dda219e5c048104b18ea3f4254a683e3e4aa8..19ff2a7bd5b0c567a8fa306d9021bc344e6fbe9b:/samples/console/console.cpp?ds=sidebyside diff --git a/samples/console/console.cpp b/samples/console/console.cpp index 395b6d6f2f..f7079f20cb 100644 --- a/samples/console/console.cpp +++ b/samples/console/console.cpp @@ -44,7 +44,7 @@ //#define TEST_EXECUTE //#define TEST_FILE //#define TEST_FILECONF -#define TEST_FILENAME +//#define TEST_FILENAME //#define TEST_FTP //#define TEST_HASH //#define TEST_LIST @@ -54,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 @@ -813,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); @@ -908,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; } } @@ -1506,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); + + 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); -#ifdef TEST_WUFTPD // test (fixed?) wxFTP bug with wu-ftpd >= 2.6.0? + 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) ) { @@ -1549,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.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); - if ( !ftp.GetDirList(files) ) + 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' ) + else // !list { - puts("ERROR: STAT failed"); - } - else - { - 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; } } @@ -1728,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 ***"); @@ -2048,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 @@ -2955,7 +3103,7 @@ static void TestTimeParse() } } -static void TestInteractive() +static void TestDateTimeInteractive() { puts("\n*** interactive wxDateTime tests ***"); @@ -4089,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 @@ -4118,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 @@ -4153,7 +4318,7 @@ int main(int argc, char **argv) TestTimeZoneBug(); } if ( 0 ) - TestInteractive(); + TestDateTimeInteractive(); #endif // TEST_DATETIME #ifdef TEST_VCARD