summaryrefslogtreecommitdiffstats
path: root/src/dot.cpp
diff options
context:
space:
mode:
authorDimitri van Heesch <dimitri@stack.nl>2004-12-28 15:52:58 (GMT)
committerDimitri van Heesch <dimitri@stack.nl>2004-12-28 15:52:58 (GMT)
commit1c51f44b5f0b3510618a283d522aab0741ddb3a1 (patch)
tree659ad23b069fb18276bbc9610ed0f2c48169722b /src/dot.cpp
parent939d1c84acd07060ee2b4bcbdc7dbccb80952385 (diff)
downloadDoxygen-1c51f44b5f0b3510618a283d522aab0741ddb3a1.zip
Doxygen-1c51f44b5f0b3510618a283d522aab0741ddb3a1.tar.gz
Doxygen-1c51f44b5f0b3510618a283d522aab0741ddb3a1.tar.bz2
Release-1.3.9.1-20041228
Diffstat (limited to 'src/dot.cpp')
-rw-r--r--src/dot.cpp420
1 files changed, 294 insertions, 126 deletions
diff --git a/src/dot.cpp b/src/dot.cpp
index ae34fb1..3ae2c58 100644
--- a/src/dot.cpp
+++ b/src/dot.cpp
@@ -35,9 +35,6 @@
#include <qtextstream.h>
#include <md5.h>
-// Enable this for transparent images
-// It doesn't seems to work very well with edge labels so I disabled it.
-//#define DOT_TRANSPARENT
//--------------------------------------------------------------------
@@ -74,9 +71,10 @@ static void writeGraphHeader(QTextStream &t)
{
t << "digraph G" << endl;
t << "{" << endl;
-#if defined(DOT_TRANSPARENT)
- t << " bgcolor=\"transparent\"" << endl;
-#endif
+ if (Config_getBool("DOT_TRANSPARENT"))
+ {
+ t << " bgcolor=\"transparent\";" << endl;
+ }
t << " edge [fontname=\"Helvetica\",fontsize=10,"
"labelfontname=\"Helvetica\",labelfontsize=10];\n";
t << " node [fontname=\"Helvetica\",fontsize=10,shape=record];\n";
@@ -393,6 +391,53 @@ class DotNodeList : public QList<DotNode>
//--------------------------------------------------------------------
+DotRunner::DotRunner(const char *file) : m_file(file)
+{
+ m_jobs.setAutoDelete(TRUE);
+}
+
+void DotRunner::addJob(const char *format,const char *output)
+{
+ QCString args = QCString("-T")+format+" -o \""+output+"\"";
+ m_jobs.append(new QCString(args));
+}
+
+bool DotRunner::run()
+{
+ QListIterator<QCString> li(m_jobs);
+ QCString *s;
+ if (Config_getBool("DOT_MULTI_TARGETS"))
+ {
+ QCString dotArgs="\""+m_file+"\"";
+ for (li.toFirst();(s=li.current());++li)
+ {
+ dotArgs+=' ';
+ dotArgs+=*s;
+ }
+ if (iSystem(Config_getString("DOT_PATH")+"dot",dotArgs)!=0)
+ {
+ goto error;
+ }
+ }
+ else
+ {
+ for (li.toFirst();(s=li.current());++li)
+ {
+ QCString dotArgs="\""+m_file+"\" "+*s;
+ if (iSystem(Config_getString("DOT_PATH")+"dot",dotArgs)!=0)
+ {
+ goto error;
+ }
+ }
+ }
+ return TRUE;
+error:
+ err("Problems running dot. Check your installation!\n");
+ return FALSE;
+}
+
+//--------------------------------------------------------------------
+
/*! helper function that deletes all nodes in a connected graph, given
* one of the graph's nodes
@@ -621,11 +666,14 @@ void DotNode::writeBox(QTextStream &t,
}
else
{
-#if defined(DOT_TRANSPARENT)
- t << ",color=\"" << labCol << "\", fillcolor=\"white\", style=\"filled\"";
-#else
- t << ",color=\"" << labCol << "\"";
-#endif
+ if (!Config_getBool("DOT_TRANSPARENT"))
+ {
+ t << ",color=\"" << labCol << "\", fillcolor=\"white\", style=\"filled\"";
+ }
+ else
+ {
+ t << ",color=\"" << labCol << "\"";
+ }
if (!m_url.isEmpty())
{
int anchorPos = m_url.findRev('#');
@@ -1067,17 +1115,23 @@ void DotGfxHierarchyTable::writeGraph(QTextStream &out,const char *path)
f.close();
resetReNumbering();
- QCString dotArgs(maxCmdLine);
- dotArgs.sprintf("\"%s\" -T%s -o \"%s\" -Timap -o \"%s\"",
- dotName.data(), imgExt.data(), imgName.data(), mapName.data());
- //printf("Running: dot %s -T%s -o %s -Timap -o %s\n",
- // dotName.data(),imgExt.data(),imgName.data(),mapName.data());
- if (iSystem(Config_getString("DOT_PATH")+"dot",dotArgs)!=0)
+ DotRunner dotRun(dotName);
+ dotRun.addJob(imgExt,imgName);
+ dotRun.addJob("imap",mapName);
+ if (!dotRun.run())
{
- err("Problems running dot. Check your installation!\n");
out << "</table>" << endl;
return;
}
+
+ //QCString dotArgs(maxCmdLine);
+ //dotArgs.sprintf("\"%s\" -T%s -o \"%s\" -Timap -o \"%s\"",
+ // dotName.data(), imgExt.data(), imgName.data(), mapName.data());
+ //if (iSystem(Config_getString("DOT_PATH")+"dot",dotArgs)!=0)
+ //{
+ // err("Problems running dot. Check your installation!\n");
+ // return;
+ //}
checkDotResult(imgName);
if (Config_getBool("DOT_CLEANUP")) thisDir.remove(dotName);
}
@@ -1625,14 +1679,22 @@ static bool findMaximalDotGraph(DotNode *root,
writeDotGraph(root,gt,format,baseName,lrRank,renderParents,
curDistance,backArrows,reNumber);
- QCString dotArgs(maxCmdLine);
// create annotated dot file
- dotArgs.sprintf("-Tdot \"%s.dot\" -o \"%s_tmp.dot\"",baseName.data(),baseName.data());
- if (iSystem(Config_getString("DOT_PATH")+"dot",dotArgs)!=0)
+ DotRunner dotRun(baseName+".dot");
+ dotRun.addJob("dot",baseName+"_tmp.dot");
+ if (!dotRun.run())
{
- err("Problems running dot. Check your installation!\n");
return FALSE;
}
+
+ //QCString dotArgs(maxCmdLine);
+ //// create annotated dot file
+ //dotArgs.sprintf("-Tdot \"%s.dot\" -o \"%s_tmp.dot\"",baseName.data(),baseName.data());
+ //if (iSystem(Config_getString("DOT_PATH")+"dot",dotArgs)!=0)
+ // {
+ // err("Problems running dot. Check your installation!\n");
+ // return FALSE;
+ //}
// extract bounding box from the result
readBoundingBoxDot(baseName+"_tmp.dot",&width,&height);
@@ -1768,32 +1830,50 @@ QCString DotClassGraph::writeGraph(QTextStream &out,
{
QCString dotArgs(maxCmdLine);
QCString imgName = baseName+"."+imgExt;
- dotArgs.sprintf("\"%s.dot\" -T%s -o \"%s\"",
- baseName.data(),imgExt.data(),imgName.data());
- if (generateImageMap)
- {
- // run dot also to create an image map
- dotArgs+=QCString(maxCmdLine).sprintf(" -Timap -o \"%s.map\"",
- baseName.data());
- }
- if (iSystem(Config_getString("DOT_PATH")+"dot",dotArgs)!=0)
+
+ DotRunner dotRun(baseName+".dot");
+ dotRun.addJob(imgExt,imgName);
+ if (generateImageMap) dotRun.addJob("imap",baseName+".map");
+ if (!dotRun.run())
{
- err("Error: Problems running dot. Check your installation!\n");
QDir::setCurrent(oldDir);
return baseName;
}
+
+ //dotArgs.sprintf("\"%s.dot\" -T%s -o \"%s\"",
+ // baseName.data(),imgExt.data(),imgName.data());
+ //if (generateImageMap)
+ //{
+ // // run dot also to create an image map
+ // dotArgs+=QCString(maxCmdLine).sprintf(" -Timap -o \"%s.map\"",
+ // baseName.data());
+ //}
+ //if (iSystem(Config_getString("DOT_PATH")+"dot",dotArgs)!=0)
+ //{
+ // err("Error: Problems running dot. Check your installation!\n");
+ // QDir::setCurrent(oldDir);
+ // return baseName;
+ //}
checkDotResult(imgName);
}
else if (format==EPS) // run dot to create a .eps image
{
- QCString dotArgs(maxCmdLine);
- dotArgs.sprintf("-Tps \"%s.dot\" -o \"%s.eps\"",baseName.data(),baseName.data());
- if (iSystem(Config_getString("DOT_PATH")+"dot",dotArgs)!=0)
+ DotRunner dotRun(baseName+".dot");
+ dotRun.addJob("ps",baseName+".eps");
+ if (!dotRun.run())
{
- err("Error: Problems running dot. Check your installation!\n");
QDir::setCurrent(oldDir);
return baseName;
}
+
+ //QCString dotArgs(maxCmdLine);
+ //dotArgs.sprintf("-Tps \"%s.dot\" -o \"%s.eps\"",baseName.data(),baseName.data());
+ //if (iSystem(Config_getString("DOT_PATH")+"dot",dotArgs)!=0)
+ //{
+ // err("Error: Problems running dot. Check your installation!\n");
+ // QDir::setCurrent(oldDir);
+ // return baseName;
+ //}
if (Config_getBool("USE_PDFLATEX"))
{
QCString epstopdfArgs(maxCmdLine);
@@ -2025,41 +2105,56 @@ QCString DotInclDepGraph::writeGraph(QTextStream &out,
format, // format
TRUE, // lrRank
FALSE, // renderParents
- FALSE // backArrows
+ m_inverse // backArrows
);
if (format==BITMAP)
{
// run dot to create a bitmap image
QCString dotArgs(maxCmdLine);
QCString imgName=baseName+"."+imgExt;
- dotArgs.sprintf("\"%s.dot\" -T%s -o \"%s\"",
- baseName.data(),imgExt.data(),imgName.data());
- if (generateImageMap)
+ DotRunner dotRun(baseName+".dot");
+ dotRun.addJob(imgExt,imgName);
+ if (generateImageMap) dotRun.addJob("imap",baseName+".map");
+ if (!dotRun.run())
{
- // run dot also to create an image map
- dotArgs+=QCString(maxCmdLine).sprintf(" -Timap -o \"%s.map\"",
- baseName.data());
- }
- if (iSystem(Config_getString("DOT_PATH")+"dot",dotArgs)!=0)
- {
- err("Problems running dot. Check your installation!\n");
QDir::setCurrent(oldDir);
return baseName;
}
+ //dotArgs.sprintf("\"%s.dot\" -T%s -o \"%s\"",
+ // baseName.data(),imgExt.data(),imgName.data());
+ //if (generateImageMap)
+ //{
+ // // run dot also to create an image map
+ // dotArgs+=QCString(maxCmdLine).sprintf(" -Timap -o \"%s.map\"",
+ // baseName.data());
+ //}
+ //if (iSystem(Config_getString("DOT_PATH")+"dot",dotArgs)!=0)
+ //{
+ // err("Problems running dot. Check your installation!\n");
+ // QDir::setCurrent(oldDir);
+ // return baseName;
+ //}
checkDotResult(imgName);
}
else if (format==EPS)
{
// run dot to create a .eps image
- QCString dotArgs(maxCmdLine);
- dotArgs.sprintf("-Tps \"%s.dot\" -o \"%s.eps\"",
- baseName.data(),baseName.data());
- if (iSystem(Config_getString("DOT_PATH")+"dot",dotArgs)!=0)
+ DotRunner dotRun(baseName+".dot");
+ dotRun.addJob("ps",baseName+".eps");
+ if (!dotRun.run())
{
- err("Problems running dot. Check your installation!\n");
QDir::setCurrent(oldDir);
return baseName;
}
+ //QCString dotArgs(maxCmdLine);
+ //dotArgs.sprintf("-Tps \"%s.dot\" -o \"%s.eps\"",
+ // baseName.data(),baseName.data());
+ //if (iSystem(Config_getString("DOT_PATH")+"dot",dotArgs)!=0)
+ //{
+ // err("Problems running dot. Check your installation!\n");
+ // QDir::setCurrent(oldDir);
+ // return baseName;
+ //}
if (Config_getBool("USE_PDFLATEX"))
{
QCString epstopdfArgs(maxCmdLine);
@@ -2218,34 +2313,49 @@ QCString DotCallGraph::writeGraph(QTextStream &out, GraphOutputFormat format,
// run dot to create a bitmap image
QCString dotArgs(maxCmdLine);
QCString imgName=baseName+"."+imgExt;
- dotArgs.sprintf("\"%s.dot\" -T%s -o \"%s\"",
- baseName.data(),imgExt.data(),imgName.data());
- if (generateImageMap)
- {
- // run dot also to create an image map
- dotArgs+=QCString(maxCmdLine).sprintf(" -Timap -o \"%s.map\"",
- baseName.data());
- }
- if (iSystem(Config_getString("DOT_PATH")+"dot",dotArgs)!=0)
+ DotRunner dotRun(baseName+".dot");
+ dotRun.addJob(imgExt,imgName);
+ if (generateImageMap) dotRun.addJob("imap",baseName+".map");
+ if (!dotRun.run())
{
- err("Problems running dot. Check your installation!\n");
QDir::setCurrent(oldDir);
return baseName;
}
+ //dotArgs.sprintf("\"%s.dot\" -T%s -o \"%s\"",
+ // baseName.data(),imgExt.data(),imgName.data());
+ //if (generateImageMap)
+ //{
+ // // run dot also to create an image map
+ // dotArgs+=QCString(maxCmdLine).sprintf(" -Timap -o \"%s.map\"",
+ // baseName.data());
+ //}
+ //if (iSystem(Config_getString("DOT_PATH")+"dot",dotArgs)!=0)
+ //{
+ // err("Problems running dot. Check your installation!\n");
+ // QDir::setCurrent(oldDir);
+ // return baseName;
+ //}
checkDotResult(imgName);
}
else if (format==EPS)
{
// run dot to create a .eps image
- QCString dotArgs(maxCmdLine);
- dotArgs.sprintf("-Tps \"%s.dot\" -o \"%s.eps\"",
- baseName.data(),baseName.data());
- if (iSystem(Config_getString("DOT_PATH")+"dot",dotArgs)!=0)
+ DotRunner dotRun(baseName+".dot");
+ dotRun.addJob("ps",baseName+".eps");
+ if (!dotRun.run())
{
- err("Problems running dot. Check your installation!\n");
QDir::setCurrent(oldDir);
return baseName;
}
+ //QCString dotArgs(maxCmdLine);
+ //dotArgs.sprintf("-Tps \"%s.dot\" -o \"%s.eps\"",
+ // baseName.data(),baseName.data());
+ //if (iSystem(Config_getString("DOT_PATH")+"dot",dotArgs)!=0)
+ //{
+ // err("Problems running dot. Check your installation!\n");
+ // QDir::setCurrent(oldDir);
+ // return baseName;
+ //}
if (Config_getBool("USE_PDFLATEX"))
{
QCString epstopdfArgs(maxCmdLine);
@@ -2410,34 +2520,49 @@ QCString DotDirDeps::writeGraph(QTextStream &out,
// run dot to create a bitmap image
QCString dotArgs(maxCmdLine);
QCString imgName=baseName+"."+imgExt;
- dotArgs.sprintf("\"%s.dot\" -T%s -o \"%s\"",
- baseName.data(),imgExt.data(),imgName.data());
- if (generateImageMap)
- {
- // run dot also to create an image map
- dotArgs+=QCString(maxCmdLine).sprintf(" -Timap -o \"%s.map\"",
- baseName.data());
- }
- if (iSystem(Config_getString("DOT_PATH")+"dot",dotArgs)!=0)
+ DotRunner dotRun(baseName+".dot");
+ dotRun.addJob(imgExt,imgName);
+ if (generateImageMap) dotRun.addJob("imap",baseName+".map");
+ if (!dotRun.run())
{
- err("Problems running dot. Check your installation!\n");
QDir::setCurrent(oldDir);
return baseName;
}
+ //dotArgs.sprintf("\"%s.dot\" -T%s -o \"%s\"",
+ // baseName.data(),imgExt.data(),imgName.data());
+ //if (generateImageMap)
+ //{
+ // // run dot also to create an image map
+ // dotArgs+=QCString(maxCmdLine).sprintf(" -Timap -o \"%s.map\"",
+ // baseName.data());
+ //}
+ //if (iSystem(Config_getString("DOT_PATH")+"dot",dotArgs)!=0)
+ //{
+ // err("Problems running dot. Check your installation!\n");
+ // QDir::setCurrent(oldDir);
+ // return baseName;
+ //}
checkDotResult(imgName);
}
else if (format==EPS)
{
// run dot to create a .eps image
- QCString dotArgs(maxCmdLine);
- dotArgs.sprintf("-Tps \"%s.dot\" -o \"%s.eps\"",
- baseName.data(),baseName.data());
- if (iSystem(Config_getString("DOT_PATH")+"dot",dotArgs)!=0)
+ DotRunner dotRun(baseName+".dot");
+ dotRun.addJob("ps",baseName+".eps");
+ if (!dotRun.run())
{
- err("Problems running dot. Check your installation!\n");
QDir::setCurrent(oldDir);
return baseName;
}
+ //QCString dotArgs(maxCmdLine);
+ //dotArgs.sprintf("-Tps \"%s.dot\" -o \"%s.eps\"",
+ // baseName.data(),baseName.data());
+ //if (iSystem(Config_getString("DOT_PATH")+"dot",dotArgs)!=0)
+ //{
+ // err("Problems running dot. Check your installation!\n");
+ // QDir::setCurrent(oldDir);
+ // return baseName;
+ //}
if (Config_getBool("USE_PDFLATEX"))
{
QCString epstopdfArgs(maxCmdLine);
@@ -2553,16 +2678,24 @@ void generateGraphLegend(const char *path)
QDir::setCurrent(d.absPath());
// run dot to generate the a bitmap image from the graph
- QCString dotArgs(maxCmdLine);
QCString imgExt = Config_getEnum("DOT_IMAGE_FORMAT");
QCString imgName = "graph_legend."+imgExt;
- dotArgs.sprintf("-T%s graph_legend.dot -o %s",imgExt.data(),imgName.data());
- if (iSystem(Config_getString("DOT_PATH")+"dot",dotArgs)!=0)
+
+ DotRunner dotRun("graph_legend.dot");
+ dotRun.addJob(imgExt,imgName);
+ if (!dotRun.run())
{
- err("Problems running dot. Check your installation!\n");
QDir::setCurrent(oldDir);
return;
}
+ //QCString dotArgs(maxCmdLine);
+ //dotArgs.sprintf("-T%s graph_legend.dot -o %s",imgExt.data(),imgName.data());
+ //if (iSystem(Config_getString("DOT_PATH")+"dot",dotArgs)!=0)
+ //{
+ // err("Problems running dot. Check your installation!\n");
+ // QDir::setCurrent(oldDir);
+ // return;
+ //}
checkDotResult(imgName);
QDir::setCurrent(oldDir);
}
@@ -2595,26 +2728,37 @@ void writeDotGraphFromFile(const char *inFile,const char *outDir,
// outf.writeBlock(a.data(),s);
//}
- QCString dotArgs(maxCmdLine);
QCString imgExt = Config_getEnum("DOT_IMAGE_FORMAT");
QCString imgName = (QCString)outFile+"."+imgExt;
- if (format==BITMAP)
- {
- dotArgs.sprintf("-T%s \"%s\" -o \"%s\"",
- imgExt.data(),
- inFile,
- imgName.data());
- }
+
+ DotRunner dotRun(inFile);
+ if (format==BITMAP)
+ dotRun.addJob(imgExt,imgName);
else // format==EPS
+ dotRun.addJob("ps",QCString(outFile)+".eps");
+ if (!dotRun.run())
{
- dotArgs.sprintf("-Tps \"%s\" -o \"%s.eps\"",inFile,outFile);
- }
- QCString dotExe = Config_getString("DOT_PATH")+"dot";
- //printf("Running: %s %s\n",dotExe.data(),dotArgs.data());
- if (iSystem(dotExe,dotArgs)!=0)
- {
- err("Problems running dot. Check your installation!\n");
+ QDir::setCurrent(oldDir);
+ return;
}
+ //QCString dotArgs(maxCmdLine);
+ //if (format==BITMAP)
+ //{
+ // dotArgs.sprintf("-T%s \"%s\" -o \"%s\"",
+ // imgExt.data(),
+ // inFile,
+ // imgName.data());
+ //}
+ //else // format==EPS
+ //{
+ // dotArgs.sprintf("-Tps \"%s\" -o \"%s.eps\"",inFile,outFile);
+ //}
+ //QCString dotExe = Config_getString("DOT_PATH")+"dot";
+ ////printf("Running: %s %s\n",dotExe.data(),dotArgs.data());
+ //if (iSystem(dotExe,dotArgs)!=0)
+ //{
+ // err("Problems running dot. Check your installation!\n");
+ //}
// Added by Nils Strom
if ( (format==EPS) && (Config_getBool("USE_PDFLATEX")) )
{
@@ -2651,17 +2795,24 @@ QString getDotImageMapFromFile(const QString& inFile, const QString& outDir,
QDir::setCurrent(outDir);
//printf("Going to dir %s\n",QDir::currentDirPath().data());
- QCString dotArgs(maxCmdLine);
- dotArgs.sprintf("-Timap \"%s\" -o \"%s\"", inFile.data(), outFile.data());
-
- QCString dotExe = Config_getString("DOT_PATH") + "dot";
- //printf("Running: %s %s\n",dotExe.data(),dotArgs.data());
- if (iSystem(dotExe,dotArgs)!=0)
+ DotRunner dotRun(inFile);
+ dotRun.addJob("imap",outFile);
+ if (!dotRun.run())
{
- err("Problems running dot. Check your installation!\n");
QDir::setCurrent(oldDir);
return "";
}
+
+ //QCString dotArgs(maxCmdLine);
+ //dotArgs.sprintf("-Timap \"%s\" -o \"%s\"", inFile.data(), outFile.data());
+ //QCString dotExe = Config_getString("DOT_PATH") + "dot";
+ ////printf("Running: %s %s\n",dotExe.data(),dotArgs.data());
+ //if (iSystem(dotExe,dotArgs)!=0)
+ //{
+ // err("Problems running dot. Check your installation!\n");
+ // QDir::setCurrent(oldDir);
+ // return "";
+ //}
QString result;
QTextOStream tmpout(&result);
convertMapFile(tmpout, outFile, relPath ,TRUE);
@@ -2928,22 +3079,31 @@ QCString DotGroupCollaboration::writeGraph( QTextStream &t, GraphOutputFormat fo
{
QCString dotArgs(maxCmdLine);
QCString imgName = baseName+"."+imgExt;
- dotArgs.sprintf("\"%s.dot\" -T%s -o \"%s\"",
- baseName.data(), imgExt.data(), imgName.data());
QCString mapName=baseName+".map";
- if (writeImageMap)
+ DotRunner dotRun(baseName);
+ dotRun.addJob(imgExt,imgName);
+ if (writeImageMap) dotRun.addJob("imap",mapName);
+ if (!dotRun.run())
{
- // run dot also to create an image map
- dotArgs+=" -Timap -o \""+mapName+"\"";
- }
-
- if (iSystem(Config_getString("DOT_PATH")+"dot",dotArgs)!=0)
- {
- err("Error: Problems running dot. Check your installation!\n");
QDir::setCurrent(oldDir);
return baseName;
}
+ //dotArgs.sprintf("\"%s.dot\" -T%s -o \"%s\"",
+ // baseName.data(), imgExt.data(), imgName.data());
+ //
+ //if (writeImageMap)
+ //{
+ // // run dot also to create an image map
+ // dotArgs+=" -Timap -o \""+mapName+"\"";
+ //}
+ //
+ //if (iSystem(Config_getString("DOT_PATH")+"dot",dotArgs)!=0)
+ //{
+ // err("Error: Problems running dot. Check your installation!\n");
+ // QDir::setCurrent(oldDir);
+ // return baseName;
+ //}
if (writeImageMap)
{
@@ -2959,15 +3119,22 @@ QCString DotGroupCollaboration::writeGraph( QTextStream &t, GraphOutputFormat fo
}
else if (format==EPS)
{
- QCString dotArgs(maxCmdLine);
- dotArgs.sprintf("-Tps \"%s.dot\" -o \"%s.eps\"",
- baseName.data(),baseName.data());
- if (iSystem(Config_getString("DOT_PATH")+"dot",dotArgs)!=0)
+ DotRunner dotRun(baseName+".dot");
+ dotRun.addJob("ps",baseName+".eps");
+ if (!dotRun.run())
{
- err("Error: Problems running dot. Check your installation!\n");
QDir::setCurrent(oldDir);
return baseName;
}
+ //QCString dotArgs(maxCmdLine);
+ //dotArgs.sprintf("-Tps \"%s.dot\" -o \"%s.eps\"",
+ // baseName.data(),baseName.data());
+ //if (iSystem(Config_getString("DOT_PATH")+"dot",dotArgs)!=0)
+ //{
+ // err("Error: Problems running dot. Check your installation!\n");
+ // QDir::setCurrent(oldDir);
+ // return baseName;
+ //}
if (Config_getBool("USE_PDFLATEX"))
{
QCString epstopdfArgs(maxCmdLine);
@@ -3074,9 +3241,10 @@ void DotGroupCollaboration::writeGraphHeader(QTextStream &t)
{
t << "digraph structs" << endl;
t << "{" << endl;
-#if defined(DOT_TRANSPARENT)
- t << " bgcolor=\"transparent\"" << endl;
-#endif
+ if (Config_getBool("DOT_TRANSPARENT"))
+ {
+ t << " bgcolor=\"transparent\";" << endl;
+ }
t << " edge [fontname=\"Helvetica\",fontsize=8,"
"labelfontname=\"Helvetica\",labelfontsize=8];\n";
t << " node [fontname=\"Helvetica\",fontsize=10,shape=record];\n";