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 as far back as 2.2 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.6-py2.py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6ae0c6caa3d7d3c115088752343d8c06cc55a75eaff356ff2c7bd567d64d128a |
|
MD5 | 197f2935a1c2ad685a580a64d8f658f1 |
|
BLAKE2b-256 | 3bd5f713a5b0e7515808e19221194339ede698c32da00a5071516710e37836c9 |