Skip to content

Commit 3997f3c

Browse files
bpo-45679: Fix caching of multi-value typing.Literal (GH-29334)
Literal[True, 2] is no longer equal to Literal[1, 2]. (cherry picked from commit 634984d) Co-authored-by: Serhiy Storchaka <storchaka@gmail.com>
1 parent da222b7 commit 3997f3c

File tree

3 files changed

+11
-6
lines changed

3 files changed

+11
-6
lines changed

Lib/test/test_typing.py

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -708,6 +708,8 @@ def test_equal(self):
708708
self.assertNotEqual(Literal[True], Literal[1])
709709
self.assertNotEqual(Literal[1], Literal[2])
710710
self.assertNotEqual(Literal[1, True], Literal[1])
711+
self.assertNotEqual(Literal[1, True], Literal[1, 1])
712+
self.assertNotEqual(Literal[1, 2], Literal[True, 2])
711713
self.assertEqual(Literal[1], Literal[1])
712714
self.assertEqual(Literal[1, 2], Literal[2, 1])
713715
self.assertEqual(Literal[1, 2, 3], Literal[1, 2, 3, 3])
@@ -4917,6 +4919,8 @@ def test_special_attrs(self):
49174919
typing.Concatenate[Any, SpecialAttrsP]: 'Concatenate',
49184920
typing.Final[Any]: 'Final',
49194921
typing.Literal[Any]: 'Literal',
4922+
typing.Literal[1, 2]: 'Literal',
4923+
typing.Literal[True, 2]: 'Literal',
49204924
typing.Optional[Any]: 'Optional',
49214925
typing.TypeGuard[Any]: 'TypeGuard',
49224926
typing.Union[Any]: 'Any',

Lib/typing.py

Lines changed: 5 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -403,9 +403,10 @@ def __getitem__(self, parameters):
403403

404404

405405
class _LiteralSpecialForm(_SpecialForm, _root=True):
406-
@_tp_cache(typed=True)
407406
def __getitem__(self, parameters):
408-
return self._getitem(self, parameters)
407+
if not isinstance(parameters, tuple):
408+
parameters = (parameters,)
409+
return self._getitem(self, *parameters)
409410

410411

411412
@_SpecialForm
@@ -528,7 +529,8 @@ def Optional(self, parameters):
528529
return Union[arg, type(None)]
529530

530531
@_LiteralSpecialForm
531-
def Literal(self, parameters):
532+
@_tp_cache(typed=True)
533+
def Literal(self, *parameters):
532534
"""Special typing form to define literal types (a.k.a. value types).
533535
534536
This form can be used to indicate to type checkers that the corresponding
@@ -551,9 +553,6 @@ def open_helper(file: str, mode: MODE) -> str:
551553
"""
552554
# There is no '_type_check' call because arguments to Literal[...] are
553555
# values, not types.
554-
if not isinstance(parameters, tuple):
555-
parameters = (parameters,)
556-
557556
parameters = _flatten_literal_params(parameters)
558557

559558
try:
Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,2 @@
1+
Fix caching of multi-value :data:`typing.Literal`. ``Literal[True, 2]`` is no
2+
longer equal to ``Literal[1, 2]``.

0 commit comments

Comments
 (0)