X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/9416aa89ca06d0fb20b1002e026d2c7ac7aa6a17..7487606ad653885f3351ce605cb8ef07969b9a1f:/wxPython/demo/OOR.py diff --git a/wxPython/demo/OOR.py b/wxPython/demo/OOR.py index 3ef0878d58..d58bc42bbd 100644 --- a/wxPython/demo/OOR.py +++ b/wxPython/demo/OOR.py @@ -27,10 +27,12 @@ class TestPanel(wxPanel): btns.Add(self.btn2) btns.Add(50, -1, 1, wxEXPAND) - sizer.Add(btns, 0, wxEXPAND|wxLEFT|wxRIGHT|wxBOTTOM, 5) + sizer.Add(btns, 0, wxEXPAND|wxALL, 15) self.SetSizer(sizer) - self.SetAutoLayout(true) + self.SetAutoLayout(True) + + self.sizer = sizer # save it for testing later EVT_BUTTON(self, BTN1, self.OnFindButton1) EVT_BUTTON(self, BTN2, self.OnFindButton2) @@ -59,6 +61,24 @@ class TestPanel(wxPanel): else: self.log.write("The objects are NOT the same! \n") + win = evt.GetEventObject() + if win is None: + self.log.write("***** OOPS! None returned...\n") + return + if win is self.btn2: + self.log.write("The objects are the same! \n") + else: + self.log.write("The objects are NOT the same! \n") + + sizer = self.GetSizer() + if sizer is None: + self.log.write("***** OOPS! None returned...\n") + return + if sizer is self.sizer: + self.log.write("The objects are the same! \n") + else: + self.log.write("The objects are NOT the same! \n") + #---------------------------------------------------------------------- @@ -79,21 +99,21 @@ SWIG isn't able to tell the actual type it just creates a new Python shadow object of the base type to wrap around the base type pointer and returns it. -

In wxPython this can cause annoying issues. For example if you -call: +

In wxPython prior to 2.3.0 this could cause annoying issues. For +example if you called:

 
         myText = someWindow.FindWindowById(txtID)
 
-expecting to get a wxTextCtrl you will actually get a wxWindow object +expecting to get a wxTextCtrl you would actually get a wxWindow object instead. If you then try to call SetValue on that object you'll get an exception since there is no such method. This is the reason for the wxPyTypeCast hack that has been in wxPython for so long. -

Even with wxPyTypeCast there is the issue that the object returned -is not the same one that was created in Python originally, but a new +

Even with wxPyTypeCast there was the issue that the object returned +was not the same one that was created in Python originally, but a new object of the same type that wraps the same C++ pointer. If the programmer has set additional attributes of that original object they will not exist in the new object. @@ -112,7 +132,16 @@ and be able to then turn wxPyTypeCast in to a no-op.

The first button below shows the first of these phases (working) -and the second will show #2 (not yet working.) +and the second will show #2 (working as of 2.3.2) """ + + + + +if __name__ == '__main__': + import sys,os + import run + run.main(['', os.path.basename(sys.argv[0])]) +