From 5e9b60fdaff11bcb21f29d319aef8ca3d5cd42c0 Mon Sep 17 00:00:00 2001 From: Kevin Ji <1146876+kevinji@users.noreply.github.com> Date: Wed, 11 Dec 2024 13:21:13 -0800 Subject: [PATCH] Add new fields to TracebackException, fix cause/context/lineno types These are derived from the TracebackException docs: https://docs.python.org/3/library/traceback.html#traceback.TracebackException and the source code: https://github.com/python/cpython/blob/8b3cccf3f9508572d85b0044519f2bd5715dacad/Lib/traceback.py#L989 --- stdlib/traceback.pyi | 15 ++++++++++++--- 1 file changed, 12 insertions(+), 3 deletions(-) diff --git a/stdlib/traceback.pyi b/stdlib/traceback.pyi index e36081acfa03..53028a2d8510 100644 --- a/stdlib/traceback.pyi +++ b/stdlib/traceback.pyi @@ -113,17 +113,26 @@ if sys.version_info >= (3, 11): def emit(self, text_gen: str | Iterable[str], margin_char: str | None = None) -> Generator[str, None, None]: ... class TracebackException: - __cause__: TracebackException - __context__: TracebackException + __cause__: TracebackException | None + __context__: TracebackException | None if sys.version_info >= (3, 11): exceptions: list[TracebackException] | None __suppress_context__: bool + if sys.version_info >= (3, 11): + __notes__: list[str] | None stack: StackSummary + + # These fields only exist for `SyntaxError`s, but there is no way to express that in the type system. filename: str - lineno: int + lineno: str | None + if sys.version_info >= (3, 10): + end_lineno: str | None text: str offset: int + if sys.version_info >= (3, 10): + end_offset: int | None msg: str + if sys.version_info >= (3, 13): @property def exc_type_str(self) -> str: ...