summaryrefslogtreecommitdiffstats
path: root/Doc/library
diff options
context:
space:
mode:
authorGeorg Brandl <georg@python.org>2008-07-19 15:51:07 (GMT)
committerGeorg Brandl <georg@python.org>2008-07-19 15:51:07 (GMT)
commit1aea30aa853759eb9be591ec05e5c809e3aab6a4 (patch)
tree89db6e9188f2dc1fe42f8514f4aa7aae7cf25990 /Doc/library
parent0f6de936f81eeb292542aa91a7dfd3fbaf887066 (diff)
downloadcpython-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.rst39
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))``.