about summary refs log tree commit diff homepage
path: root/lib/Solver/FastCexSolver.cpp
diff options
context:
space:
mode:
authorDaniel Dunbar <daniel@zuster.org>2009-06-09 06:20:23 +0000
committerDaniel Dunbar <daniel@zuster.org>2009-06-09 06:20:23 +0000
commitaad9179e9401872640bf19ebd7a4e215c4ec5702 (patch)
tree8fc3c93ed807f88b54cc1cbf59e2e2c61751fdaf /lib/Solver/FastCexSolver.cpp
parent4b861bad5d3a832ff4d91610dfa766149003e07f (diff)
downloadklee-aad9179e9401872640bf19ebd7a4e215c4ec5702.tar.gz
Use Array* to map objects instead of id.
git-svn-id: https://llvm.org/svn/llvm-project/klee/trunk@73126 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Solver/FastCexSolver.cpp')
-rw-r--r--lib/Solver/FastCexSolver.cpp22
1 files changed, 11 insertions, 11 deletions
diff --git a/lib/Solver/FastCexSolver.cpp b/lib/Solver/FastCexSolver.cpp
index 1d06ca33..608388bb 100644
--- a/lib/Solver/FastCexSolver.cpp
+++ b/lib/Solver/FastCexSolver.cpp
@@ -337,8 +337,8 @@ public:
 
 class CexRangeEvaluator : public ExprRangeEvaluator<ValueRange> {
 public:
-  std::map<unsigned, CexObjectData*> &objects;
-  CexRangeEvaluator(std::map<unsigned, CexObjectData*> &_objects) 
+  std::map<const Array*, CexObjectData*> &objects;
+  CexRangeEvaluator(std::map<const Array*, CexObjectData*> &_objects) 
     : objects(_objects) {}
 
   ValueRange getInitialReadRange(const Array &os, ValueRange index) {
@@ -355,15 +355,15 @@ protected:
       return ReadExpr::create(UpdateList(&array, 0), 
                               ConstantExpr::alloc(index, Expr::Int32));
       
-    std::map<unsigned, CexObjectData*>::iterator it = objects.find(array.id);
+    std::map<const Array*, CexObjectData*>::iterator it = objects.find(&array);
     return ConstantExpr::alloc((it == objects.end() ? 127 : 
                                 it->second->getPossibleValue(index)),
                                Expr::Int8);
   }
 
 public:
-  std::map<unsigned, CexObjectData*> &objects;
-  CexPossibleEvaluator(std::map<unsigned, CexObjectData*> &_objects) 
+  std::map<const Array*, CexObjectData*> &objects;
+  CexPossibleEvaluator(std::map<const Array*, CexObjectData*> &_objects) 
     : objects(_objects) {}
 };
 
@@ -376,7 +376,7 @@ protected:
       return ReadExpr::create(UpdateList(&array, 0), 
                               ConstantExpr::alloc(index, Expr::Int32));
       
-    std::map<unsigned, CexObjectData*>::iterator it = objects.find(array.id);
+    std::map<const Array*, CexObjectData*>::iterator it = objects.find(&array);
     if (it == objects.end())
       return ReadExpr::create(UpdateList(&array, 0), 
                               ConstantExpr::alloc(index, Expr::Int32));
@@ -390,14 +390,14 @@ protected:
   }
 
 public:
-  std::map<unsigned, CexObjectData*> &objects;
-  CexExactEvaluator(std::map<unsigned, CexObjectData*> &_objects) 
+  std::map<const Array*, CexObjectData*> &objects;
+  CexExactEvaluator(std::map<const Array*, CexObjectData*> &_objects) 
     : objects(_objects) {}
 };
 
 class CexData {
 public:
-  std::map<unsigned, CexObjectData*> objects;
+  std::map<const Array*, CexObjectData*> objects;
 
   CexData(const CexData&); // DO NOT IMPLEMENT
   void operator=(const CexData&); // DO NOT IMPLEMENT
@@ -405,13 +405,13 @@ public:
 public:
   CexData() {}
   ~CexData() {
-    for (std::map<unsigned, CexObjectData*>::iterator it = objects.begin(),
+    for (std::map<const Array*, CexObjectData*>::iterator it = objects.begin(),
            ie = objects.end(); it != ie; ++it)
       delete it->second;
   }
 
   CexObjectData &getObjectData(const Array *A) {
-    CexObjectData *&Entry = objects[A->id];
+    CexObjectData *&Entry = objects[A];
 
     if (!Entry)
       Entry = new CexObjectData(A->size);