Thanks to visit codestin.com
Credit goes to github.com

Skip to content

Commit 0c9258a

Browse files
authored
bpo-36332: Allow compile() to handle AST objects with assignment expressions (GH-12398)
1 parent 2ddc7f6 commit 0c9258a

3 files changed

Lines changed: 17 additions & 3 deletions

File tree

Lib/test/test_ast.py

Lines changed: 11 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -135,6 +135,9 @@ def to_tuple(t):
135135
"@deco1\n@deco2()\nclass C: pass",
136136
# Decorator with generator argument
137137
"@deco(a for a in b)\ndef f(): pass",
138+
# Simple assignment expression
139+
"(a := 1)",
140+
138141
]
139142

140143
# These are compiled through "single"
@@ -276,6 +279,13 @@ def test_snippets(self):
276279
with self.subTest(action="compiling", input=i, kind=kind):
277280
compile(ast_tree, "?", kind)
278281

282+
def test_ast_validation(self):
283+
# compile() is the only function that calls PyAST_Validate
284+
snippets_to_validate = exec_tests + single_tests + eval_tests
285+
for snippet in snippets_to_validate:
286+
tree = ast.parse(snippet)
287+
compile(tree, '<string>', 'exec')
288+
279289
def test_slice(self):
280290
slc = ast.parse("x[::]").body[0].value.slice
281291
self.assertIsNone(slc.upper)
@@ -1677,6 +1687,7 @@ def main():
16771687
('Module', [('AsyncFunctionDef', (3, 0), 'f', ('arguments', [], None, [], [], None, []), [('Pass', (3, 15))], [('Name', (1, 1), 'deco1', ('Load',)), ('Call', (2, 0), ('Name', (2, 1), 'deco2', ('Load',)), [], [])], None, None)], []),
16781688
('Module', [('ClassDef', (3, 0), 'C', [], [], [('Pass', (3, 9))], [('Name', (1, 1), 'deco1', ('Load',)), ('Call', (2, 0), ('Name', (2, 1), 'deco2', ('Load',)), [], [])])], []),
16791689
('Module', [('FunctionDef', (2, 0), 'f', ('arguments', [], None, [], [], None, []), [('Pass', (2, 9))], [('Call', (1, 1), ('Name', (1, 1), 'deco', ('Load',)), [('GeneratorExp', (1, 5), ('Name', (1, 6), 'a', ('Load',)), [('comprehension', ('Name', (1, 12), 'a', ('Store',)), ('Name', (1, 17), 'b', ('Load',)), [], 0)])], [])], None, None)], []),
1690+
('Module', [('Expr', (1, 0), ('NamedExpr', (1, 1), ('Name', (1, 1), 'a', ('Store',)), ('Constant', (1, 6), 1, None)))], []),
16801691
]
16811692
single_results = [
16821693
('Interactive', [('Expr', (1, 0), ('BinOp', (1, 0), ('Constant', (1, 0), 1, None), ('Add',), ('Constant', (1, 2), 2, None)))]),
Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,2 @@
1+
The builtin :func:`compile` can now handle AST objects that contain
2+
assignment expressions. Patch by Pablo Galindo.

Python/ast.c

Lines changed: 4 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -316,13 +316,14 @@ validate_expr(expr_ty exp, expr_context_ty ctx)
316316
return validate_exprs(exp->v.List.elts, ctx, 0);
317317
case Tuple_kind:
318318
return validate_exprs(exp->v.Tuple.elts, ctx, 0);
319+
case NamedExpr_kind:
320+
return validate_expr(exp->v.NamedExpr.value, Load);
319321
/* This last case doesn't have any checking. */
320322
case Name_kind:
321323
return 1;
322-
default:
323-
PyErr_SetString(PyExc_SystemError, "unexpected expression");
324-
return 0;
325324
}
325+
PyErr_SetString(PyExc_SystemError, "unexpected expression");
326+
return 0;
326327
}
327328

328329
static int

0 commit comments

Comments
 (0)