]> git.saurik.com Git - wxWidgets.git/blobdiff - samples/typetest/typetest.cpp
SendDestroyEvent
[wxWidgets.git] / samples / typetest / typetest.cpp
index dd9dab7be6a6cf030f84fca5f51b77a19f800121..695f8fec2b1a0f1e523639ac80497023a25ca8f4 100644 (file)
@@ -24,8 +24,6 @@
 #include "wx/wx.h"
 #endif
 
-#include "wx/time.h"
-#include "wx/date.h"
 #include "wx/variant.h"
 #include "wx/mimetype.h"
 
@@ -58,10 +56,6 @@ IMPLEMENT_APP    (MyApp)
 IMPLEMENT_DYNAMIC_CLASS    (MyApp, wxApp)
 
 BEGIN_EVENT_TABLE(MyApp, wxApp)
-#if wxUSE_TIMEDATE
-    EVT_MENU(TYPES_DATE,      MyApp::DoDateDemo)
-    EVT_MENU(TYPES_TIME,      MyApp::DoTimeDemo)
-#endif // wxUSE_TIMEDATE
     EVT_MENU(TYPES_VARIANT,   MyApp::DoVariantDemo)
     EVT_MENU(TYPES_BYTEORDER, MyApp::DoByteOrderDemo)
 #if wxUSE_UNICODE
@@ -94,10 +88,6 @@ bool MyApp::OnInit()
     file_menu->Append(TYPES_QUIT, _T("E&xit\tAlt-X"));
 
     wxMenu *test_menu = new wxMenu;
-#if wxUSE_TIMEDATE
-    test_menu->Append(TYPES_DATE, _T("&Date test"));
-    test_menu->Append(TYPES_TIME, _T("&Time test"));
-#endif // wxUSE_TIMEDATE
     test_menu->Append(TYPES_VARIANT, _T("&Variant test"));
     test_menu->Append(TYPES_BYTEORDER, _T("&Byteorder test"));
 #if wxUSE_UNICODE
@@ -118,14 +108,15 @@ bool MyApp::OnInit()
     menu_bar->Append(test_menu, _T("&Tests"));
     frame->SetMenuBar(menu_bar);
 
-    m_textCtrl = new wxTextCtrl(frame, -1, _T(""), wxPoint(0, 0), wxDefaultSize, wxTE_MULTILINE);
+    m_textCtrl = new wxTextCtrl(frame, wxID_ANY, wxEmptyString,
+        wxDefaultPosition, wxDefaultSize, wxTE_MULTILINE);
 
     // Show the frame
-    frame->Show(TRUE);
+    frame->Show(true);
 
     SetTopWindow(frame);
 
-    return TRUE;
+    return true;
 }
 
 void MyApp::DoStreamDemo(wxCommandEvent& WXUNUSED(event))
@@ -737,7 +728,6 @@ void MyApp::DoStreamDemo6(wxCommandEvent& WXUNUSED(event))
     textCtrl.WriteText( _T("\nTesting Ungetch():\n\n") );
 
     char ch = 0;
-    size_t pos = 0;
     wxString str;
 
     textCtrl.WriteText( _T("Writing number 0 to 9 to wxFileOutputStream...\n\n") );
@@ -753,7 +743,7 @@ void MyApp::DoStreamDemo6(wxCommandEvent& WXUNUSED(event))
     wxFileInputStream file_input( wxString(_T("test_wx.dat")) );
 
     ch = file_input.GetC();
-    pos = file_input.TellI();
+    size_t pos = file_input.TellI();
     str.Printf( wxT("Read char: %d. Now at position %d\n\n"), (int) ch, (int) pos );
     textCtrl.WriteText( str );
 
@@ -817,7 +807,6 @@ void MyApp::DoStreamDemo7(wxCommandEvent& WXUNUSED(event))
     textCtrl.WriteText( _T("\nTesting Ungetch() in buffered input stream:\n\n") );
 
     char ch = 0;
