New submission from Ned Batchelder <n...@nedbatchelder.com>:
This code shows a raise inside an except/else/if that isn't run, but incorrectly appears in the trace output (see the ***** line): $ cat arcs_1160.py def func(x): try: b = 6 except ZeroDivisionError: pass else: if x == "raise": raise ValueError() finally: f = 23 func("other") $ python3.10 -c "import sys; print(sys.version)" 3.10.1 (main, Dec 14 2021, 08:30:13) [Clang 12.0.0 (clang-1200.0.32.29)] $ python3.10 -m trace --trace arcs_1160.py --- modulename: arcs_1160, funcname: <module> arcs_1160.py(1): def func(x): arcs_1160.py(12): func("other") --- modulename: arcs_1160, funcname: func arcs_1160.py(2): try: arcs_1160.py(3): b = 6 arcs_1160.py(7): if x == "raise": arcs_1160.py(10): f = 23 $ python3.11 -c "import sys; print(sys.version)" 3.11.0a3+ (heads/main:d24cd49acb, Jan 11 2022, 07:29:41) [Clang 12.0.0 (clang-1200.0.32.29)] $ python3.11 -m trace --trace arcs_1160.py --- modulename: arcs_1160, funcname: <module> arcs_1160.py(1): def func(x): arcs_1160.py(12): func("other") --- modulename: arcs_1160, funcname: func arcs_1160.py(2): try: arcs_1160.py(3): b = 6 arcs_1160.py(7): if x == "raise": arcs_1160.py(8): raise ValueError() <<********** arcs_1160.py(10): f = 23 ---------- components: Interpreter Core keywords: 3.11regression messages: 410300 nosy: Mark.Shannon, nedbat priority: normal severity: normal status: open title: 3.11: except/else/if/raise traced incorrectly versions: Python 3.11 _______________________________________ Python tracker <rep...@bugs.python.org> <https://bugs.python.org/issue46344> _______________________________________ _______________________________________________ Python-bugs-list mailing list Unsubscribe: https://mail.python.org/mailman/options/python-bugs-list/archive%40mail-archive.com