Skip to content

Commit 7e08baf

Browse files
committed
Expand TypeVarTuple default (PEP 696)
1 parent 9f51057 commit 7e08baf

File tree

2 files changed

+8
-6
lines changed

2 files changed

+8
-6
lines changed

mypy/expandtype.py

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -277,6 +277,8 @@ def visit_unpack_type(self, t: UnpackType) -> Type:
277277
def expand_unpack(self, t: UnpackType) -> list[Type]:
278278
assert isinstance(t.type, TypeVarTupleType)
279279
repl = get_proper_type(self.variables.get(t.type.id, t.type))
280+
if isinstance(repl, UnpackType):
281+
repl = repl.type
280282
if isinstance(repl, TupleType):
281283
return repl.items
282284
elif (

test-data/unit/check-typevar-defaults.test

Lines changed: 6 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -274,8 +274,8 @@ def func_c1(
274274
# reveal_type(a) # Revealed type is "__main__.ClassC1[builtins.int, builtins.str]" # TODO
275275
reveal_type(b) # N: Revealed type is "__main__.ClassC1[builtins.float]"
276276

277-
# k = ClassC1() # TODO
278-
# reveal_type(k) # Revealed type is "__main__.ClassC1[builtins.int, builtins.str]" # TODO
277+
k = ClassC1()
278+
reveal_type(k) # N: Revealed type is "__main__.ClassC1[builtins.int, builtins.str]"
279279
l = ClassC1[float]()
280280
reveal_type(l) # N: Revealed type is "__main__.ClassC1[builtins.float]"
281281

@@ -290,8 +290,8 @@ def func_c2(
290290
# reveal_type(b) # Revealed type is "__main__.ClassC2[builtins.int, Unpack[builtins.tuple[builtins.float, ...]]]" # TODO
291291
reveal_type(c) # N: Revealed type is "__main__.ClassC2[builtins.int]"
292292

293-
# k = ClassC2() # TODO
294-
# reveal_type(k) # Revealed type is "__main__.ClassC2[builtins.str, Unpack[builtins.tuple[builtins.float, ...]]]" # TODO
293+
k = ClassC2()
294+
reveal_type(k) # N: Revealed type is "__main__.ClassC2[builtins.str, Unpack[builtins.tuple[builtins.float, ...]]]"
295295
l = ClassC2[int]()
296296
# reveal_type(l) # Revealed type is "__main__.ClassC2[builtins.int, Unpack[builtins.tuple[builtins.float, ...]]]" # TODO
297297
m = ClassC2[int, Unpack[Tuple[()]]]()
@@ -308,8 +308,8 @@ def func_c3(
308308
reveal_type(b) # N: Revealed type is "__main__.ClassC3[builtins.int]"
309309
reveal_type(c) # N: Revealed type is "__main__.ClassC3[builtins.int, builtins.float]"
310310

311-
# k = ClassC3() # TODO
312-
# reveal_type(k) # Revealed type is "__main__.ClassC3[builtins.str]" # TODO
311+
k = ClassC3()
312+
reveal_type(k) # N: Revealed type is "__main__.ClassC3[builtins.str]"
313313
l = ClassC3[int]()
314314
reveal_type(l) # N: Revealed type is "__main__.ClassC3[builtins.int]"
315315
m = ClassC3[int, Unpack[Tuple[float]]]()

0 commit comments

Comments
 (0)