-    size_t pos = 0;
     wxString str;
 
     textCtrl.WriteText( _T("Writing number 0 to 9 to wxFileOutputStream...\n\n") );
@@ -834,7 +823,7 @@ void MyApp::DoStreamDemo7(wxCommandEvent& WXUNUSED(event))
     wxBufferedInputStream buf_input( file_input );
 
     ch = buf_input.GetC();
-    pos = buf_input.TellI();
+    size_t pos = buf_input.TellI();
     str.Printf( wxT("Read char: %d. Now at position %d\n\n"), (int) ch, (int) pos );
     textCtrl.WriteText( str );
 
@@ -904,11 +893,6 @@ void MyApp::DoUnicodeDemo(wxCommandEvent& WXUNUSED(event))
     printf( "\n\nConversion with wxConvLocal:\n" );
     wxConvCurrent = &wxConvLocal;
     printf( (const char*) str.mbc_str() );
-#if defined(__WXGTK__)
-    printf( "\n\nConversion with wxConvGdk:\n" );
-    wxConvCurrent = &wxConvGdk;
-    printf( (const char*) str.mbc_str() );
-#endif
     printf( "\n\nConversion with wxConvLibc:\n" );
     wxConvCurrent = &wxConvLibc;
     printf( (const char*) str.mbc_str() );
@@ -973,7 +957,7 @@ void MyApp::DoMIMEDemo(wxCommandEvent& WXUNUSED(event))
             textCtrl << _T("MIME information about extension '") << ext << _T("'\n")
                      << _T("\tMIME type: ") << ( !type ? wxT("unknown")
                                                    : type.c_str() ) << '\n'
-                     << _T("\tDescription: ") << ( !desc ? wxT("") : desc.c_str() )
+                     << _T("\tDescription: ") << ( !desc ? wxEmptyString : desc.c_str() )
                         << '\n'
                      << _T("\tCommand to open: ") << ( !open ? wxT("no") : open.c_str() )
                         << '\n';
@@ -991,186 +975,32 @@ void MyApp::DoByteOrderDemo(wxCommandEvent& WXUNUSED(event))
     textCtrl.Clear();
     textCtrl << _T("\nTest byte order macros:\n\n");
 
-    if (wxBYTE_ORDER == wxLITTLE_ENDIAN)
+    #if wxBYTE_ORDER == wxLITTLE_ENDIAN
         textCtrl << _T("This is a little endian system.\n\n");
-    else
+    #else
         textCtrl << _T("This is a big endian system.\n\n");
+    #endif
 
     wxString text;
 
     wxInt32 var = 0xF1F2F3F4;
-    text = _T("");
+    text = wxEmptyString;
     text.Printf( _T("Value of wxInt32 is now: %#x.\n\n"), var );
     textCtrl.WriteText( text );
 
-    text = _T("");
+    text = wxEmptyString;
     text.Printf( _T("Value of swapped wxInt32 is: %#x.\n\n"), wxINT32_SWAP_ALWAYS( var ) );
     textCtrl.WriteText( text );
 
-    text = _T("");
+    text = wxEmptyString;
     text.Printf( _T("Value of wxInt32 swapped on little endian is: %#x.\n\n"), wxINT32_SWAP_ON_LE( var ) );
     textCtrl.WriteText( text );
 
-    text = _T("");
+    text = wxEmptyString;
     text.Printf( _T("Value of wxInt32 swapped on big endian is: %#x.\n\n"), wxINT32_SWAP_ON_BE( var ) );
     textCtrl.WriteText( text );
 }
 
