Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

gh-102114: Make dis print more concise tracebacks for syntax errors in str inputs #102115

Merged
merged 10 commits into from
Apr 15, 2023
2 changes: 2 additions & 0 deletions Lib/dis.py
Original file line number Diff line number Diff line change
Expand Up @@ -66,6 +66,8 @@ def _try_compile(source, name):
try:
c = compile(source, name, 'eval')
except SyntaxError:
c = None
if not c:
iritkatriel marked this conversation as resolved.
Show resolved Hide resolved
iritkatriel marked this conversation as resolved.
Show resolved Hide resolved
c = compile(source, name, 'exec')
return c

Expand Down
7 changes: 7 additions & 0 deletions Lib/test/test_dis.py
Original file line number Diff line number Diff line change
Expand Up @@ -1067,6 +1067,13 @@ def check(expected, **kwargs):
check(dis_nested_2, depth=None)
check(dis_nested_2)

def test__try_compile_no_context_exc_on_error(self):
# see gh-102114
try:
dis._try_compile(")", "")
except Exception as e:
self.assertIsNone(e.__context__)

@staticmethod
def code_quicken(f, times=ADAPTIVE_WARMUP_DELAY):
for _ in range(times):
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
Functions from :mod:`dis` module that accept source code string as argument now print shorter traceback if given string contains syntax/indentation error
chgnrdv marked this conversation as resolved.
Show resolved Hide resolved