diff options
author | Warren Hunt <whunt@google.com> | 2013-10-11 20:19:00 +0000 |
---|---|---|
committer | Warren Hunt <whunt@google.com> | 2013-10-11 20:19:00 +0000 |
commit | 8f8bad723d0fb448c548d9f417fb36f6dfaee019 (patch) | |
tree | 06ebe0ae96b3d79a9d3e27cc65d189152ac16cfe /clang/lib/Sema | |
parent | adff3ae3c8e9f3c2bf5caae0d1cb7484fa1b1ff6 (diff) | |
download | bcm5719-llvm-8f8bad723d0fb448c548d9f417fb36f6dfaee019.tar.gz bcm5719-llvm-8f8bad723d0fb448c548d9f417fb36f6dfaee019.zip |
Adds Microsoft compatiable C++ record layout code to clang.
llvm-svn: 192494
Diffstat (limited to 'clang/lib/Sema')
-rw-r--r-- | clang/lib/Sema/SemaDecl.cpp | 3 | ||||
-rw-r--r-- | clang/lib/Sema/SemaDeclCXX.cpp | 7 |
2 files changed, 8 insertions, 2 deletions
diff --git a/clang/lib/Sema/SemaDecl.cpp b/clang/lib/Sema/SemaDecl.cpp index 52297d7f6ff..daf135a06e8 100644 --- a/clang/lib/Sema/SemaDecl.cpp +++ b/clang/lib/Sema/SemaDecl.cpp @@ -11503,8 +11503,7 @@ Decl *Sema::ActOnIvar(Scope *S, if (BitWidth) { // 6.7.2.1p3, 6.7.2.1p4 - BitWidth = - VerifyBitField(Loc, II, T, /*IsMsStruct=*/false, BitWidth).take(); + BitWidth = VerifyBitField(Loc, II, T, /*IsMsStruct*/false, BitWidth).take(); if (!BitWidth) D.setInvalidType(); } else { diff --git a/clang/lib/Sema/SemaDeclCXX.cpp b/clang/lib/Sema/SemaDeclCXX.cpp index 66749c5c644..6ec344d1e3c 100644 --- a/clang/lib/Sema/SemaDeclCXX.cpp +++ b/clang/lib/Sema/SemaDeclCXX.cpp @@ -4451,6 +4451,13 @@ void Sema::CheckCompletedCXXClass(CXXRecordDecl *Record) { } } + // Check to see if we're trying to lay out a struct using the ms_struct + // attribute that is dynamic. + if (Record->isMsStruct(Context) && Record->isDynamicClass()) { + Diag(Record->getLocation(), diag::warn_pragma_ms_struct_failed); + Record->dropAttr<MsStructAttr>(); + } + // Declare inheriting constructors. We do this eagerly here because: // - The standard requires an eager diagnostic for conflicting inheriting // constructors from different classes. |