PR5520: Make sure to check whether the base type is complete before looking for
operator->. llvm-svn: 89180
This commit is contained in:
parent
49939c2914
commit
132e70bfa4
|
@ -5503,6 +5503,11 @@ Sema::BuildOverloadedArrowExpr(Scope *S, ExprArg BaseIn, SourceLocation OpLoc) {
|
||||||
OverloadCandidateSet CandidateSet;
|
OverloadCandidateSet CandidateSet;
|
||||||
const RecordType *BaseRecord = Base->getType()->getAs<RecordType>();
|
const RecordType *BaseRecord = Base->getType()->getAs<RecordType>();
|
||||||
|
|
||||||
|
if (RequireCompleteType(Base->getLocStart(), Base->getType(),
|
||||||
|
PDiag(diag::err_typecheck_incomplete_tag)
|
||||||
|
<< Base->getSourceRange()))
|
||||||
|
return ExprError();
|
||||||
|
|
||||||
LookupResult R(*this, OpName, OpLoc, LookupOrdinaryName);
|
LookupResult R(*this, OpName, OpLoc, LookupOrdinaryName);
|
||||||
LookupQualifiedName(R, BaseRecord->getDecl());
|
LookupQualifiedName(R, BaseRecord->getDecl());
|
||||||
R.suppressDiagnostics();
|
R.suppressDiagnostics();
|
||||||
|
|
|
@ -16,7 +16,10 @@ struct C : A, B {
|
||||||
|
|
||||||
struct D : A { };
|
struct D : A { };
|
||||||
|
|
||||||
void f(C &c, D& d) {
|
struct E; // expected-note {{forward declaration of 'struct E'}}
|
||||||
|
|
||||||
|
void f(C &c, D& d, E& e) {
|
||||||
c->f(); // expected-error{{use of overloaded operator '->' is ambiguous}}
|
c->f(); // expected-error{{use of overloaded operator '->' is ambiguous}}
|
||||||
d->f();
|
d->f();
|
||||||
|
e->f(); // expected-error{{incomplete definition of type}}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue