diff options
author | Argyrios Kyrtzidis <akyrtzi@gmail.com> | 2011-02-28 01:28:18 +0000 |
---|---|---|
committer | Argyrios Kyrtzidis <akyrtzi@gmail.com> | 2011-02-28 01:28:18 +0000 |
commit | d3bf3c0287a057eafe4b5d5588ebbb29f40ab6e1 (patch) | |
tree | 991f0f9ae25dd00eb112586b890fbf700dc64e62 /lib/StaticAnalyzer/Core/SVals.cpp | |
parent | d84f422ebfde2145bce79a8fa823e3393b392994 (diff) |
[analyzer] Introduce SVal::getAsVarDecl().
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@126627 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/StaticAnalyzer/Core/SVals.cpp')
-rw-r--r-- | lib/StaticAnalyzer/Core/SVals.cpp | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/lib/StaticAnalyzer/Core/SVals.cpp b/lib/StaticAnalyzer/Core/SVals.cpp index 4614e349de..76ad94e40d 100644 --- a/lib/StaticAnalyzer/Core/SVals.cpp +++ b/lib/StaticAnalyzer/Core/SVals.cpp @@ -60,6 +60,16 @@ const FunctionDecl *SVal::getAsFunctionDecl() const { return NULL; } +const VarDecl* SVal::getAsVarDecl() const { + if (const loc::MemRegionVal* X = dyn_cast<loc::MemRegionVal>(this)) { + const MemRegion* R = X->getRegion(); + if (const VarRegion *VR = R->getAs<VarRegion>()) + return cast<VarDecl>(VR->getDecl()); + } + + return NULL; +} + /// getAsLocSymbol - If this SVal is a location (subclasses Loc) and /// wraps a symbol, return that SymbolRef. Otherwise return 0. // FIXME: should we consider SymbolRef wrapped in CodeTextRegion? |