Doxygen
Loading...
Searching...
No Matches
msc.cpp File Reference
#include "msc.h"
#include "portable.h"
#include "config.h"
#include "message.h"
#include "docparser.h"
#include "docnode.h"
#include "doxygen.h"
#include "indexlist.h"
#include "util.h"
#include "mscgen_api.h"
#include "dir.h"
#include "textstream.h"
#include "stringutil.h"
+ Include dependency graph for msc.cpp:

Go to the source code of this file.

Functions

static bool convertMapFile (TextStream &t, const QCString &mapName, const QCString &relPath, const QCString &context, const QCString &srcFile, int srcLine)
 
static bool do_mscgen_generate (const QCString &inFile, const QCString &outFile, mscgen_format_t msc_format, const QCString &srcFile, int srcLine)
 
void writeMscGraphFromFile (const QCString &inFile, const QCString &outDir, const QCString &outFile, MscOutputFormat format, const QCString &srcFile, int srcLine)
 
static QCString getMscImageMapFromFile (const QCString &inFile, const QCString &, const QCString &relPath, const QCString &context, bool writeSVGMap, const QCString &srcFile, int srcLine)
 
void writeMscImageMapFromFile (TextStream &t, const QCString &inFile, const QCString &outDir, const QCString &relPath, const QCString &baseName, const QCString &context, MscOutputFormat format, const QCString &srcFile, int srcLine)
 

Variables

static const int maxCmdLine = 40960
 

Function Documentation

◆ convertMapFile()

static bool convertMapFile ( TextStream & t,
const QCString & mapName,
const QCString & relPath,
const QCString & context,
const QCString & srcFile,
int srcLine )
static

Definition at line 32 of file msc.cpp.

34{
35 std::ifstream f = Portable::openInputStream(mapName);
36 if (!f.is_open())
37 {
38 err("failed to open map file {} for inclusion in the docs!\n"
39 "If you installed Graphviz/dot after a previous failing run, \n"
40 "try deleting the output directory and rerun doxygen.\n",mapName);
41 return false;
42 }
43 const int maxLineLen=1024;
44 char url[maxLineLen];
45 char ref[maxLineLen];
46 int x1=0, y1=0, x2=0, y2=0;
47 std::string line;
48 while (getline(f,line))
49 {
50 bool isRef = false;
51 //printf("ReadLine '%s'\n",line.c_str());
52 if (literal_at(line.c_str(),"rect"))
53 {
54 // obtain the url and the coordinates in the order used by graphviz-1.5
55 sscanf(line.c_str(),"rect %s %d,%d %d,%d",url,&x1,&y1,&x2,&y2);
56
57 if (qstrcmp(url,"\\ref")==0 || qstrcmp(url,"@ref")==0)
58 {
59 isRef = true;
60 sscanf(line.c_str(),"rect %s %s %d,%d %d,%d",ref,url,&x1,&y1,&x2,&y2);
61 }
62
63 // sanity checks
64 if (y2<y1) { int temp=y2; y2=y1; y1=temp; }
65 if (x2<x1) { int temp=x2; x2=x1; x1=temp; }
66
67
68 bool link = false;
69 if ( isRef )
70 {
71 // handle doxygen \ref tag URL reference
72
73 auto parser { createDocParser() };
74 auto dfAst { createRef( *parser.get(), url, context, srcFile, srcLine) };
75 auto dfAstImpl = dynamic_cast<const DocNodeAST*>(dfAst.get());
76 const DocRef *df = std::get_if<DocRef>(&dfAstImpl->root);
77 if (!df->file().isEmpty() || !df->anchor().isEmpty())
78 {
79 link = true;
80 t << "<area href=\"";
81 t << externalRef(relPath,df->ref(),TRUE);
82 }
83 if (!df->file().isEmpty())
84 {
85 QCString fn = df->file();
87 t << fn;
88 }
89 if (!df->anchor().isEmpty())
90 {
91 t << "#" << df->anchor();
92 }
93 }
94 else
95 {
96 link = true;
97 t << "<area href=\"";
98 t << url;
99 }
100 if (link)
101 {
102 t << "\" shape=\"rect\" coords=\""
103 << x1 << "," << y1 << "," << x2 << "," << y2 << "\""
104 << " alt=\"\"/>\n";
105 }
106 }
107 }
108
109 return true;
110}
Class representing the abstract syntax tree of a documentation block.
Definition docnode.h:1460
Node representing a reference to some item.
Definition docnode.h:772
QCString anchor() const
Definition docnode.h:779
QCString file() const
Definition docnode.h:776
QCString ref() const
Definition docnode.h:778
This is an alternative implementation of QCString.
Definition qcstring.h:101
bool isEmpty() const
Returns TRUE iff the string is empty.
Definition qcstring.h:150
IDocParserPtr createDocParser()
factory function to create a parser
Definition docparser.cpp:55
IDocNodeASTPtr createRef(IDocParser &parserIntf, const QCString &target, const QCString &context, const QCString &srcFile, int srcLine)
#define err(fmt,...)
Definition message.h:127
std::ifstream openInputStream(const QCString &name, bool binary=false, bool openAtEnd=false)
Definition portable.cpp:676
#define TRUE
Definition qcstring.h:37
int qstrcmp(const char *str1, const char *str2)
Definition qcstring.h:69
bool literal_at(const char *data, const char(&str)[N])
returns TRUE iff data points to a substring that matches string literal str
Definition stringutil.h:98
QCString externalRef(const QCString &relPath, const QCString &ref, bool href)
Definition util.cpp:6222
void addHtmlExtensionIfMissing(QCString &fName)
Definition util.cpp:5399

