diff options
author | Zhongxing Xu <xuzhongxing@gmail.com> | 2008-11-19 11:03:17 +0000 |
---|---|---|
committer | Zhongxing Xu <xuzhongxing@gmail.com> | 2008-11-19 11:03:17 +0000 |
commit | b8e54884c858af5ab0af76a83ad654b397101729 (patch) | |
tree | 2bb7a9cdb17c39b920cc09a8f95d640bd1aaf966 /clang/lib/Analysis/SymbolManager.cpp | |
parent | 2ae21ee51798759d1fa455969f53c5a428e3f091 (diff) | |
download | bcm5719-llvm-b8e54884c858af5ab0af76a83ad654b397101729.tar.gz bcm5719-llvm-b8e54884c858af5ab0af76a83ad654b397101729.zip |
Add SymbolData for array elements and struct fields.
llvm-svn: 59618
Diffstat (limited to 'clang/lib/Analysis/SymbolManager.cpp')
-rw-r--r-- | clang/lib/Analysis/SymbolManager.cpp | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/clang/lib/Analysis/SymbolManager.cpp b/clang/lib/Analysis/SymbolManager.cpp index 7829e3ace3a..aee74a4a14e 100644 --- a/clang/lib/Analysis/SymbolManager.cpp +++ b/clang/lib/Analysis/SymbolManager.cpp @@ -51,6 +51,41 @@ SymbolID SymbolManager::getSymbol(VarDecl* D) { DataMap[SymbolCounter] = SD; return SymbolCounter++; } + +SymbolID SymbolManager::getElementSymbol(const MemRegion* R, + const llvm::APSInt* Idx){ + llvm::FoldingSetNodeID ID; + SymbolDataElement::Profile(ID, R, Idx); + void* InsertPos; + SymbolData* SD = DataSet.FindNodeOrInsertPos(ID, InsertPos); + + if (SD) + return SD->getSymbol(); + + SD = (SymbolData*) BPAlloc.Allocate<SymbolDataElement>(); + new (SD) SymbolDataElement(SymbolCounter, R, Idx); + + DataSet.InsertNode(SD, InsertPos); + DataMap[SymbolCounter] = SD; + return SymbolCounter++; +} + +SymbolID SymbolManager::getFieldSymbol(const MemRegion* R, const FieldDecl* D) { + llvm::FoldingSetNodeID ID; + SymbolDataField::Profile(ID, R, D); + void* InsertPos; + SymbolData* SD = DataSet.FindNodeOrInsertPos(ID, InsertPos); + + if (SD) + return SD->getSymbol(); + + SD = (SymbolData*) BPAlloc.Allocate<SymbolDataField>(); + new (SD) SymbolDataField(SymbolCounter, R, D); + + DataSet.InsertNode(SD, InsertPos); + DataMap[SymbolCounter] = SD; + return SymbolCounter++; +} SymbolID SymbolManager::getContentsOfSymbol(SymbolID sym) { |