git: eca6e0f7e460 - main - Apply clang fix for assertion failure building webkit2-gtk

From: Dimitry Andric <dim_at_FreeBSD.org>
Date: Fri, 27 May 2022 17:44:19 UTC
The branch main has been updated by dim:

URL: https://cgit.FreeBSD.org/src/commit/?id=eca6e0f7e460bf9a4a6e1bd5198d75168280c88e

commit eca6e0f7e460bf9a4a6e1bd5198d75168280c88e
Author:     Dimitry Andric <dim@FreeBSD.org>
AuthorDate: 2022-05-27 17:43:39 +0000
Commit:     Dimitry Andric <dim@FreeBSD.org>
CommitDate: 2022-05-27 17:44:06 +0000

    Apply clang fix for assertion failure building webkit2-gtk
    
    Merge commit 30baa5d2a450 from llvm git (by Richard Smith):
    
      PR45879: Fix assert when constant evaluating union assignment.
    
      Consider the form of the first operand of a class assignment not the
      second operand when implicitly starting the lifetimes of union members.
      Also add a missing check that the assignment call actually came from a
      syntactic assignment, not from a direct call to `operator=`.
    
    PR:             264280
    Reported by:    bapt
    MFC after:      3 days
---
 contrib/llvm-project/clang/lib/AST/ExprConstant.cpp | 12 +++++++++---
 1 file changed, 9 insertions(+), 3 deletions(-)

diff --git a/contrib/llvm-project/clang/lib/AST/ExprConstant.cpp b/contrib/llvm-project/clang/lib/AST/ExprConstant.cpp
index e8ceaa6f71ee..6ebf9f6a2578 100644
--- a/contrib/llvm-project/clang/lib/AST/ExprConstant.cpp
+++ b/contrib/llvm-project/clang/lib/AST/ExprConstant.cpp
@@ -6127,9 +6127,6 @@ static bool HandleFunctionCall(SourceLocation CallLoc,
     if (!handleTrivialCopy(Info, MD->getParamDecl(0), Args[0], RHSValue,
                            MD->getParent()->isUnion()))
       return false;
-    if (Info.getLangOpts().CPlusPlus20 && MD->isTrivial() &&
-        !HandleUnionActiveMemberChange(Info, Args[0], *This))
-      return false;
     if (!handleAssignment(Info, Args[0], *This, MD->getThisType(),
                           RHSValue))
       return false;
@@ -7641,6 +7638,15 @@ public:
         if (!EvaluateObjectArgument(Info, Args[0], ThisVal))
           return false;
         This = &ThisVal;
+
+        // If this is syntactically a simple assignment using a trivial
+        // assignment operator, start the lifetimes of union members as needed,
+        // per C++20 [class.union]5.
+        if (Info.getLangOpts().CPlusPlus20 && OCE &&
+            OCE->getOperator() == OO_Equal && MD->isTrivial() &&
+            !HandleUnionActiveMemberChange(Info, Args[0], ThisVal))
+          return false;
+
         Args = Args.slice(1);
       } else if (MD && MD->isLambdaStaticInvoker()) {
         // Map the static invoker for the lambda back to the call operator.