diff options
Diffstat (limited to 'lib/Analysis/BasicStore.cpp')
-rw-r--r-- | lib/Analysis/BasicStore.cpp | 34 |
1 files changed, 34 insertions, 0 deletions
diff --git a/lib/Analysis/BasicStore.cpp b/lib/Analysis/BasicStore.cpp index ace8f3fbb5..867028dc19 100644 --- a/lib/Analysis/BasicStore.cpp +++ b/lib/Analysis/BasicStore.cpp @@ -56,6 +56,14 @@ public: const char* nl, const char *sep); virtual RegionExtent getExtent(Region R); + + /// getBindings - Returns all bindings in the specified store that bind + /// to the specified symbolic value. + virtual void getBindings(llvm::SmallVectorImpl<store::Binding>& bindings, + Store store, SymbolID Sym); + + /// BindingAsString - Returns a string representing the given binding. + virtual std::string BindingAsString(store::Binding binding); }; } // end anonymous namespace @@ -326,3 +334,29 @@ void BasicStoreManager::print(Store store, std::ostream& Out, I.getData().print(Out); } } + +void +BasicStoreManager::getBindings(llvm::SmallVectorImpl<store::Binding>& bindings, + Store store, SymbolID Sym) { + + VarBindingsTy VB((VarBindingsTy::TreeTy*) store); + + for (VarBindingsTy::iterator I=VB.begin(), E=VB.end(); I!=E; ++I) { + if (const lval::SymbolVal* SV=dyn_cast<lval::SymbolVal>(&I->second)) { + if (SV->getSymbol() == Sym) + bindings.push_back(I->first); + + continue; + } + + if (const nonlval::SymbolVal* SV=dyn_cast<nonlval::SymbolVal>(&I->second)){ + if (SV->getSymbol() == Sym) + bindings.push_back(I->first); + } + } +} + +std::string BasicStoreManager::BindingAsString(store::Binding binding) { + // A binding is just an VarDecl*. + return ((VarDecl*) binding)->getName(); +} |