-#if wxUSE_TIMEDATE
-
-void MyApp::DoTimeDemo(wxCommandEvent& WXUNUSED(event))
-{
-    wxTextCtrl& textCtrl = * GetTextCtrl();
-
-    textCtrl.Clear();
-    textCtrl << _T("\nTest class wxTime:\n");
-    wxTime now;
-    textCtrl << _T("It is now ") << (wxString) now << _T("\n");
-}
-
-void MyApp::DoDateDemo(wxCommandEvent& WXUNUSED(event))
-{
-    wxTextCtrl& textCtrl = * GetTextCtrl();
-
-    textCtrl.Clear();
-    textCtrl << _T("\nTest class wxDate") << _T("\n");
-
-    // Various versions of the constructors
-    // and various output
-
-    wxDate x(10,20,1962);
-
-    textCtrl << x.FormatDate(wxFULL) << _T("  (full)\n");
-
-    // constuctor with a string, just printing the day of the week
-    wxDate y(_T("8/8/1988"));
-
-    textCtrl << y.FormatDate(wxDAY) << _T("  (just day)\n");
-
-    // constructor with a julian
-    wxDate z( 2450000L );
-    textCtrl << z.FormatDate(wxFULL) << _T("  (full)\n");
-
-    // using date addition and subtraction
-    wxDate a = x + 10;
-    textCtrl << a.FormatDate(wxFULL) << _T("  (full)\n");
-    a = a - 25;
-    textCtrl << a.FormatDate(wxEUROPEAN) << _T("  (European)\n");
-
-    // Using subtraction of two date objects
-    wxDate a1 = wxString(_T("7/13/1991"));
-    wxDate a2 = a1 + 14;
-    textCtrl << (a1-a2) << _T("\n");
-    textCtrl << (a2+=10) << _T("\n");
-
-    a1++;
-    textCtrl << _T("Tomorrow= ") << a1.FormatDate(wxFULL) << _T("\n");
-
-    wxDate tmpDate1(_T("08/01/1991"));
-    wxDate tmpDate2(_T("07/14/1991"));
-    textCtrl << _T("a1 (7-14-91) < 8-01-91 ? ==> ") << ((a1 < tmpDate1) ? _T("TRUE") : _T("FALSE")) << _T("\n");
-    textCtrl << _T("a1 (7-14-91) > 8-01-91 ? ==> ") << ((a1 > tmpDate1) ? _T("TRUE") : _T("FALSE")) << _T("\n");
-    textCtrl << _T("a1 (7-14-91)== 7-14-91 ? ==> ") << ((a1==tmpDate2) ? _T("TRUE") : _T("FALSE")) << _T("\n");
-
-    wxDate a3 = a1;
-    textCtrl << _T("a1 (7-14-91)== a3 (7-14-91) ? ==> ") << ((a1==a3) ? _T("TRUE") : _T("FALSE")) << _T("\n");
-    wxDate a4 = a1;
-    textCtrl << _T("a1 (7-14-91)== a4 (7-15-91) ? ==> ") << ((a1==++a4) ? _T("TRUE") : _T("FALSE")) << _T("\n");
-
-    wxDate a5 = wxString(_T("today"));
-    textCtrl << _T("Today is: ") << a5 << _T("\n");
-    a4 = _T("TODAY");
-    textCtrl << _T("Today (a4) is: ") << a4 << _T("\n");
-
-    textCtrl << _T("Today + 4 is: ") << (a4+=4) << _T("\n");
-    a4 = _T("TODAY");
-    textCtrl << _T("Today - 4 is: ") << (a4-=4) << _T("\n");
-
-    textCtrl << _T("=========== Leap Year Test ===========\n");
-    a1 = _T("1/15/1992");
-    textCtrl << a1.FormatDate(wxFULL) << _T("  ") << ((a1.IsLeapYear()) ? _T("Leap") : _T("non-Leap"));
-    textCtrl << _T("  ") << _T("day of year:  ") << a1.GetDayOfYear() << _T("\n");
-
-    a1 = _T("2/16/1993");
-    textCtrl << a1.FormatDate(wxFULL) << _T("  ") << ((a1.IsLeapYear()) ? _T("Leap") : _T("non-Leap"));
-    textCtrl << _T("  ") << _T("day of year:  ") << a1.GetDayOfYear() << _T("\n");
-
-    textCtrl << _T("================== string assignment test ====================\n");
-    wxString date_string=a1;
-    textCtrl << _T("a1 as a string (s/b 2/16/1993) ==> ") << date_string << _T("\n");
-
-    textCtrl << _T("================== SetFormat test ============================\n");
-    a1.SetFormat(wxFULL);
-    textCtrl << _T("a1 (s/b FULL format) ==> ") << a1 << _T("\n");
-    a1.SetFormat(wxEUROPEAN);
-    textCtrl << _T("a1 (s/b EUROPEAN format) ==> ") << a1 << _T("\n");
-
-    textCtrl << _T("================== SetOption test ============================\n");
-    textCtrl << _T("Date abbreviation ON\n");
-
-    a1.SetOption(wxDATE_ABBR);
-    a1.SetFormat(wxMONTH);
-    textCtrl << _T("a1 (s/b MONTH format) ==> ") << a1 << _T("\n");
-    a1.SetFormat(wxDAY);
-    textCtrl << _T("a1 (s/b DAY format) ==> ") << a1 << _T("\n");
-    a1.SetFormat(wxFULL);
-    textCtrl << _T("a1 (s/b FULL format) ==> ") << a1 << _T("\n");
-    a1.SetFormat(wxEUROPEAN);
-    textCtrl << _T("a1 (s/b EUROPEAN format) ==> ") << a1 << _T("\n");
-    textCtrl << _T("Century suppression ON\n");
-    a1.SetOption(wxNO_CENTURY);
-    a1.SetFormat(wxMDY);
-    textCtrl << _T("a1 (s/b MDY format) ==> ") << a1 << _T("\n");
-    textCtrl << _T("Century suppression OFF\n");
-    a1.SetOption(wxNO_CENTURY,FALSE);
-    textCtrl << _T("a1 (s/b MDY format) ==> ") << a1 << _T("\n");
-    textCtrl << _T("Century suppression ON\n");
-    a1.SetOption(wxNO_CENTURY);
-    textCtrl << _T("a1 (s/b MDY format) ==> ") << a1 << _T("\n");
-    a1.SetFormat(wxFULL);
-    textCtrl << _T("a1 (s/b FULL format) ==> ") << a1 << _T("\n");
-
-    textCtrl << _T("\n=============== Version 4.0 Enhancement Test =================\n");
-
-    wxDate v4(_T("11/26/1966"));
-    textCtrl << _T("\n---------- Set Stuff -----------\n");
-    textCtrl << _T("First, 'Set' to today...") << _T("\n");
-    textCtrl << _T("Before 'Set' => ") << v4 << _T("\n");
-    textCtrl << _T("After  'Set' => ") << v4.Set() << _T("\n\n");
-
-    textCtrl << _T("Set to 11/26/66 => ") << v4.Set(11,26,1966) << _T("\n");
-    textCtrl << _T("Current Julian  => ") << v4.GetJulianDate() << _T("\n");
-    textCtrl << _T("Set to Julian 2450000L => ") << v4.Set(2450000L) << _T("\n");
-    textCtrl << _T("See! => ") << v4.GetJulianDate() << _T("\n");
-
-    textCtrl << _T("---------- Add Stuff -----------\n");
-    textCtrl << _T("Start => ") << v4 << _T("\n");
-    textCtrl << _T("Add 4 Weeks => ") << v4.AddWeeks(4) << _T("\n");
-    textCtrl << _T("Sub 1 Month => ") << v4.AddMonths(-1) << _T("\n");
-    textCtrl << _T("Add 2 Years => ") << v4.AddYears(2) << _T("\n");
-
-    textCtrl << _T("---------- Misc Stuff -----------\n");
-    textCtrl << _T("The date aboves' day of the month is => ") << v4.GetDay() << _T("\n");
-    textCtrl << _T("There are ") << v4.GetDaysInMonth() << _T(" days in this month.\n");
-    textCtrl << _T("The first day of this month lands on ") << v4.GetFirstDayOfMonth() << _T("\n");
-    textCtrl << _T("This day happens to be ") << v4.GetDayOfWeekName() << _T("\n");
-    textCtrl << _T("the ") << v4.GetDayOfWeek() << _T(" day of the week,") << _T("\n");
-    textCtrl << _T("on the ") << v4.GetWeekOfYear() << _T(" week of the year,") << _T("\n");
-    textCtrl << _T("on the ") << v4.GetWeekOfMonth() << _T(" week of the month, ") << _T("\n");
-    textCtrl << _T("(which is ") << v4.GetMonthName() << _T(")\n");
-    textCtrl << _T("the ")<< v4.GetMonth() << _T("th month in the year.\n");
-    textCtrl << _T("The year alone is ") << v4.GetYear() << _T("\n");
-
-    textCtrl << _T("---------- First and Last Stuff -----------\n");
-    v4.Set();
-    textCtrl << _T("The first date of this month is ") << v4.GetMonthStart() << _T("\n");
-    textCtrl << _T("The last date of this month is ") << v4.GetMonthEnd() << _T("\n");
-    textCtrl << _T("The first date of this year is ") << v4.GetYearStart() << _T("\n");
-    textCtrl << _T("The last date of this year is ") << v4.GetYearEnd() << _T("\n");
-}
-
-#endif // wxUSE_TIMEDATE
-
 void MyApp::DoVariantDemo(wxCommandEvent& WXUNUSED(event) )
 {
     wxTextCtrl& textCtrl = * GetTextCtrl();
@@ -1194,10 +1024,8 @@ void MyApp::DoVariantDemo(wxCommandEvent& WXUNUSED(event) )
     long l = var1;
 
     // suppress compile warnings about unused variables
-    if ( l < v )
-    {
-        ;
-    }
+    wxUnusedVar(l);
+    wxUnusedVar(v);
 
     wxStringList stringList;
     stringList.Add(_T("one")); stringList.Add(_T("two")); stringList.Add(_T("three"));
@@ -1217,6 +1045,18 @@ void MyApp::DoVariantDemo(wxCommandEvent& WXUNUSED(event) )
     {
         textCtrl << _T("var1[") << (int) i << _T("] (type ") << var1[i].GetType() << _T(") = ") << var1[i].MakeString() << _T("\n");
     }
+
+    var1 = wxVariant(new wxFont(wxSystemSettings::GetFont(wxSYS_OEM_FIXED_FONT)));
+    textCtrl << _T("var1 = (wxfont)\"");
+    wxFont* font = wxGetVariantCast(var1,wxFont);
+    if (font)
+    {
+        textCtrl << font->GetNativeFontInfoDesc() << _T("\"\n");
+    }
+    else
+    {
+        textCtrl << _T("(null)\"\n");
+    }
 }
 
 BEGIN_EVENT_TABLE(MyFrame, wxFrame)
@@ -1226,21 +1066,21 @@ END_EVENT_TABLE()
 
 // My frame constructor
 MyFrame::MyFrame(wxFrame *parent, const wxString& title,
-       const wxPoint& pos, const wxSize& size):
-  wxFrame(parent, -1, title, pos, size)
+    const wxPoint& pos, const wxSize& size)
+    : wxFrame(parent, wxID_ANY, title, pos, size)
 {}
 
 void MyFrame::OnQuit(wxCommandEvent& WXUNUSED(event) )
 {
-  Close(TRUE);
+    Close(true);
 }
 
 void MyFrame::OnAbout(wxCommandEvent& WXUNUSED(event) )
 {
-  wxMessageDialog dialog(this, _T("Tests various wxWindows types"),
-      _T("About Types"), wxYES_NO|wxCANCEL);
+    wxMessageDialog dialog(this, _T("Tests various wxWindows types"),
+        _T("About Types"), wxYES_NO|wxCANCEL);
 
-  dialog.ShowModal();
+    dialog.ShowModal();
 }