Refactor MemRegionManager instance variable into parent class. No functionality change.
llvm-svn: 61888
This commit is contained in:
parent
f325278799
commit
682c3a6dd6
|
@ -37,7 +37,14 @@ class StoreManager {
|
|||
public:
|
||||
typedef llvm::SmallSet<SymbolRef, 20> LiveSymbolsTy;
|
||||
typedef llvm::DenseSet<SymbolRef> DeadSymbolsTy;
|
||||
|
||||
|
||||
protected:
|
||||
/// MRMgr - Manages region objects associated with this StoreManager.
|
||||
MemRegionManager MRMgr;
|
||||
|
||||
StoreManager(llvm::BumpPtrAllocator& Alloc) : MRMgr(Alloc) {}
|
||||
|
||||
public:
|
||||
virtual ~StoreManager() {}
|
||||
|
||||
/// Retrieve - Retrieves the value bound to specified location. The optional
|
||||
|
@ -64,7 +71,7 @@ public:
|
|||
SVal V) = 0;
|
||||
|
||||
virtual Store getInitialStore() = 0;
|
||||
virtual MemRegionManager& getRegionManager() = 0;
|
||||
MemRegionManager& getRegionManager() { return MRMgr; }
|
||||
|
||||
virtual SVal getLValueVar(const GRState* St, const VarDecl* VD) = 0;
|
||||
|
||||
|
|
|
@ -26,14 +26,13 @@ namespace {
|
|||
class VISIBILITY_HIDDEN BasicStoreManager : public StoreManager {
|
||||
VarBindingsTy::Factory VBFactory;
|
||||
GRStateManager& StateMgr;
|
||||
MemRegionManager MRMgr;
|
||||
const MemRegion* SelfRegion;
|
||||
|
||||
public:
|
||||
BasicStoreManager(GRStateManager& mgr)
|
||||
: VBFactory(mgr.getAllocator()),
|
||||
: StoreManager(mgr.getAllocator()),
|
||||
VBFactory(mgr.getAllocator()),
|
||||
StateMgr(mgr),
|
||||
MRMgr(StateMgr.getAllocator()),
|
||||
SelfRegion(0) {}
|
||||
|
||||
~BasicStoreManager() {}
|
||||
|
@ -49,7 +48,6 @@ public:
|
|||
Store BindInternal(Store St, Loc LV, SVal V);
|
||||
Store Remove(Store St, Loc LV);
|
||||
Store getInitialStore();
|
||||
MemRegionManager& getRegionManager() { return MRMgr; }
|
||||
|
||||
// FIXME: Investigate what is using this. This method should be removed.
|
||||
virtual Loc getLoc(const VarDecl* VD) {
|
||||
|
|
|
@ -54,6 +54,7 @@ namespace clang {
|
|||
//
|
||||
// MemRegions represent chunks of memory with a size (their "extent"). This
|
||||
// GDM entry tracks the extents for regions. Extents are in bytes.
|
||||
//
|
||||
namespace { class VISIBILITY_HIDDEN RegionExtents {}; }
|
||||
static int RegionExtentsIndex = 0;
|
||||
namespace clang {
|
||||
|
@ -108,14 +109,13 @@ class VISIBILITY_HIDDEN RegionStoreManager : public StoreManager {
|
|||
RegionViews::Factory RVFactory;
|
||||
|
||||
GRStateManager& StateMgr;
|
||||
MemRegionManager MRMgr;
|
||||
|
||||
public:
|
||||
RegionStoreManager(GRStateManager& mgr)
|
||||
: RBFactory(mgr.getAllocator()),
|
||||
: StoreManager(mgr.getAllocator()),
|
||||
RBFactory(mgr.getAllocator()),
|
||||
RVFactory(mgr.getAllocator()),
|
||||
StateMgr(mgr),
|
||||
MRMgr(StateMgr.getAllocator()) {}
|
||||
StateMgr(mgr) {}
|
||||
|
||||
virtual ~RegionStoreManager() {}
|
||||
|
||||
|
|
Loading…
Reference in New Issue