[clang] [Clang] Correctly handle allocations in the condition of a `if constexpr` (PR #146890)
Erich Keane via cfe-commits
cfe-commits at lists.llvm.org
Thu Jul 3 07:32:21 PDT 2025
================
@@ -1931,15 +1931,13 @@ Parser::ParseCXXCondition(StmtResult *InitStmt, SourceLocation Loc,
return ParseCXXCondition(nullptr, Loc, CK, MissingOK);
}
- ExprResult Expr = [&] {
- EnterExpressionEvaluationContext Eval(
- Actions, Sema::ExpressionEvaluationContext::ConstantEvaluated,
- /*LambdaContextDecl=*/nullptr,
- /*ExprContext=*/Sema::ExpressionEvaluationContextRecord::EK_Other,
- /*ShouldEnter=*/CK == Sema::ConditionKind::ConstexprIf);
- // Parse the expression.
- return ParseExpression(); // expression
- }();
+ EnterExpressionEvaluationContext Eval(
----------------
erichkeane wrote:
Oh wait, `ParseCXXCondition` is recursive here, right? So it WILL cover the ParseCXXCondition on line 1949?
Is it problematic in the init-statement that we would have TWO eval contexts (1 for init + conditon, and 1 for just condition)?
https://github.com/llvm/llvm-project/pull/146890
More information about the cfe-commits
mailing list