25 lines
596 B
Plaintext
25 lines
596 B
Plaintext
An ``++except++`` clause that only rethrows the caught exception has the same effect as omitting the ``++except++`` altogether and letting it bubble up automatically, but with more code and the additional detriment of leaving maintainers scratching their heads.
|
|
|
|
Such clauses should either be eliminated or populated with the appropriate logic.
|
|
|
|
== Noncompliant Code Example
|
|
|
|
----
|
|
a = {}
|
|
try:
|
|
a[5]
|
|
except KeyError:
|
|
raise # Noncompliant
|
|
----
|
|
|
|
== Compliant Solution
|
|
|
|
----
|
|
a = {}
|
|
try:
|
|
a[5]
|
|
except KeyError as e:
|
|
logging.exception('error while accessing the dict')
|
|
raise e
|
|
----
|