summaryrefslogtreecommitdiffstats
path: root/clang/lib
diff options
context:
space:
mode:
authorDouglas Gregor <dgregor@apple.com>2010-04-22 14:36:26 +0000
committerDouglas Gregor <dgregor@apple.com>2010-04-22 14:36:26 +0000
commitfceea36501a441a3bf829fc83967f53fd82edfb8 (patch)
treebf8837691c62e7507ce98902b6cd3cd21856255d /clang/lib
parent73519609d42f9939bbeded919d8b6fbf3b87bc7f (diff)
downloadbcm5719-llvm-fceea36501a441a3bf829fc83967f53fd82edfb8.tar.gz
bcm5719-llvm-fceea36501a441a3bf829fc83967f53fd82edfb8.zip
When checking whether to diagnose an initialized "extern" variable,
look for the const on the base type rather than on the top-level type. Fixes PR6495 properly. llvm-svn: 102066
Diffstat (limited to 'clang/lib')
-rw-r--r--clang/lib/Sema/SemaDecl.cpp6
1 files changed, 5 insertions, 1 deletions
diff --git a/clang/lib/Sema/SemaDecl.cpp b/clang/lib/Sema/SemaDecl.cpp
index 8fce6393c64..c9001f10303 100644
--- a/clang/lib/Sema/SemaDecl.cpp
+++ b/clang/lib/Sema/SemaDecl.cpp
@@ -3856,7 +3856,8 @@ void Sema::AddInitializerToDecl(DeclPtrTy dcl, ExprArg init, bool DirectInit) {
}
} else if (VDecl->isFileVarDecl()) {
if (VDecl->getStorageClass() == VarDecl::Extern &&
- (!getLangOptions().CPlusPlus || !VDecl->getType().isConstQualified()))
+ (!getLangOptions().CPlusPlus ||
+ !Context.getBaseElementType(VDecl->getType()).isConstQualified()))
Diag(VDecl->getLocation(), diag::warn_extern_init);
if (!VDecl->isInvalidDecl()) {
InitializationSequence InitSeq(*this, Entity, Kind, &Init, 1);
@@ -5667,6 +5668,9 @@ void Sema::DiagnoseNontrivial(const RecordType* T, CXXSpecialMember member) {
// Check whether the member was user-declared.
switch (member) {
+ case CXXInvalid:
+ break;
+
case CXXConstructor:
if (RD->hasUserDeclaredConstructor()) {
typedef CXXRecordDecl::ctor_iterator ctor_iter;
OpenPOWER on IntegriCloud