References addHtmlExtensionIfMissing(), DocRef::anchor(), createDocParser(), createRef(), err, externalRef(), DocRef::file(), QCString::isEmpty(), literal_at(), Portable::openInputStream(), qstrcmp(), DocRef::ref(), and TRUE.

Referenced by getMscImageMapFromFile().

◆ do_mscgen_generate()

static bool do_mscgen_generate ( const QCString & inFile,
const QCString & outFile,
mscgen_format_t msc_format,
const QCString & srcFile,
int srcLine )
static

Definition at line 112 of file msc.cpp.

114{
115 auto mscgen_tool = Config_getString(MSCGEN_TOOL).stripWhiteSpace();
116 if (!mscgen_tool.isEmpty()) // use external mscgen tool
117 {
118 QCString type;
119 switch (msc_format)
120 {
121 case mscgen_format_png:
122 type = "png";
123 break;
124 case mscgen_format_eps:
125 type = "eps";
126 break;
127 case mscgen_format_svg:
128 type = "svg";
129 break;
130 case mscgen_format_pngmap:
131 case mscgen_format_svgmap:
132 type = "ismap";
133 break;
134 }
135 int exitcode = Portable::system(mscgen_tool,"-T"+type+" -o "+outFile+" "+inFile);
136 if (exitcode!=0)
137 {
138 err_full(srcFile,srcLine,"Problems running external tool {} given via MSCGEN_TOOL (exit status: {})."
139 " Look for typos in your msc file and check error messages above.",
140 mscgen_tool,exitcode);
141 return false;
142 }
143 }
144 else // use built-in mscgen tool
145 {
146 int code = mscgen_generate(inFile.data(),outFile.data(),msc_format);
147 if (code!=0)
148 {
149 err_full(srcFile,srcLine,"Problems generating msc output (error={}). Look for typos in you msc file '{}'",
150 mscgen_error2str(code),inFile);
151 return false;
152 }
153 }
154 return true;
155}
const char * data() const
Returns a pointer to the contents of the string in the form of a 0-terminated C string.
Definition qcstring.h:159
#define Config_getString(name)
Definition config.h:32
#define err_full(file, line, fmt,...)
Definition message.h:132
int system(const QCString &command, const QCString &args, bool commandHasConsole=true)
Definition portable.cpp:106

References Config_getString, QCString::data(), err_full, and Portable::system().

Referenced by getMscImageMapFromFile(), and writeMscGraphFromFile().

◆ getMscImageMapFromFile()

static QCString getMscImageMapFromFile ( const QCString & inFile,
const QCString & ,
const QCString & relPath,
const QCString & context,
bool writeSVGMap,
const QCString & srcFile,
int srcLine )
static

Definition at line 214 of file msc.cpp.

217{
218 QCString outFile = inFile + ".map";
219
220 if (!do_mscgen_generate(inFile,outFile,
221 writeSVGMap ? mscgen_format_svgmap : mscgen_format_pngmap,
222 srcFile,srcLine))
223 return "";
224
225 TextStream t;
226 convertMapFile(t, outFile, relPath, context, srcFile, srcLine);
227
228 Dir().remove(outFile.str());
229
230 return t.str();
231}
Class representing a directory in the file system.
Definition dir.h:75
bool remove(const std::string &path, bool acceptsAbsPath=true) const
Definition dir.cpp:314
const std::string & str() const
Definition qcstring.h:537
Text streaming class that buffers data.
Definition textstream.h:36
std::string str() const
Return the contents of the buffer as a std::string object.
Definition textstream.h:229
static bool convertMapFile(TextStream &t, const QCString &mapName, const QCString &relPath, const QCString &context, const QCString &srcFile, int srcLine)
Definition msc.cpp:32
static bool do_mscgen_generate(const QCString &inFile, const QCString &outFile, mscgen_format_t msc_format, const QCString &srcFile, int srcLine)
Definition msc.cpp:112

References convertMapFile(), do_mscgen_generate(), Dir::remove(), QCString::str(), and TextStream::str().

Referenced by writeMscImageMapFromFile().

