diff options
author | Ted Kremenek <kremenek@apple.com> | 2008-02-19 20:51:40 +0000 |
---|---|---|
committer | Ted Kremenek <kremenek@apple.com> | 2008-02-19 20:51:40 +0000 |
commit | 4baef06bbccf930617104df02d9c652cad3842e8 (patch) | |
tree | 6d9ff2cb00cad8a39b1bc4afbdc10daba594b605 /clang/Analysis/SymbolManager.cpp | |
parent | 901540f118cd091626cacb67ece23ef11fbbff41 (diff) | |
download | bcm5719-llvm-4baef06bbccf930617104df02d9c652cad3842e8.tar.gz bcm5719-llvm-4baef06bbccf930617104df02d9c652cad3842e8.zip |
Implemented "getType()" for symbolic values representing the "contents" of
another symbolic value.
llvm-svn: 47339
Diffstat (limited to 'clang/Analysis/SymbolManager.cpp')
-rw-r--r-- | clang/Analysis/SymbolManager.cpp | 7 |
1 files changed, 6 insertions, 1 deletions
diff --git a/clang/Analysis/SymbolManager.cpp b/clang/Analysis/SymbolManager.cpp index bdda0e6eed3..ced5741f447 100644 --- a/clang/Analysis/SymbolManager.cpp +++ b/clang/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(); + } } } |