aboutsummaryrefslogtreecommitdiff
path: root/lib/Analysis/SymbolManager.cpp
diff options
context:
space:
mode:
authorZhongxing Xu <xuzhongxing@gmail.com>2009-03-25 05:58:37 +0000
committerZhongxing Xu <xuzhongxing@gmail.com>2009-03-25 05:58:37 +0000
commita129eb974d8ff0ad4a4dd94ad1e6c5f98897ddb4 (patch)
tree324b0f41b3a8ebe9cb2c6d66bfaa5feab91b6f9f /lib/Analysis/SymbolManager.cpp
parentea728acde83cfaee282ab239fa2c22dccca819a0 (diff)
This patch adds two more SymbolData subclasses: SymIntExpr and SymSymExpr, for
representing symbolic expressions like 'x'+3 and 'x'+'y'. The design is subjected to change later when we fix the class hierarchy of symbolic expressions. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@67678 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Analysis/SymbolManager.cpp')
-rw-r--r--lib/Analysis/SymbolManager.cpp41
1 files changed, 41 insertions, 0 deletions
diff --git a/lib/Analysis/SymbolManager.cpp b/lib/Analysis/SymbolManager.cpp
index efc7cd3b86..33d6a5722e 100644
--- a/lib/Analysis/SymbolManager.cpp
+++ b/lib/Analysis/SymbolManager.cpp
@@ -74,6 +74,47 @@ SymbolRef SymbolManager::getConjuredSymbol(const Stmt* E, QualType T,
return SymbolCounter++;
}
+SymbolRef SymbolManager::getSymIntExpr(SymbolRef lhs,BinaryOperator::Opcode op,
+ const llvm::APSInt& v, QualType t) {
+ llvm::FoldingSetNodeID ID;
+ SymIntExpr::Profile(ID, lhs, op, v, t);
+ void* InsertPos;
+
+ SymbolData* data = DataSet.FindNodeOrInsertPos(ID, InsertPos);
+
+ if (data)
+ return data->getSymbol();
+
+ data = (SymIntExpr*) BPAlloc.Allocate<SymIntExpr>();
+ new (data) SymIntExpr(SymbolCounter, lhs, op, v, t);
+
+ DataSet.InsertNode(data, InsertPos);
+ DataMap[SymbolCounter] = data;
+
+ return SymbolCounter++;
+}
+
+SymbolRef SymbolManager::getSymSymExpr(SymbolRef lhs, BinaryOperator::Opcode op,
+ SymbolRef rhs, QualType t) {
+ llvm::FoldingSetNodeID ID;
+ SymSymExpr::Profile(ID, lhs, op, rhs, t);
+ void* InsertPos;
+
+ SymbolData* data = DataSet.FindNodeOrInsertPos(ID, InsertPos);
+
+ if (data)
+ return data->getSymbol();
+
+ data = (SymSymExpr*) BPAlloc.Allocate<SymSymExpr>();
+ new (data) SymSymExpr(SymbolCounter, lhs, op, rhs, t);
+
+ DataSet.InsertNode(data, InsertPos);
+ DataMap[SymbolCounter] = data;
+
+ return SymbolCounter++;
+}
+
+
const SymbolData& SymbolManager::getSymbolData(SymbolRef Sym) const {
DataMapTy::const_iterator I = DataMap.find(Sym);
assert (I != DataMap.end());