diff options
author | Devang Patel <dpatel@apple.com> | 2009-07-30 23:59:04 +0000 |
---|---|---|
committer | Devang Patel <dpatel@apple.com> | 2009-07-30 23:59:04 +0000 |
commit | 49fe6c914c5f356a97619046384d7ceb2cb5187e (patch) | |
tree | 985d23cf65e67074b45ca6f7dd01947fa7d554ef /lib/VMCore/Module.cpp | |
parent | f1da1f5f97b3e0b79381eaf39e827dd723abfb65 (diff) |
Add getOrInsertNamedMetadata().
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@77646 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/VMCore/Module.cpp')
-rw-r--r-- | lib/VMCore/Module.cpp | 17 |
1 files changed, 14 insertions, 3 deletions
diff --git a/lib/VMCore/Module.cpp b/lib/VMCore/Module.cpp index 9e1622e93d..e06e79a026 100644 --- a/lib/VMCore/Module.cpp +++ b/lib/VMCore/Module.cpp @@ -289,13 +289,24 @@ GlobalAlias *Module::getNamedAlias(const StringRef &Name) const { return dyn_cast_or_null<GlobalAlias>(getNamedValue(Name)); } -/// getNamedMetadata - Return the first named MDNode in the module with the -/// specified name. This method returns null if a MDNode with the specified -/// name is not found. +/// getNamedMetadata - Return the first NamedMDNode in the module with the +/// specified name. This method returns null if a NamedMDNode with the +//// specified name is not found. NamedMDNode *Module::getNamedMetadata(const StringRef &Name) const { return dyn_cast_or_null<NamedMDNode>(getValueSymbolTable().lookup(Name)); } +/// getOrInsertNamedMetadata - Return the first named MDNode in the module +/// with the specified name. This method returns a new NamedMDNode if a +/// NamedMDNode with the specified name is not found. +NamedMDNode *Module::getOrInsertNamedMetadata(const StringRef &Name) { + NamedMDNode *NMD = + dyn_cast_or_null<NamedMDNode>(getValueSymbolTable().lookup(Name)); + if (!NMD) + NMD = NamedMDNode::Create(Name, NULL, 0, this); + return NMD; +} + //===----------------------------------------------------------------------===// // Methods for easy access to the types in the module. // |