diff --git a/capnp/lib/capnp.pyx b/capnp/lib/capnp.pyx index ea31e73..298b9bd 100644 --- a/capnp/lib/capnp.pyx +++ b/capnp/lib/capnp.pyx @@ -260,9 +260,9 @@ class KjException(Exception): def _to_python(self): message = self.message - if self.wrapper.type == 'FAILED': + if self.wrapper is not None and self.wrapper.type == 'FAILED': if 'has no such' in self.message: - return AttributeError(message) + return AttributeError(message).with_traceback(self.__traceback__) return self @@ -1147,7 +1147,7 @@ cdef class _DynamicStructReader: try: return self._get(field) except KjException as e: - raise e._to_python(), None, _sys.exc_info()[2] + raise e._to_python() from None cpdef _get_by_field(self, _StructSchemaField field): return to_python_reader(self.thisptr.getByField(field.thisptr), self) @@ -1394,7 +1394,7 @@ cdef class _DynamicStructBuilder: try: return self._get(field) except KjException as e: - raise e._to_python(), None, _sys.exc_info()[2] + raise e._to_python() from None cpdef _set(self, field, value): _setDynamicField(self.thisptr, field, value, self._parent) @@ -1406,7 +1406,7 @@ cdef class _DynamicStructBuilder: try: self._set(field, value) except KjException as e: - raise e._to_python(), None, _sys.exc_info()[2] + raise e._to_python() from None cpdef _has(self, field): return self.thisptr.has(field) @@ -1658,7 +1658,7 @@ cdef class _DynamicStructPipeline: try: return self._get(field) except KjException as e: - raise e._to_python(), None, _sys.exc_info()[2] + raise e._to_python() from None property schema: """A property that returns the _StructSchema object matching this reader""" @@ -2044,7 +2044,7 @@ cdef class _RemotePromise: try: return self._get(field) except KjException as e: - raise e._to_python(), None, _sys.exc_info()[2] + raise e._to_python() from None property schema: """A property that returns the _StructSchema object matching this reader""" @@ -2198,7 +2198,7 @@ cdef class _DynamicCapabilityClient: raise AttributeError('Method named %s not found' % name) return _partial(self._send, name) except KjException as e: - raise e._to_python(), None, _sys.exc_info()[2] + raise e._to_python() from None cpdef upcast(self, schema) except +reraise_kj_exception: cdef _InterfaceSchema s