forked from OSchip/llvm-project
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:
parent
e974a6afaf
commit
60f2e1efb8
|
@ -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;
|
||||
}
|
||||
|
||||
|
|
|
@ -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(),
|
||||
|
|
|
@ -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;
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue