diff options
| author | Douglas Gregor <dgregor@apple.com> | 2010-04-22 14:36:26 +0000 |
|---|---|---|
| committer | Douglas Gregor <dgregor@apple.com> | 2010-04-22 14:36:26 +0000 |
| commit | fceea36501a441a3bf829fc83967f53fd82edfb8 (patch) | |
| tree | bf8837691c62e7507ce98902b6cd3cd21856255d /clang/lib | |
| parent | 73519609d42f9939bbeded919d8b6fbf3b87bc7f (diff) | |
| download | bcm5719-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.cpp | 6 |
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; |

