r247375 - [modules] Slightly defang an assert that produces false-positives on the selfhost bot.
Richard Smith via cfe-commits
cfe-commits at lists.llvm.org
Thu Sep 10 19:22:03 PDT 2015
Author: rsmith
Date: Thu Sep 10 21:22:03 2015
New Revision: 247375
URL: http://llvm.org/viewvc/llvm-project?rev=247375&view=rev
Log:
[modules] Slightly defang an assert that produces false-positives on the selfhost bot.
Modified:
cfe/trunk/lib/Serialization/ASTWriterDecl.cpp
Modified: cfe/trunk/lib/Serialization/ASTWriterDecl.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Serialization/ASTWriterDecl.cpp?rev=247375&r1=247374&r2=247375&view=diff
==============================================================================
--- cfe/trunk/lib/Serialization/ASTWriterDecl.cpp (original)
+++ cfe/trunk/lib/Serialization/ASTWriterDecl.cpp Thu Sep 10 21:22:03 2015
@@ -1522,20 +1522,21 @@ void ASTDeclWriter::VisitDeclContext(Dec
Record.push_back(VisibleOffset);
}
-/// \brief Is this a local declaration (that is, one that will be written to
-/// our AST file)? This is the case for declarations that are neither imported
-/// from another AST file nor predefined.
-static bool isLocalDecl(ASTWriter &W, const Decl *D) {
- if (D->isFromASTFile())
- return false;
- return W.getDeclID(D) >= NUM_PREDEF_DECL_IDS;
-}
-
const Decl *ASTWriter::getFirstLocalDecl(const Decl *D) {
- assert(isLocalDecl(*this, D) && "expected a local declaration");
+ /// \brief Is this a local declaration (that is, one that will be written to
+ /// our AST file)? This is the case for declarations that are neither imported
+ /// from another AST file nor predefined.
+ auto IsLocalDecl = [&](const Decl *D) -> bool {
+ if (D->isFromASTFile())
+ return false;
+ auto I = DeclIDs.find(D);
+ return (I == DeclIDs.end() || I->second >= NUM_PREDEF_DECL_IDS);
+ };
+
+ assert(IsLocalDecl(D) && "expected a local declaration");
const Decl *Canon = D->getCanonicalDecl();
- if (isLocalDecl(*this, Canon))
+ if (IsLocalDecl(Canon))
return Canon;
const Decl *&CacheEntry = FirstLocalDeclCache[Canon];
@@ -1543,7 +1544,7 @@ const Decl *ASTWriter::getFirstLocalDecl
return CacheEntry;
for (const Decl *Redecl = D; Redecl; Redecl = Redecl->getPreviousDecl())
- if (isLocalDecl(*this, Redecl))
+ if (IsLocalDecl(Redecl))
D = Redecl;
return CacheEntry = D;
}
More information about the cfe-commits
mailing list