Don't produce diagnostics for missing ctor-initializers during template

instantiations if we encountered errors parsing some of the initializers.

llvm-svn: 164578
This commit is contained in:
Richard Smith 2012-09-25 00:23:05 +00:00
parent e974a6afaf
commit 60f2e1efb8
3 changed files with 23 additions and 2 deletions

View File

@ -2966,6 +2966,10 @@ bool Sema::SetCtorInitializers(CXXConstructorDecl *Constructor,
Constructor->setCtorInitializers(baseOrMemberInitializers);
}
// Let template instantiation know whether we had errors.
if (AnyErrors)
Constructor->setInvalidDecl();
return false;
}

View File

@ -2986,7 +2986,7 @@ Sema::InstantiateMemInitializers(CXXConstructorDecl *New,
const MultiLevelTemplateArgumentList &TemplateArgs) {
SmallVector<CXXCtorInitializer*, 4> NewInits;
bool AnyErrors = false;
bool AnyErrors = Tmpl->isInvalidDecl();
// Instantiate all the initializers.
for (CXXConstructorDecl::init_const_iterator Inits = Tmpl->init_begin(),

View File

@ -53,3 +53,20 @@ namespace PR7259 {
return 0;
}
}
namespace NonDependentError {
struct Base { Base(int); }; // expected-note 2{{candidate}}
template<typename T>
struct Derived1 : Base {
Derived1() : Base(1, 2) {} // expected-error {{no matching constructor}}
};
template<typename T>
struct Derived2 : Base {
Derived2() : BaseClass(1) {} // expected-error {{does not name a non-static data member or base}}
};
Derived1<void> d1;
Derived2<void> d2;
}