aboutsummaryrefslogtreecommitdiffstats
path: root/lib/VMCore/AsmWriter.cpp
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2009-12-31 01:54:05 +0000
committerChris Lattner <sabre@nondot.org>2009-12-31 01:54:05 +0000
commit54cc2c6679420652da692ee3ea252c9e1834246f (patch)
treeccc3763d3b1fc0e97223974b99b383ff39657090 /lib/VMCore/AsmWriter.cpp
parent103ba9779c950c982364f9c110ceba2c49827e7f (diff)
downloadexternal_llvm-54cc2c6679420652da692ee3ea252c9e1834246f.zip
external_llvm-54cc2c6679420652da692ee3ea252c9e1834246f.tar.gz
external_llvm-54cc2c6679420652da692ee3ea252c9e1834246f.tar.bz2
unify two copies of the NamedMDNode printing code.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@92327 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/VMCore/AsmWriter.cpp')
-rw-r--r--lib/VMCore/AsmWriter.cpp47
1 files changed, 22 insertions, 25 deletions
diff --git a/lib/VMCore/AsmWriter.cpp b/lib/VMCore/AsmWriter.cpp
index d2693c8..c838c76 100644
--- a/lib/VMCore/AsmWriter.cpp
+++ b/lib/VMCore/AsmWriter.cpp
@@ -634,8 +634,8 @@ void SlotTracker::processModule() {
E = TheModule->named_metadata_end(); I != E; ++I) {
const NamedMDNode *NMD = I;
for (unsigned i = 0, e = NMD->getNumOperands(); i != e; ++i) {
- MDNode *MD = dyn_cast_or_null<MDNode>(NMD->getOperand(i));
- if (MD)
+ // FIXME: Change accessor to be type safe.
+ if (MDNode *MD = cast_or_null<MDNode>(NMD->getOperand(i)))
CreateMetadataSlot(MD);
}
}
@@ -1312,6 +1312,8 @@ public:
M->getMDKindNames(MDNames);
}
+ void printNamedMDNode(const NamedMDNode *NMD);
+
void write(const Module *M) { printModule(M); }
void write(const GlobalValue *G) {
@@ -1446,23 +1448,29 @@ void AssemblyWriter::printModule(const Module *M) {
// Output named metadata.
if (!M->named_metadata_empty()) Out << '\n';
+
for (Module::const_named_metadata_iterator I = M->named_metadata_begin(),
- E = M->named_metadata_end(); I != E; ++I) {
- const NamedMDNode *NMD = I;
- Out << "!" << NMD->getName() << " = !{";
- for (unsigned i = 0, e = NMD->getNumOperands(); i != e; ++i) {
- if (i) Out << ", ";
- MDNode *MD = dyn_cast_or_null<MDNode>(NMD->getOperand(i));
- Out << '!' << Machine.getMetadataSlot(MD);
- }
- Out << "}\n";
- }
+ E = M->named_metadata_end(); I != E; ++I)
+ printNamedMDNode(I);
// Output metadata.
if (!Machine.mdnEmpty()) Out << '\n';
WriteMDNodes(Out, TypePrinter, Machine);
}
+void AssemblyWriter::printNamedMDNode(const NamedMDNode *NMD) {
+ Out << "!" << NMD->getName() << " = !{";
+ for (unsigned i = 0, e = NMD->getNumOperands(); i != e; ++i) {
+ if (i) Out << ", ";
+ // FIXME: Change accessor to be typesafe.
+ // FIXME: This doesn't handle null??
+ MDNode *MD = cast_or_null<MDNode>(NMD->getOperand(i));
+ Out << '!' << Machine.getMetadataSlot(MD);
+ }
+ Out << "}\n";
+}
+
+
static void PrintLinkage(GlobalValue::LinkageTypes LT,
formatted_raw_ostream &Out) {
switch (LT) {
@@ -2100,19 +2108,8 @@ void Value::print(raw_ostream &ROS, AssemblyAnnotationWriter *AAW) const {
WriteMDNodes(OS, TypePrinter, SlotTable);
} else if (const NamedMDNode *N = dyn_cast<NamedMDNode>(this)) {
SlotTracker SlotTable(N->getParent());
- TypePrinting TypePrinter;
- SlotTable.initialize();
- OS << "!" << N->getName() << " = !{";
- for (unsigned i = 0, e = N->getNumOperands(); i != e; ++i) {
- if (i) OS << ", ";
- MDNode *MD = dyn_cast_or_null<MDNode>(N->getOperand(i));
- if (MD)
- OS << '!' << SlotTable.getMetadataSlot(MD);
- else
- OS << "null";
- }
- OS << "}\n";
- WriteMDNodes(OS, TypePrinter, SlotTable);
+ AssemblyWriter W(OS, SlotTable, N->getParent(), AAW);
+ W.printNamedMDNode(N);
} else if (const Constant *C = dyn_cast<Constant>(this)) {
TypePrinting TypePrinter;
TypePrinter.print(C->getType(), OS);