Halfway conversion from custom printing to GraphWriter printing

llvm-svn: 4146
This commit is contained in:
Chris Lattner 2002-10-13 19:31:57 +00:00
parent 54905ed38c
commit ee64370eb5

View File

@ -6,9 +6,11 @@
#include "llvm/Analysis/DataStructure.h" #include "llvm/Analysis/DataStructure.h"
#include "llvm/Analysis/DSGraph.h" #include "llvm/Analysis/DSGraph.h"
#include "llvm/Analysis/DSGraphTraits.h"
#include "llvm/Module.h" #include "llvm/Module.h"
#include "llvm/Assembly/Writer.h" #include "llvm/Assembly/Writer.h"
#include "Support/CommandLine.h" #include "Support/CommandLine.h"
#include "Support/GraphWriter.h"
#include <fstream> #include <fstream>
#include <sstream> #include <sstream>
using std::string; using std::string;
@ -165,6 +167,36 @@ void DSGraph::print(std::ostream &O) const {
O << "}\n"; O << "}\n";
} }
template<>
struct DOTGraphTraits<DSGraph*> : public DefaultDOTGraphTraits {
static std::string getGraphName(DSGraph *G) {
if (G->hasFunction())
return "Function " + G->getFunction().getName();
else
return "Non-function graph";
}
static const char *getGraphProperties(DSGraph *G) {
return "\tnode [shape=Mrecord];\n"
"\tedge [arrowtail=\"dot\"];\n"
"\tsize=\"10,7.5\";\n"
"\trotate=\"90\";\n";
}
static std::string getNodeLabel(DSNode *Node, DSGraph *Graph) {
return getCaption(Node, Graph);
}
static std::string getNodeAttributes(DSNode *N) {
return "";//fontname=Courier";
}
//static int getEdgeSourceLabel(DSNode *Node, node_iterator I) {
// return MergeMap[i];
// }
};
void DSGraph::writeGraphToFile(std::ostream &O, const string &GraphName) { void DSGraph::writeGraphToFile(std::ostream &O, const string &GraphName) {
string Filename = GraphName + ".dot"; string Filename = GraphName + ".dot";
@ -172,6 +204,7 @@ void DSGraph::writeGraphToFile(std::ostream &O, const string &GraphName) {
std::ofstream F(Filename.c_str()); std::ofstream F(Filename.c_str());
if (F.good()) { if (F.good()) {
WriteGraph(F, this);
print(F); print(F);
O << " [" << getGraphSize() << "+" << getFunctionCalls().size() << "]\n"; O << " [" << getGraphSize() << "+" << getFunctionCalls().size() << "]\n";
} else { } else {