[clang] Reapply "[Clang][CWG1815] Support lifetime extension of temporary created by aggregate initialization using a default member initializer" (PR #108039)
via cfe-commits
cfe-commits at lists.llvm.org
Wed Sep 11 07:29:30 PDT 2024
================
@@ -2509,8 +2509,9 @@ Parser::DeclGroupPtrTy Parser::ParseDeclGroup(ParsingDeclSpec &DS,
// P2718R0 - Lifetime extension in range-based for loops.
if (getLangOpts().CPlusPlus23) {
- auto &LastRecord = Actions.ExprEvalContexts.back();
+ auto &LastRecord = Actions.currentEvaluationContext();
LastRecord.InLifetimeExtendingContext = true;
+ LastRecord.RebuildDefaultArgOrDefaultInit = true;
----------------
yronglin wrote:
Because it used for P2718R0 - Lifetime extension in range-based for loops. It's a C++23 feature. we also need to rebuild default-arg and default-init when we collect temporaries in a for-range-init.
https://github.com/llvm/llvm-project/pull/108039
More information about the cfe-commits
mailing list