]> git.saurik.com Git - wxWidgets.git/blobdiff - wxPython/demo/ErrorDialogs.py
When destroying the window, only remove it from its Cocoa parent if
[wxWidgets.git] / wxPython / demo / ErrorDialogs.py
index 18076f8bc1362f1b22ede1ca53b25114b9feed1a..f264f8f92f057090c1064a8fadfe9f75c5ed91b9 100644 (file)
@@ -2,10 +2,25 @@
 # usual wxWindows license stuff here.
 # by Chris Fama, with thanks to Robin Dunn, and others on the wxPython-users
 # mailing list.
 # usual wxWindows license stuff here.
 # by Chris Fama, with thanks to Robin Dunn, and others on the wxPython-users
 # mailing list.
+#
+# 11/22/2003 - Jeff Grimmett (grimmtooth@softhome.net)
+#
+# o Updated for wx namespace
+# 
+# 11/25/2003 - Jeff Grimmett (grimmtooth@softhome.net)
+#
+# o Looks like we have issues until the library is updated.
+#   - Had to rename back to wx* naming conventions
+#   - Getting unusual failures in the library itself when that is done.
+#
+
+import  sys
+
+import  wx
+import  wx.lib.ErrorDialogs as  edlg
 
 
-from wxPython.wx import *
-from wxPython.lib.ErrorDialogs import *
 _debug = 0
 _debug = 0
+
 ID_TEXT = 10000
 ID_BUTTON_wxPyNonFatalError = 10001
 ID_BUTTON_wxPyFatalError = 10002
 ID_TEXT = 10000
 ID_BUTTON_wxPyNonFatalError = 10001
 ID_BUTTON_wxPyFatalError = 10002
@@ -14,53 +29,63 @@ ID_BUTTON_wxPyNonFatalErrorDialog = 10004
 ID_BUTTON_wxPyFatalErrorDialogWithTraceback = 10005
 ID_BUTTON_wxPyNonFatalErrorDialogWithTraceback = 10006
 
 ID_BUTTON_wxPyFatalErrorDialogWithTraceback = 10005
 ID_BUTTON_wxPyNonFatalErrorDialogWithTraceback = 10006
 
