1. wxShell fixes: now really uses shell (it wasn't different from wxExecute!)
and also added a version which captures the programs output 2. fix for compilers which have void ftime() (my mingw does) in timercmn.cpp 3. updated console sample to test wxShell/wxExecute 4. treetest now can toggle images or change their size 5. wxTreeCtrl doesn't crash if it has no image list git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@6404 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
		@@ -32,11 +32,13 @@
 | 
			
		||||
//#define TEST_ARRAYS
 | 
			
		||||
//#define TEST_CMDLINE
 | 
			
		||||
//#define TEST_DIR
 | 
			
		||||
//#define TEST_EXECUTE
 | 
			
		||||
#define TEST_FILECONF
 | 
			
		||||
#define TEST_EXECUTE
 | 
			
		||||
//#define TEST_FILECONF
 | 
			
		||||
//#define TEST_HASH
 | 
			
		||||
//#define TEST_LOG
 | 
			
		||||
//#define TEST_LONGLONG
 | 
			
		||||
//#define TEST_MIME
 | 
			
		||||
//#define TEST_SOCKETS
 | 
			
		||||
//#define TEST_STRINGS
 | 
			
		||||
//#define TEST_THREADS
 | 
			
		||||
//#define TEST_TIME
 | 
			
		||||
@@ -176,16 +178,55 @@ static void TestExecute()
 | 
			
		||||
 | 
			
		||||
#ifdef __UNIX__
 | 
			
		||||
    #define COMMAND "echo hi"
 | 
			
		||||
    #define SHELL_COMMAND "echo hi from shell"
 | 
			
		||||
    #define REDIRECT_COMMAND "date"
 | 
			
		||||
#elif defined(__WXMSW__)
 | 
			
		||||
    #define COMMAND "command.com -c 'echo hi'"
 | 
			
		||||
    #define SHELL_COMMAND "echo hi"
 | 
			
		||||
    #define REDIRECT_COMMAND COMMAND
 | 
			
		||||
#else
 | 
			
		||||
    #error "no command to exec"
 | 
			
		||||
#endif // OS
 | 
			
		||||
 | 
			
		||||
    if ( wxExecute(COMMAND) == 0 )
 | 
			
		||||
        puts("\nOk.");
 | 
			
		||||
    printf("Testing wxShell: ");
 | 
			
		||||
    fflush(stdout);
 | 
			
		||||
    if ( wxShell(SHELL_COMMAND) )
 | 
			
		||||
        puts("Ok.");
 | 
			
		||||
    else
 | 
			
		||||
        puts("\nError.");
 | 
			
		||||
        puts("ERROR.");
 | 
			
		||||
 | 
			
		||||
    printf("Testing wxExecute: ");
 | 
			
		||||
    fflush(stdout);
 | 
			
		||||
    if ( wxExecute(COMMAND, TRUE /* sync */) == 0 )
 | 
			
		||||
        puts("Ok.");
 | 
			
		||||
    else
 | 
			
		||||
        puts("ERROR.");
 | 
			
		||||
 | 
			
		||||
#if 0 // no, it doesn't work (yet?)
 | 
			
		||||
    printf("Testing async wxExecute: ");
 | 
			
		||||
    fflush(stdout);
 | 
			
		||||
    if ( wxExecute(COMMAND) != 0 )
 | 
			
		||||
        puts("Ok (command launched).");
 | 
			
		||||
    else
 | 
			
		||||
        puts("ERROR.");
 | 
			
		||||
#endif // 0
 | 
			
		||||
 | 
			
		||||
    printf("Testing wxExecute with redirection:\n");
 | 
			
		||||
    wxArrayString output;
 | 
			
		||||
    if ( wxExecute(REDIRECT_COMMAND, output) != 0 )
 | 
			
		||||
    {
 | 
			
		||||
        puts("ERROR.");
 | 
			
		||||
    }
 | 
			
		||||
    else
 | 
			
		||||
    {
 | 
			
		||||
        size_t count = output.GetCount();
 | 
			
		||||
        for ( size_t n = 0; n < count; n++ )
 | 
			
		||||
        {
 | 
			
		||||
            printf("\t%s\n", output[n].c_str());
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        puts("Ok.");
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#endif // TEST_EXECUTE
 | 
			
		||||
@@ -253,6 +294,92 @@ static void TestFileConfRead()
 | 
			
		||||
 | 
			
		||||
#endif // TEST_FILECONF
 | 
			
		||||
 | 
			
		||||
// ----------------------------------------------------------------------------
 | 
			
		||||
// wxHashTable
 | 
			
		||||
// ----------------------------------------------------------------------------
 | 
			
		||||
 | 
			
		||||
#ifdef TEST_HASH
 | 
			
		||||
 | 
			
		||||
#include <wx/hash.h>
 | 
			
		||||
 | 
			
		||||
struct Foo
 | 
			
		||||
{
 | 
			
		||||
    Foo(int n_) { n = n_; count++; }
 | 
			
		||||
    ~Foo() { count--; }
 | 
			
		||||
 | 
			
		||||
    int n;
 | 
			
		||||
 | 
			
		||||
    static size_t count;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
size_t Foo::count = 0;
 | 
			
		||||
 | 
			
		||||
WX_DECLARE_LIST(Foo, wxListFoos);
 | 
			
		||||
WX_DECLARE_HASH(Foo, wxListFoos, wxHashFoos);
 | 
			
		||||
 | 
			
		||||
#include <wx/listimpl.cpp>
 | 
			
		||||
 | 
			
		||||
WX_DEFINE_LIST(wxListFoos);
 | 
			
		||||
 | 
			
		||||
static void TestHash()
 | 
			
		||||
{
 | 
			
		||||
    puts("*** Testing wxHashTable ***\n");
 | 
			
		||||
 | 
			
		||||
    {
 | 
			
		||||
        wxHashFoos hash;
 | 
			
		||||
        hash.DeleteContents(TRUE);
 | 
			
		||||
 | 
			
		||||
        printf("Hash created: %u foos in hash, %u foos totally\n",
 | 
			
		||||
               hash.GetCount(), Foo::count);
 | 
			
		||||
 | 
			
		||||
        static const int hashTestData[] =
 | 
			
		||||
        {
 | 
			
		||||
            0, 1, 17, -2, 2, 4, -4, 345, 3, 3, 2, 1,
 | 
			
		||||
        };
 | 
			
		||||
 | 
			
		||||
        size_t n;
 | 
			
		||||
        for ( n = 0; n < WXSIZEOF(hashTestData); n++ )
 | 
			
		||||
        {
 | 
			
		||||
            hash.Put(hashTestData[n], n, new Foo(n));
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        printf("Hash filled: %u foos in hash, %u foos totally\n",
 | 
			
		||||
               hash.GetCount(), Foo::count);
 | 
			
		||||
 | 
			
		||||
        puts("Hash access test:");
 | 
			
		||||
        for ( n = 0; n < WXSIZEOF(hashTestData); n++ )
 | 
			
		||||
        {
 | 
			
		||||
            printf("\tGetting element with key %d, value %d: ",
 | 
			
		||||
                   hashTestData[n], n);
 | 
			
		||||
            Foo *foo = hash.Get(hashTestData[n], n);
 | 
			
		||||
            if ( !foo )
 | 
			
		||||
            {
 | 
			
		||||
                printf("ERROR, not found.\n");
 | 
			
		||||
            }
 | 
			
		||||
            else
 | 
			
		||||
            {
 | 
			
		||||
                printf("%d (%s)\n", foo->n,
 | 
			
		||||
                       (size_t)foo->n == n ? "ok" : "ERROR");
 | 
			
		||||
            }
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        printf("\nTrying to get an element not in hash: ");
 | 
			
		||||
 | 
			
		||||
        if ( hash.Get(1234) || hash.Get(1, 0) )
 | 
			
		||||
        {
 | 
			
		||||
            puts("ERROR: found!");
 | 
			
		||||
        }
 | 
			
		||||
        else
 | 
			
		||||
        {
 | 
			
		||||
            puts("ok (not found)");
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    printf("Hash destroyed: %u foos left\n", Foo::count);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#endif // TEST_HASH
 | 
			
		||||
 | 
			
		||||
// ----------------------------------------------------------------------------
 | 
			
		||||
// MIME types
 | 
			
		||||
// ----------------------------------------------------------------------------
 | 
			
		||||
@@ -555,6 +682,39 @@ static void TestBitOperations()
 | 
			
		||||
 | 
			
		||||
#endif // TEST_LONGLONG
 | 
			
		||||
 | 
			
		||||
// ----------------------------------------------------------------------------
 | 
			
		||||
// sockets
 | 
			
		||||
// ----------------------------------------------------------------------------
 | 
			
		||||
 | 
			
		||||
#ifdef TEST_SOCKETS
 | 
			
		||||
 | 
			
		||||
#include <wx/socket.h>
 | 
			
		||||
 | 
			
		||||
static void TestSocketClient()
 | 
			
		||||
{
 | 
			
		||||
    puts("*** Testing wxSocketClient ***\n");
 | 
			
		||||
 | 
			
		||||
    wxIPV4address addrDst;
 | 
			
		||||
    addrDst.Hostname("www.wxwindows.org");
 | 
			
		||||
    addrDst.Service(80);
 | 
			
		||||
 | 
			
		||||
    wxSocketClient client;
 | 
			
		||||
    if ( !client.Connect(addrDst) )
 | 
			
		||||
    {
 | 
			
		||||
        printf("ERROR: failed to connect to %s\n", addrDst.Hostname().c_str());
 | 
			
		||||
    }
 | 
			
		||||
    else
 | 
			
		||||
    {
 | 
			
		||||
        char buf[8192];
 | 
			
		||||
 | 
			
		||||
        client.Write("get /front.htm\n", 17);
 | 
			
		||||
        client.Read(buf, WXSIZEOF(buf));
 | 
			
		||||
        printf("Server replied:\n%s", buf);
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#endif // TEST_SOCKETS
 | 
			
		||||
 | 
			
		||||
// ----------------------------------------------------------------------------
 | 
			
		||||
// date time
 | 
			
		||||
// ----------------------------------------------------------------------------
 | 
			
		||||
@@ -2217,10 +2377,18 @@ int main(int argc, char **argv)
 | 
			
		||||
    }
 | 
			
		||||
#endif // TEST_LONGLONG
 | 
			
		||||
 | 
			
		||||
#ifdef TEST_HASH
 | 
			
		||||
    TestHash();
 | 
			
		||||
#endif // TEST_HASH
 | 
			
		||||
 | 
			
		||||
#ifdef TEST_MIME
 | 
			
		||||
    TestMimeEnum();
 | 
			
		||||
#endif // TEST_MIME
 | 
			
		||||
 | 
			
		||||
#ifdef TEST_SOCKETS
 | 
			
		||||
    TestSocketClient();
 | 
			
		||||
#endif // TEST_SOCKETS
 | 
			
		||||
 | 
			
		||||
#ifdef TEST_TIME
 | 
			
		||||
    if ( 0 )
 | 
			
		||||
    {
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user