From: Marshall Clow Date: Mon, 13 May 2019 19:29:23 +0000 (+0000) Subject: Make more friendly with unions. Reviewed as https://reviews.llvm.org/D61858 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=2d96fcd91c5a9cbd7da8c2118611a7dcf97f1b72;p=clang Make more friendly with unions. Reviewed as https://reviews.llvm.org/D61858 git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@360614 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Sema/SemaExprCXX.cpp b/lib/Sema/SemaExprCXX.cpp index 8f00887ebc..87dc3a9a54 100644 --- a/lib/Sema/SemaExprCXX.cpp +++ b/lib/Sema/SemaExprCXX.cpp @@ -5118,8 +5118,15 @@ static bool EvaluateBinaryTypeTrait(Sema &Self, TypeTrait BTT, QualType LhsT, assert(Self.Context.hasSameUnqualifiedType(LhsT, RhsT) == (lhsRecord == rhsRecord)); + // Unions are never base classes, and never have base classes. + // It doesn't matter if they are complete or not. See PR#41843 + if (lhsRecord && lhsRecord->getDecl()->isUnion()) + return false; + if (rhsRecord && rhsRecord->getDecl()->isUnion()) + return false; + if (lhsRecord == rhsRecord) - return !lhsRecord->getDecl()->isUnion(); + return true; // C++0x [meta.rel]p2: // If Base and Derived are class types and are different types diff --git a/test/SemaCXX/type-traits.cpp b/test/SemaCXX/type-traits.cpp index 1ab35dfc1a..9bc238e678 100644 --- a/test/SemaCXX/type-traits.cpp +++ b/test/SemaCXX/type-traits.cpp @@ -14,6 +14,7 @@ typedef NonPOD NonPODArMB[10][2]; enum Enum { EV }; struct POD { Enum e; int i; float f; NonPOD* p; }; struct Empty {}; +struct IncompleteStruct; typedef Empty EmptyAr[10]; typedef Empty EmptyArNB[]; typedef Empty EmptyArMB[1][2]; @@ -1915,6 +1916,20 @@ void is_base_of() { { int arr[F(__is_base_of(Base, NonderivedTemp))]; } { int arr[F(__is_base_of(Base, UndefinedTemp))]; } // expected-error {{implicit instantiation of undefined template 'UndefinedTemp'}} + { int arr[F(__is_base_of(IncompleteUnion, IncompleteUnion))]; } + { int arr[F(__is_base_of(Union, IncompleteUnion))]; } + { int arr[F(__is_base_of(IncompleteUnion, Union))]; } + { int arr[F(__is_base_of(IncompleteStruct, IncompleteUnion))]; } + { int arr[F(__is_base_of(IncompleteUnion, IncompleteStruct))]; } + { int arr[F(__is_base_of(Empty, IncompleteUnion))]; } + { int arr[F(__is_base_of(IncompleteUnion, Empty))]; } + { int arr[F(__is_base_of(int, IncompleteUnion))]; } + { int arr[F(__is_base_of(IncompleteUnion, int))]; } + { int arr[F(__is_base_of(Empty, Union))]; } + { int arr[F(__is_base_of(Union, Empty))]; } + { int arr[F(__is_base_of(int, Empty))]; } + { int arr[F(__is_base_of(Union, int))]; } + isBaseOfT(); isBaseOfF();