mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-10 13:51:37 +00:00
IR: Split out writeMDTuple(), NFC
Prepare for more subclasses of `UniquableMDNode` than `MDTuple`. llvm-svn: 225732
This commit is contained in:
parent
9b4c13fcea
commit
ae28e300da
@ -1249,12 +1249,9 @@ static void WriteConstantInternal(raw_ostream &Out, const Constant *CV,
|
||||
Out << "<placeholder or erroneous Constant>";
|
||||
}
|
||||
|
||||
static void WriteMDNodeBodyInternal(raw_ostream &Out, const MDNode *Node,
|
||||
TypePrinting *TypePrinter,
|
||||
SlotTracker *Machine,
|
||||
const Module *Context) {
|
||||
if (Node->isDistinct())
|
||||
Out << "distinct ";
|
||||
static void writeMDTuple(raw_ostream &Out, const MDTuple *Node,
|
||||
TypePrinting *TypePrinter, SlotTracker *Machine,
|
||||
const Module *Context) {
|
||||
Out << "!{";
|
||||
for (unsigned mi = 0, me = Node->getNumOperands(); mi != me; ++mi) {
|
||||
const Metadata *MD = Node->getOperand(mi);
|
||||
@ -1275,6 +1272,27 @@ static void WriteMDNodeBodyInternal(raw_ostream &Out, const MDNode *Node,
|
||||
Out << "}";
|
||||
}
|
||||
|
||||
static void WriteMDNodeBodyInternal(raw_ostream &Out, const MDNode *Node,
|
||||
TypePrinting *TypePrinter,
|
||||
SlotTracker *Machine,
|
||||
const Module *Context) {
|
||||
assert(isa<UniquableMDNode>(Node) && "Expected uniquable MDNode");
|
||||
|
||||
auto *Uniquable = cast<UniquableMDNode>(Node);
|
||||
if (Uniquable->isDistinct())
|
||||
Out << "distinct ";
|
||||
|
||||
switch (Uniquable->getMetadataID()) {
|
||||
default:
|
||||
llvm_unreachable("Expected uniquable MDNode");
|
||||
#define HANDLE_UNIQUABLE_LEAF(CLASS) \
|
||||
case Metadata::CLASS##Kind: \
|
||||
write##CLASS(Out, cast<CLASS>(Uniquable), TypePrinter, Machine, Context); \
|
||||
break;
|
||||
#include "llvm/IR/Metadata.def"
|
||||
}
|
||||
}
|
||||
|
||||
// Full implementation of printing a Value as an operand with support for
|
||||
// TypePrinting, etc.
|
||||
static void WriteAsOperandInternal(raw_ostream &Out, const Value *V,
|
||||
|
Loading…
Reference in New Issue
Block a user