forked from OSchip/llvm-project
parent
9ec6a826dd
commit
dfe29ae5db
|
@ -327,18 +327,16 @@ bool Sema::DiagnoseUseOfDecl(NamedDecl *D, SourceLocation Loc,
|
||||||
if (getLangOpts().CPlusPlus && isa<FunctionDecl>(D)) {
|
if (getLangOpts().CPlusPlus && isa<FunctionDecl>(D)) {
|
||||||
// If there were any diagnostics suppressed by template argument deduction,
|
// If there were any diagnostics suppressed by template argument deduction,
|
||||||
// emit them now.
|
// emit them now.
|
||||||
SuppressedDiagnosticsMap::iterator
|
auto Pos = SuppressedDiagnostics.find(D->getCanonicalDecl());
|
||||||
Pos = SuppressedDiagnostics.find(D->getCanonicalDecl());
|
|
||||||
if (Pos != SuppressedDiagnostics.end()) {
|
if (Pos != SuppressedDiagnostics.end()) {
|
||||||
SmallVectorImpl<PartialDiagnosticAt> &Suppressed = Pos->second;
|
for (const PartialDiagnosticAt &Suppressed : Pos->second)
|
||||||
for (unsigned I = 0, N = Suppressed.size(); I != N; ++I)
|
Diag(Suppressed.first, Suppressed.second);
|
||||||
Diag(Suppressed[I].first, Suppressed[I].second);
|
|
||||||
|
|
||||||
// Clear out the list of suppressed diagnostics, so that we don't emit
|
// Clear out the list of suppressed diagnostics, so that we don't emit
|
||||||
// them again for this specialization. However, we don't obsolete this
|
// them again for this specialization. However, we don't obsolete this
|
||||||
// entry from the table, because we want to avoid ever emitting these
|
// entry from the table, because we want to avoid ever emitting these
|
||||||
// diagnostics again.
|
// diagnostics again.
|
||||||
Suppressed.clear();
|
Pos->second.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
// C++ [basic.start.main]p3:
|
// C++ [basic.start.main]p3:
|
||||||
|
@ -1462,12 +1460,11 @@ Sema::CreateGenericSelectionExpr(SourceLocation KeyLoc,
|
||||||
Diag(ControllingExpr->getLocStart(), diag::err_generic_sel_multi_match)
|
Diag(ControllingExpr->getLocStart(), diag::err_generic_sel_multi_match)
|
||||||
<< ControllingExpr->getSourceRange() << ControllingExpr->getType()
|
<< ControllingExpr->getSourceRange() << ControllingExpr->getType()
|
||||||
<< (unsigned) CompatIndices.size();
|
<< (unsigned) CompatIndices.size();
|
||||||
for (SmallVectorImpl<unsigned>::iterator I = CompatIndices.begin(),
|
for (unsigned I : CompatIndices) {
|
||||||
E = CompatIndices.end(); I != E; ++I) {
|
Diag(Types[I]->getTypeLoc().getBeginLoc(),
|
||||||
Diag(Types[*I]->getTypeLoc().getBeginLoc(),
|
|
||||||
diag::note_compat_assoc)
|
diag::note_compat_assoc)
|
||||||
<< Types[*I]->getTypeLoc().getSourceRange()
|
<< Types[I]->getTypeLoc().getSourceRange()
|
||||||
<< Types[*I]->getType();
|
<< Types[I]->getType();
|
||||||
}
|
}
|
||||||
return ExprError();
|
return ExprError();
|
||||||
}
|
}
|
||||||
|
@ -1550,8 +1547,8 @@ Sema::ActOnStringLiteral(ArrayRef<Token> StringToks, Scope *UDLScope) {
|
||||||
return ExprError();
|
return ExprError();
|
||||||
|
|
||||||
SmallVector<SourceLocation, 4> StringTokLocs;
|
SmallVector<SourceLocation, 4> StringTokLocs;
|
||||||
for (unsigned i = 0; i != StringToks.size(); ++i)
|
for (const Token &Tok : StringToks)
|
||||||
StringTokLocs.push_back(StringToks[i].getLocation());
|
StringTokLocs.push_back(Tok.getLocation());
|
||||||
|
|
||||||
QualType CharTy = Context.CharTy;
|
QualType CharTy = Context.CharTy;
|
||||||
StringLiteral::StringKind Kind = StringLiteral::Ascii;
|
StringLiteral::StringKind Kind = StringLiteral::Ascii;
|
||||||
|
@ -1850,8 +1847,8 @@ Sema::DiagnoseEmptyLookup(Scope *S, CXXScopeSpec &SS, LookupResult &R,
|
||||||
}
|
}
|
||||||
|
|
||||||
// Do we really want to note all of these?
|
// Do we really want to note all of these?
|
||||||
for (LookupResult::iterator I = R.begin(), E = R.end(); I != E; ++I)
|
for (NamedDecl *D : R)
|
||||||
Diag((*I)->getLocation(), diag::note_dependent_var_use);
|
Diag(D->getLocation(), diag::note_dependent_var_use);
|
||||||
|
|
||||||
// Return true if we are inside a default argument instantiation
|
// Return true if we are inside a default argument instantiation
|
||||||
// and the found name refers to an instance member function, otherwise
|
// and the found name refers to an instance member function, otherwise
|
||||||
|
@ -1912,15 +1909,13 @@ Sema::DiagnoseEmptyLookup(Scope *S, CXXScopeSpec &SS, LookupResult &R,
|
||||||
OverloadCandidateSet OCS(R.getNameLoc(),
|
OverloadCandidateSet OCS(R.getNameLoc(),
|
||||||
OverloadCandidateSet::CSK_Normal);
|
OverloadCandidateSet::CSK_Normal);
|
||||||
OverloadCandidateSet::iterator Best;
|
OverloadCandidateSet::iterator Best;
|
||||||
for (TypoCorrection::decl_iterator CD = Corrected.begin(),
|
for (NamedDecl *CD : Corrected) {
|
||||||
CDEnd = Corrected.end();
|
|
||||||
CD != CDEnd; ++CD) {
|
|
||||||
if (FunctionTemplateDecl *FTD =
|
if (FunctionTemplateDecl *FTD =
|
||||||
dyn_cast<FunctionTemplateDecl>(*CD))
|
dyn_cast<FunctionTemplateDecl>(CD))
|
||||||
AddTemplateOverloadCandidate(
|
AddTemplateOverloadCandidate(
|
||||||
FTD, DeclAccessPair::make(FTD, AS_none), ExplicitTemplateArgs,
|
FTD, DeclAccessPair::make(FTD, AS_none), ExplicitTemplateArgs,
|
||||||
Args, OCS);
|
Args, OCS);
|
||||||
else if (FunctionDecl *FD = dyn_cast<FunctionDecl>(*CD))
|
else if (FunctionDecl *FD = dyn_cast<FunctionDecl>(CD))
|
||||||
if (!ExplicitTemplateArgs || ExplicitTemplateArgs->size() == 0)
|
if (!ExplicitTemplateArgs || ExplicitTemplateArgs->size() == 0)
|
||||||
AddOverloadCandidate(FD, DeclAccessPair::make(FD, AS_none),
|
AddOverloadCandidate(FD, DeclAccessPair::make(FD, AS_none),
|
||||||
Args, OCS);
|
Args, OCS);
|
||||||
|
@ -2679,9 +2674,7 @@ bool Sema::UseArgumentDependentLookup(const CXXScopeSpec &SS,
|
||||||
|
|
||||||
// Turn off ADL when we find certain kinds of declarations during
|
// Turn off ADL when we find certain kinds of declarations during
|
||||||
// normal lookup:
|
// normal lookup:
|
||||||
for (LookupResult::iterator I = R.begin(), E = R.end(); I != E; ++I) {
|
for (NamedDecl *D : R) {
|
||||||
NamedDecl *D = *I;
|
|
||||||
|
|
||||||
// C++0x [basic.lookup.argdep]p3:
|
// C++0x [basic.lookup.argdep]p3:
|
||||||
// -- a declaration of a class member
|
// -- a declaration of a class member
|
||||||
// Since using decls preserve this property, we check this on the
|
// Since using decls preserve this property, we check this on the
|
||||||
|
@ -4413,10 +4406,8 @@ static TypoCorrection TryTypoCorrectionForCall(Sema &S, Expr *Fn,
|
||||||
if (Corrected.isOverloaded()) {
|
if (Corrected.isOverloaded()) {
|
||||||
OverloadCandidateSet OCS(NameLoc, OverloadCandidateSet::CSK_Normal);
|
OverloadCandidateSet OCS(NameLoc, OverloadCandidateSet::CSK_Normal);
|
||||||
OverloadCandidateSet::iterator Best;
|
OverloadCandidateSet::iterator Best;
|
||||||
for (TypoCorrection::decl_iterator CD = Corrected.begin(),
|
for (NamedDecl *CD : Corrected) {
|
||||||
CDEnd = Corrected.end();
|
if (FunctionDecl *FD = dyn_cast<FunctionDecl>(CD))
|
||||||
CD != CDEnd; ++CD) {
|
|
||||||
if (FunctionDecl *FD = dyn_cast<FunctionDecl>(*CD))
|
|
||||||
S.AddOverloadCandidate(FD, DeclAccessPair::make(FD, AS_none), Args,
|
S.AddOverloadCandidate(FD, DeclAccessPair::make(FD, AS_none), Args,
|
||||||
OCS);
|
OCS);
|
||||||
}
|
}
|
||||||
|
@ -4567,7 +4558,7 @@ bool Sema::GatherArgumentsForCall(SourceLocation CallLoc, FunctionDecl *FDecl,
|
||||||
bool IsListInitialization) {
|
bool IsListInitialization) {
|
||||||
unsigned NumParams = Proto->getNumParams();
|
unsigned NumParams = Proto->getNumParams();
|
||||||
bool Invalid = false;
|
bool Invalid = false;
|
||||||
unsigned ArgIx = 0;
|
size_t ArgIx = 0;
|
||||||
// Continue to check argument types (even if we have too few/many args).
|
// Continue to check argument types (even if we have too few/many args).
|
||||||
for (unsigned i = FirstParam; i < NumParams; i++) {
|
for (unsigned i = FirstParam; i < NumParams; i++) {
|
||||||
QualType ProtoArgType = Proto->getParamType(i);
|
QualType ProtoArgType = Proto->getParamType(i);
|
||||||
|
@ -4637,26 +4628,25 @@ bool Sema::GatherArgumentsForCall(SourceLocation CallLoc, FunctionDecl *FDecl,
|
||||||
// return __unknown_anytype aren't *really* variadic.
|
// return __unknown_anytype aren't *really* variadic.
|
||||||
if (Proto->getReturnType() == Context.UnknownAnyTy && FDecl &&
|
if (Proto->getReturnType() == Context.UnknownAnyTy && FDecl &&
|
||||||
FDecl->isExternC()) {
|
FDecl->isExternC()) {
|
||||||
for (unsigned i = ArgIx, e = Args.size(); i != e; ++i) {
|
for (Expr *A : Args.slice(ArgIx)) {
|
||||||
QualType paramType; // ignored
|
QualType paramType; // ignored
|
||||||
ExprResult arg = checkUnknownAnyArg(CallLoc, Args[i], paramType);
|
ExprResult arg = checkUnknownAnyArg(CallLoc, A, paramType);
|
||||||
Invalid |= arg.isInvalid();
|
Invalid |= arg.isInvalid();
|
||||||
AllArgs.push_back(arg.get());
|
AllArgs.push_back(arg.get());
|
||||||
}
|
}
|
||||||
|
|
||||||
// Otherwise do argument promotion, (C99 6.5.2.2p7).
|
// Otherwise do argument promotion, (C99 6.5.2.2p7).
|
||||||
} else {
|
} else {
|
||||||
for (unsigned i = ArgIx, e = Args.size(); i != e; ++i) {
|
for (Expr *A : Args.slice(ArgIx)) {
|
||||||
ExprResult Arg = DefaultVariadicArgumentPromotion(Args[i], CallType,
|
ExprResult Arg = DefaultVariadicArgumentPromotion(A, CallType, FDecl);
|
||||||
FDecl);
|
|
||||||
Invalid |= Arg.isInvalid();
|
Invalid |= Arg.isInvalid();
|
||||||
AllArgs.push_back(Arg.get());
|
AllArgs.push_back(Arg.get());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Check for array bounds violations.
|
// Check for array bounds violations.
|
||||||
for (unsigned i = ArgIx, e = Args.size(); i != e; ++i)
|
for (Expr *A : Args.slice(ArgIx))
|
||||||
CheckArrayAccess(Args[i]);
|
CheckArrayAccess(A);
|
||||||
}
|
}
|
||||||
return Invalid;
|
return Invalid;
|
||||||
}
|
}
|
||||||
|
@ -10983,10 +10973,8 @@ static bool isQualifiedMemberAccess(Expr *E) {
|
||||||
if (!ULE->getQualifier())
|
if (!ULE->getQualifier())
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
for (UnresolvedLookupExpr::decls_iterator D = ULE->decls_begin(),
|
for (NamedDecl *D : ULE->decls()) {
|
||||||
DEnd = ULE->decls_end();
|
if (CXXMethodDecl *Method = dyn_cast<CXXMethodDecl>(D)) {
|
||||||
D != DEnd; ++D) {
|
|
||||||
if (CXXMethodDecl *Method = dyn_cast<CXXMethodDecl>(*D)) {
|
|
||||||
if (Method->isInstance())
|
if (Method->isInstance())
|
||||||
return true;
|
return true;
|
||||||
} else {
|
} else {
|
||||||
|
@ -11326,9 +11314,8 @@ ExprResult Sema::BuildBuiltinOffsetOf(SourceLocation BuiltinLoc,
|
||||||
}
|
}
|
||||||
|
|
||||||
CXXBasePath &Path = Paths.front();
|
CXXBasePath &Path = Paths.front();
|
||||||
for (CXXBasePath::iterator B = Path.begin(), BEnd = Path.end();
|
for (const CXXBasePathElement &B : Path)
|
||||||
B != BEnd; ++B)
|
Comps.push_back(OffsetOfNode(B.Base));
|
||||||
Comps.push_back(OffsetOfNode(B->Base));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (IndirectMemberDecl) {
|
if (IndirectMemberDecl) {
|
||||||
|
@ -11596,8 +11583,7 @@ ExprResult Sema::ActOnBlockStmtExpr(SourceLocation CaretLoc,
|
||||||
// Set the captured variables on the block.
|
// Set the captured variables on the block.
|
||||||
// FIXME: Share capture structure between BlockDecl and CapturingScopeInfo!
|
// FIXME: Share capture structure between BlockDecl and CapturingScopeInfo!
|
||||||
SmallVector<BlockDecl::Capture, 4> Captures;
|
SmallVector<BlockDecl::Capture, 4> Captures;
|
||||||
for (unsigned i = 0, e = BSI->Captures.size(); i != e; i++) {
|
for (CapturingScopeInfo::Capture &Cap : BSI->Captures) {
|
||||||
CapturingScopeInfo::Capture &Cap = BSI->Captures[i];
|
|
||||||
if (Cap.isThisCapture())
|
if (Cap.isThisCapture())
|
||||||
continue;
|
continue;
|
||||||
BlockDecl::Capture NewCap(Cap.getVariable(), Cap.isBlockCapture(),
|
BlockDecl::Capture NewCap(Cap.getVariable(), Cap.isBlockCapture(),
|
||||||
|
@ -12037,9 +12023,8 @@ bool Sema::DiagnoseAssignmentResult(AssignConvertType ConvTy,
|
||||||
// If we can fix the conversion, suggest the FixIts.
|
// If we can fix the conversion, suggest the FixIts.
|
||||||
assert(ConvHints.isNull() || Hint.isNull());
|
assert(ConvHints.isNull() || Hint.isNull());
|
||||||
if (!ConvHints.isNull()) {
|
if (!ConvHints.isNull()) {
|
||||||
for (std::vector<FixItHint>::iterator HI = ConvHints.Hints.begin(),
|
for (FixItHint &H : ConvHints.Hints)
|
||||||
HE = ConvHints.Hints.end(); HI != HE; ++HI)
|
FDiag << H;
|
||||||
FDiag << *HI;
|
|
||||||
} else {
|
} else {
|
||||||
FDiag << Hint;
|
FDiag << Hint;
|
||||||
}
|
}
|
||||||
|
@ -12214,16 +12199,16 @@ Sema::VerifyIntegerConstantExpression(Expr *E, llvm::APSInt *Result,
|
||||||
if (!Folded || !AllowFold) {
|
if (!Folded || !AllowFold) {
|
||||||
if (!Diagnoser.Suppress) {
|
if (!Diagnoser.Suppress) {
|
||||||
Diagnoser.diagnoseNotICE(*this, DiagLoc, E->getSourceRange());
|
Diagnoser.diagnoseNotICE(*this, DiagLoc, E->getSourceRange());
|
||||||
for (unsigned I = 0, N = Notes.size(); I != N; ++I)
|
for (const PartialDiagnosticAt &Note : Notes)
|
||||||
Diag(Notes[I].first, Notes[I].second);
|
Diag(Note.first, Note.second);
|
||||||
}
|
}
|
||||||
|
|
||||||
return ExprError();
|
return ExprError();
|
||||||
}
|
}
|
||||||
|
|
||||||
Diagnoser.diagnoseFold(*this, DiagLoc, E->getSourceRange());
|
Diagnoser.diagnoseFold(*this, DiagLoc, E->getSourceRange());
|
||||||
for (unsigned I = 0, N = Notes.size(); I != N; ++I)
|
for (const PartialDiagnosticAt &Note : Notes)
|
||||||
Diag(Notes[I].first, Notes[I].second);
|
Diag(Note.first, Note.second);
|
||||||
|
|
||||||
if (Result)
|
if (Result)
|
||||||
*Result = EvalResult.Val.getInt();
|
*Result = EvalResult.Val.getInt();
|
||||||
|
@ -13413,15 +13398,13 @@ ExprResult Sema::ActOnConstantExpression(ExprResult Res) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void Sema::CleanupVarDeclMarking() {
|
void Sema::CleanupVarDeclMarking() {
|
||||||
for (llvm::SmallPtrSetIterator<Expr*> i = MaybeODRUseExprs.begin(),
|
for (Expr *E : MaybeODRUseExprs) {
|
||||||
e = MaybeODRUseExprs.end();
|
|
||||||
i != e; ++i) {
|
|
||||||
VarDecl *Var;
|
VarDecl *Var;
|
||||||
SourceLocation Loc;
|
SourceLocation Loc;
|
||||||
if (DeclRefExpr *DRE = dyn_cast<DeclRefExpr>(*i)) {
|
if (DeclRefExpr *DRE = dyn_cast<DeclRefExpr>(E)) {
|
||||||
Var = cast<VarDecl>(DRE->getDecl());
|
Var = cast<VarDecl>(DRE->getDecl());
|
||||||
Loc = DRE->getLocation();
|
Loc = DRE->getLocation();
|
||||||
} else if (MemberExpr *ME = dyn_cast<MemberExpr>(*i)) {
|
} else if (MemberExpr *ME = dyn_cast<MemberExpr>(E)) {
|
||||||
Var = cast<VarDecl>(ME->getMemberDecl());
|
Var = cast<VarDecl>(ME->getMemberDecl());
|
||||||
Loc = ME->getMemberLoc();
|
Loc = ME->getMemberLoc();
|
||||||
} else {
|
} else {
|
||||||
|
|
Loading…
Reference in New Issue