-def ErrorDialogsDemoPanelFunc( parent, call_fit = true, set_sizer = true ):
-    item0 = wxBoxSizer( wxVERTICAL )
-    
-    item1 = wxStaticText( parent, ID_TEXT, "Please select one of the buttons below for an example using explicit errors...", wxDefaultPosition, wxDefaultSize, 0 )
-    item0.AddWindow( item1, 0, wxALIGN_CENTRE|wxALL, 5 )
+def ErrorDialogsDemoPanelFunc( parent, call_fit = True, set_sizer = True ):
+    item0 = wx.BoxSizer( wx.VERTICAL )
+
+    item1 = wx.StaticText(
+        parent, ID_TEXT, 
+        "Please select one of the buttons below for an example using explicit errors..."
+        )
+        
+    item0.AddWindow( item1, 0, wx.ALIGN_CENTRE|wx.ALL, 5 )
+
+    item2 = wx.FlexGridSizer( 0, 2, 0, 0 )
+
+    item3 = wx.Button( parent, ID_BUTTON_wxPyNonFatalError, "wxPyNonFatalError")
+    item2.AddWindow( item3, 0, wx.ALIGN_CENTRE|wx.ALL, 5 )
 
 
-    item2 = wxFlexGridSizer( 0, 2, 0, 0 )
-    
-    item3 = wxButton( parent, ID_BUTTON_wxPyNonFatalError, "wxPyNonFatalError", wxDefaultPosition, wxDefaultSize, 0 )
-    item2.AddWindow( item3, 0, wxALIGN_CENTRE|wxALL, 5 )
+    item4 = wx.Button( parent, ID_BUTTON_wxPyFatalError, "wxPyFatalError")
+    item2.AddWindow( item4, 0, wx.ALIGN_CENTRE|wx.ALL, 5 )
 
 
-    item4 = wxButton( parent, ID_BUTTON_wxPyFatalError, "wxPyFatalError", wxDefaultPosition, wxDefaultSize, 0 )
-    item2.AddWindow( item4, 0, wxALIGN_CENTRE|wxALL, 5 )
+    item0.AddSizer( item2, 0, wx.ALIGN_CENTRE|wx.ALL, 5 )
 
 
-    item0.AddSizer( item2, 0, wxALIGN_CENTRE|wxALL, 5 )
+    item5 = wx.StaticText( parent, ID_TEXT, "Please select one of the buttons below for interpreter errors...")
+    item0.AddWindow( item5, 0, wx.ALIGN_CENTRE|wx.ALL, 5 )
 
 
-    item5 = wxStaticText( parent, ID_TEXT, "Please select one of the buttons below for interpreter errors...", wxDefaultPosition, wxDefaultSize, 0 )
-    item0.AddWindow( item5, 0, wxALIGN_CENTRE|wxALL, 5 )
+    item6 = wx.FlexGridSizer( 0, 2, 0, 0 )
 
 
-    item6 = wxFlexGridSizer( 0, 2, 0, 0 )
-    
-    item7 = wxButton( parent, ID_BUTTON_wxPyFatalErrorDialog, "wxPyFatalErrorDialog", wxDefaultPosition, wxDefaultSize, 0 )
-    item6.AddWindow( item7, 0, wxALIGN_CENTRE|wxALL, 5 )
+    item7 = wx.Button( parent, ID_BUTTON_wxPyFatalErrorDialog, "wxPyFatalErrorDialog")
+    item6.AddWindow( item7, 0, wx.ALIGN_CENTRE|wx.ALL, 5 )
 
 
-    item8 = wxButton( parent, ID_BUTTON_wxPyNonFatalErrorDialog, "wxPyNonFatalErrorDialog", wxDefaultPosition, wxDefaultSize, 0 )
-    item6.AddWindow( item8, 0, wxALIGN_CENTRE|wxALL, 5 )
+    item8 = wx.Button( parent, ID_BUTTON_wxPyNonFatalErrorDialog, "wxPyNonFatalErrorDialog")
+    item6.AddWindow( item8, 0, wx.ALIGN_CENTRE|wx.ALL, 5 )
 
 
-    item9 = wxButton( parent, ID_BUTTON_wxPyFatalErrorDialogWithTraceback, "wxPyFatalErrorDialogWithTraceback", wxDefaultPosition, wxDefaultSize, 0 )
-    item6.AddWindow( item9, 0, wxALIGN_CENTRE|wxALL, 5 )
+    item9 = wx.Button(
+        parent, ID_BUTTON_wxPyFatalErrorDialogWithTraceback, 
+        "wxPyFatalErrorDialogWithTraceback"
+        )
+    item6.AddWindow( item9, 0, wx.ALIGN_CENTRE|wx.ALL, 5 )
 
 
-    item10 = wxButton( parent, ID_BUTTON_wxPyNonFatalErrorDialogWithTraceback, "wxPyNonFatalErrorDialogWithTraceback", wxDefaultPosition, wxDefaultSize, 0 )
+    item10 = wx.Button(
+        parent, ID_BUTTON_wxPyNonFatalErrorDialogWithTraceback, 
+        "wxPyNonFatalErrorDialogWithTraceback"
+        )
     item10.SetDefault()
     item10.SetDefault()
-    item6.AddWindow( item10, 0, wxALIGN_CENTRE|wxALL, 5 )
+    item6.AddWindow( item10, 0, wx.ALIGN_CENTRE|wx.ALL, 5 )
 
 
-    item0.AddSizer( item6, 0, wxALIGN_CENTRE|wxALL, 5 )
+    item0.AddSizer( item6, 0, wx.ALIGN_CENTRE|wx.ALL, 5 )
 
 
-    item11 = wxFlexGridSizer( 0, 2, 0, 0 )
-    
-    item0.AddSizer( item11, 0, wxALIGN_CENTRE|wxALL, 5 )
+    item11 = wx.FlexGridSizer( 0, 2, 0, 0 )
 
 
-    if set_sizer == true:
-        parent.SetAutoLayout( true )
+    item0.AddSizer( item11, 0, wx.ALIGN_CENTRE|wx.ALL, 5 )
+
+    if set_sizer == True:
+        parent.SetAutoLayout( True )
         parent.SetSizer( item0 )
         parent.SetSizer( item0 )
-        if call_fit == true:
+        if call_fit == True:
             item0.Fit( parent )
             item0.SetSizeHints( parent )
             item0.Fit( parent )
             item0.SetSizeHints( parent )
-    
+
     return item0
 
 # Menu bar functions
     return item0
 
 # Menu bar functions
@@ -70,43 +95,36 @@ def ErrorDialogsDemoPanelFunc( parent, call_fit = true, set_sizer = true ):
 
 # End of generated file
 
 
 # End of generated file
 
-class MyPanel(wxPanel):
+class MyPanel(wx.Panel):
     def __init__(self,parent=None):
     def __init__(self,parent=None):
-        wxPanel.__init__(self,parent,-1)
+        wx.Panel.__init__(self,parent,-1)
+
         args = (None, -1)
         kwargs = {
             'programname': "sumthing",
             'mailto': "me@sumwear",
         args = (None, -1)
         kwargs = {
             'programname': "sumthing",
             'mailto': "me@sumwear",
-            'whendismissed': "from wxPython.wx import * ; wxBell()"}
+            'whendismissed': "from wxPython.wx import * ; wxBell()"
+            }
+
         self.dialogs = map(apply,
         self.dialogs = map(apply,
-                           [wxPyNonFatalErrorDialogWithTraceback,
-                            wxPyNonFatalErrorDialog,#WithTraceback
-                            wxPyFatalErrorDialogWithTraceback,
-                            wxPyFatalErrorDialog],#WithTraceback
+                           [edlg.wxPyNonFatalErrorDialogWithTraceback,
+                            edlg.wxPyNonFatalErrorDialog,#WithTraceback
+                            edlg.wxPyFatalErrorDialogWithTraceback,
+                            edlg.wxPyFatalErrorDialog #WithTraceback
+                            ],
                            (args,) * 4,
                            (args,) * 4,
-                           (kwargs,) * 4)
+                           (kwargs,) * 4
+                           )
+
         ErrorDialogsDemoPanelFunc(self)
 
         ErrorDialogsDemoPanelFunc(self)
 
