[Sema] Use range-based for loops. NFC

llvm-svn: 256135
This commit is contained in:
Craig Topper 2015-12-21 06:35:56 +00:00
parent 9ec6a826dd
commit dfe29ae5db
1 changed files with 39 additions and 56 deletions

View File

@ -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 {