aboutsummaryrefslogtreecommitdiffstats
path: root/lib/VMCore
diff options
context:
space:
mode:
authorDevang Patel <dpatel@apple.com>2010-01-12 18:34:06 +0000
committerDevang Patel <dpatel@apple.com>2010-01-12 18:34:06 +0000
commit8b9d64605d602e5ba7b1effcb07320d82d717d1d (patch)
treeb9ca5788e930a6077497944374e35de9988758fc /lib/VMCore
parent44a441c039289ae735f2130a66baf62de97c9b00 (diff)
downloadexternal_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.cpp31
-rw-r--r--lib/VMCore/Module.cpp6
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.
//