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/SemaDeclCXX.cpp | |
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/SemaDeclCXX.cpp')
-rw-r--r-- | clang/lib/Sema/SemaDeclCXX.cpp | 7 |
1 files changed, 7 insertions, 0 deletions
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. |