Context managers for controlling exception chaining.
Project description
Provides a different way of controlling exception chaining (the implicit __context__ and explicit __cause__) beyond just raise ... from ....
Versioning
This library’s version numbers follow the SemVer 2.0.0 specification.
Installation
pip install exceptioncontext
Usage
Import as needed:
from exceptioncontext import cause, context, suppress_context
Explicitly chain exception (set __cause__):
with cause(Exception("foo")):
raise Exception("bar")
Override implicitly chained exception (set __context__):
with context(Exception("foo")):
raise Exception("bar")
Manually control context suppression (set __suppress_context__):
with suppress_context(False):
raise Exception("foo")
Reduce repetition in code like
if some_condition:
raise SomeError("foo") from earlier_exception
elif other_condition:
raise OtherError("bar") from earlier_exception
else:
raise Exception("qux") from earlier_exception
by turning it into
with context(earlier_exception):
if some_condition:
raise SomeError("foo")
elif other_condition:
raise OtherError("bar")
else:
raise Exception("qux")
You now have more freedom in refactoring exception logic, because chaining is fully independent of the raise statement, and freely composable with other code:
with cause(earlier_exception):
helper_function()
Portability
Portable to all releases of both Python 3 and Python 2.
(The oldest tested is 2.5, but it will likely work on all Python 2 versions and probably on even earlier versions, when paired with something like with-as-a-function.)
On implementations of Python where setting the exception chaining attributes on an exception raises an AttributeError, exceptioncontext gracefully degrades to doing nothing.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for exceptioncontext-1.0.4-py2.py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | c9d1ad5e54be9166dc288b77a00bd462cdb316843febe657c9b6b45e3ad569e9 |
|
MD5 | ed98743b8459aadbf60eed812276d7cd |
|
BLAKE2b-256 | 36e3f78e42065da266497d49d125739bd26763d19aa9cb1d098a110965df934c |