X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/4acff284f9516e2a4f0fcfa7bcfa3f497b8005cc..a22d737782e9b36acb6f400db669845cf73cc478:/wxPython/src/_extras.py diff --git a/wxPython/src/_extras.py b/wxPython/src/_extras.py index 866ab98cf7..d90b2a39f9 100644 --- a/wxPython/src/_extras.py +++ b/wxPython/src/_extras.py @@ -649,6 +649,8 @@ def wxPyTypeCast(obj, typeStr): #---------------------------------------------------------------------------- +class wxPyDeadObjectError(AttributeError): + pass class _wxPyDeadObject: """ @@ -656,15 +658,21 @@ class _wxPyDeadObject: changed to this class when the C++ object is deleted. This should help prevent crashes due to referencing a bogus C++ pointer. """ + reprStr = "wxPython wrapper for DELETED %s object! (The C++ object no longer exists.)" + attrStr = "The C++ %s object has been deleted, attribute access no longer allowed." + def __repr__( self ): if not hasattr(self, "_name"): self._name = "[unknown]" - return 'wxPython wrapper for deleted %s object!!! Programming logic error' % self._name + return self.reprStr % self._name def __getattr__( self, *args ): if not hasattr(self, "_name"): self._name = "[unknown]" - raise ValueError, 'Attempt to access attribute of a deleted %s object' % self._name + raise wxPyDeadObjectError( self.attrStr % self._name ) + + def __nonzero__(self): + return 0 #----------------------------------------------------------------------