diff options
author | Georg Brandl <georg@python.org> | 2008-07-19 15:51:07 (GMT) |
---|---|---|
committer | Georg Brandl <georg@python.org> | 2008-07-19 15:51:07 (GMT) |
commit | 1aea30aa853759eb9be591ec05e5c809e3aab6a4 (patch) | |
tree | 89db6e9188f2dc1fe42f8514f4aa7aae7cf25990 /Doc/library | |
parent | 0f6de936f81eeb292542aa91a7dfd3fbaf887066 (diff) | |
download | cpython-1aea30aa853759eb9be591ec05e5c809e3aab6a4.zip cpython-1aea30aa853759eb9be591ec05e5c809e3aab6a4.tar.gz cpython-1aea30aa853759eb9be591ec05e5c809e3aab6a4.tar.bz2 |
#3113: document exception chaining.
Diffstat (limited to 'Doc/library')
-rw-r--r-- | Doc/library/traceback.rst | 39 |
1 files changed, 23 insertions, 16 deletions
diff --git a/Doc/library/traceback.rst b/Doc/library/traceback.rst index 389753a..dd3ae69 100644 --- a/Doc/library/traceback.rst +++ b/Doc/library/traceback.rst @@ -1,4 +1,3 @@ - :mod:`traceback` --- Print or retrieve a stack traceback ======================================================== @@ -29,29 +28,31 @@ The module defines the following functions: object to receive the output. -.. function:: print_exception(type, value, traceback[, limit[, file]]) +.. function:: print_exception(type, value, traceback[, limit[, file[, chain]]]) Print exception information and up to *limit* stack trace entries from - *traceback* to *file*. This differs from :func:`print_tb` in the following ways: - (1) if *traceback* is not ``None``, it prints a header ``Traceback (most recent - call last):``; (2) it prints the exception *type* and *value* after the stack - trace; (3) if *type* is :exc:`SyntaxError` and *value* has the appropriate - format, it prints the line where the syntax error occurred with a caret - indicating the approximate position of the error. - + *traceback* to *file*. This differs from :func:`print_tb` in the following + ways: -.. function:: print_exc([limit[, file]]) + * if *traceback* is not ``None``, it prints a header ``Traceback (most recent + call last):`` + * it prints the exception *type* and *value* after the stack trace + * if *type* is :exc:`SyntaxError` and *value* has the appropriate format, it + prints the line where the syntax error occurred with a caret indicating the + approximate position of the error. - This is a shorthand for ``print_exception(*sys.exc_info())``. + If *chain* is true (the default), then chained exceptions (the + :attr:`__cause__` or :attr:`__context__` attributes of the exception) will be + printed as well, like the interpreter itself does when printing an unhandled + exception. -.. function:: format_exc([limit]) +.. function:: print_exc([limit[, file[, chain]]]) - This is like ``print_exc(limit)`` but returns a string instead of printing to a - file. + This is a shorthand for ``print_exception(*sys.exc_info())``. -.. function:: print_last([limit[, file]]) +.. function:: print_last([limit[, file[, chain]]]) This is a shorthand for ``print_exception(sys.last_type, sys.last_value, sys.last_traceback, limit, file)``. @@ -103,7 +104,7 @@ The module defines the following functions: occurred is the always last string in the list. -.. function:: format_exception(type, value, tb[, limit]) +.. function:: format_exception(type, value, tb[, limit[, chain]]) Format a stack trace and the exception information. The arguments have the same meaning as the corresponding arguments to :func:`print_exception`. The @@ -112,6 +113,12 @@ The module defines the following functions: same text is printed as does :func:`print_exception`. +.. function:: format_exc([limit[, chain]]) + + This is like ``print_exc(limit)`` but returns a string instead of printing to a + file. + + .. function:: format_tb(tb[, limit]) A shorthand for ``format_list(extract_tb(tb, limit))``. |