diff options
author | Devang Patel <dpatel@apple.com> | 2010-01-12 18:34:06 +0000 |
---|---|---|
committer | Devang Patel <dpatel@apple.com> | 2010-01-12 18:34:06 +0000 |
commit | 8b9d64605d602e5ba7b1effcb07320d82d717d1d (patch) | |
tree | b9ca5788e930a6077497944374e35de9988758fc /lib/VMCore | |
parent | 44a441c039289ae735f2130a66baf62de97c9b00 (diff) | |
download | external_llvm-8b9d64605d602e5ba7b1effcb07320d82d717d1d.zip external_llvm-8b9d64605d602e5ba7b1effcb07320d82d717d1d.tar.gz external_llvm-8b9d64605d602e5ba7b1effcb07320d82d717d1d.tar.bz2 |
Use ilist_tratis to autoinsert and remove NamedMDNode from MDSymbolTable.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@93247 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/VMCore')
-rw-r--r-- | lib/VMCore/Metadata.cpp | 31 | ||||
-rw-r--r-- | lib/VMCore/Module.cpp | 6 |
2 files changed, 25 insertions, 12 deletions
diff --git a/lib/VMCore/Metadata.cpp b/lib/VMCore/Metadata.cpp index 1499313..5ea7bd4 100644 --- a/lib/VMCore/Metadata.cpp +++ b/lib/VMCore/Metadata.cpp @@ -239,6 +239,26 @@ void MDNode::replaceOperand(MDNodeOperand *Op, Value *To) { //===----------------------------------------------------------------------===// // NamedMDNode implementation. // + +namespace llvm { +// SymbolTableListTraits specialization for MDSymbolTable. +void ilist_traits<NamedMDNode> +::addNodeToList(NamedMDNode *N) { + assert(N->getParent() == 0 && "Value already in a container!!"); + Module *Owner = getListOwner(); + N->setParent(Owner); + MDSymbolTable &ST = Owner->getMDSymbolTable(); + ST.insert(N->getName(), N); +} + +void ilist_traits<NamedMDNode>::removeNodeFromList(NamedMDNode *N) { + N->setParent(0); + Module *Owner = getListOwner(); + MDSymbolTable &ST = Owner->getMDSymbolTable(); + ST.remove(N->getName()); +} +} + static SmallVector<WeakVH, 4> &getNMDOps(void *Operands) { return *(SmallVector<WeakVH, 4>*)Operands; } @@ -254,10 +274,8 @@ NamedMDNode::NamedMDNode(LLVMContext &C, StringRef N, for (unsigned i = 0; i != NumMDs; ++i) Node.push_back(WeakVH(MDs[i])); - if (ParentModule) { + if (ParentModule) ParentModule->getNamedMDList().push_back(this); - ParentModule->addMDNodeName(N, this); - } } NamedMDNode *NamedMDNode::Create(const NamedMDNode *NMD, Module *M) { @@ -295,7 +313,6 @@ void NamedMDNode::addOperand(MDNode *M) { /// eraseFromParent - Drop all references and remove the node from parent /// module. void NamedMDNode::eraseFromParent() { - getParent()->getMDSymbolTable().remove(getName()); getParent()->getNamedMDList().erase(this); } @@ -306,8 +323,10 @@ void NamedMDNode::dropAllReferences() { /// setName - Set the name of this named metadata. void NamedMDNode::setName(StringRef N) { - if (!N.empty()) - Name = N.str(); + assert (!N.empty() && "Invalid named metadata name!"); + Name = N.str(); + if (Parent) + Parent->getMDSymbolTable().insert(N, this); } /// getName - Return a constant reference to this named metadata's name. diff --git a/lib/VMCore/Module.cpp b/lib/VMCore/Module.cpp index 510f3d5..503e708 100644 --- a/lib/VMCore/Module.cpp +++ b/lib/VMCore/Module.cpp @@ -325,12 +325,6 @@ NamedMDNode *Module::getOrInsertNamedMetadata(StringRef Name) { return NMD; } -/// addMDNodeName - Insert an entry in the NamedMDNode symbol table mapping -/// Name to NMD. -void Module::addMDNodeName(StringRef Name, NamedMDNode *NMD) { - NamedMDSymTab->insert(Name, NMD); -} - //===----------------------------------------------------------------------===// // Methods for easy access to the types in the module. // |