summaryrefslogtreecommitdiffstats
path: root/clang/lib/Sema/SemaDeclCXX.cpp
diff options
context:
space:
mode:
authorWarren Hunt <whunt@google.com>2013-10-11 20:19:00 +0000
committerWarren Hunt <whunt@google.com>2013-10-11 20:19:00 +0000
commit8f8bad723d0fb448c548d9f417fb36f6dfaee019 (patch)
tree06ebe0ae96b3d79a9d3e27cc65d189152ac16cfe /clang/lib/Sema/SemaDeclCXX.cpp
parentadff3ae3c8e9f3c2bf5caae0d1cb7484fa1b1ff6 (diff)
downloadbcm5719-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.cpp7
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.
OpenPOWER on IntegriCloud