From 407c0cb64a804e6f5ffa693ec0e79c9171393a29 Mon Sep 17 00:00:00 2001 From: ringabout <43030857+ringabout@users.noreply.github.com> Date: Fri, 26 Apr 2024 19:00:25 +0800 Subject: [PATCH] fixes #23522; fixes pre-existing wrong type for iter in `liftIterSym` (#23538) fixes #23522 --- compiler/lambdalifting.nim | 3 +-- tests/js/t7109.nim | 3 +++ 2 files changed, 4 insertions(+), 2 deletions(-) diff --git a/compiler/lambdalifting.nim b/compiler/lambdalifting.nim index c32a1c6149..faa043cb49 100644 --- a/compiler/lambdalifting.nim +++ b/compiler/lambdalifting.nim @@ -258,8 +258,7 @@ proc liftIterSym*(g: ModuleGraph; n: PNode; idgen: IdGenerator; owner: PSym): PN let iter = n.sym assert iter.isIterator - result = newNodeIT(nkStmtListExpr, n.info, n.typ) - + result = newNodeIT(nkStmtListExpr, n.info, iter.typ) let hp = getHiddenParam(g, iter) var env: PNode if owner.isIterator: diff --git a/tests/js/t7109.nim b/tests/js/t7109.nim index 015d11d87b..a1a3b718ea 100644 --- a/tests/js/t7109.nim +++ b/tests/js/t7109.nim @@ -3,3 +3,6 @@ iterator iter*(): int {.closure.} = var x = iter doAssert x() == 3 + +let fIt = iterator(): int = yield 70 +doAssert fIt() == 70