diff options
| author | Yong He <yonghe@outlook.com> | 2025-05-16 10:42:11 -0700 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2025-05-16 10:42:11 -0700 |
| commit | 9dfd5244ad2953753535e82acd05e72e5ab2bc5f (patch) | |
| tree | 0f7c8a0bf4ea3dd25348e1d1ac8e5bfcfd8c9724 /source/slang/slang-check-expr.cpp | |
| parent | 1fd7b2296d8360c245a0c732e7f842876533f92a (diff) | |
Allow lambda exprs without captures to coerce to `functype`. (#7129)
Diffstat (limited to 'source/slang/slang-check-expr.cpp')
| -rw-r--r-- | source/slang/slang-check-expr.cpp | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/source/slang/slang-check-expr.cpp b/source/slang/slang-check-expr.cpp index 41f945763..ad36a7e4a 100644 --- a/source/slang/slang-check-expr.cpp +++ b/source/slang/slang-check-expr.cpp @@ -2887,6 +2887,7 @@ Expr* SemanticsVisitor::CheckInvokeExprWithCheckedOperands(InvokeExpr* expr) } } } + rs->checked = true; return rs; } @@ -4209,9 +4210,9 @@ Expr* SemanticsExprVisitor::visitLambdaExpr(LambdaExpr* lambdaExpr) if (m_parentFunc) { nameBuilder << getText(m_parentFunc->getName()); + nameBuilder << "_"; + nameBuilder << m_parentFunc->members.getCount(); } - nameBuilder << "_"; - nameBuilder << m_parentFunc->members.getCount(); auto name = getName(nameBuilder.getBuffer()); lambdaStructDecl->nameAndLoc.name = name; lambdaStructDecl->nameAndLoc.loc = lambdaExpr->loc; @@ -4283,6 +4284,7 @@ Expr* SemanticsExprVisitor::visitLambdaExpr(LambdaExpr* lambdaExpr) auto resultLambdaObj = synthesizer.emitCtorInvokeExpr( synthesizer.emitStaticTypeExpr(DeclRefType::create(m_astBuilder, lambdaStructDecl)), _Move(args)); + resultLambdaObj->loc = lambdaExpr->loc; auto checkedResultExpr = dispatchExpr(resultLambdaObj, *this); return checkedResultExpr; } |
