From: Aaron Ballman Date: Fri, 1 Jun 2012 00:02:08 +0000 (+0000) Subject: Anonymous union members within a struct are now properly handled as an unevaluated... X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=1dfc4ba88714d8ac9a85dba051cf94e57f7b3e04;p=clang Anonymous union members within a struct are now properly handled as an unevaluated field in C++11 mode. This fixes PR12866. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@157784 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Sema/SemaExprMember.cpp b/lib/Sema/SemaExprMember.cpp index 6af4040784..f8bf908dfc 100644 --- a/lib/Sema/SemaExprMember.cpp +++ b/lib/Sema/SemaExprMember.cpp @@ -115,7 +115,7 @@ static IMAKind ClassifyImplicitMemberAccess(Sema &SemaRef, NamedDecl *D = *I; if (D->isCXXInstanceMember()) { - if (dyn_cast(D)) + if (dyn_cast(D) || dyn_cast(D)) isField = true; CXXRecordDecl *R = cast(D->getDeclContext()); diff --git a/test/SemaCXX/anonymous-union-cxx11.cpp b/test/SemaCXX/anonymous-union-cxx11.cpp new file mode 100644 index 0000000000..8e682ebcda --- /dev/null +++ b/test/SemaCXX/anonymous-union-cxx11.cpp @@ -0,0 +1,13 @@ +// RUN: %clang_cc1 -std=c++11 -fsyntax-only -verify -pedantic %s + +namespace PR12866 { + struct bar { + union { + int member; + }; + }; + + void foo( void ) { + (void)sizeof(bar::member); + } +}