aboutsummaryrefslogtreecommitdiff
path: root/lib/Checker/GRCoreEngine.cpp
diff options
context:
space:
mode:
authorTed Kremenek <kremenek@apple.com>2010-11-13 05:04:49 +0000
committerTed Kremenek <kremenek@apple.com>2010-11-13 05:04:49 +0000
commit3e47b486f200d2b4cfb069c6f0d20fe5cf189fcd (patch)
tree40ce1a6bd9f6ec53b5af99ec4a3b552e8b2a431e /lib/Checker/GRCoreEngine.cpp
parent72a014197ceb759f14eeca78c713caf64d6d196d (diff)
Add GRWorkList::VisitItemsInWorkList() to allow a client to introspect the contents of a worklist.
This API required changing the BFS worklist to use a deque instead of a queue, but that is better for performance reasons anyway. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@118982 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Checker/GRCoreEngine.cpp')
-rw-r--r--lib/Checker/GRCoreEngine.cpp48
1 files changed, 40 insertions, 8 deletions
diff --git a/lib/Checker/GRCoreEngine.cpp b/lib/Checker/GRCoreEngine.cpp
index 4bcac4d16b..50aa563c69 100644
--- a/lib/Checker/GRCoreEngine.cpp
+++ b/lib/Checker/GRCoreEngine.cpp
@@ -36,6 +36,8 @@ GRTransferFuncs* MakeCFRefCountTF(ASTContext& Ctx, bool GCEnabled,
// Worklist classes for exploration of reachable states.
//===----------------------------------------------------------------------===//
+GRWorkList::Visitor::~Visitor() {}
+
namespace {
class DFS : public GRWorkList {
llvm::SmallVector<GRWorkListUnit,20> Stack;
@@ -54,26 +56,42 @@ public:
Stack.pop_back(); // This technically "invalidates" U, but we are fine.
return U;
}
+
+ virtual bool VisitItemsInWorkList(Visitor &V) {
+ for (llvm::SmallVectorImpl<GRWorkListUnit>::iterator
+ I = Stack.begin(), E = Stack.end(); I != E; ++I) {
+ if (V.Visit(*I))
+ return true;
+ }
+ return false;
+ }
};
class BFS : public GRWorkList {
- std::queue<GRWorkListUnit> Queue;
+ std::deque<GRWorkListUnit> Queue;
public:
virtual bool hasWork() const {
return !Queue.empty();
}
virtual void Enqueue(const GRWorkListUnit& U) {
- Queue.push(U);
+ Queue.push_front(U);
}
virtual GRWorkListUnit Dequeue() {
- // Don't use const reference. The subsequent pop_back() might make it
- // unsafe.
GRWorkListUnit U = Queue.front();
- Queue.pop();
+ Queue.pop_front();
return U;
}
+
+ virtual bool VisitItemsInWorkList(Visitor &V) {
+ for (std::deque<GRWorkListUnit>::iterator
+ I = Queue.begin(), E = Queue.end(); I != E; ++I) {
+ if (V.Visit(*I))
+ return true;
+ }
+ return false;
+ }
};
} // end anonymous namespace
@@ -87,7 +105,7 @@ GRWorkList *GRWorkList::MakeBFS() { return new BFS(); }
namespace {
class BFSBlockDFSContents : public GRWorkList {
- std::queue<GRWorkListUnit> Queue;
+ std::deque<GRWorkListUnit> Queue;
llvm::SmallVector<GRWorkListUnit,20> Stack;
public:
virtual bool hasWork() const {
@@ -96,7 +114,7 @@ namespace {
virtual void Enqueue(const GRWorkListUnit& U) {
if (isa<BlockEntrance>(U.getNode()->getLocation()))
- Queue.push(U);
+ Queue.push_front(U);
else
Stack.push_back(U);
}
@@ -113,9 +131,23 @@ namespace {
// Don't use const reference. The subsequent pop_back() might make it
// unsafe.
GRWorkListUnit U = Queue.front();
- Queue.pop();
+ Queue.pop_front();
return U;
}
+ virtual bool VisitItemsInWorkList(Visitor &V) {
+ for (llvm::SmallVectorImpl<GRWorkListUnit>::iterator
+ I = Stack.begin(), E = Stack.end(); I != E; ++I) {
+ if (V.Visit(*I))
+ return true;
+ }
+ for (std::deque<GRWorkListUnit>::iterator
+ I = Queue.begin(), E = Queue.end(); I != E; ++I) {
+ if (V.Visit(*I))
+ return true;
+ }
+ return false;
+ }
+
};
} // end anonymous namespace