[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