-        EVT_BUTTON(self,
-                   ID_BUTTON_wxPyFatalErrorDialog,
-                   self.DoDialog)
-        EVT_BUTTON(self,
-                   ID_BUTTON_wxPyNonFatalError,
-                   self.DoDialog)
-        EVT_BUTTON(self,
-                   ID_BUTTON_wxPyFatalError,
-                   self.DoDialog)
-        EVT_BUTTON(self,
-                   ID_BUTTON_wxPyFatalErrorDialogWithTraceback,
-                   self.DoDialog)
-        EVT_BUTTON(self,
-                   ID_BUTTON_wxPyNonFatalErrorDialog,
-                   self.DoDialog)
-        EVT_BUTTON(self,
-                   ID_BUTTON_wxPyNonFatalErrorDialogWithTraceback,
-                   self.DoDialog)
-        EVT_CLOSE(self,self.OnClose)
-    
+        self.Bind(wx.EVT_BUTTON, self.DoDialog, id=ID_BUTTON_wxPyFatalErrorDialog)
+        self.Bind(wx.EVT_BUTTON, self.DoDialog, id=ID_BUTTON_wxPyNonFatalError)
+        self.Bind(wx.EVT_BUTTON, self.DoDialog, id=ID_BUTTON_wxPyFatalError)
+        self.Bind(wx.EVT_BUTTON, self.DoDialog, id=ID_BUTTON_wxPyFatalErrorDialogWithTraceback)
+        self.Bind(wx.EVT_BUTTON, self.DoDialog, id=ID_BUTTON_wxPyNonFatalErrorDialog)
+        self.Bind(wx.EVT_BUTTON, self.DoDialog, id=ID_BUTTON_wxPyNonFatalErrorDialogWithTraceback)
+
     IndexFromID = {
         ID_BUTTON_wxPyFatalErrorDialog: 3,
         ID_BUTTON_wxPyFatalErrorDialogWithTraceback: 2,
     IndexFromID = {
         ID_BUTTON_wxPyFatalErrorDialog: 3,
         ID_BUTTON_wxPyFatalErrorDialogWithTraceback: 2,
@@ -116,11 +134,12 @@ class MyPanel(wxPanel):
 
     def DoDialog(self,event):
         id = event.GetId()
 
     def DoDialog(self,event):
         id = event.GetId()
+
         if id in [ID_BUTTON_wxPyFatalError,ID_BUTTON_wxPyNonFatalError]:
             if id == ID_BUTTON_wxPyFatalError:
                 print "%s.DoDialog(): testing explicit wxPyFatalError..."\
                       % self
         if id in [ID_BUTTON_wxPyFatalError,ID_BUTTON_wxPyNonFatalError]:
             if id == ID_BUTTON_wxPyFatalError:
                 print "%s.DoDialog(): testing explicit wxPyFatalError..."\
                       % self
-                wxPyFatalError(self,"Test Non-fatal error.<p>"
+                edlg.wxPyFatalError(self,"Test Non-fatal error.<p>"
                                "Nearly arbitrary HTML (i.e., that which is"
                                " understood by <B><I>wxHtmlWindow</i></b>)."
                                "<p><table border=\"2\"><tr><td>This</td><td>is</td></tr>"
                                "Nearly arbitrary HTML (i.e., that which is"
                                " understood by <B><I>wxHtmlWindow</i></b>)."
                                "<p><table border=\"2\"><tr><td>This</td><td>is</td></tr>"
@@ -128,7 +147,7 @@ class MyPanel(wxPanel):
             else:
                 print "%s.DoDialog(): testing explicit wxPyNonFatalError..."\
                       % self
             else:
                 print "%s.DoDialog(): testing explicit wxPyNonFatalError..."\
                       % self
-                wxPyNonFatalError(self,"Test Non-fatal error.<p>"
+                edlg.wxPyNonFatalError(self,"Test Non-fatal error.<p>"
                                   "Nearly arbitrary HTML (i.e., that which is"
                                   " understood by <B><I>wxHtmlWindow</i></b>)."
                                   "<p><table border=\"2\"><tr><td>This</td><td>is</td></tr>"
                                   "Nearly arbitrary HTML (i.e., that which is"
                                   " understood by <B><I>wxHtmlWindow</i></b>)."
                                   "<p><table border=\"2\"><tr><td>This</td><td>is</td></tr>"
@@ -138,41 +157,41 @@ class MyPanel(wxPanel):
             print "%s.DoDialog(): testing %s..." % (self,sys.stderr)
             this_will_generate_a_NameError_exception
 
             print "%s.DoDialog(): testing %s..." % (self,sys.stderr)
             this_will_generate_a_NameError_exception
 
-    def OnClose(self,evt):
+    def ShutdownDemo(self):
         for d in self.dialogs:
         for d in self.dialogs:
-            d.Destroy ()
-        self.Destroy ()
+            d.Destroy()
+
+
 
 
-class MyFrame(wxFrame):
+class MyFrame(wx.Frame):
     def __init__(self,parent=None):
     def __init__(self,parent=None):
-        wxFrame.__init__(self,parent,-1,
+        wx.Frame.__init__(self,parent,-1,
                          "Please make a selection...",
                          )
                          "Please make a selection...",
                          )
-        self. panel = MyPanel(self)
-        EVT_CLOSE (self,self.OnCloseWindow)
+        self.panel = MyPanel(self)
+        self.Bind(wx.EVT_CLOSE, self.OnCloseWindow)
 
     def OnCloseWindow(self,event):
         self.panel.Close()
         self.Destroy()
 
 
     def OnCloseWindow(self,event):
         self.panel.Close()
         self.Destroy()
 
-class MyApp(wxApp):
+class MyApp(wx.App):
     def OnInit(self):
         frame = MyFrame()
     def OnInit(self):
         frame = MyFrame()
-        frame.Show(true)
+        frame.Show(True)
         self.SetTopWindow(frame)
         self.SetTopWindow(frame)
-        return true
+        return True
 
 def runTest(pframe, nb, log):
     panel = MyPanel(nb)
     return panel
 
 
 def runTest(pframe, nb, log):
     panel = MyPanel(nb)
     return panel
 
-from wxPython.lib import ErrorDialogs
-ErrorDialogs._debug = 1
+edlg._debug = 1
 
 if __name__ == "__main__":
 
 if __name__ == "__main__":
-    sys.stderr = wxPyNonWindowingErrorHandler()
+    sys.stderr = edlg.wxPyNonWindowingErrorHandler()
     app = MyApp(0)
     app.MainLoop()
     sys.exit()
 else:
     app = MyApp(0)
     app.MainLoop()
     sys.exit()
 else:
-    overview = ErrorDialogs.__doc__
+    overview = edlg.__doc__