From: Ted Kremenek Date: Tue, 19 Feb 2008 20:51:40 +0000 (+0000) Subject: Implemented "getType()" for symbolic values representing the "contents" of X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=a888c98b424b0232c45ae61d13b073bf81eaa859;p=clang 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 --- 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(this)->getDecl()->getType(); + case ContentsOfKind: { + SymbolID x = cast(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 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); } };