aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTed Kremenek <kremenek@apple.com>2008-02-19 20:51:40 +0000
committerTed Kremenek <kremenek@apple.com>2008-02-19 20:51:40 +0000
commita888c98b424b0232c45ae61d13b073bf81eaa859 (patch)
treef1e25a93d12a4ca5fa62320675bbf12e91aeed0c
parent145cd89f9233d375381aa13bd28b2d36f83e6181 (diff)
Implemented "getType()" for symbolic values representing the "contents" of
another symbolic value. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@47339 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r--Analysis/SymbolManager.cpp7
-rw-r--r--include/clang/Analysis/PathSensitive/SymbolManager.h6
2 files changed, 10 insertions, 3 deletions
diff --git a/Analysis/SymbolManager.cpp b/Analysis/SymbolManager.cpp
index bdda0e6eed..ced5741f44 100644
--- a/Analysis/SymbolManager.cpp
+++ b/Analysis/SymbolManager.cpp
@@ -38,7 +38,7 @@ SymbolID SymbolManager::getContentsOfSymbol(SymbolID sym) {
return X;
}
-QualType SymbolData::getType() const {
+QualType SymbolData::getType(const SymbolManager& SymMgr) const {
switch (getKind()) {
default:
assert (false && "getType() not implemented for this symbol.");
@@ -46,6 +46,11 @@ QualType SymbolData::getType() const {
case ParmKind:
return cast<SymbolDataParmVar>(this)->getDecl()->getType();
+ case ContentsOfKind: {
+ SymbolID x = cast<SymbolDataContentsOf>(this)->getSymbol();
+ QualType T = SymMgr.getSymbolData(x).getType(SymMgr);
+ return T->getAsPointerType()->getPointeeType();
+ }
}
}
diff --git a/include/clang/Analysis/PathSensitive/SymbolManager.h b/include/clang/Analysis/PathSensitive/SymbolManager.h
index 2114dc6033..d29e0e08b9 100644
--- a/include/clang/Analysis/PathSensitive/SymbolManager.h
+++ b/include/clang/Analysis/PathSensitive/SymbolManager.h
@@ -24,6 +24,8 @@
namespace clang {
+class SymbolManager;
+
class SymbolID {
unsigned Data;
public:
@@ -76,7 +78,7 @@ public:
return K == R.K && Data == R.Data;
}
- QualType getType() const;
+ QualType getType(const SymbolManager& SymMgr) const;
// Implement isa<T> support.
static inline bool classof(const SymbolData*) { return true; }
@@ -164,7 +166,7 @@ public:
}
inline QualType getType(SymbolID ID) const {
- return getSymbolData(ID).getType();
+ return getSymbolData(ID).getType(*this);
}
};