Implemented "getType()" for symbolic values representing the "contents" of
another symbolic value.
llvm-svn: 47339
diff --git a/clang/Analysis/SymbolManager.cpp b/clang/Analysis/SymbolManager.cpp
index bdda0e6..ced5741 100644
--- a/clang/Analysis/SymbolManager.cpp
+++ b/clang/Analysis/SymbolManager.cpp
@@ -38,7 +38,7 @@
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 @@
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();
+ }
}
}