Added -view-background to avoid waiting for each GraphViz invocation.

GV and XDOT paths are untested but should work the same.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@152179 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Andrew Trick 2012-03-07 00:18:27 +00:00
parent 0df7f8821c
commit 255cd51fbd

View File

@ -11,12 +11,16 @@
// //
//===----------------------------------------------------------------------===// //===----------------------------------------------------------------------===//
#include "llvm/Support/CommandLine.h"
#include "llvm/Support/GraphWriter.h" #include "llvm/Support/GraphWriter.h"
#include "llvm/Support/Path.h" #include "llvm/Support/Path.h"
#include "llvm/Support/Program.h" #include "llvm/Support/Program.h"
#include "llvm/Config/config.h" #include "llvm/Config/config.h"
using namespace llvm; using namespace llvm;
static cl::opt<bool> ViewBackground("view-background", cl::Hidden,
cl::desc("Execute graph viewer in the background. Creates tmp file litter."));
std::string llvm::DOT::EscapeString(const std::string &Label) { std::string llvm::DOT::EscapeString(const std::string &Label) {
std::string Str(Label); std::string Str(Label);
for (unsigned i = 0; i != Str.length(); ++i) for (unsigned i = 0; i != Str.length(); ++i)
@ -49,10 +53,30 @@ std::string llvm::DOT::EscapeString(const std::string &Label) {
return Str; return Str;
} }
// Execute the graph viewer. Return true if successful.
static bool ExecGraphViewer(const sys::Path &ExecPath,
std::vector<const char*> &args,
const sys::Path &Filename,
bool wait,
std::string &ErrMsg) {
if (wait) {
if (sys::Program::ExecuteAndWait(ExecPath, &args[0],0,0,0,0,&ErrMsg)) {
errs() << "Error: " << ErrMsg << "\n";
return false;
}
Filename.eraseFromDisk();
errs() << " done. \n";
}
else {
sys::Program::ExecuteNoWait(ExecPath, &args[0],0,0,0,&ErrMsg);
errs() << "Remember to erase graph file: " << Filename.str() << "\n";
}
return true;
}
void llvm::DisplayGraph(const sys::Path &Filename, bool wait, void llvm::DisplayGraph(const sys::Path &Filename, bool wait,
GraphProgram::Name program) { GraphProgram::Name program) {
wait &= !ViewBackground;
std::string ErrMsg; std::string ErrMsg;
#if HAVE_GRAPHVIZ #if HAVE_GRAPHVIZ
sys::Path Graphviz(LLVM_PATH_GRAPHVIZ); sys::Path Graphviz(LLVM_PATH_GRAPHVIZ);
@ -63,12 +87,8 @@ void llvm::DisplayGraph(const sys::Path &Filename, bool wait,
args.push_back(0); args.push_back(0);
errs() << "Running 'Graphviz' program... "; errs() << "Running 'Graphviz' program... ";
if (sys::Program::ExecuteAndWait(Graphviz, &args[0],0,0,0,0,&ErrMsg)) { if (!ExecGraphViewer(Graphviz, args, Filename, wait, ErrMsg))
errs() << "Error: " << ErrMsg << "\n";
return; return;
}
Filename.eraseFromDisk();
errs() << " done. \n";
#elif HAVE_XDOT_PY #elif HAVE_XDOT_PY
std::vector<const char*> args; std::vector<const char*> args;
@ -87,13 +107,8 @@ void llvm::DisplayGraph(const sys::Path &Filename, bool wait,
args.push_back(0); args.push_back(0);
errs() << "Running 'xdot.py' program... "; errs() << "Running 'xdot.py' program... ";
if (sys::Program::ExecuteAndWait(sys::Path(LLVM_PATH_XDOT_PY), if (!ExecGraphViewer(sys::Path(LLVM_PATH_XDOT_PY), args, Filename, wait, ErrMsg))
&args[0],0,0,0,0,&ErrMsg)) {
errs() << "Error: " << ErrMsg << "\n";
return; return;
}
Filename.eraseFromDisk();
errs() << " done. \n";
#elif (HAVE_GV && (HAVE_DOT || HAVE_FDP || HAVE_NEATO || \ #elif (HAVE_GV && (HAVE_DOT || HAVE_FDP || HAVE_NEATO || \
HAVE_TWOPI || HAVE_CIRCO)) HAVE_TWOPI || HAVE_CIRCO))
@ -153,11 +168,8 @@ void llvm::DisplayGraph(const sys::Path &Filename, bool wait,
errs() << "Running '" << prog.str() << "' program... "; errs() << "Running '" << prog.str() << "' program... ";
if (sys::Program::ExecuteAndWait(prog, &args[0], 0, 0, 0, 0, &ErrMsg)) { if (!ExecGraphViewer(prog, args, Filename, wait, ErrMsg))
errs() << "Error: " << ErrMsg << "\n";
return; return;
}
errs() << " done. \n";
sys::Path gv(LLVM_PATH_GV); sys::Path gv(LLVM_PATH_GV);
args.clear(); args.clear();
@ -167,17 +179,9 @@ void llvm::DisplayGraph(const sys::Path &Filename, bool wait,
args.push_back(0); args.push_back(0);
ErrMsg.clear(); ErrMsg.clear();
if (wait) { if (!ExecGraphViewer(gv, args, PSFilename, wait, ErrMsg))
if (sys::Program::ExecuteAndWait(gv, &args[0],0,0,0,0,&ErrMsg)) return;
errs() << "Error: " << ErrMsg << "\n";
Filename.eraseFromDisk();
PSFilename.eraseFromDisk();
}
else {
sys::Program::ExecuteNoWait(gv, &args[0],0,0,0,&ErrMsg);
errs() << "Remember to erase graph files: " << Filename.str() << " "
<< PSFilename.str() << "\n";
}
#elif HAVE_DOTTY #elif HAVE_DOTTY
sys::Path dotty(LLVM_PATH_DOTTY); sys::Path dotty(LLVM_PATH_DOTTY);
@ -186,15 +190,12 @@ void llvm::DisplayGraph(const sys::Path &Filename, bool wait,
args.push_back(Filename.c_str()); args.push_back(Filename.c_str());
args.push_back(0); args.push_back(0);
errs() << "Running 'dotty' program... ";
if (sys::Program::ExecuteAndWait(dotty, &args[0],0,0,0,0,&ErrMsg)) {
errs() << "Error: " << ErrMsg << "\n";
} else {
// Dotty spawns another app and doesn't wait until it returns // Dotty spawns another app and doesn't wait until it returns
#if defined (__MINGW32__) || defined (_WINDOWS) #if defined (__MINGW32__) || defined (_WINDOWS)
wait = false;
#endif
errs() << "Running 'dotty' program... ";
if (!ExecGraphViewer(dotty, args, Filename, wait, ErrMsg))
return; return;
#endif
Filename.eraseFromDisk();
}
#endif #endif
} }