From 094bef56a7900f13bb777f9a352704104b1458e7 Mon Sep 17 00:00:00 2001 From: Ted Kremenek Date: Fri, 30 Oct 2009 17:47:32 +0000 Subject: [PATCH] Make checkers run in deterministic order. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@85597 91177308-0d34-0410-b5e6-96231b3b80d8 --- .../Analysis/PathSensitive/GRExprEngine.h | 19 +++++++++++---- lib/Analysis/GRExprEngine.cpp | 24 ++++++++++++------- 2 files changed, 29 insertions(+), 14 deletions(-) diff --git a/include/clang/Analysis/PathSensitive/GRExprEngine.h b/include/clang/Analysis/PathSensitive/GRExprEngine.h index 89ca337f15..90124c279d 100644 --- a/include/clang/Analysis/PathSensitive/GRExprEngine.h +++ b/include/clang/Analysis/PathSensitive/GRExprEngine.h @@ -76,7 +76,11 @@ class GRExprEngine : public GRSubEngine { llvm::OwningPtr BatchAuditor; - llvm::DenseMap Checkers; + typedef llvm::DenseMap CheckerMap; + CheckerMap CheckerM; + + typedef std::vector >CheckersOrdered; + CheckersOrdered Checkers; /// BR - The BugReporter associated with this engine. It is important that // this object be placed at the very end of member variables so that its @@ -205,13 +209,18 @@ public: void RegisterInternalChecks(); template - void registerCheck(Checker *check) { - Checkers[CHECKER::getTag()] = check; + void registerCheck(CHECKER *check) { + unsigned entry = Checkers.size(); + void *tag = CHECKER::getTag(); + Checkers.push_back(std::make_pair(tag, check)); + CheckerM[tag] = entry; } + + Checker *lookupChecker(void *tag) const; template - CHECKER *getChecker() { - return static_cast(Checkers[CHECKER::getTag()]); + CHECKER *getChecker() const { + return static_cast(lookupChecker(CHECKER::getTag())); } bool isRetStackAddr(const ExplodedNode* N) const { diff --git a/lib/Analysis/GRExprEngine.cpp b/lib/Analysis/GRExprEngine.cpp index 88e67981ac..284fae8675 100644 --- a/lib/Analysis/GRExprEngine.cpp +++ b/lib/Analysis/GRExprEngine.cpp @@ -118,13 +118,11 @@ void GRExprEngine::CheckerVisit(Stmt *S, ExplodedNodeSet &Dst, ExplodedNodeSet Tmp; ExplodedNodeSet *PrevSet = &Src; - for (llvm::DenseMap::iterator I = Checkers.begin(), - E = Checkers.end(); I != E; ++I) { - - llvm::DenseMap::iterator X = I; - - ExplodedNodeSet *CurrSet = (++X == E) ? &Dst + for (CheckersOrdered::iterator I=Checkers.begin(),E=Checkers.end(); I!=E; ++I) + { + ExplodedNodeSet *CurrSet = (I+1 == E) ? &Dst : (PrevSet == &Tmp) ? &Src : &Tmp; + CurrSet->clear(); void *tag = I->first; Checker *checker = I->second; @@ -146,7 +144,7 @@ ExplodedNode *GRExprEngine::CheckerVisitLocation(Stmt *S, ExplodedNode *Pred, if (Checkers.empty()) return Pred; - for (llvm::DenseMap::iterator I = Checkers.begin(), + for (CheckersOrdered::iterator I = Checkers.begin(), E = Checkers.end(); I != E; ++I) { Pred = I->second->CheckLocation(S, Pred, state, V, *this); if (!Pred) @@ -184,8 +182,7 @@ GRExprEngine::GRExprEngine(AnalysisManager &mgr) GRExprEngine::~GRExprEngine() { BR.FlushReports(); delete [] NSExceptionInstanceRaiseSelectors; - for (llvm::DenseMap::iterator I=Checkers.begin(), - E=Checkers.end(); I!=E; ++I) + for (CheckersOrdered::iterator I=Checkers.begin(), E=Checkers.end(); I!=E;++I) delete I->second; } @@ -2860,6 +2857,15 @@ void GRExprEngine::VisitBinaryOperator(BinaryOperator* B, } } +//===----------------------------------------------------------------------===// +// Checker registration/lookup. +//===----------------------------------------------------------------------===// + +Checker *GRExprEngine::lookupChecker(void *tag) const { + CheckerMap::iterator I = CheckerM.find(tag); + return (I == CheckerM.end()) ? NULL : Checkers[I->second].second; +} + //===----------------------------------------------------------------------===// // Visualization. //===----------------------------------------------------------------------===// -- 2.40.0