From: Robin Dunn Date: Fri, 28 May 2004 19:59:29 +0000 (+0000) Subject: Some error recovery and other tweaks X-Git-Url: https://git.saurik.com/wxWidgets.git/commitdiff_plain/0625ef6849f4069540a05ccfb6a42f5fd87a97cb?hp=fdde476d53dcdb03bebd8ead8cea2c377fc3567d Some error recovery and other tweaks git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@27490 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775 --- diff --git a/wxPython/samples/embedded/embedded.cpp b/wxPython/samples/embedded/embedded.cpp index 20213fdae0..2805a649cf 100644 --- a/wxPython/samples/embedded/embedded.cpp +++ b/wxPython/samples/embedded/embedded.cpp @@ -42,8 +42,8 @@ class MyApp : public wxApp { public: virtual bool OnInit(); - virtual ~MyApp(); - void Init_wxPython(); + virtual int OnExit(); + bool Init_wxPython(); private: PyThreadState* m_mainTState; }; @@ -68,36 +68,51 @@ private: bool MyApp::OnInit() { - Init_wxPython(); + if ( !Init_wxPython() ) + // don't start the app if we can't initialize wxPython. + return false; + MyFrame *frame = new MyFrame(_T("Embedded wxPython Test"), - wxPoint(50, 50), wxSize(700, 600)); - frame->Show(TRUE); - return TRUE; + wxDefaultPosition, wxSize(700, 600)); + frame->Show(true); + return true; } -void MyApp::Init_wxPython() + +bool MyApp::Init_wxPython() { // Initialize Python Py_Initialize(); PyEval_InitThreads(); - // Load the wxPython core API. Imports the wx._core module and sets a - // local pointer to a function table located there. - wxPyCoreAPI_IMPORT(); - + // Load the wxPython core API. Imports the wx._core_ module and sets a + // local pointer to a function table located there. The pointer is used + // internally by the rest of the API functions. + if ( ! wxPyCoreAPI_IMPORT() ) { + wxLogError(wxT("***** Error importing the wxPython API! *****")); + PyErr_Print(); + Py_Finalize(); + return false; + } + // Save the current Python thread state and release the // Global Interpreter Lock. m_mainTState = wxPyBeginAllowThreads(); + + return true; } -MyApp::~MyApp() +int MyApp::OnExit() { // Restore the thread state and tell Python to cleanup after itself. - // wxPython will do its own cleanup as part of that process. + // wxPython will do its own cleanup as part of that process. This is done + // in OnExit instead of ~MyApp because OnExit is only called if OnInit is + // successful. wxPyEndAllowThreads(m_mainTState); Py_Finalize(); + return 0; } @@ -138,8 +153,8 @@ MyFrame::MyFrame(const wxString& title, const wxPoint& pos, const wxSize& size) // Make some child windows from C++ wxSplitterWindow* sp = new wxSplitterWindow(this, -1); - wxPanel* p1 = new wxPanel(sp, -1); - p1->SetFont(wxFont(12, wxSWISS, wxNORMAL, wxBOLD)); + wxPanel* p1 = new wxPanel(sp, -1, wxDefaultPosition, wxDefaultSize, wxSUNKEN_BORDER); + new wxStaticText(p1, -1, _T("The frame, menu, splitter, this panel and this text were created in C++..."), wxPoint(10,10)); @@ -172,7 +187,7 @@ void MyFrame::OnPyFrame(wxCommandEvent& event) // C++ code in any way, you can execute it with PyRun_SimpleString. - // First, whenever you do anyting with Python objects or code, you + // First, whenever you do anything with Python objects or code, you // *MUST* aquire the Global Interpreter Lock and block other // Python threads from running. bool blocked = wxPyBeginBlockThreads(); diff --git a/wxPython/samples/embedded/embedded_sample.py b/wxPython/samples/embedded/embedded_sample.py index 5fa38aba93..beed13cbb0 100644 --- a/wxPython/samples/embedded/embedded_sample.py +++ b/wxPython/samples/embedded/embedded_sample.py @@ -3,12 +3,11 @@ from wx.py import shell, version class MyPanel(wx.Panel): def __init__(self, parent): - wx.Panel.__init__(self, parent, -1) + wx.Panel.__init__(self, parent, -1, style=wx.SUNKEN_BORDER) text = wx.StaticText(self, -1, "Everything on this side of the splitter comes from Python.") - text.SetFont(wx.Font(12, wx.SWISS, wx.NORMAL, wx.BOLD)) - + intro = 'Welcome To PyCrust %s - The Flakiest Python Shell' % version.VERSION pycrust = shell.Shell(self, -1, introText=intro) #pycrust = wxTextCtrl(self, -1, intro)