◆ writeMscGraphFromFile()

void writeMscGraphFromFile ( const QCString & inFile,
const QCString & outDir,
const QCString & outFile,
MscOutputFormat format,
const QCString & srcFile,
int srcLine )

Definition at line 157 of file msc.cpp.

161{
162 QCString absOutFile = outDir;
163 absOutFile+=Portable::pathSeparator();
164 absOutFile+=outFile;
165
166 mscgen_format_t msc_format = mscgen_format_png;
167 QCString imgName = absOutFile;
168 switch (format)
169 {
171 msc_format = mscgen_format_png;
172 imgName+=".png";
173 break;
175 msc_format = mscgen_format_eps;
176 imgName+=".eps";
177 break;
179 msc_format = mscgen_format_svg;
180 imgName+=".svg";
181 break;
182 default:
183 return;
184 }
185 if (!do_mscgen_generate(inFile,imgName,msc_format,srcFile,srcLine))
186 {
187 return;
188 }
189
190 if ( (format==MscOutputFormat::EPS) && (Config_getBool(USE_PDFLATEX)) )
191 {
193 epstopdfArgs.sprintf("\"%s.eps\" --outfile=\"%s.pdf\"",
194 qPrint(absOutFile),qPrint(absOutFile));
195 if (Portable::system("epstopdf",epstopdfArgs)!=0)
196 {
197 err_full(srcFile,srcLine,"Problems running epstopdf when processing '{}.eps'. Check your TeX installation!", absOutFile);
198 }
199 else
200 {
201 Dir().remove((absOutFile + ".eps").data());
202 }
203 }
204
205 int i=std::max(imgName.findRev('/'),imgName.findRev('\\'));
206 if (i!=-1) // strip path
207 {
208 imgName=imgName.right(imgName.length()-i-1);
209 }
210 Doxygen::indexList->addImageFile(imgName);
211
212}
static IndexList * indexList
Definition doxygen.h:134
size_t length() const
Returns the length of the string, not counting the 0-terminator.
Definition qcstring.h:153
QCString right(size_t len) const
Definition qcstring.h:219
@ ExplicitSize
Definition qcstring.h:133
int findRev(char c, int index=-1, bool cs=TRUE) const
Definition qcstring.cpp:91
#define Config_getBool(name)
Definition config.h:33
static const int maxCmdLine
Definition dia.cpp:24
QCString pathSeparator()
Definition portable.cpp:391
const char * qPrint(const char *s)
Definition qcstring.h:672

References BITMAP, Config_getBool, do_mscgen_generate(), EPS, err_full, QCString::ExplicitSize, QCString::findRev(), Doxygen::indexList, QCString::length(), maxCmdLine, Portable::pathSeparator(), qPrint(), Dir::remove(), QCString::right(), QCString::sprintf(), SVG, and Portable::system().

Referenced by DocbookDocVisitor::startMscFile(), LatexDocVisitor::startMscFile(), DocbookDocVisitor::writeMscFile(), HtmlDocVisitor::writeMscFile(), LatexDocVisitor::writeMscFile(), and RTFDocVisitor::writeMscFile().

◆ writeMscImageMapFromFile()

void writeMscImageMapFromFile ( TextStream & t,
const QCString & inFile,
const QCString & outDir,
const QCString & relPath,
const QCString & baseName,
const QCString & context,
MscOutputFormat format,
const QCString & srcFile,
int srcLine )

Definition at line 233 of file msc.cpp.

242{
243 QCString mapName = baseName+".map";
244 t << "<img src=\"" << relPath << baseName << ".";
245 switch (format)
246 {
248 t << "png";
249 break;
251 t << "eps";
252 break;
254 t << "svg";
255 break;
256 default:
257 t << "unknown";
258 }
259 QCString imap = getMscImageMapFromFile(inFile,outDir,relPath,context,format==MscOutputFormat::SVG,srcFile,srcLine);
260 if (!imap.isEmpty())
261 {
262 t << "\" alt=\""
263 << baseName << "\" border=\"0\" usemap=\"#" << mapName << "\"/>\n";
264 t << "<map name=\"" << mapName << "\" id=\"" << mapName << "\">" << imap << "</map>\n";
265 }
266 else
267 {
268 t << "\" alt=\"" << baseName << "\" border=\"0\"/>\n";
269 }
270}
static QCString getMscImageMapFromFile(const QCString &inFile, const QCString &, const QCString &relPath, const QCString &context, bool writeSVGMap, const QCString &srcFile, int srcLine)
Definition msc.cpp:214

References BITMAP, EPS, getMscImageMapFromFile(), QCString::isEmpty(), and SVG.

Referenced by HtmlDocVisitor::writeMscFile().

Variable Documentation

◆ maxCmdLine

const int maxCmdLine = 40960
static

Definition at line 30 of file msc.cpp.