Skip to content

Commit cae6018

Browse files
authored
bpo-42316: Allow unparenthesized walrus operator in indexes (GH-23317)
1 parent cb3e5ed commit cae6018

File tree

4 files changed

+29
-7
lines changed

4 files changed

+29
-7
lines changed

Grammar/python.gram

+1-1
Original file line numberDiff line numberDiff line change
@@ -491,7 +491,7 @@ slices[expr_ty]:
491491
| a[asdl_expr_seq*]=','.slice+ [','] { _Py_Tuple(a, Load, EXTRA) }
492492
slice[expr_ty]:
493493
| a=[expression] ':' b=[expression] c=[':' d=[expression] { d }] { _Py_Slice(a, b, c, EXTRA) }
494-
| a=expression { a }
494+
| a=named_expression { a }
495495
atom[expr_ty]:
496496
| NAME
497497
| 'True' { _Py_Constant(Py_True, NULL, EXTRA) }

Lib/test/test_named_expressions.py

+21
Original file line numberDiff line numberDiff line change
@@ -271,6 +271,27 @@ def test_named_expression_assignment_16(self):
271271
fib = {(c := a): (a := b) + (b := a + c) - b for __ in range(6)}
272272
self.assertEqual(fib, {1: 2, 2: 3, 3: 5, 5: 8, 8: 13, 13: 21})
273273

274+
def test_named_expression_assignment_17(self):
275+
a = [1]
276+
element = a[b:=0]
277+
self.assertEqual(b, 0)
278+
self.assertEqual(element, a[0])
279+
280+
def test_named_expression_assignment_18(self):
281+
class TwoDimensionalList:
282+
def __init__(self, two_dimensional_list):
283+
self.two_dimensional_list = two_dimensional_list
284+
285+
def __getitem__(self, index):
286+
return self.two_dimensional_list[index[0]][index[1]]
287+
288+
a = TwoDimensionalList([[1], [2]])
289+
element = a[b:=0, c:=0]
290+
self.assertEqual(b, 0)
291+
self.assertEqual(c, 0)
292+
self.assertEqual(element, a.two_dimensional_list[b][c])
293+
294+
274295

275296
class NamedExpressionScopeTest(unittest.TestCase):
276297

Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
Allow an unparenthesized walrus in subscript indexes.

Parser/parser.c

+6-6
Original file line numberDiff line numberDiff line change
@@ -10639,7 +10639,7 @@ slices_rule(Parser *p)
1063910639
return _res;
1064010640
}
1064110641

10642-
// slice: expression? ':' expression? [':' expression?] | expression
10642+
// slice: expression? ':' expression? [':' expression?] | named_expression
1064310643
static expr_ty
1064410644
slice_rule(Parser *p)
1064510645
{
@@ -10701,18 +10701,18 @@ slice_rule(Parser *p)
1070110701
D(fprintf(stderr, "%*c%s slice[%d-%d]: %s failed!\n", p->level, ' ',
1070210702
p->error_indicator ? "ERROR!" : "-", _mark, p->mark, "expression? ':' expression? [':' expression?]"));
1070310703
}
10704-
{ // expression
10704+
{ // named_expression
1070510705
if (p->error_indicator) {
1070610706
D(p->level--);
1070710707
return NULL;
1070810708
}
10709-
D(fprintf(stderr, "%*c> slice[%d-%d]: %s\n", p->level, ' ', _mark, p->mark, "expression"));
10709+
D(fprintf(stderr, "%*c> slice[%d-%d]: %s\n", p->level, ' ', _mark, p->mark, "named_expression"));
1071010710
expr_ty a;
1071110711
if (
10712-
(a = expression_rule(p)) // expression
10712+
(a = named_expression_rule(p)) // named_expression
1071310713
)
1071410714
{
10715-
D(fprintf(stderr, "%*c+ slice[%d-%d]: %s succeeded!\n", p->level, ' ', _mark, p->mark, "expression"));
10715+
D(fprintf(stderr, "%*c+ slice[%d-%d]: %s succeeded!\n", p->level, ' ', _mark, p->mark, "named_expression"));
1071610716
_res = a;
1071710717
if (_res == NULL && PyErr_Occurred()) {
1071810718
p->error_indicator = 1;
@@ -10723,7 +10723,7 @@ slice_rule(Parser *p)
1072310723
}
1072410724
p->mark = _mark;
1072510725
D(fprintf(stderr, "%*c%s slice[%d-%d]: %s failed!\n", p->level, ' ',
10726-
p->error_indicator ? "ERROR!" : "-", _mark, p->mark, "expression"));
10726+
p->error_indicator ? "ERROR!" : "-", _mark, p->mark, "named_expression"));
1072710727
}
1072810728
_res = NULL;
1072910729
done:

0 commit comments

Comments
 (0)