Commit 38e67b40 authored by Dimitri van Heesch's avatar Dimitri van Heesch

config.xml is now used to generate configoptions.cpp and config.doc

parent 10ab1d5d
...@@ -27,6 +27,11 @@ ...@@ -27,6 +27,11 @@
/addon/doxmlparser/src/Makefile /addon/doxmlparser/src/Makefile
/addon/doxyapp/Makefile /addon/doxyapp/Makefile
/addon/doxywizard/Makefile /addon/doxywizard/Makefile
/addon/doxywizard/Makefile.doxywizard
/addon/doxywizard/config_lex.cpp
/addon/doxywizard/moc
/addon/doxywizard/obj
/addon/doxywizard/rcc
/examples/Makefile /examples/Makefile
/Makefile /Makefile
......
This source diff could not be displayed because it is too large. You can view the blob instead.
#ifndef CONFIGDOC_H
#define CONFIGDOC_H
class DocIntf;
void addConfigDocs(DocIntf *doc);
#endif
#ifndef DOCINTF_H
#define DOCINTF_H
class DocIntf
{
public:
virtual ~DocIntf() {}
virtual void setHeader(const char *header) = 0;
virtual void add(const char *name,const char *docs) = 0;
};
#endif
...@@ -20,9 +20,15 @@ macx-g++ { ...@@ -20,9 +20,15 @@ macx-g++ {
# Input # Input
HEADERS += doxywizard.h version.h expert.h config.h helplabel.h \ HEADERS += doxywizard.h version.h expert.h config.h helplabel.h \
inputbool.h inputstring.h inputint.h inputstrlist.h wizard.h inputbool.h inputstring.h inputint.h inputstrlist.h wizard.h docintf.h
SOURCES += doxywizard.cpp ../../src/version.cpp expert.cpp wizard.cpp \ SOURCES += doxywizard.cpp ../../src/version.cpp expert.cpp wizard.cpp \
inputbool.cpp inputstring.cpp inputint.cpp inputstrlist.cpp inputbool.cpp inputstring.cpp inputint.cpp inputstrlist.cpp
LEXSOURCES += config.l LEXSOURCES += config.l
RESOURCES += doxywizard.qrc RESOURCES += doxywizard.qrc
win32:RC_FILE += doxywizard.rc win32:RC_FILE += doxywizard.rc
configdoc.target = configdoc.cpp
configdoc.commands = python ../../src/configgen.py -wiz ../../src/config.xml > configdoc.cpp
configdoc.depends = ../../src/config.xml ../../src/configgen.py
QMAKE_EXTRA_TARGETS += configdoc
GENERATED_SOURCES += $$configdoc.target
#include <QtGui>
#include <QtXml>
#include "expert.h" #include "expert.h"
#include "inputbool.h" #include "inputbool.h"
#include "inputstring.h" #include "inputstring.h"
#include "inputint.h" #include "inputint.h"
#include "inputstring.h" #include "inputstring.h"
#include "inputstrlist.h" #include "inputstrlist.h"
#include <QtGui>
#include <QtXml>
#include "config.h" #include "config.h"
#include "version.h" #include "version.h"
#include "configdoc.h"
#include "../../src/settings.h" #include "../../src/settings.h"
#undef SA
#define SA(x) QString::fromAscii(x) #define SA(x) QString::fromAscii(x)
static QString convertToComment(const QString &s) static QString convertToComment(const QString &s)
...@@ -27,6 +27,20 @@ static QString convertToComment(const QString &s) ...@@ -27,6 +27,20 @@ static QString convertToComment(const QString &s)
} }
} }
void Expert::setHeader(const char *header)
{
m_header = SA(header);
}
void Expert::add(const char *name,const char *docs)
{
Input *opt = m_options[SA(name)];
if (opt)
{
opt->setTemplateDocs(SA(docs));
}
}
//------------------------------------------------------------------------------------ //------------------------------------------------------------------------------------
Expert::Expert() Expert::Expert()
...@@ -53,8 +67,9 @@ Expert::Expert() ...@@ -53,8 +67,9 @@ Expert::Expert()
m_rootElement = configXml.documentElement(); m_rootElement = configXml.documentElement();
createTopics(m_rootElement); createTopics(m_rootElement);
m_helper = new QTextEdit; m_helper = new QTextBrowser;
m_helper->setReadOnly(true); m_helper->setReadOnly(true);
m_helper->setOpenExternalLinks(TRUE);
m_splitter = new QSplitter(Qt::Vertical); m_splitter = new QSplitter(Qt::Vertical);
m_splitter->addWidget(m_treeWidget); m_splitter->addWidget(m_treeWidget);
m_splitter->addWidget(m_helper); m_splitter->addWidget(m_helper);
...@@ -75,6 +90,8 @@ Expert::Expert() ...@@ -75,6 +90,8 @@ Expert::Expert()
connect(m_next,SIGNAL(clicked()),SLOT(nextTopic())); connect(m_next,SIGNAL(clicked()),SLOT(nextTopic()));
connect(m_prev,SIGNAL(clicked()),SLOT(prevTopic())); connect(m_prev,SIGNAL(clicked()),SLOT(prevTopic()));
addConfigDocs(this);
} }
Expert::~Expert() Expert::~Expert()
...@@ -111,6 +128,273 @@ void Expert::createTopics(const QDomElement &rootElem) ...@@ -111,6 +128,273 @@ void Expert::createTopics(const QDomElement &rootElem)
SLOT(activateTopic(QTreeWidgetItem *,QTreeWidgetItem *))); SLOT(activateTopic(QTreeWidgetItem *,QTreeWidgetItem *)));
} }
static QString getDocsForNode(const QDomElement &child)
{
QString type = child.attribute(SA("type"));
QString docs = SA("");
// read documentation text
QDomElement docsVal = child.firstChildElement();
while (!docsVal.isNull())
{
if (docsVal.tagName()==SA("docs") &&
docsVal.attribute(SA("doxywizard")) != SA("0"))
{
for (QDomNode n = docsVal.firstChild(); !n.isNull(); n = n.nextSibling())
{
QDomText t = n.toText();
if (!t.isNull()) docs+=t.data();
}
docs+=SA("<br/>");
}
docsVal = docsVal.nextSiblingElement();
}
// for an enum we list the values
if (type==SA("enum"))
{
docs += SA("Possible values are: ");
int numValues=0;
docsVal = child.firstChildElement();
while (!docsVal.isNull())
{
if (docsVal.tagName()==SA("value"))
{
numValues++;
}
docsVal = docsVal.nextSiblingElement();
}
int i=0;
docsVal = child.firstChildElement();
while (!docsVal.isNull())
{
if (docsVal.tagName()==SA("value"))
{
i++;
docs += SA("<code>") + docsVal.attribute(SA("name")) + SA("</code>");
QString desc = docsVal.attribute(SA("desc"));
if (!desc.isEmpty())
{
docs+= SA(" ")+desc;
}
if (i==numValues-1)
{
docs+=SA(" and ");
}
else if (i==numValues)
{
docs+=SA(".");
}
else
{
docs+=SA(", ");
}
}
docsVal = docsVal.nextSiblingElement();
}
docs+=SA("<br/>");
docs+=SA("The default value is: <code>")+
child.attribute(SA("defval"))+
SA("</code>.");
}
else if (type==SA("int"))
{
docs+=SA("Minimum value: ")+child.attribute(SA("minval"))+SA(", ");
docs+=SA("maximum value: ")+child.attribute(SA("maxval"))+SA(", ");
docs+=SA("default value: ")+child.attribute(SA("defval"))+SA(".");
}
else if (type==SA("bool"))
{
if (child.hasAttribute(SA("altdefval")))
{
docs+=SA("The default value is: system dependent.");
}
else
{
QString defval = child.attribute(SA("defval"));
docs+=SA("The default value is: <code>")+
(defval==SA("1")?SA("YES"):SA("NO"))+
SA("</code>.");
}
}
else if (type==SA("list"))
{
if (child.attribute(SA("format"))==SA("string"))
{
int numValues = 0;
docsVal = child.firstChildElement();
while (!docsVal.isNull())
{
if (docsVal.tagName()==SA("value"))
{
if (docsVal.attribute(SA("name"))!=SA("")) numValues++;
}
docsVal = docsVal.nextSiblingElement();
}
if (numValues>0)
{
int i = 0;
docsVal = child.firstChildElement();
while (!docsVal.isNull())
{
if (docsVal.tagName()==SA("value"))
{
i++;
docs += SA("<code>") + docsVal.attribute(SA("name")) + SA("</code>");
QString desc = docsVal.attribute(SA("desc"));
if (desc != SA(""))
{
docs += SA(" ") + desc;
}
if (i==numValues-1)
{
docs += SA(" and ");
}
else if (i==numValues)
{
docs += SA(".");
}
else
{
docs += SA(", ");
}
}
docsVal = docsVal.nextSiblingElement();
}
}
}
}
else if (type==SA("string"))
{
QString defval = child.attribute(SA("defval"));
if (child.attribute(SA("format")) == SA("dir"))
{
if (defval != SA(""))
{
docs += SA("The default directory is: <code>") + defval + SA("</code>.");
}
}
else if (child.attribute(SA("format")) == SA("file"))
{
QString abspath = child.attribute(SA("abspath"));
if (defval != SA(""))
{
if (abspath != SA("1"))
{
docs += SA("The default file is: <code>") + defval + SA("</code>.");
}
else
{
docs += SA("The default file (with absolute path) is: <code>") + defval + SA("</code>.");
}
}
else
{
if (abspath == SA("1"))
{
docs += SA("The file has to be specified with full path.");
}
}
}
else // if (child.attribute(SA("format")) == SA("string"))
{
if (defval != SA(""))
{
docs += SA("The default value is: <code>") + defval + SA("</code>.");
}
}
}
if (child.hasAttribute(SA("depends")))
{
QString dependsOn = child.attribute(SA("depends"));
docs += SA("<br/>");
docs+= SA("This tag requires that the tag \\ref cfg_");
docs+= dependsOn.toLower();
docs+= SA(" \"");
docs+= dependsOn.toUpper();
docs+= SA("\" is set to <code>YES</code>.");
}
// Remove / replace doxygen markup strings
// the regular expressions are hard to read so the intention will be given
QRegExp regexp;
// remove \n at end and replace by a space
regexp.setPattern(SA("\\n$"));
docs.replace(regexp,SA(" "));
// remove <br> at end
regexp.setPattern(SA("<br> *$"));
docs.replace(regexp,SA(" "));
// \c word -> <code>word</code>
regexp.setPattern(SA("\\\\c[ ]+([^ ]+) "));
docs.replace(regexp,SA("<code>\\1</code> "));
// `word` -> <code>word</code>
docs.replace(SA("``"),SA(""));
regexp.setPattern(SA("`([^`]+)`"));
docs.replace(regexp,SA("<code>\\1</code> "));
// \ref key "desc" -> <code>desc</code>
regexp.setPattern(SA("\\\\ref[ ]+[^ ]+[ ]+\"([^ ]+)\""));
docs.replace(regexp,SA("<code>\\1</code> "));
//\ref specials
// \ref <key> -> description
regexp.setPattern(SA("\\\\ref[ ]+doxygen_usage"));
docs.replace(regexp,SA("\"Doxygen usage\""));
regexp.setPattern(SA("\\\\ref[ ]+extsearch"));
docs.replace(regexp,SA("\"External Indexing and Searching\""));
regexp.setPattern(SA("\\\\ref[ ]+external"));
docs.replace(regexp,SA("\"Linking to external documentation\""));
// fallback for not handled
docs.replace(SA("\\\\ref"),SA(""));
// \b word -> <b>word<\b>
regexp.setPattern(SA("\\\\b[ ]+([^ ]+) "));
docs.replace(regexp,SA("<b>\\1</b> "));
// \e word -> <em>word<\em>
regexp.setPattern(SA("\\\\e[ ]+([^ ]+) "));
docs.replace(regexp,SA("<em>\\1</em> "));
// \note -> <br>Note:
// @note -> <br>Note:
docs.replace(SA("\\note"),SA("<br>Note:"));
docs.replace(SA("@note"),SA("<br>Note:"));
// \#include -> #include
// \#undef -> #undef
docs.replace(SA("\\#include"),SA("#include"));
docs.replace(SA("\\#undef"),SA("#undef"));
// -# -> <br>-
// " - " -> <br>-
docs.replace(SA("-#"),SA("<br>-"));
docs.replace(SA(" - "),SA("<br>-"));
// \verbatim -> <pre>
// \endverbatim -> </pre>
docs.replace(SA("\\verbatim"),SA("<pre>"));
docs.replace(SA("\\endverbatim"),SA("</pre>"));
// \sa -> <br>See also:
// \par -> <br>
docs.replace(SA("\\sa"),SA("<br>See also:"));
docs.replace(SA("\\par"),SA("<br>"));
// 2xbackslash -> backslash
// \@ -> @
docs.replace(SA("\\\\"),SA("\\"));
docs.replace(SA("\\@"),SA("@"));
// \& -> &
// \$ -> $
docs.replace(SA("\\&"),SA("&"));
docs.replace(SA("\\$"),SA("$"));
// \< -> &lt;
// \> -> &gt;
docs.replace(SA("\\<"),SA("&lt;"));
docs.replace(SA("\\>"),SA("&gt;"));
regexp.setPattern(SA(" (http:[^ \\)]*)([ \\)])"));
docs.replace(regexp,SA(" <a href=\"\\1\">\\1</a>\\2"));
// LaTeX name as formula -> LaTeX
regexp.setPattern(SA("\\\\f\\$\\\\mbox\\{\\\\LaTeX\\}\\\\f\\$"));
docs.replace(regexp,SA("LaTeX"));
// Other forula's (now just 2) so explicitely mentioned.
regexp.setPattern(SA("\\\\f\\$2\\^\\{\\(16\\+\\\\mbox\\{LOOKUP\\\\_CACHE\\\\_SIZE\\}\\)\\}\\\\f\\$"));
docs.replace(regexp,SA("2^(16+LOOKUP_CACHE_SIZE)"));
regexp.setPattern(SA("\\\\f\\$2\\^\\{16\\} = 65536\\\\f\\$"));
docs.replace(regexp,SA("2^16=65536"));
return docs.trimmed();
}
QWidget *Expert::createTopicWidget(QDomElement &elem) QWidget *Expert::createTopicWidget(QDomElement &elem)
{ {
...@@ -125,6 +409,7 @@ QWidget *Expert::createTopicWidget(QDomElement &elem) ...@@ -125,6 +409,7 @@ QWidget *Expert::createTopicWidget(QDomElement &elem)
if (setting.isEmpty() || IS_SUPPORTED(setting.toAscii())) if (setting.isEmpty() || IS_SUPPORTED(setting.toAscii()))
{ {
QString type = child.attribute(SA("type")); QString type = child.attribute(SA("type"));
QString docs = getDocsForNode(child);
if (type==SA("bool")) if (type==SA("bool"))
{ {
InputBool *boolOption = InputBool *boolOption =
...@@ -132,7 +417,7 @@ QWidget *Expert::createTopicWidget(QDomElement &elem) ...@@ -132,7 +417,7 @@ QWidget *Expert::createTopicWidget(QDomElement &elem)
layout,row, layout,row,
child.attribute(SA("id")), child.attribute(SA("id")),
child.attribute(SA("defval"))==SA("1"), child.attribute(SA("defval"))==SA("1"),
child.attribute(SA("docs")) docs
); );
m_options.insert( m_options.insert(
child.attribute(SA("id")), child.attribute(SA("id")),
...@@ -163,7 +448,7 @@ QWidget *Expert::createTopicWidget(QDomElement &elem) ...@@ -163,7 +448,7 @@ QWidget *Expert::createTopicWidget(QDomElement &elem)
child.attribute(SA("id")), child.attribute(SA("id")),
child.attribute(SA("defval")), child.attribute(SA("defval")),
mode, mode,
child.attribute(SA("docs")), docs,
child.attribute(SA("abspath")) child.attribute(SA("abspath"))
); );
m_options.insert( m_options.insert(
...@@ -180,12 +465,15 @@ QWidget *Expert::createTopicWidget(QDomElement &elem) ...@@ -180,12 +465,15 @@ QWidget *Expert::createTopicWidget(QDomElement &elem)
child.attribute(SA("id")), child.attribute(SA("id")),
child.attribute(SA("defval")), child.attribute(SA("defval")),
InputString::StringFixed, InputString::StringFixed,
child.attribute(SA("docs")) docs
); );
QDomElement enumVal = child.firstChildElement(); QDomElement enumVal = child.firstChildElement();
while (!enumVal.isNull()) while (!enumVal.isNull())
{
if (enumVal.tagName()==SA("value"))
{ {
enumList->addValue(enumVal.attribute(SA("name"))); enumList->addValue(enumVal.attribute(SA("name")));
}
enumVal = enumVal.nextSiblingElement(); enumVal = enumVal.nextSiblingElement();
} }
enumList->setDefault(); enumList->setDefault();
...@@ -203,7 +491,7 @@ QWidget *Expert::createTopicWidget(QDomElement &elem) ...@@ -203,7 +491,7 @@ QWidget *Expert::createTopicWidget(QDomElement &elem)
child.attribute(SA("defval")).toInt(), child.attribute(SA("defval")).toInt(),
child.attribute(SA("minval")).toInt(), child.attribute(SA("minval")).toInt(),
child.attribute(SA("maxval")).toInt(), child.attribute(SA("maxval")).toInt(),
child.attribute(SA("docs")) docs
); );
m_options.insert( m_options.insert(
child.attribute(SA("id")), child.attribute(SA("id")),
...@@ -235,8 +523,11 @@ QWidget *Expert::createTopicWidget(QDomElement &elem) ...@@ -235,8 +523,11 @@ QWidget *Expert::createTopicWidget(QDomElement &elem)
QStringList sl; QStringList sl;
QDomElement listVal = child.firstChildElement(); QDomElement listVal = child.firstChildElement();
while (!listVal.isNull()) while (!listVal.isNull())
{
if (listVal.tagName()==SA("value"))
{ {
sl.append(listVal.attribute(SA("name"))); sl.append(listVal.attribute(SA("name")));
}
listVal = listVal.nextSiblingElement(); listVal = listVal.nextSiblingElement();
} }
InputStrList *listOption = InputStrList *listOption =
...@@ -245,7 +536,7 @@ QWidget *Expert::createTopicWidget(QDomElement &elem) ...@@ -245,7 +536,7 @@ QWidget *Expert::createTopicWidget(QDomElement &elem)
child.attribute(SA("id")), child.attribute(SA("id")),
sl, sl,
mode, mode,
child.attribute(SA("docs")) docs
); );
m_options.insert( m_options.insert(
child.attribute(SA("id")), child.attribute(SA("id")),
...@@ -366,26 +657,30 @@ void Expert::loadConfig(const QString &fileName) ...@@ -366,26 +657,30 @@ void Expert::loadConfig(const QString &fileName)
void Expert::saveTopic(QTextStream &t,QDomElement &elem,QTextCodec *codec, void Expert::saveTopic(QTextStream &t,QDomElement &elem,QTextCodec *codec,
bool brief) bool brief)
{ {
// write group header if (!brief)
{
t << endl; t << endl;
}
t << "#---------------------------------------------------------------------------" << endl; t << "#---------------------------------------------------------------------------" << endl;
t << "# " << elem.attribute(SA("docs")) << endl; t << "# " << elem.attribute(SA("docs")) << endl;
t << "#---------------------------------------------------------------------------" << endl; t << "#---------------------------------------------------------------------------" << endl;
// write options... // write options...
QDomElement childElem = elem.firstChildElement(); QDomElement childElem = elem.firstChildElement();
while (!childElem.isNull()) while (!childElem.isNull())
{ {
QString setting = childElem.attribute(SA("setting"));
QString type = childElem.attribute(SA("type")); QString type = childElem.attribute(SA("type"));
QString name = childElem.attribute(SA("id")); QString name = childElem.attribute(SA("id"));
if (setting.isEmpty() || IS_SUPPORTED(setting.toAscii()))
{
QHash<QString,Input*>::const_iterator i = m_options.find(name); QHash<QString,Input*>::const_iterator i = m_options.find(name);
if (i!=m_options.end()) if (i!=m_options.end())
{ {
Input *option = i.value(); Input *option = i.value();
if (!brief) if (option && !brief)
{ {
t << endl; t << endl;
t << convertToComment(childElem.attribute(SA("docs"))); t << convertToComment(option->templateDocs());
t << endl; t << endl;
} }
t << name.leftJustified(23) << "= "; t << name.leftJustified(23) << "= ";
...@@ -395,26 +690,18 @@ void Expert::saveTopic(QTextStream &t,QDomElement &elem,QTextCodec *codec, ...@@ -395,26 +690,18 @@ void Expert::saveTopic(QTextStream &t,QDomElement &elem,QTextCodec *codec,
} }
t << endl; t << endl;
} }
}
childElem = childElem.nextSiblingElement(); childElem = childElem.nextSiblingElement();
} }
} }
bool Expert::writeConfig(QTextStream &t,bool brief) bool Expert::writeConfig(QTextStream &t,bool brief)
{ {
// write global header
t << "# Doxyfile " << versionString << endl << endl;
if (!brief) if (!brief)
{ {
// write global header t << convertToComment(m_header);
t << "# Doxyfile " << versionString << endl << endl; // TODO: add version
t << "# This file describes the settings to be used by the documentation system\n";
t << "# doxygen (www.doxygen.org) for a project\n";
t << "#\n";
t << "# All text after a hash (#) is considered a comment and will be ignored\n";
t << "# The format is:\n";
t << "# TAG = value [value, ...]\n";
t << "# For lists items can also be appended using:\n";
t << "# TAG += value [value, ...]\n";
t << "# Values that contain spaces should be placed between quotes (\" \")\n";
} }
QTextCodec *codec = 0; QTextCodec *codec = 0;
...@@ -429,8 +716,11 @@ bool Expert::writeConfig(QTextStream &t,bool brief) ...@@ -429,8 +716,11 @@ bool Expert::writeConfig(QTextStream &t,bool brief)
} }
QDomElement childElem = m_rootElement.firstChildElement(); QDomElement childElem = m_rootElement.firstChildElement();
while (!childElem.isNull()) while (!childElem.isNull())
{
if (childElem.tagName()==SA("group"))
{ {
saveTopic(t,childElem,codec,brief); saveTopic(t,childElem,codec,brief);
}
childElem = childElem.nextSiblingElement(); childElem = childElem.nextSiblingElement();
} }
return true; return true;
......
...@@ -5,16 +5,18 @@ ...@@ -5,16 +5,18 @@
#include <QDomElement> #include <QDomElement>
#include <QHash> #include <QHash>
#include "docintf.h"
class QTreeWidget; class QTreeWidget;
class QTreeWidgetItem; class QTreeWidgetItem;
class QStackedWidget; class QStackedWidget;
class QSettings; class QSettings;
class QTextEdit; class QTextBrowser;
class QTextCodec; class QTextCodec;
class QPushButton; class QPushButton;
class Input; class Input;
class Expert : public QSplitter class Expert : public QSplitter, public DocIntf
{ {
Q_OBJECT Q_OBJECT
...@@ -33,6 +35,10 @@ class Expert : public QSplitter ...@@ -33,6 +35,10 @@ class Expert : public QSplitter
bool pdfOutputPresent(const QString &workingDir) const; bool pdfOutputPresent(const QString &workingDir) const;
QString getHtmlOutputIndex(const QString &workingDir) const; QString getHtmlOutputIndex(const QString &workingDir) const;
// DocIntf methods
void setHeader(const char *name);
void add(const char *name,const char *doc);
public slots: public slots:
void activateTopic(QTreeWidgetItem *,QTreeWidgetItem *); void activateTopic(QTreeWidgetItem *,QTreeWidgetItem *);
QWidget *createTopicWidget(QDomElement &elem); QWidget *createTopicWidget(QDomElement &elem);
...@@ -50,7 +56,7 @@ class Expert : public QSplitter ...@@ -50,7 +56,7 @@ class Expert : public QSplitter
void saveTopic(QTextStream &t,QDomElement &elem,QTextCodec *codec,bool brief); void saveTopic(QTextStream &t,QDomElement &elem,QTextCodec *codec,bool brief);
QSplitter *m_splitter; QSplitter *m_splitter;
QTextEdit *m_helper; QTextBrowser *m_helper;
QTreeWidget *m_treeWidget; QTreeWidget *m_treeWidget;
QStackedWidget *m_topicStack; QStackedWidget *m_topicStack;
QHash<QString,QWidget *> m_topics; QHash<QString,QWidget *> m_topics;
...@@ -60,6 +66,7 @@ class Expert : public QSplitter ...@@ -60,6 +66,7 @@ class Expert : public QSplitter
QPushButton *m_prev; QPushButton *m_prev;
QDomElement m_rootElement; QDomElement m_rootElement;
bool m_inShowHelp; bool m_inShowHelp;
QString m_header;
}; };
#endif #endif
...@@ -23,11 +23,13 @@ class Input ...@@ -23,11 +23,13 @@ class Input
virtual Kind kind() const = 0; virtual Kind kind() const = 0;
virtual QString docs() const = 0; virtual QString docs() const = 0;
virtual QString id() const = 0; virtual QString id() const = 0;
virtual QString templateDocs() const = 0;
virtual void addDependency(Input *option) = 0; virtual void addDependency(Input *option) = 0;
virtual void setEnabled(bool) = 0; virtual void setEnabled(bool) = 0;
virtual void updateDependencies() = 0; virtual void updateDependencies() = 0;
virtual void reset() = 0; virtual void reset() = 0;
virtual void writeValue(QTextStream &t,QTextCodec *codec) = 0; virtual void writeValue(QTextStream &t,QTextCodec *codec) = 0;
virtual void setTemplateDocs(const QString &docs) = 0;
}; };
......
...@@ -36,10 +36,12 @@ class InputBool : public QObject, public Input ...@@ -36,10 +36,12 @@ class InputBool : public QObject, public Input
Kind kind() const { return Bool; } Kind kind() const { return Bool; }
QString docs() const { return m_docs; } QString docs() const { return m_docs; }
QString id() const { return m_id; } QString id() const { return m_id; }
QString templateDocs() const { return m_tdocs; }
void addDependency(Input *option) { m_dependencies+=option; } void addDependency(Input *option) { m_dependencies+=option; }
void setEnabled(bool); void setEnabled(bool);
void updateDependencies(); void updateDependencies();
void writeValue(QTextStream &t,QTextCodec *codec); void writeValue(QTextStream &t,QTextCodec *codec);
void setTemplateDocs(const QString &docs) { m_tdocs = docs; }
public slots: public slots:
void reset(); void reset();
...@@ -64,7 +66,7 @@ class InputBool : public QObject, public Input ...@@ -64,7 +66,7 @@ class InputBool : public QObject, public Input
QList<Input*> m_dependencies; QList<Input*> m_dependencies;
QString m_id; QString m_id;
QLabel *m_lab; QLabel *m_lab;
QString m_tdocs;
}; };
#endif #endif
...@@ -39,10 +39,12 @@ class InputInt : public QObject, public Input ...@@ -39,10 +39,12 @@ class InputInt : public QObject, public Input
Kind kind() const { return Int; } Kind kind() const { return Int; }
QString docs() const { return m_docs; } QString docs() const { return m_docs; }
QString id() const { return m_id; } QString id() const { return m_id; }
QString templateDocs() const { return m_tdocs; }
void addDependency(Input *) { Q_ASSERT(false); } void addDependency(Input *) { Q_ASSERT(false); }
void setEnabled(bool); void setEnabled(bool);
void updateDependencies() {} void updateDependencies() {}
void writeValue(QTextStream &t,QTextCodec *codec); void writeValue(QTextStream &t,QTextCodec *codec);
void setTemplateDocs(const QString &docs) { m_tdocs = docs; }
public slots: public slots:
void reset(); void reset();
...@@ -66,6 +68,7 @@ class InputInt : public QObject, public Input ...@@ -66,6 +68,7 @@ class InputInt : public QObject, public Input
QVariant m_value; QVariant m_value;
QString m_docs; QString m_docs;
QString m_id; QString m_id;
QString m_tdocs;
}; };
#endif #endif
...@@ -53,10 +53,12 @@ class InputString : public QObject, public Input ...@@ -53,10 +53,12 @@ class InputString : public QObject, public Input
Kind kind() const { return String; } Kind kind() const { return String; }
QString docs() const { return m_docs; } QString docs() const { return m_docs; }
QString id() const { return m_id; } QString id() const { return m_id; }
QString templateDocs() const { return m_tdocs; }
void addDependency(Input *) { Q_ASSERT(false); } void addDependency(Input *) { Q_ASSERT(false); }
void setEnabled(bool); void setEnabled(bool);
void updateDependencies() {} void updateDependencies() {}
void writeValue(QTextStream &t,QTextCodec *codec); void writeValue(QTextStream &t,QTextCodec *codec);
void setTemplateDocs(const QString &docs) { m_tdocs = docs; }
public slots: public slots:
void reset(); void reset();
...@@ -86,6 +88,7 @@ class InputString : public QObject, public Input ...@@ -86,6 +88,7 @@ class InputString : public QObject, public Input
QString m_docs; QString m_docs;
QString m_id; QString m_id;
bool m_absPath; bool m_absPath;
QString m_tdocs;
}; };
#endif #endif
...@@ -49,10 +49,12 @@ class InputStrList : public QObject, public Input ...@@ -49,10 +49,12 @@ class InputStrList : public QObject, public Input
Kind kind() const { return StrList; } Kind kind() const { return StrList; }
QString docs() const { return m_docs; } QString docs() const { return m_docs; }
QString id() const { return m_id; } QString id() const { return m_id; }
QString templateDocs() const { return m_tdocs; }
void addDependency(Input *) { Q_ASSERT(false); } void addDependency(Input *) { Q_ASSERT(false); }
void setEnabled(bool); void setEnabled(bool);
void updateDependencies() {} void updateDependencies() {}
void writeValue(QTextStream &t,QTextCodec *codec); void writeValue(QTextStream &t,QTextCodec *codec);
void setTemplateDocs(const QString &docs) { m_tdocs = docs; }
public slots: public slots:
void reset(); void reset();
...@@ -85,7 +87,7 @@ class InputStrList : public QObject, public Input ...@@ -85,7 +87,7 @@ class InputStrList : public QObject, public Input
QVariant m_value; QVariant m_value;
QString m_docs; QString m_docs;
QString m_id; QString m_id;
QString m_tdocs;
}; };
#endif #endif
...@@ -12,7 +12,7 @@ ...@@ -12,7 +12,7 @@
# Documents produced by Doxygen are derivative works derived from the # Documents produced by Doxygen are derivative works derived from the
# input used in their production; they are not affected by this license. # input used in their production; they are not affected by this license.
all: language FORCE all: language config.doc FORCE
DOXYGEN_DOCDIR=$(DOXYDOCS); \ DOXYGEN_DOCDIR=$(DOXYDOCS); \
export DOXYGEN_DOCDIR; \ export DOXYGEN_DOCDIR; \
VERSION=$(VERSION) ; \ VERSION=$(VERSION) ; \
...@@ -33,4 +33,7 @@ language: language.doc ...@@ -33,4 +33,7 @@ language: language.doc
language.doc: $(wildcard ../src/translator*.h) maintainers.txt language.tpl translator.py language.doc: $(wildcard ../src/translator*.h) maintainers.txt language.tpl translator.py
python translator.py python translator.py
config.doc: ../src/config.xml ../src/configgen.py
python ../src/configgen.py -doc ../src/config.xml > config.doc
FORCE: FORCE:
...@@ -12,7 +12,7 @@ ...@@ -12,7 +12,7 @@
# Documents produced by Doxygen are derivative works derived from the # Documents produced by Doxygen are derivative works derived from the
# input used in their production; they are not affected by this license. # input used in their production; they are not affected by this license.
all: language FORCE all: language config.doc FORCE
@xcopy /s /q /i ..\examples ..\html\examples @xcopy /s /q /i ..\examples ..\html\examples
set DOXYGEN_DOCDIR=. & \ set DOXYGEN_DOCDIR=. & \
set VERSION=$(VERSION) & \ set VERSION=$(VERSION) & \
...@@ -33,4 +33,8 @@ language: language.doc ...@@ -33,4 +33,8 @@ language: language.doc
language.doc: maintainers.txt language.tpl translator.py language.doc: maintainers.txt language.tpl translator.py
set DOXYGEN_DOCDIR=. & set VERSION=$(VERSION) & python translator.py set DOXYGEN_DOCDIR=. & set VERSION=$(VERSION) & python translator.py
config.doc: ..\src\config.xml ..\src\configgen.py
python ..\src\configgen.py -doc ..\src\config.xml > config.doc
FORCE: FORCE:
...@@ -12,7 +12,7 @@ ...@@ -12,7 +12,7 @@
# Documents produced by Doxygen are derivative works derived from the # Documents produced by Doxygen are derivative works derived from the
# input used in their production; they are not affected by this license. # input used in their production; they are not affected by this license.
all: language FORCE all: language config.doc FORCE
@xcopy /s /q /i ..\examples ..\html\examples @xcopy /s /q /i ..\examples ..\html\examples
set DOXYGEN_DOCDIR=. set DOXYGEN_DOCDIR=.
set VERSION=$(VERSION) set VERSION=$(VERSION)
...@@ -35,4 +35,7 @@ language.doc: maintainers.txt language.tpl translator.py ...@@ -35,4 +35,7 @@ language.doc: maintainers.txt language.tpl translator.py
set VERSION=$(VERSION) set VERSION=$(VERSION)
python translator.py python translator.py
config.doc: ../src/config.xml ../src/configgen.py
python ../src/configgen.py -doc ../src/config.xml > config.doc
FORCE: FORCE:
This source diff could not be displayed because it is too large. You can view the blob instead.
...@@ -74,10 +74,8 @@ class ConfigOption ...@@ -74,10 +74,8 @@ class ConfigOption
virtual void writeTemplate(FTextStream &t,bool sl,bool upd) = 0; virtual void writeTemplate(FTextStream &t,bool sl,bool upd) = 0;
virtual void convertStrToVal() {} virtual void convertStrToVal() {}
virtual void substEnvVars() = 0; virtual void substEnvVars() = 0;
virtual void writeXML(FTextStream&) {}
virtual void init() {} virtual void init() {}
QCString convertToComment(const QCString &s, const QCString &u);
void writeBoolValue(FTextStream &t,bool v); void writeBoolValue(FTextStream &t,bool v);
void writeIntValue(FTextStream &t,int i); void writeIntValue(FTextStream &t,int i);
void writeStringValue(FTextStream &t,QCString &s); void writeStringValue(FTextStream &t,QCString &s);
...@@ -103,16 +101,7 @@ class ConfigInfo : public ConfigOption ...@@ -103,16 +101,7 @@ class ConfigInfo : public ConfigOption
m_name = name; m_name = name;
m_doc = doc; m_doc = doc;
} }
void writeTemplate(FTextStream &t, bool sl,bool) void writeTemplate(FTextStream &t, bool sl,bool);
{
if (!sl)
{
t << "\n";
}
t << "#---------------------------------------------------------------------------\n";
t << "# " << m_doc << endl;
t << "#---------------------------------------------------------------------------\n";
}
void substEnvVars() {} void substEnvVars() {}
}; };
...@@ -133,24 +122,8 @@ class ConfigList : public ConfigOption ...@@ -133,24 +122,8 @@ class ConfigList : public ConfigOption
void setWidgetType(WidgetType w) { m_widgetType = w; } void setWidgetType(WidgetType w) { m_widgetType = w; }
WidgetType widgetType() const { return m_widgetType; } WidgetType widgetType() const { return m_widgetType; }
QStrList *valueRef() { return &m_value; } QStrList *valueRef() { return &m_value; }
void writeTemplate(FTextStream &t,bool sl,bool) void writeTemplate(FTextStream &t,bool sl,bool);
{
if (!sl)
{
t << endl;
t << convertToComment(m_doc, m_userComment);
t << endl;
}
else if (!m_userComment.isEmpty())
{
t << convertToComment("", m_userComment);
}
t << m_name << m_spaces.left(MAX_OPTION_LENGTH-m_name.length()) << "=";
writeStringList(t,m_value);
t << "\n";
}
void substEnvVars(); void substEnvVars();
void writeXML(FTextStream&);
void init() { m_value.clear(); } void init() { m_value.clear(); }
private: private:
QStrList m_value; QStrList m_value;
...@@ -177,23 +150,7 @@ class ConfigEnum : public ConfigOption ...@@ -177,23 +150,7 @@ class ConfigEnum : public ConfigOption
} }
QCString *valueRef() { return &m_value; } QCString *valueRef() { return &m_value; }
void substEnvVars(); void substEnvVars();
void writeTemplate(FTextStream &t,bool sl,bool) void writeTemplate(FTextStream &t,bool sl,bool);
{
if (!sl)
{
t << endl;
t << convertToComment(m_doc, m_userComment);
t << endl;
}
else if (!m_userComment.isEmpty())
{
t << convertToComment("", m_userComment);
}
t << m_name << m_spaces.left(MAX_OPTION_LENGTH-m_name.length()) << "=";
writeStringValue(t,m_value);
t << "\n";
}
void writeXML(FTextStream&);
void init() { m_value = m_defValue.copy(); } void init() { m_value = m_defValue.copy(); }
private: private:
...@@ -222,24 +179,8 @@ class ConfigString : public ConfigOption ...@@ -222,24 +179,8 @@ class ConfigString : public ConfigOption
WidgetType widgetType() const { return m_widgetType; } WidgetType widgetType() const { return m_widgetType; }
void setDefaultValue(const char *v) { m_defValue = v; } void setDefaultValue(const char *v) { m_defValue = v; }
QCString *valueRef() { return &m_value; } QCString *valueRef() { return &m_value; }
void writeTemplate(FTextStream &t,bool sl,bool) void writeTemplate(FTextStream &t,bool sl,bool);
{
if (!sl)
{
t << endl;
t << convertToComment(m_doc, m_userComment);
t << endl;
}
else if (!m_userComment.isEmpty())
{
t << convertToComment("", m_userComment);
}
t << m_name << m_spaces.left(MAX_OPTION_LENGTH-m_name.length()) << "=";
writeStringValue(t,m_value);
t << "\n";
}
void substEnvVars(); void substEnvVars();
void writeXML(FTextStream&);
void init() { m_value = m_defValue.copy(); } void init() { m_value = m_defValue.copy(); }
private: private:
...@@ -269,30 +210,7 @@ class ConfigInt : public ConfigOption ...@@ -269,30 +210,7 @@ class ConfigInt : public ConfigOption
int maxVal() const { return m_maxVal; } int maxVal() const { return m_maxVal; }
void convertStrToVal(); void convertStrToVal();
void substEnvVars(); void substEnvVars();
void writeTemplate(FTextStream &t,bool sl,bool upd) void writeTemplate(FTextStream &t,bool sl,bool upd);
{
if (!sl)
{
t << endl;
t << convertToComment(m_doc, m_userComment);
t << endl;
}
else if (!m_userComment.isEmpty())
{
t << convertToComment("", m_userComment);
}
t << m_name << m_spaces.left(MAX_OPTION_LENGTH-m_name.length()) << "=";
if (upd && !m_valueString.isEmpty())
{
writeStringValue(t,m_valueString);
}
else
{
writeIntValue(t,m_value);
}
t << "\n";
}
void writeXML(FTextStream&);
void init() { m_value = m_defValue; } void init() { m_value = m_defValue; }
private: private:
int m_value; int m_value;
...@@ -320,30 +238,7 @@ class ConfigBool : public ConfigOption ...@@ -320,30 +238,7 @@ class ConfigBool : public ConfigOption
void convertStrToVal(); void convertStrToVal();
void substEnvVars(); void substEnvVars();
void setValueString(const QCString &v) { m_valueString = v; } void setValueString(const QCString &v) { m_valueString = v; }
void writeTemplate(FTextStream &t,bool sl,bool upd) void writeTemplate(FTextStream &t,bool sl,bool upd);
{
if (!sl)
{
t << endl;
t << convertToComment(m_doc, m_userComment);
t << endl;
}
else if (!m_userComment.isEmpty())
{
t << convertToComment("", m_userComment);
}
t << m_name << m_spaces.left(MAX_OPTION_LENGTH-m_name.length()) << "=";
if (upd && !m_valueString.isEmpty())
{
writeStringValue(t,m_valueString);
}
else
{
writeBoolValue(t,m_value);
}
t << "\n";
}
void writeXML(FTextStream&);
void init() { m_value = m_defValue; } void init() { m_value = m_defValue; }
private: private:
bool m_value; bool m_value;
...@@ -358,9 +253,8 @@ class ConfigObsolete : public ConfigOption ...@@ -358,9 +253,8 @@ class ConfigObsolete : public ConfigOption
public: public:
ConfigObsolete(const char *name) : ConfigOption(O_Obsolete) ConfigObsolete(const char *name) : ConfigOption(O_Obsolete)
{ m_name = name; } { m_name = name; }
void writeTemplate(FTextStream &,bool,bool) {} void writeTemplate(FTextStream &,bool,bool);
void substEnvVars() {} void substEnvVars() {}
void writeXML(FTextStream&);
}; };
/** Section marker for compile time optional options /** Section marker for compile time optional options
...@@ -370,13 +264,12 @@ class ConfigDisabled : public ConfigOption ...@@ -370,13 +264,12 @@ class ConfigDisabled : public ConfigOption
public: public:
ConfigDisabled(const char *name) : ConfigOption(O_Disabled) ConfigDisabled(const char *name) : ConfigOption(O_Disabled)
{ m_name = name; } { m_name = name; }
void writeTemplate(FTextStream &,bool,bool) {} void writeTemplate(FTextStream &,bool,bool);
void substEnvVars() {} void substEnvVars() {}
void writeXML(FTextStream&);
}; };
// some convenience macros // some convenience macros for access the config options
#define Config_getString(val) Config::instance()->getString(__FILE__,__LINE__,val) #define Config_getString(val) Config::instance()->getString(__FILE__,__LINE__,val)
#define Config_getInt(val) Config::instance()->getInt(__FILE__,__LINE__,val) #define Config_getInt(val) Config::instance()->getInt(__FILE__,__LINE__,val)
#define Config_getList(val) Config::instance()->getList(__FILE__,__LINE__,val) #define Config_getList(val) Config::instance()->getList(__FILE__,__LINE__,val)
...@@ -571,8 +464,7 @@ class Config ...@@ -571,8 +464,7 @@ class Config
*/ */
void writeTemplate(FTextStream &t,bool shortIndex,bool updateOnly); void writeTemplate(FTextStream &t,bool shortIndex,bool updateOnly);
/** Write XML representation of the config file */ void setHeader(const char *header) { m_header = header; }
void writeXML(FTextStream &t);
///////////////////////////// /////////////////////////////
// internal API // internal API
...@@ -658,6 +550,7 @@ class Config ...@@ -658,6 +550,7 @@ class Config
static Config *m_instance; static Config *m_instance;
QCString m_userComment; QCString m_userComment;
bool m_initialized; bool m_initialized;
QCString m_header;
}; };
#endif #endif
...@@ -77,7 +77,7 @@ static QCString configStringRecode( ...@@ -77,7 +77,7 @@ static QCString configStringRecode(
/* ----------------------------------------------------------------- /* -----------------------------------------------------------------
*/ */
QCString ConfigOption::convertToComment(const QCString &s, const QCString &u) static QCString convertToComment(const QCString &s, const QCString &u)
{ {
//printf("convertToComment(%s)=%s\n",s.data(),u.data()); //printf("convertToComment(%s)=%s\n",s.data(),u.data());
QCString result; QCString result;
...@@ -291,106 +291,120 @@ bool &Config::getBool(const char *fileName,int num,const char *name) const ...@@ -291,106 +291,120 @@ bool &Config::getBool(const char *fileName,int num,const char *name) const
return *((ConfigBool *)opt)->valueRef(); return *((ConfigBool *)opt)->valueRef();
} }
/* ----------------------------------------------------------------- /* ------------------------------------------ */
*/
void ConfigInt::writeXML(FTextStream& t)
{
t << " <option type='int' "
"id='" << convertToXML(name()) << "' "
"docs='\n" << convertToXML(docs()) << "' "
"minval='" << m_minVal << "' "
"maxval='" << m_maxVal << "' "
"defval='" << m_defValue << "'";
if (!m_dependency.isEmpty()) t << " depends='" << m_dependency << "'";
t << "/>" << endl;
}
void ConfigBool::writeXML(FTextStream& t) void ConfigInfo::writeTemplate(FTextStream &t, bool sl,bool)
{ {
t << " <option type='bool' " if (!sl)
"id='" << convertToXML(name()) << "' " {
"docs='\n" << convertToXML(docs()) << "' " t << "\n";
"defval='" << m_defValue << "'"; }
if (!m_dependency.isEmpty()) t << " depends='" << m_dependency << "'"; t << "#---------------------------------------------------------------------------\n";
t << "/>" << endl; t << "# " << m_doc << endl;
t << "#---------------------------------------------------------------------------\n";
} }
void ConfigString::writeXML(FTextStream& t) void ConfigList::writeTemplate(FTextStream &t,bool sl,bool)
{ {
QString format; if (!sl)
switch (m_widgetType) {
{ t << endl;
case String: format="string"; break; t << convertToComment(m_doc, m_userComment);
case File: format="file"; break; t << endl;
case Dir: format="dir"; break; }
} else if (!m_userComment.isEmpty())
t << " <option type='string' " {
"id='" << convertToXML(name()) << "' " t << convertToComment("", m_userComment);
"format='" << format << "' " }
"docs='\n" << convertToXML(docs()) << "' " t << m_name << m_spaces.left(MAX_OPTION_LENGTH-m_name.length()) << "=";
"defval='" << convertToXML(m_defValue) << "'"; writeStringList(t,m_value);
if (!m_dependency.isEmpty()) t << " depends='" << m_dependency << "'"; t << "\n";
t << "/>" << endl;
} }
void ConfigEnum::writeXML(FTextStream &t) void ConfigEnum::writeTemplate(FTextStream &t,bool sl,bool)
{ {
t << " <option type='enum' " if (!sl)
"id='" << convertToXML(name()) << "' "
"defval='" << convertToXML(m_defValue) << "' "
"docs='\n" << convertToXML(docs()) << "'";
if (!m_dependency.isEmpty()) t << " depends='" << m_dependency << "'";
t << ">" << endl;
char *enumVal = m_valueRange.first();
while (enumVal)
{ {
t << " <value name='" << convertToXML(enumVal) << "'/>" << endl; t << endl;
enumVal = m_valueRange.next(); t << convertToComment(m_doc, m_userComment);
t << endl;
} }
else if (!m_userComment.isEmpty())
t << " </option>" << endl; {
t << convertToComment("", m_userComment);
}
t << m_name << m_spaces.left(MAX_OPTION_LENGTH-m_name.length()) << "=";
writeStringValue(t,m_value);
t << "\n";
} }
void ConfigList::writeXML(FTextStream &t) void ConfigString::writeTemplate(FTextStream &t,bool sl,bool)
{ {
QString format; if (!sl)
switch (m_widgetType)
{ {
case String: format="string"; break; t << endl;
case File: format="file"; break; t << convertToComment(m_doc, m_userComment);
case Dir: format="dir"; break; t << endl;
case FileAndDir: format="filedir"; break;
} }
t << " <option type='list' " else if (!m_userComment.isEmpty())
"id='" << convertToXML(name()) << "' "
"format='" << format << "' "
"docs='\n" << convertToXML(docs()) << "'";
if (!m_dependency.isEmpty()) t << " depends='" << m_dependency << "'";
t << ">" << endl;
char *enumVal = m_value.first();
while (enumVal)
{ {
t << " <value name='" << convertToXML(enumVal) << "'/>" << endl; t << convertToComment("", m_userComment);
enumVal = m_value.next();
} }
t << m_name << m_spaces.left(MAX_OPTION_LENGTH-m_name.length()) << "=";
t << " </option>" << endl; writeStringValue(t,m_value);
t << "\n";
} }
void ConfigObsolete::writeXML(FTextStream &t) void ConfigInt::writeTemplate(FTextStream &t,bool sl,bool upd)
{ {
t << " <option type='obsolete' " if (!sl)
"id='" << convertToXML(name()) << "'/>" << endl; {
t << endl;
t << convertToComment(m_doc, m_userComment);
t << endl;
}
else if (!m_userComment.isEmpty())
{
t << convertToComment("", m_userComment);
}
t << m_name << m_spaces.left(MAX_OPTION_LENGTH-m_name.length()) << "=";
if (upd && !m_valueString.isEmpty())
{
writeStringValue(t,m_valueString);
}
else
{
writeIntValue(t,m_value);
}
t << "\n";
} }
void ConfigDisabled::writeXML(FTextStream &t) void ConfigBool::writeTemplate(FTextStream &t,bool sl,bool upd)
{ {
t << " <option type='disabled' " if (!sl)
"id='" << convertToXML(name()) << "'/>" << endl; {
t << endl;
t << convertToComment(m_doc, m_userComment);
t << endl;
}
else if (!m_userComment.isEmpty())
{
t << convertToComment("", m_userComment);
}
t << m_name << m_spaces.left(MAX_OPTION_LENGTH-m_name.length()) << "=";
if (upd && !m_valueString.isEmpty())
{
writeStringValue(t,m_valueString);
}
else
{
writeBoolValue(t,m_value);
}
t << "\n";
} }
void ConfigObsolete::writeTemplate(FTextStream &,bool,bool) {}
void ConfigDisabled::writeTemplate(FTextStream &,bool,bool) {}
/* ----------------------------------------------------------------- /* -----------------------------------------------------------------
* *
...@@ -830,17 +844,7 @@ void Config::writeTemplate(FTextStream &t,bool sl,bool upd) ...@@ -830,17 +844,7 @@ void Config::writeTemplate(FTextStream &t,bool sl,bool upd)
t << "# Doxyfile " << versionString << endl << endl; t << "# Doxyfile " << versionString << endl << endl;
if (!sl) if (!sl)
{ {
t << "# This file describes the settings to be used by the documentation system\n"; t << convertToComment(m_header,"");
t << "# doxygen (www.doxygen.org) for a project.\n";
t << "#\n";
t << "# All text after a double hash (##) is considered a comment and is placed\n";
t << "# in front of the TAG it is preceding .\n";
t << "# All text after a hash (#) is considered a comment and will be ignored.\n";
t << "# The format is:\n";
t << "# TAG = value [value, ...]\n";
t << "# For lists items can also be appended using:\n";
t << "# TAG += value [value, ...]\n";
t << "# Values that contain spaces should be placed between quotes (\" \").\n";
} }
ConfigOption *option = m_options->first(); ConfigOption *option = m_options->first();
while (option) while (option)
...@@ -856,36 +860,6 @@ void Config::writeTemplate(FTextStream &t,bool sl,bool upd) ...@@ -856,36 +860,6 @@ void Config::writeTemplate(FTextStream &t,bool sl,bool upd)
} }
} }
void Config::writeXML(FTextStream &t)
{
t << "<doxygenconfig>" << endl;
bool first=TRUE;
ConfigOption *option = m_options->first();
while (option)
{
if (option->kind()==ConfigOption::O_Info)
{
if (!first) t << " </group>" << endl;
t << " <group name='" << option->name() << "' "
"docs='" << option->docs() << "'>" << endl;
first=FALSE;
}
else
{
option->writeXML(t);
}
option = m_options->next();
}
option = m_obsolete->first();
while (option)
{
option->writeXML(t);
option = m_obsolete->next();
}
if (!first) t << " </group>" << endl;
t << "</doxygenconfig>" << endl;
}
void Config::convertStrToVal() void Config::convertStrToVal()
{ {
ConfigOption *option = m_options->first(); ConfigOption *option = m_options->first();
......
This source diff could not be displayed because it is too large. You can view the blob instead.
# python script to generate configoptions.cpp from config.xml #!/usr/bin/python
# python script to generate configoptions.cpp and config.doc from config.xml
# #
# Copyright (C) 1997-2013 by Dimitri van Heesch. # Copyright (C) 1997-2013 by Dimitri van Heesch.
# #
...@@ -13,116 +14,550 @@ ...@@ -13,116 +14,550 @@
# #
import xml.dom.minidom import xml.dom.minidom
import sys import sys
import re
import textwrap
from xml.dom import minidom, Node from xml.dom import minidom, Node
def addValues(var,node):
def transformDocs(doc):
# join lines, unless it is an empty line
# remove doxygen layout constructs
doc = doc.strip()
doc = doc.replace("\n", " ")
doc = doc.replace("\r", " ")
doc = doc.replace("\t", " ")
doc = doc.replace("\\&", "&")
doc = doc.replace("\\c ", " ")
doc = doc.replace("\\b ", " ")
doc = doc.replace("\\e ", " ")
doc = doc.replace("\\$", "$")
doc = doc.replace("\\#include ", "#include ")
doc = doc.replace("\\#undef ", "#undef ")
doc = doc.replace("-# ", "\n - ")
doc = doc.replace(" - ", "\n - ")
doc = doc.replace("\\sa", "\nSee also: ")
doc = doc.replace("\\par", "\n")
doc = doc.replace("@note", "\nNote:")
doc = doc.replace("\\note", "\nNote:")
doc = doc.replace("\\verbatim", "\n")
doc = doc.replace("\\endverbatim", "\n")
doc = doc.replace("<code>", "")
doc = doc.replace("</code>", "")
doc = doc.replace("`", "")
doc = doc.replace("\\<", "<")
doc = doc.replace("\\>", ">")
doc = doc.replace("\\@", "@")
doc = doc.replace("\\\\", "\\")
# \ref name "description" -> description
doc = re.sub('\\\\ref +[^ ]* +"([^"]*)"', '\\1', doc)
# \ref specials
# \ref <key> -> description
doc = re.sub('\\\\ref +doxygen_usage', '"Doxygen usage"', doc)
doc = re.sub('\\\\ref +extsearch', '"External Indexing and Searching"',
doc)
doc = re.sub('\\\\ref +external', '"Linking to external documentation"',
doc)
# fallback for not handled
doc = re.sub('\\\\ref', '', doc)
#<a href="address">description</a> -> description (see: address)
doc = re.sub('<a +href="([^"]*)" *>([^<]*)</a>', '\\2 (see: \\1)', doc)
# LaTeX name as formula -> LaTeX
doc = doc.replace("\\f$\\mbox{\\LaTeX}\\f$", "LaTeX")
# Other forula's (now just 2) so explicitely mentioned.
doc = doc.replace("\\f$2^{(16+\\mbox{LOOKUP\\_CACHE\\_SIZE})}\\f$",
"2^(16+LOOKUP_CACHE_SIZE)")
doc = doc.replace("\\f$2^{16} = 65536\\f$", "2^16=65536")
# remove consecutive spaces
doc = re.sub(" +", " ", doc)
# a dirty trick to get an extra empty line in Doxyfile documentation.
# <br> will be removed later on again, we need it here otherwise splitlines
# will filter the extra line.
doc = doc.replace("<br>", "\n<br>\n")
#
doc = doc.splitlines()
split_doc = []
for line in doc:
split_doc += textwrap.wrap(line, 78)
# replace \ by \\, replace " by \", and ' ' by a newline with end string
# and start string at next line
docC = []
for line in split_doc:
docC.append(line.strip().replace('\\', '\\\\').
replace('"', '\\"').replace("<br>", ""))
return docC
def collectValues(node):
values = []
for n in node.childNodes:
if (n.nodeName == "value"):
if n.nodeType == Node.ELEMENT_NODE:
if n.getAttribute('name') != "":
name = "<code>" + n.getAttribute('name') + "</code>"
desc = n.getAttribute('desc')
if (desc != ""):
name += " " + desc
values.append(name)
return values
def addValues(var, node):
for n in node.childNodes:
if (n.nodeName == "value"):
if n.nodeType == Node.ELEMENT_NODE:
name = n.getAttribute('name')
print " %s->addValue(\"%s\");" % (var, name)
def parseHeader(node,objName):
doc = ""
for n in node.childNodes:
if n.nodeType == Node.ELEMENT_NODE:
if (n.nodeName == "docs"):
if (n.getAttribute('doxyfile') != "0"):
doc += parseDocs(n)
docC = transformDocs(doc)
print " %s->setHeader(" % (objName)
rng = len(docC)
for i in range(rng):
line = docC[i]
if i != rng - 1: # since we go from 0 to rng-1
print " \"%s\\n\"" % (line)
else:
print " \"%s\"" % (line)
print " );"
def prepCDocs(node):
type = node.getAttribute('type')
format = node.getAttribute('format')
defval = node.getAttribute('defval')
adefval = node.getAttribute('altdefval')
doc = "";
if (type != 'obsolete'):
for n in node.childNodes: for n in node.childNodes:
if (n.nodeName == "docs"):
if (n.getAttribute('doxyfile') != "0"):
if n.nodeType == Node.ELEMENT_NODE: if n.nodeType == Node.ELEMENT_NODE:
name = n.getAttribute('name'); doc += parseDocs(n)
print " %s->addValue(\"%s\");" % (var,name) if (type == 'enum'):
values = collectValues(node)
doc += "Possible values are: "
rng = len(values)
for i in range(rng):
val = values[i]
if i == rng - 2:
doc += "%s and " % (val)
elif i == rng - 1:
doc += "%s." % (val)
else:
doc += "%s, " % (val)
if (defval != ""):
doc += "<br>"
doc += "The default value is: <code>%s</code>." % (defval)
elif (type == 'int'):
minval = node.getAttribute('minval')
maxval = node.getAttribute('maxval')
doc += "%s: %s, %s: %s, %s: %s." % (" Minimum value", minval,
"maximum value", maxval,
"default value", defval)
elif (type == 'bool'):
if (node.hasAttribute('altdefval')):
doc += "%s: %s." % ("Default value", "system dependent")
else:
doc += "%s: %s." % ("Default value", "YES" if (defval == "1") else "NO")
elif (type == 'list'):
if format == 'string':
values = collectValues(node)
rng = len(values)
for i in range(rng):
val = values[i]
if i == rng - 2:
doc += "%s and " % (val)
elif i == rng - 1:
doc += "%s." % (val)
else:
doc += "%s, " % (val)
elif (type == 'string'):
if format == 'dir':
if defval != '':
doc += "The default directory is: <code>%s</code>." % (
defval)
elif format == 'file':
abspath = node.getAttribute('abspath')
if defval != '':
if abspath != '1':
doc += "The default file is: <code>%s</code>." % (
defval)
else:
doc += "%s: %s%s%s." % (
"The default file (with absolute path) is",
"<code>",defval,"</code>")
else:
if abspath == '1':
doc += "The file has to be specified with full path."
else: # format == 'string':
if defval != '':
doc += "The default value is: <code>%s</code>." % (
defval)
# depends handling
if (node.hasAttribute('depends')):
depends = node.getAttribute('depends')
doc += "<br>"
doc += "%s \\ref cfg_%s \"%s\" is set to \\c YES." % (
"This tag requires that the tag", depends.lower(), depends.upper())
docC = transformDocs(doc)
return docC;
def parseOption(node): def parseOption(node):
# Handling part for Doxyfile
name = node.getAttribute('id') name = node.getAttribute('id')
type = node.getAttribute('type') type = node.getAttribute('type')
format = node.getAttribute('format') format = node.getAttribute('format')
doc = node.getAttribute('docs')
defval = node.getAttribute('defval') defval = node.getAttribute('defval')
adefval = node.getAttribute('altdefval') adefval = node.getAttribute('altdefval')
depends = node.getAttribute('depends') depends = node.getAttribute('depends')
setting = node.getAttribute('setting') setting = node.getAttribute('setting')
# replace \ by \\, replace " by \", and ' ' by a newline with end string and start string at next line docC = prepCDocs(node);
docC = doc.strip().replace('\\','\\\\').replace('"','\\"').replace(' ','\\n"\n\t\t\t"') if len(setting) > 0:
if len(setting)>0:
print "#if %s" % (setting) print "#if %s" % (setting)
print " //----" print " //----"
if type=='bool': if type == 'bool':
if len(adefval)>0: if len(adefval) > 0:
enabled = adefval enabled = adefval
elif defval=='1': elif defval == '1':
enabled = "TRUE" enabled = "TRUE"
else: else:
enabled = "FALSE" enabled = "FALSE"
print " cb = cfg->addBool(" print " cb = cfg->addBool("
print " \"%s\"," % (name) print " \"%s\"," % (name)
print " \"%s\"," % (docC) rng = len(docC)
for i in range(rng):
line = docC[i]
if i != rng - 1: # since we go from 0 to rng-1
print " \"%s\\n\"" % (line)
else:
print " \"%s\"," % (line)
print " %s" % (enabled) print " %s" % (enabled)
print " );" print " );"
if depends!='': if depends != '':
print " cb->addDependency(\"%s\");" % (depends) print " cb->addDependency(\"%s\");" % (depends)
elif type=='string': elif type == 'string':
print " cs = cfg->addString(" print " cs = cfg->addString("
print " \"%s\"," % (name) print " \"%s\"," % (name)
print " \"%s\"" % (docC) rng = len(docC)
for i in range(rng):
line = docC[i]
if i != rng - 1: # since we go from 0 to rng-1
print " \"%s\\n\"" % (line)
else:
print " \"%s\"" % (line)
print " );" print " );"
if defval!='': if defval != '':
print " cs->setDefaultValue(\"%s\");" % (defval) print " cs->setDefaultValue(\"%s\");" % (defval)
if format=='file': if format == 'file':
print " cs->setWidgetType(ConfigString::File);" print " cs->setWidgetType(ConfigString::File);"
elif format=='dir': elif format == 'dir':
print " cs->setWidgetType(ConfigString::Dir);" print " cs->setWidgetType(ConfigString::Dir);"
if depends!='': if depends != '':
print " cs->addDependency(\"%s\");" % (depends) print " cs->addDependency(\"%s\");" % (depends)
elif type=='enum': elif type == 'enum':
print " ce = cfg->addEnum(" print " ce = cfg->addEnum("
print " \"%s\"," % (name) print " \"%s\"," % (name)
print " \"%s\"," % (docC) rng = len(docC)
for i in range(rng):
line = docC[i]
if i != rng - 1: # since we go from 0 to rng-1
print " \"%s\\n\"" % (line)
else:
print " \"%s\"," % (line)
print " \"%s\"" % (defval) print " \"%s\"" % (defval)
print " );" print " );"
addValues("ce",node) addValues("ce", node)
if depends!='': if depends != '':
print " ce->addDependency(\"%s\");" % (depends) print " ce->addDependency(\"%s\");" % (depends)
elif type=='int': elif type == 'int':
minval = node.getAttribute('minval') minval = node.getAttribute('minval')
maxval = node.getAttribute('maxval') maxval = node.getAttribute('maxval')
print " ci = cfg->addInt(" print " ci = cfg->addInt("
print " \"%s\"," % (name) print " \"%s\"," % (name)
print " \"%s\"," % (docC) rng = len(docC)
print " %s,%s,%s" % (minval,maxval,defval) for i in range(rng):
line = docC[i]
if i != rng - 1: # since we go from 0 to rng-1
print " \"%s\\n\"" % (line)
else:
print " \"%s\"," % (line)
print " %s,%s,%s" % (minval, maxval, defval)
print " );" print " );"
if depends!='': if depends != '':
print " ci->addDependency(\"%s\");" % (depends) print " ci->addDependency(\"%s\");" % (depends)
elif type=='list': elif type == 'list':
print " cl = cfg->addList(" print " cl = cfg->addList("
print " \"%s\"," % (name) print " \"%s\"," % (name)
print " \"%s\"" % (docC) rng = len(docC)
for i in range(rng):
line = docC[i]
if i != rng - 1: # since we go from 0 to rng-1
print " \"%s\\n\"" % (line)
else:
print " \"%s\"" % (line)
print " );" print " );"
addValues("cl",node) addValues("cl", node)
if depends!='': if depends != '':
print " cl->addDependency(\"%s\");" % (depends) print " cl->addDependency(\"%s\");" % (depends)
if format=='file': if format == 'file':
print " cl->setWidgetType(ConfigList::File);" print " cl->setWidgetType(ConfigList::File);"
elif format=='dir': elif format == 'dir':
print " cl->setWidgetType(ConfigList::Dir);" print " cl->setWidgetType(ConfigList::Dir);"
elif format=='filedir': elif format == 'filedir':
print " cl->setWidgetType(ConfigList::FileAndDir);" print " cl->setWidgetType(ConfigList::FileAndDir);"
elif type=='obsolete': elif type == 'obsolete':
print " cfg->addObsolete(\"%s\");" % (name) print " cfg->addObsolete(\"%s\");" % (name)
if len(setting)>0: if len(setting) > 0:
print "#else" print "#else"
print " cfg->addDisabled(\"%s\");" % (name) print " cfg->addDisabled(\"%s\");" % (name)
print "#endif" print "#endif"
def parseGroups(node): def parseGroups(node):
name = node.getAttribute('name') name = node.getAttribute('name')
doc = node.getAttribute('docs') doc = node.getAttribute('docs')
print " //---------------------------------------------------------------------------"; print "%s%s" % (" //-----------------------------------------",
print " cfg->addInfo(\"%s\",\"%s\");" % (name,doc) "----------------------------------")
print " //---------------------------------------------------------------------------"; print " cfg->addInfo(\"%s\",\"%s\");" % (name, doc)
print "%s%s" % (" //-----------------------------------------",
"----------------------------------")
print print
for n in node.childNodes: for n in node.childNodes:
if n.nodeType == Node.ELEMENT_NODE: if n.nodeType == Node.ELEMENT_NODE:
parseOption(n) parseOption(n)
def parseGroupCDocs(node):
for n in node.childNodes:
if n.nodeType == Node.ELEMENT_NODE:
type = n.getAttribute('type')
name = n.getAttribute('id')
docC = prepCDocs(n);
if type != 'obsolete':
print " doc->add("
print " \"%s\"," % (name)
rng = len(docC)
for i in range(rng):
line = docC[i]
if i != rng - 1: # since we go from 0 to rng-1
print " \"%s\\n\"" % (line)
else:
print " \"%s\"" % (line)
print " );"
def parseOptionDoc(node, first):
# Handling part for documentation
name = node.getAttribute('id')
type = node.getAttribute('type')
format = node.getAttribute('format')
defval = node.getAttribute('defval')
adefval = node.getAttribute('altdefval')
depends = node.getAttribute('depends')
setting = node.getAttribute('setting')
doc = ""
if (type != 'obsolete'):
for n in node.childNodes:
if (n.nodeName == "docs"):
if (n.getAttribute('documentation') != "0"):
if n.nodeType == Node.ELEMENT_NODE:
doc += parseDocs(n)
if (first):
print " \\anchor cfg_%s" % (name.lower())
print "<dl>"
print ""
print "<dt>\\c %s <dd>" % (name)
else:
print " \\anchor cfg_%s" % (name.lower())
print "<dt>\\c %s <dd>" % (name)
print " \\addindex %s" % (name)
print doc
if (type == 'enum'):
values = collectValues(node)
print ""
print "Possible values are: "
rng = len(values)
for i in range(rng):
val = values[i]
if i == rng - 2:
print "%s and " % (val)
elif i == rng - 1:
print "%s." % (val)
else:
print "%s, " % (val)
if (defval != ""):
print ""
print "The default value is: <code>%s</code>." % (defval)
print ""
elif (type == 'int'):
minval = node.getAttribute('minval')
maxval = node.getAttribute('maxval')
print ""
print "%s: %s%s%s, %s: %s%s%s, %s: %s%s%s." % (
" Minimum value", "<code>", minval, "</code>",
"maximum value", "<code>", maxval, "</code>",
"default value", "<code>", defval, "</code>")
print ""
elif (type == 'bool'):
print ""
if (node.hasAttribute('altdefval')):
print "Default value is system dependent."
else:
print "The default value is: <code>%s</code>." % (
"YES" if (defval == "1") else "NO")
print ""
elif (type == 'list'):
if format == 'string':
values = collectValues(node)
rng = len(values)
for i in range(rng):
val = values[i]
if i == rng - 2:
print "%s and " % (val)
elif i == rng - 1:
print "%s." % (val)
else:
print "%s, " % (val)
print ""
elif (type == 'string'):
if format == 'dir':
if defval != '':
print "The default directory is: <code>%s</code>." % (
defval)
elif format == 'file':
abspath = node.getAttribute('abspath')
if defval != '':
if abspath != '1':
print "The default file is: <code>%s</code>." % (
defval)
else:
print "%s: %s%s%s." % (
"The default file (with absolute path) is",
"<code>",defval,"</code>")
else:
if abspath == '1':
print "The file has to be specified with full path."
else: # format == 'string':
if defval != '':
print "The default value is: <code>%s</code>." % (
defval)
print ""
# depends handling
if (node.hasAttribute('depends')):
depends = node.getAttribute('depends')
print "%s \\ref cfg_%s \"%s\" is set to \\c YES." % (
"This tag requires that the tag", depends.lower(), depends.upper())
return False
def parseGroupsDoc(node):
name = node.getAttribute('name')
doc = node.getAttribute('docs')
print "\section config_%s %s" % (name.lower(), doc)
# Start of list has been moved to the first option for better
# anchor placement
# print "<dl>"
# print ""
first = True
for n in node.childNodes:
if n.nodeType == Node.ELEMENT_NODE:
first = parseOptionDoc(n, first)
if (not first):
print "</dl>"
def parseGroupsList(node, commandsList):
list = ()
for n in node.childNodes:
if n.nodeType == Node.ELEMENT_NODE:
type = n.getAttribute('type')
if type != 'obsolete':
commandsList = commandsList + (n.getAttribute('id'),)
return commandsList
def parseDocs(node):
doc = ""
for n in node.childNodes:
if n.nodeType == Node.TEXT_NODE:
doc += n.nodeValue.strip()
if n.nodeType == Node.CDATA_SECTION_NODE:
doc += n.nodeValue.rstrip("\r\n ").lstrip("\r\n")
#doc += "<br>"
return doc
def parseHeaderDoc(node):
doc = ""
for n in node.childNodes:
if n.nodeType == Node.ELEMENT_NODE:
if (n.nodeName == "docs"):
if (n.getAttribute('documentation') != "0"):
doc += parseDocs(n)
print doc
def parseFooterDoc(node):
doc = ""
for n in node.childNodes:
if n.nodeType == Node.ELEMENT_NODE:
if (n.nodeName == "docs"):
if (n.getAttribute('documentation') != "0"):
doc += parseDocs(n)
print doc
def main(): def main():
doc = xml.dom.minidom.parse(sys.argv[1]) if len(sys.argv)<3 or (not sys.argv[1] in ['-doc','-cpp','-wiz']):
sys.exit('Usage: %s -doc|-cpp|-wiz config.xml' % sys.argv[0])
try:
doc = xml.dom.minidom.parse(sys.argv[2])
except Exception as inst:
print >> sys.stderr
print >> sys.stderr, inst
print >> sys.stderr
sys.exit(1)
elem = doc.documentElement elem = doc.documentElement
if (sys.argv[1] == "-doc"):
print "/* WARNING: This file is generated!" print "/* WARNING: This file is generated!"
print " * Do not edit this file, but edit config.xml instead and run" print " * Do not edit this file, but edit config.xml instead and run"
print " * python configgen.py to regenerate this file!" print " * python configgen.py -doc config.xml to regenerate this file!"
print " */"
# process header
for n in elem.childNodes:
if n.nodeType == Node.ELEMENT_NODE:
if (n.nodeName == "header"):
parseHeaderDoc(n)
# generate list with all commands
commandsList = ()
for n in elem.childNodes:
if n.nodeType == Node.ELEMENT_NODE:
if (n.nodeName == "group"):
commandsList = parseGroupsList(n, commandsList)
print "\\secreflist"
for x in sorted(commandsList):
print "\\refitem cfg_%s %s" % (x.lower(), x)
print "\\endsecreflist"
# process groups and options
for n in elem.childNodes:
if n.nodeType == Node.ELEMENT_NODE:
if (n.nodeName == "group"):
parseGroupsDoc(n)
# process footers
for n in elem.childNodes:
if n.nodeType == Node.ELEMENT_NODE:
if (n.nodeName == "footer"):
parseFooterDoc(n)
elif (sys.argv[1] == "-cpp"):
print "/* WARNING: This file is generated!"
print " * Do not edit this file, but edit config.xml instead and run"
print " * python configgen.py -cpp config.xml to regenerate this file!"
print " */" print " */"
print "" print ""
print "#include \"configoptions.h\"" print "#include \"configoptions.h\""
...@@ -138,11 +573,35 @@ def main(): ...@@ -138,11 +573,35 @@ def main():
print " ConfigInt *ci;" print " ConfigInt *ci;"
print " ConfigBool *cb;" print " ConfigBool *cb;"
print "" print ""
# process header
for n in elem.childNodes:
if n.nodeType == Node.ELEMENT_NODE:
if (n.nodeName == "header"):
parseHeader(n,'cfg')
for n in elem.childNodes: for n in elem.childNodes:
if n.nodeType == Node.ELEMENT_NODE: if n.nodeType == Node.ELEMENT_NODE:
if (n.nodeName == "group"):
parseGroups(n) parseGroups(n)
print "}" print "}"
elif (sys.argv[1] == "-wiz"):
print "/* WARNING: This file is generated!"
print " * Do not edit this file, but edit config.xml instead and run"
print " * python configgen.py -wiz config.xml to regenerate this file!"
print " */"
print "#include \"configdoc.h\""
print "#include \"docintf.h\""
print ""
print "void addConfigDocs(DocIntf *doc)"
print "{"
for n in elem.childNodes:
if n.nodeType == Node.ELEMENT_NODE:
if (n.nodeName == "header"):
parseHeader(n,'doc')
for n in elem.childNodes:
if n.nodeType == Node.ELEMENT_NODE:
if (n.nodeName == "group"):
parseGroupCDocs(n)
print "}"
if __name__ == '__main__': if __name__ == '__main__':
main() main()
This source diff could not be displayed because it is too large. You can view the blob instead.
/****************************************************************************** /******************************************************************************
*
*
*
* *
* Copyright (C) 1997-2013 by Dimitri van Heesch. * Copyright (C) 1997-2013 by Dimitri van Heesch.
* *
......
...@@ -176,7 +176,6 @@ static QDict<FileDef> g_usingDeclarations(1009); // used classes ...@@ -176,7 +176,6 @@ static QDict<FileDef> g_usingDeclarations(1009); // used classes
static FileStorage *g_storage = 0; static FileStorage *g_storage = 0;
static bool g_successfulRun = FALSE; static bool g_successfulRun = FALSE;
static bool g_dumpSymbolMap = FALSE; static bool g_dumpSymbolMap = FALSE;
static bool g_dumpConfigAsXML = FALSE;
void clearAll() void clearAll()
{ {
...@@ -9756,18 +9755,6 @@ static void dumpSymbolMap() ...@@ -9756,18 +9755,6 @@ static void dumpSymbolMap()
} }
} }
//----------------------------------------------------------------------------
void dumpConfigAsXML()
{
QFile f("config.xml");
if (f.open(IO_WriteOnly))
{
FTextStream t(&f);
Config::instance()->writeXML(t);
}
}
//---------------------------------------------------------------------------- //----------------------------------------------------------------------------
// print the usage of doxygen // print the usage of doxygen
...@@ -10184,9 +10171,6 @@ void readConfiguration(int argc, char **argv) ...@@ -10184,9 +10171,6 @@ void readConfiguration(int argc, char **argv)
case 'm': case 'm':
g_dumpSymbolMap = TRUE; g_dumpSymbolMap = TRUE;
break; break;
case 'x':
g_dumpConfigAsXML = TRUE;
break;
case '-': case '-':
if (qstrcmp(&argv[optind][2],"help")==0) if (qstrcmp(&argv[optind][2],"help")==0)
{ {
...@@ -10221,18 +10205,8 @@ void readConfiguration(int argc, char **argv) ...@@ -10221,18 +10205,8 @@ void readConfiguration(int argc, char **argv)
Config::instance()->init(); Config::instance()->init();
if (genConfig) if (genConfig)
{
if (g_dumpConfigAsXML)
{
checkConfiguration();
generateConfigFile(configName,shortList);
dumpConfigAsXML();
exit(0);
}
else
{ {
generateConfigFile(configName,shortList); generateConfigFile(configName,shortList);
}
cleanUpDoxygen(); cleanUpDoxygen();
exit(0); exit(0);
} }
......
...@@ -47,6 +47,6 @@ sub GenerateDep { ...@@ -47,6 +47,6 @@ sub GenerateDep {
#$ GenerateDep("config.cpp","config.l"); #$ GenerateDep("config.cpp","config.l");
$(LEX) -PconfigYY -t config.l >config.cpp $(LEX) -PconfigYY -t config.l >config.cpp
configoptions.cpp: config.xml configoptions.cpp: config.xml configgen.py
python configgen.py config.xml >configoptions.cpp python configgen.py -cpp config.xml >configoptions.cpp
<?xml version="1.0" encoding="Windows-1252"?> <?xml version="1.0" encoding="Windows-1252"?>
<VisualStudioProject <VisualStudioProject
ProjectType="Visual C++" ProjectType="Visual C++"
Version="9.00" Version="9,00"
Name="doxywizard" Name="doxywizard"
ProjectGUID="{77C9C2D3-EA3F-3D59-8B4C-0ED852890172}" ProjectGUID="{77C9C2D3-EA3F-3D59-8B4C-0ED852890172}"
Keyword="Qt4VSv1.0" Keyword="Qt4VSv1.0"
...@@ -45,7 +45,7 @@ ...@@ -45,7 +45,7 @@
Name="VCCLCompilerTool" Name="VCCLCompilerTool"
AdditionalOptions="-Zm200 -w34100 -w34189 -Zm200 -w34100 -w34189 -w34100 -w34189" AdditionalOptions="-Zm200 -w34100 -w34189 -Zm200 -w34100 -w34189 -w34100 -w34189"
Optimization="4" Optimization="4"
AdditionalIncludeDirectories="&quot;..\..\..\Qt\4.4.3\include\QtCore&quot;,&quot;..\..\..\Qt\4.4.3\include\QtCore&quot;,&quot;..\..\..\Qt\4.4.3\include\QtGui&quot;,&quot;..\..\..\Qt\4.4.3\include\QtGui&quot;,&quot;..\..\..\Qt\4.4.3\include\QtXml&quot;,&quot;..\..\..\Qt\4.4.3\include\QtXml&quot;,&quot;..\..\..\Qt\4.4.3\include&quot;,&quot;..\addon\doxywizard&quot;,&quot;c:\Qt\4.4.3\include\ActiveQt&quot;,&quot;..\addon\doxywizard\moc&quot;,&quot;..\addon\doxywizard&quot;,&quot;.&quot;,..\..\..\Qt\4.4.3\mkspecs\win32-msvc2005" AdditionalIncludeDirectories="&quot;$(QT_DIR)\include\QtCore&quot;,&quot;$(QT_DIR)\include\QtCore&quot;,&quot;$(QT_DIR)\include\QtGui&quot;,&quot;$(QT_DIR)\include\QtGui&quot;,&quot;$(QT_DIR)\include\QtXml&quot;,&quot;$(QT_DIR)\include\QtXml&quot;,&quot;$(QT_DIR)\include&quot;,&quot;..\addon\doxywizard&quot;,&quot;c:\Qt\4.4.3\include\ActiveQt&quot;,&quot;..\addon\doxywizard\moc&quot;,&quot;..\addon\doxywizard&quot;,&quot;.&quot;,$(QT_DIR)\mkspecs\win32-msvc2005"
PreprocessorDefinitions="_WINDOWS,UNICODE,WIN32,QT_LARGEFILE_SUPPORT,QT_NO_CAST_FROM_ASCII,QT_NO_CAST_TO_ASCII,QT_XML_LIB,QT_GUI_LIB,QT_CORE_LIB,QT_THREAD_SUPPORT" PreprocessorDefinitions="_WINDOWS,UNICODE,WIN32,QT_LARGEFILE_SUPPORT,QT_NO_CAST_FROM_ASCII,QT_NO_CAST_TO_ASCII,QT_XML_LIB,QT_GUI_LIB,QT_CORE_LIB,QT_THREAD_SUPPORT"
GeneratePreprocessedFile="0" GeneratePreprocessedFile="0"
ExceptionHandling="1" ExceptionHandling="1"
...@@ -138,7 +138,7 @@ ...@@ -138,7 +138,7 @@
Name="VCCLCompilerTool" Name="VCCLCompilerTool"
AdditionalOptions="-Zm200 -w34100 -w34189 -Zm200 -w34100 -w34189 -w34100 -w34189" AdditionalOptions="-Zm200 -w34100 -w34189 -Zm200 -w34100 -w34189 -w34100 -w34189"
Optimization="2" Optimization="2"
AdditionalIncludeDirectories="&quot;..\..\..\Qt\4.4.3\include\QtCore&quot;,&quot;..\..\..\Qt\4.4.3\include\QtCore&quot;,&quot;..\..\..\Qt\4.4.3\include\QtGui&quot;,&quot;..\..\..\Qt\4.4.3\include\QtGui&quot;,&quot;..\..\..\Qt\4.4.3\include\QtXml&quot;,&quot;..\..\..\Qt\4.4.3\include\QtXml&quot;,&quot;..\..\..\Qt\4.4.3\include&quot;,&quot;..\addon\doxywizard&quot;,&quot;c:\Qt\4.4.3\include\ActiveQt&quot;,&quot;..\addon\doxywizard\moc&quot;,&quot;..\addon\doxywizard&quot;,&quot;.&quot;,..\..\..\Qt\4.4.3\mkspecs\win32-msvc2008" AdditionalIncludeDirectories="&quot;$(QT_DIR)\include\QtCore&quot;,&quot;$(QT_DIR)\include\QtCore&quot;,&quot;$(QT_DIR)\include\QtGui&quot;,&quot;$(QT_DIR)\include\QtGui&quot;,&quot;$(QT_DIR)\include\QtXml&quot;,&quot;$(QT_DIR)\include\QtXml&quot;,&quot;$(QT_DIR)\include&quot;,&quot;..\addon\doxywizard&quot;,&quot;c:\Qt\4.4.3\include\ActiveQt&quot;,&quot;..\addon\doxywizard\moc&quot;,&quot;..\addon\doxywizard&quot;,&quot;.&quot;,$(QT_DIR)\mkspecs\win32-msvc2008"
PreprocessorDefinitions="QT_NO_DEBUG,NDEBUG,_WINDOWS,UNICODE,WIN32,QT_LARGEFILE_SUPPORT,QT_NO_CAST_FROM_ASCII,QT_NO_CAST_TO_ASCII,QT_NO_DEBUG,QT_XML_LIB,QT_GUI_LIB,QT_CORE_LIB,QT_THREAD_SUPPORT,NDEBUG" PreprocessorDefinitions="QT_NO_DEBUG,NDEBUG,_WINDOWS,UNICODE,WIN32,QT_LARGEFILE_SUPPORT,QT_NO_CAST_FROM_ASCII,QT_NO_CAST_TO_ASCII,QT_NO_DEBUG,QT_XML_LIB,QT_GUI_LIB,QT_CORE_LIB,QT_THREAD_SUPPORT,NDEBUG"
GeneratePreprocessedFile="0" GeneratePreprocessedFile="0"
ExceptionHandling="1" ExceptionHandling="1"
...@@ -264,8 +264,8 @@ ...@@ -264,8 +264,8 @@
<Tool <Tool
Name="VCCustomBuildTool" Name="VCCustomBuildTool"
Description="MOC ..\addon\doxywizard\doxywizard.h" Description="MOC ..\addon\doxywizard\doxywizard.h"
CommandLine="C:\Qt\4.4.3\bin\moc.exe -DUNICODE -DWIN32 -DQT_LARGEFILE_SUPPORT -DQT_NO_CAST_FROM_ASCII -DQT_NO_CAST_TO_ASCII -DQT_XML_LIB -DQT_GUI_LIB -DQT_CORE_LIB -DQT_THREAD_SUPPORT -I&quot;..\..\..\Qt\4.4.3\include\QtCore&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtCore&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtGui&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtGui&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtXml&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtXml&quot; -I&quot;..\..\..\Qt\4.4.3\include&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;c:\Qt\4.4.3\include\ActiveQt&quot; -I&quot;..\addon\doxywizard\moc&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;.&quot; -I..\..\..\Qt\4.4.3\mkspecs\win32-msvc2005 -D_MSC_VER=1400 -DWIN32 ..\addon\doxywizard\doxywizard.h -o moc\moc_doxywizard.cpp&#x0D;&#x0A;" CommandLine="$(QT_DIR)\bin\moc.exe -DUNICODE -DWIN32 -DQT_LARGEFILE_SUPPORT -DQT_NO_CAST_FROM_ASCII -DQT_NO_CAST_TO_ASCII -DQT_XML_LIB -DQT_GUI_LIB -DQT_CORE_LIB -DQT_THREAD_SUPPORT -I&quot;$(QT_DIR)\include\QtCore&quot; -I&quot;$(QT_DIR)\include\QtCore&quot; -I&quot;$(QT_DIR)\include\QtGui&quot; -I&quot;$(QT_DIR)\include\QtGui&quot; -I&quot;$(QT_DIR)\include\QtXml&quot; -I&quot;$(QT_DIR)\include\QtXml&quot; -I&quot;$(QT_DIR)\include&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;c:\Qt\4.4.3\include\ActiveQt&quot; -I&quot;..\addon\doxywizard\moc&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;.&quot; -I$(QT_DIR)\mkspecs\win32-msvc2005 -D_MSC_VER=1400 -DWIN32 ..\addon\doxywizard\doxywizard.h -o moc\moc_doxywizard.cpp&#x0D;&#x0A;"
AdditionalDependencies="..\addon\doxywizard\doxywizard.h;C:\Qt\4.4.3\bin\moc.exe" AdditionalDependencies="..\addon\doxywizard\doxywizard.h;$(QT_DIR)\bin\moc.exe"
Outputs="moc\moc_doxywizard.cpp" Outputs="moc\moc_doxywizard.cpp"
/> />
</FileConfiguration> </FileConfiguration>
...@@ -275,8 +275,8 @@ ...@@ -275,8 +275,8 @@
<Tool <Tool
Name="VCCustomBuildTool" Name="VCCustomBuildTool"
Description="MOC ..\addon\doxywizard\doxywizard.h" Description="MOC ..\addon\doxywizard\doxywizard.h"
CommandLine="C:\Qt\4.4.3\bin\moc.exe -DUNICODE -DWIN32 -DQT_LARGEFILE_SUPPORT -DQT_NO_CAST_FROM_ASCII -DQT_NO_CAST_TO_ASCII -DQT_NO_DEBUG -DQT_XML_LIB -DQT_GUI_LIB -DQT_CORE_LIB -DQT_THREAD_SUPPORT -I&quot;..\..\..\Qt\4.4.3\include\QtCore&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtCore&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtGui&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtGui&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtXml&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtXml&quot; -I&quot;..\..\..\Qt\4.4.3\include&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;c:\Qt\4.4.3\include\ActiveQt&quot; -I&quot;..\addon\doxywizard\moc&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;.&quot; -I..\..\..\Qt\4.4.3\mkspecs\win32-msvc2005 -D_MSC_VER=1400 -DWIN32 ..\addon\doxywizard\doxywizard.h -o moc\moc_doxywizard.cpp&#x0D;&#x0A;" CommandLine="$(QT_DIR)\bin\moc.exe -DUNICODE -DWIN32 -DQT_LARGEFILE_SUPPORT -DQT_NO_CAST_FROM_ASCII -DQT_NO_CAST_TO_ASCII -DQT_NO_DEBUG -DQT_XML_LIB -DQT_GUI_LIB -DQT_CORE_LIB -DQT_THREAD_SUPPORT -I&quot;$(QT_DIR)\include\QtCore&quot; -I&quot;$(QT_DIR)\include\QtCore&quot; -I&quot;$(QT_DIR)\include\QtGui&quot; -I&quot;$(QT_DIR)\include\QtGui&quot; -I&quot;$(QT_DIR)\include\QtXml&quot; -I&quot;$(QT_DIR)\include\QtXml&quot; -I&quot;$(QT_DIR)\include&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;c:\Qt\4.4.3\include\ActiveQt&quot; -I&quot;..\addon\doxywizard\moc&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;.&quot; -I$(QT_DIR)\mkspecs\win32-msvc2005 -D_MSC_VER=1400 -DWIN32 ..\addon\doxywizard\doxywizard.h -o moc\moc_doxywizard.cpp&#x0D;&#x0A;"
AdditionalDependencies="..\addon\doxywizard\doxywizard.h;C:\Qt\4.4.3\bin\moc.exe" AdditionalDependencies="..\addon\doxywizard\doxywizard.h;$(QT_DIR)\bin\moc.exe"
Outputs="moc\moc_doxywizard.cpp" Outputs="moc\moc_doxywizard.cpp"
/> />
</FileConfiguration> </FileConfiguration>
...@@ -290,8 +290,8 @@ ...@@ -290,8 +290,8 @@
<Tool <Tool
Name="VCCustomBuildTool" Name="VCCustomBuildTool"
Description="MOC ..\addon\doxywizard\expert.h" Description="MOC ..\addon\doxywizard\expert.h"
CommandLine="C:\Qt\4.4.3\bin\moc.exe -DUNICODE -DWIN32 -DQT_LARGEFILE_SUPPORT -DQT_NO_CAST_FROM_ASCII -DQT_NO_CAST_TO_ASCII -DQT_XML_LIB -DQT_GUI_LIB -DQT_CORE_LIB -DQT_THREAD_SUPPORT -I&quot;..\..\..\Qt\4.4.3\include\QtCore&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtCore&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtGui&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtGui&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtXml&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtXml&quot; -I&quot;..\..\..\Qt\4.4.3\include&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;c:\Qt\4.4.3\include\ActiveQt&quot; -I&quot;..\addon\doxywizard\moc&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;.&quot; -I..\..\..\Qt\4.4.3\mkspecs\win32-msvc2005 -D_MSC_VER=1400 -DWIN32 ..\addon\doxywizard\expert.h -o moc\moc_expert.cpp&#x0D;&#x0A;" CommandLine="$(QT_DIR)\bin\moc.exe -DUNICODE -DWIN32 -DQT_LARGEFILE_SUPPORT -DQT_NO_CAST_FROM_ASCII -DQT_NO_CAST_TO_ASCII -DQT_XML_LIB -DQT_GUI_LIB -DQT_CORE_LIB -DQT_THREAD_SUPPORT -I&quot;$(QT_DIR)\include\QtCore&quot; -I&quot;$(QT_DIR)\include\QtCore&quot; -I&quot;$(QT_DIR)\include\QtGui&quot; -I&quot;$(QT_DIR)\include\QtGui&quot; -I&quot;$(QT_DIR)\include\QtXml&quot; -I&quot;$(QT_DIR)\include\QtXml&quot; -I&quot;$(QT_DIR)\include&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;c:\Qt\4.4.3\include\ActiveQt&quot; -I&quot;..\addon\doxywizard\moc&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;.&quot; -I$(QT_DIR)\mkspecs\win32-msvc2005 -D_MSC_VER=1400 -DWIN32 ..\addon\doxywizard\expert.h -o moc\moc_expert.cpp&#x0D;&#x0A;"
AdditionalDependencies="..\addon\doxywizard\expert.h;C:\Qt\4.4.3\bin\moc.exe" AdditionalDependencies="..\addon\doxywizard\expert.h;$(QT_DIR)\bin\moc.exe"
Outputs="moc\moc_expert.cpp" Outputs="moc\moc_expert.cpp"
/> />
</FileConfiguration> </FileConfiguration>
...@@ -301,8 +301,8 @@ ...@@ -301,8 +301,8 @@
<Tool <Tool
Name="VCCustomBuildTool" Name="VCCustomBuildTool"
Description="MOC ..\addon\doxywizard\expert.h" Description="MOC ..\addon\doxywizard\expert.h"
CommandLine="C:\Qt\4.4.3\bin\moc.exe -DUNICODE -DWIN32 -DQT_LARGEFILE_SUPPORT -DQT_NO_CAST_FROM_ASCII -DQT_NO_CAST_TO_ASCII -DQT_NO_DEBUG -DQT_XML_LIB -DQT_GUI_LIB -DQT_CORE_LIB -DQT_THREAD_SUPPORT -I&quot;..\..\..\Qt\4.4.3\include\QtCore&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtCore&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtGui&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtGui&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtXml&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtXml&quot; -I&quot;..\..\..\Qt\4.4.3\include&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;c:\Qt\4.4.3\include\ActiveQt&quot; -I&quot;..\addon\doxywizard\moc&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;.&quot; -I..\..\..\Qt\4.4.3\mkspecs\win32-msvc2005 -D_MSC_VER=1400 -DWIN32 ..\addon\doxywizard\expert.h -o moc\moc_expert.cpp&#x0D;&#x0A;" CommandLine="$(QT_DIR)\bin\moc.exe -DUNICODE -DWIN32 -DQT_LARGEFILE_SUPPORT -DQT_NO_CAST_FROM_ASCII -DQT_NO_CAST_TO_ASCII -DQT_NO_DEBUG -DQT_XML_LIB -DQT_GUI_LIB -DQT_CORE_LIB -DQT_THREAD_SUPPORT -I&quot;$(QT_DIR)\include\QtCore&quot; -I&quot;$(QT_DIR)\include\QtCore&quot; -I&quot;$(QT_DIR)\include\QtGui&quot; -I&quot;$(QT_DIR)\include\QtGui&quot; -I&quot;$(QT_DIR)\include\QtXml&quot; -I&quot;$(QT_DIR)\include\QtXml&quot; -I&quot;$(QT_DIR)\include&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;c:\Qt\4.4.3\include\ActiveQt&quot; -I&quot;..\addon\doxywizard\moc&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;.&quot; -I$(QT_DIR)\mkspecs\win32-msvc2005 -D_MSC_VER=1400 -DWIN32 ..\addon\doxywizard\expert.h -o moc\moc_expert.cpp&#x0D;&#x0A;"
AdditionalDependencies="..\addon\doxywizard\expert.h;C:\Qt\4.4.3\bin\moc.exe" AdditionalDependencies="..\addon\doxywizard\expert.h;$(QT_DIR)\bin\moc.exe"
Outputs="moc\moc_expert.cpp" Outputs="moc\moc_expert.cpp"
/> />
</FileConfiguration> </FileConfiguration>
...@@ -316,8 +316,8 @@ ...@@ -316,8 +316,8 @@
<Tool <Tool
Name="VCCustomBuildTool" Name="VCCustomBuildTool"
Description="MOC ..\addon\doxywizard\helplabel.h" Description="MOC ..\addon\doxywizard\helplabel.h"
CommandLine="C:\Qt\4.4.3\bin\moc.exe -DUNICODE -DWIN32 -DQT_LARGEFILE_SUPPORT -DQT_NO_CAST_FROM_ASCII -DQT_NO_CAST_TO_ASCII -DQT_XML_LIB -DQT_GUI_LIB -DQT_CORE_LIB -DQT_THREAD_SUPPORT -I&quot;..\..\..\Qt\4.4.3\include\QtCore&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtCore&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtGui&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtGui&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtXml&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtXml&quot; -I&quot;..\..\..\Qt\4.4.3\include&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;c:\Qt\4.4.3\include\ActiveQt&quot; -I&quot;..\addon\doxywizard\moc&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;.&quot; -I..\..\..\Qt\4.4.3\mkspecs\win32-msvc2005 -D_MSC_VER=1400 -DWIN32 ..\addon\doxywizard\helplabel.h -o moc\moc_helplabel.cpp&#x0D;&#x0A;" CommandLine="$(QT_DIR)\bin\moc.exe -DUNICODE -DWIN32 -DQT_LARGEFILE_SUPPORT -DQT_NO_CAST_FROM_ASCII -DQT_NO_CAST_TO_ASCII -DQT_XML_LIB -DQT_GUI_LIB -DQT_CORE_LIB -DQT_THREAD_SUPPORT -I&quot;$(QT_DIR)\include\QtCore&quot; -I&quot;$(QT_DIR)\include\QtCore&quot; -I&quot;$(QT_DIR)\include\QtGui&quot; -I&quot;$(QT_DIR)\include\QtGui&quot; -I&quot;$(QT_DIR)\include\QtXml&quot; -I&quot;$(QT_DIR)\include\QtXml&quot; -I&quot;$(QT_DIR)\include&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;c:\Qt\4.4.3\include\ActiveQt&quot; -I&quot;..\addon\doxywizard\moc&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;.&quot; -I$(QT_DIR)\mkspecs\win32-msvc2005 -D_MSC_VER=1400 -DWIN32 ..\addon\doxywizard\helplabel.h -o moc\moc_helplabel.cpp&#x0D;&#x0A;"
AdditionalDependencies="..\addon\doxywizard\helplabel.h;C:\Qt\4.4.3\bin\moc.exe" AdditionalDependencies="..\addon\doxywizard\helplabel.h;$(QT_DIR)\bin\moc.exe"
Outputs="moc\moc_helplabel.cpp" Outputs="moc\moc_helplabel.cpp"
/> />
</FileConfiguration> </FileConfiguration>
...@@ -327,8 +327,8 @@ ...@@ -327,8 +327,8 @@
<Tool <Tool
Name="VCCustomBuildTool" Name="VCCustomBuildTool"
Description="MOC ..\addon\doxywizard\helplabel.h" Description="MOC ..\addon\doxywizard\helplabel.h"
CommandLine="C:\Qt\4.4.3\bin\moc.exe -DUNICODE -DWIN32 -DQT_LARGEFILE_SUPPORT -DQT_NO_CAST_FROM_ASCII -DQT_NO_CAST_TO_ASCII -DQT_NO_DEBUG -DQT_XML_LIB -DQT_GUI_LIB -DQT_CORE_LIB -DQT_THREAD_SUPPORT -I&quot;..\..\..\Qt\4.4.3\include\QtCore&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtCore&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtGui&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtGui&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtXml&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtXml&quot; -I&quot;..\..\..\Qt\4.4.3\include&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;c:\Qt\4.4.3\include\ActiveQt&quot; -I&quot;..\addon\doxywizard\moc&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;.&quot; -I..\..\..\Qt\4.4.3\mkspecs\win32-msvc2005 -D_MSC_VER=1400 -DWIN32 ..\addon\doxywizard\helplabel.h -o moc\moc_helplabel.cpp&#x0D;&#x0A;" CommandLine="$(QT_DIR)\bin\moc.exe -DUNICODE -DWIN32 -DQT_LARGEFILE_SUPPORT -DQT_NO_CAST_FROM_ASCII -DQT_NO_CAST_TO_ASCII -DQT_NO_DEBUG -DQT_XML_LIB -DQT_GUI_LIB -DQT_CORE_LIB -DQT_THREAD_SUPPORT -I&quot;$(QT_DIR)\include\QtCore&quot; -I&quot;$(QT_DIR)\include\QtCore&quot; -I&quot;$(QT_DIR)\include\QtGui&quot; -I&quot;$(QT_DIR)\include\QtGui&quot; -I&quot;$(QT_DIR)\include\QtXml&quot; -I&quot;$(QT_DIR)\include\QtXml&quot; -I&quot;$(QT_DIR)\include&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;c:\Qt\4.4.3\include\ActiveQt&quot; -I&quot;..\addon\doxywizard\moc&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;.&quot; -I$(QT_DIR)\mkspecs\win32-msvc2005 -D_MSC_VER=1400 -DWIN32 ..\addon\doxywizard\helplabel.h -o moc\moc_helplabel.cpp&#x0D;&#x0A;"
AdditionalDependencies="..\addon\doxywizard\helplabel.h;C:\Qt\4.4.3\bin\moc.exe" AdditionalDependencies="..\addon\doxywizard\helplabel.h;$(QT_DIR)\bin\moc.exe"
Outputs="moc\moc_helplabel.cpp" Outputs="moc\moc_helplabel.cpp"
/> />
</FileConfiguration> </FileConfiguration>
...@@ -342,8 +342,8 @@ ...@@ -342,8 +342,8 @@
<Tool <Tool
Name="VCCustomBuildTool" Name="VCCustomBuildTool"
Description="MOC ..\addon\doxywizard\inputbool.h" Description="MOC ..\addon\doxywizard\inputbool.h"
CommandLine="C:\Qt\4.4.3\bin\moc.exe -DUNICODE -DWIN32 -DQT_LARGEFILE_SUPPORT -DQT_NO_CAST_FROM_ASCII -DQT_NO_CAST_TO_ASCII -DQT_XML_LIB -DQT_GUI_LIB -DQT_CORE_LIB -DQT_THREAD_SUPPORT -I&quot;..\..\..\Qt\4.4.3\include\QtCore&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtCore&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtGui&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtGui&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtXml&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtXml&quot; -I&quot;..\..\..\Qt\4.4.3\include&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;c:\Qt\4.4.3\include\ActiveQt&quot; -I&quot;..\addon\doxywizard\moc&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;.&quot; -I..\..\..\Qt\4.4.3\mkspecs\win32-msvc2005 -D_MSC_VER=1400 -DWIN32 ..\addon\doxywizard\inputbool.h -o moc\moc_inputbool.cpp&#x0D;&#x0A;" CommandLine="$(QT_DIR)\bin\moc.exe -DUNICODE -DWIN32 -DQT_LARGEFILE_SUPPORT -DQT_NO_CAST_FROM_ASCII -DQT_NO_CAST_TO_ASCII -DQT_XML_LIB -DQT_GUI_LIB -DQT_CORE_LIB -DQT_THREAD_SUPPORT -I&quot;$(QT_DIR)\include\QtCore&quot; -I&quot;$(QT_DIR)\include\QtCore&quot; -I&quot;$(QT_DIR)\include\QtGui&quot; -I&quot;$(QT_DIR)\include\QtGui&quot; -I&quot;$(QT_DIR)\include\QtXml&quot; -I&quot;$(QT_DIR)\include\QtXml&quot; -I&quot;$(QT_DIR)\include&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;c:\Qt\4.4.3\include\ActiveQt&quot; -I&quot;..\addon\doxywizard\moc&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;.&quot; -I$(QT_DIR)\mkspecs\win32-msvc2005 -D_MSC_VER=1400 -DWIN32 ..\addon\doxywizard\inputbool.h -o moc\moc_inputbool.cpp&#x0D;&#x0A;"
AdditionalDependencies="..\addon\doxywizard\inputbool.h;C:\Qt\4.4.3\bin\moc.exe" AdditionalDependencies="..\addon\doxywizard\inputbool.h;$(QT_DIR)\bin\moc.exe"
Outputs="moc\moc_inputbool.cpp" Outputs="moc\moc_inputbool.cpp"
/> />
</FileConfiguration> </FileConfiguration>
...@@ -353,8 +353,8 @@ ...@@ -353,8 +353,8 @@
<Tool <Tool
Name="VCCustomBuildTool" Name="VCCustomBuildTool"
Description="MOC ..\addon\doxywizard\inputbool.h" Description="MOC ..\addon\doxywizard\inputbool.h"
CommandLine="C:\Qt\4.4.3\bin\moc.exe -DUNICODE -DWIN32 -DQT_LARGEFILE_SUPPORT -DQT_NO_CAST_FROM_ASCII -DQT_NO_CAST_TO_ASCII -DQT_NO_DEBUG -DQT_XML_LIB -DQT_GUI_LIB -DQT_CORE_LIB -DQT_THREAD_SUPPORT -I&quot;..\..\..\Qt\4.4.3\include\QtCore&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtCore&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtGui&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtGui&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtXml&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtXml&quot; -I&quot;..\..\..\Qt\4.4.3\include&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;c:\Qt\4.4.3\include\ActiveQt&quot; -I&quot;..\addon\doxywizard\moc&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;.&quot; -I..\..\..\Qt\4.4.3\mkspecs\win32-msvc2005 -D_MSC_VER=1400 -DWIN32 ..\addon\doxywizard\inputbool.h -o moc\moc_inputbool.cpp&#x0D;&#x0A;" CommandLine="$(QT_DIR)\bin\moc.exe -DUNICODE -DWIN32 -DQT_LARGEFILE_SUPPORT -DQT_NO_CAST_FROM_ASCII -DQT_NO_CAST_TO_ASCII -DQT_NO_DEBUG -DQT_XML_LIB -DQT_GUI_LIB -DQT_CORE_LIB -DQT_THREAD_SUPPORT -I&quot;$(QT_DIR)\include\QtCore&quot; -I&quot;$(QT_DIR)\include\QtCore&quot; -I&quot;$(QT_DIR)\include\QtGui&quot; -I&quot;$(QT_DIR)\include\QtGui&quot; -I&quot;$(QT_DIR)\include\QtXml&quot; -I&quot;$(QT_DIR)\include\QtXml&quot; -I&quot;$(QT_DIR)\include&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;c:\Qt\4.4.3\include\ActiveQt&quot; -I&quot;..\addon\doxywizard\moc&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;.&quot; -I$(QT_DIR)\mkspecs\win32-msvc2005 -D_MSC_VER=1400 -DWIN32 ..\addon\doxywizard\inputbool.h -o moc\moc_inputbool.cpp&#x0D;&#x0A;"
AdditionalDependencies="..\addon\doxywizard\inputbool.h;C:\Qt\4.4.3\bin\moc.exe" AdditionalDependencies="..\addon\doxywizard\inputbool.h;$(QT_DIR)\bin\moc.exe"
Outputs="moc\moc_inputbool.cpp" Outputs="moc\moc_inputbool.cpp"
/> />
</FileConfiguration> </FileConfiguration>
...@@ -368,8 +368,8 @@ ...@@ -368,8 +368,8 @@
<Tool <Tool
Name="VCCustomBuildTool" Name="VCCustomBuildTool"
Description="MOC ..\addon\doxywizard\inputint.h" Description="MOC ..\addon\doxywizard\inputint.h"
CommandLine="C:\Qt\4.4.3\bin\moc.exe -DUNICODE -DWIN32 -DQT_LARGEFILE_SUPPORT -DQT_NO_CAST_FROM_ASCII -DQT_NO_CAST_TO_ASCII -DQT_XML_LIB -DQT_GUI_LIB -DQT_CORE_LIB -DQT_THREAD_SUPPORT -I&quot;..\..\..\Qt\4.4.3\include\QtCore&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtCore&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtGui&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtGui&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtXml&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtXml&quot; -I&quot;..\..\..\Qt\4.4.3\include&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;c:\Qt\4.4.3\include\ActiveQt&quot; -I&quot;..\addon\doxywizard\moc&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;.&quot; -I..\..\..\Qt\4.4.3\mkspecs\win32-msvc2005 -D_MSC_VER=1400 -DWIN32 ..\addon\doxywizard\inputint.h -o moc\moc_inputint.cpp&#x0D;&#x0A;" CommandLine="$(QT_DIR)\bin\moc.exe -DUNICODE -DWIN32 -DQT_LARGEFILE_SUPPORT -DQT_NO_CAST_FROM_ASCII -DQT_NO_CAST_TO_ASCII -DQT_XML_LIB -DQT_GUI_LIB -DQT_CORE_LIB -DQT_THREAD_SUPPORT -I&quot;$(QT_DIR)\include\QtCore&quot; -I&quot;$(QT_DIR)\include\QtCore&quot; -I&quot;$(QT_DIR)\include\QtGui&quot; -I&quot;$(QT_DIR)\include\QtGui&quot; -I&quot;$(QT_DIR)\include\QtXml&quot; -I&quot;$(QT_DIR)\include\QtXml&quot; -I&quot;$(QT_DIR)\include&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;c:\Qt\4.4.3\include\ActiveQt&quot; -I&quot;..\addon\doxywizard\moc&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;.&quot; -I$(QT_DIR)\mkspecs\win32-msvc2005 -D_MSC_VER=1400 -DWIN32 ..\addon\doxywizard\inputint.h -o moc\moc_inputint.cpp&#x0D;&#x0A;"
AdditionalDependencies="..\addon\doxywizard\inputint.h;C:\Qt\4.4.3\bin\moc.exe" AdditionalDependencies="..\addon\doxywizard\inputint.h;$(QT_DIR)\bin\moc.exe"
Outputs="moc\moc_inputint.cpp" Outputs="moc\moc_inputint.cpp"
/> />
</FileConfiguration> </FileConfiguration>
...@@ -379,8 +379,8 @@ ...@@ -379,8 +379,8 @@
<Tool <Tool
Name="VCCustomBuildTool" Name="VCCustomBuildTool"
Description="MOC ..\addon\doxywizard\inputint.h" Description="MOC ..\addon\doxywizard\inputint.h"
CommandLine="C:\Qt\4.4.3\bin\moc.exe -DUNICODE -DWIN32 -DQT_LARGEFILE_SUPPORT -DQT_NO_CAST_FROM_ASCII -DQT_NO_CAST_TO_ASCII -DQT_NO_DEBUG -DQT_XML_LIB -DQT_GUI_LIB -DQT_CORE_LIB -DQT_THREAD_SUPPORT -I&quot;..\..\..\Qt\4.4.3\include\QtCore&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtCore&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtGui&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtGui&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtXml&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtXml&quot; -I&quot;..\..\..\Qt\4.4.3\include&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;c:\Qt\4.4.3\include\ActiveQt&quot; -I&quot;..\addon\doxywizard\moc&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;.&quot; -I..\..\..\Qt\4.4.3\mkspecs\win32-msvc2005 -D_MSC_VER=1400 -DWIN32 ..\addon\doxywizard\inputint.h -o moc\moc_inputint.cpp&#x0D;&#x0A;" CommandLine="$(QT_DIR)\bin\moc.exe -DUNICODE -DWIN32 -DQT_LARGEFILE_SUPPORT -DQT_NO_CAST_FROM_ASCII -DQT_NO_CAST_TO_ASCII -DQT_NO_DEBUG -DQT_XML_LIB -DQT_GUI_LIB -DQT_CORE_LIB -DQT_THREAD_SUPPORT -I&quot;$(QT_DIR)\include\QtCore&quot; -I&quot;$(QT_DIR)\include\QtCore&quot; -I&quot;$(QT_DIR)\include\QtGui&quot; -I&quot;$(QT_DIR)\include\QtGui&quot; -I&quot;$(QT_DIR)\include\QtXml&quot; -I&quot;$(QT_DIR)\include\QtXml&quot; -I&quot;$(QT_DIR)\include&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;c:\Qt\4.4.3\include\ActiveQt&quot; -I&quot;..\addon\doxywizard\moc&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;.&quot; -I$(QT_DIR)\mkspecs\win32-msvc2005 -D_MSC_VER=1400 -DWIN32 ..\addon\doxywizard\inputint.h -o moc\moc_inputint.cpp&#x0D;&#x0A;"
AdditionalDependencies="..\addon\doxywizard\inputint.h;C:\Qt\4.4.3\bin\moc.exe" AdditionalDependencies="..\addon\doxywizard\inputint.h;$(QT_DIR)\bin\moc.exe"
Outputs="moc\moc_inputint.cpp" Outputs="moc\moc_inputint.cpp"
/> />
</FileConfiguration> </FileConfiguration>
...@@ -394,8 +394,8 @@ ...@@ -394,8 +394,8 @@
<Tool <Tool
Name="VCCustomBuildTool" Name="VCCustomBuildTool"
Description="MOC ..\addon\doxywizard\inputstring.h" Description="MOC ..\addon\doxywizard\inputstring.h"
CommandLine="C:\Qt\4.4.3\bin\moc.exe -DUNICODE -DWIN32 -DQT_LARGEFILE_SUPPORT -DQT_NO_CAST_FROM_ASCII -DQT_NO_CAST_TO_ASCII -DQT_XML_LIB -DQT_GUI_LIB -DQT_CORE_LIB -DQT_THREAD_SUPPORT -I&quot;..\..\..\Qt\4.4.3\include\QtCore&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtCore&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtGui&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtGui&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtXml&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtXml&quot; -I&quot;..\..\..\Qt\4.4.3\include&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;c:\Qt\4.4.3\include\ActiveQt&quot; -I&quot;..\addon\doxywizard\moc&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;.&quot; -I..\..\..\Qt\4.4.3\mkspecs\win32-msvc2005 -D_MSC_VER=1400 -DWIN32 ..\addon\doxywizard\inputstring.h -o moc\moc_inputstring.cpp&#x0D;&#x0A;" CommandLine="$(QT_DIR)\bin\moc.exe -DUNICODE -DWIN32 -DQT_LARGEFILE_SUPPORT -DQT_NO_CAST_FROM_ASCII -DQT_NO_CAST_TO_ASCII -DQT_XML_LIB -DQT_GUI_LIB -DQT_CORE_LIB -DQT_THREAD_SUPPORT -I&quot;$(QT_DIR)\include\QtCore&quot; -I&quot;$(QT_DIR)\include\QtCore&quot; -I&quot;$(QT_DIR)\include\QtGui&quot; -I&quot;$(QT_DIR)\include\QtGui&quot; -I&quot;$(QT_DIR)\include\QtXml&quot; -I&quot;$(QT_DIR)\include\QtXml&quot; -I&quot;$(QT_DIR)\include&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;c:\Qt\4.4.3\include\ActiveQt&quot; -I&quot;..\addon\doxywizard\moc&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;.&quot; -I$(QT_DIR)\mkspecs\win32-msvc2005 -D_MSC_VER=1400 -DWIN32 ..\addon\doxywizard\inputstring.h -o moc\moc_inputstring.cpp&#x0D;&#x0A;"
AdditionalDependencies="..\addon\doxywizard\inputstring.h;C:\Qt\4.4.3\bin\moc.exe" AdditionalDependencies="..\addon\doxywizard\inputstring.h;$(QT_DIR)\bin\moc.exe"
Outputs="moc\moc_inputstring.cpp" Outputs="moc\moc_inputstring.cpp"
/> />
</FileConfiguration> </FileConfiguration>
...@@ -405,8 +405,8 @@ ...@@ -405,8 +405,8 @@
<Tool <Tool
Name="VCCustomBuildTool" Name="VCCustomBuildTool"
Description="MOC ..\addon\doxywizard\inputstring.h" Description="MOC ..\addon\doxywizard\inputstring.h"
CommandLine="C:\Qt\4.4.3\bin\moc.exe -DUNICODE -DWIN32 -DQT_LARGEFILE_SUPPORT -DQT_NO_CAST_FROM_ASCII -DQT_NO_CAST_TO_ASCII -DQT_NO_DEBUG -DQT_XML_LIB -DQT_GUI_LIB -DQT_CORE_LIB -DQT_THREAD_SUPPORT -I&quot;..\..\..\Qt\4.4.3\include\QtCore&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtCore&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtGui&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtGui&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtXml&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtXml&quot; -I&quot;..\..\..\Qt\4.4.3\include&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;c:\Qt\4.4.3\include\ActiveQt&quot; -I&quot;..\addon\doxywizard\moc&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;.&quot; -I..\..\..\Qt\4.4.3\mkspecs\win32-msvc2005 -D_MSC_VER=1400 -DWIN32 ..\addon\doxywizard\inputstring.h -o moc\moc_inputstring.cpp&#x0D;&#x0A;" CommandLine="$(QT_DIR)\bin\moc.exe -DUNICODE -DWIN32 -DQT_LARGEFILE_SUPPORT -DQT_NO_CAST_FROM_ASCII -DQT_NO_CAST_TO_ASCII -DQT_NO_DEBUG -DQT_XML_LIB -DQT_GUI_LIB -DQT_CORE_LIB -DQT_THREAD_SUPPORT -I&quot;$(QT_DIR)\include\QtCore&quot; -I&quot;$(QT_DIR)\include\QtCore&quot; -I&quot;$(QT_DIR)\include\QtGui&quot; -I&quot;$(QT_DIR)\include\QtGui&quot; -I&quot;$(QT_DIR)\include\QtXml&quot; -I&quot;$(QT_DIR)\include\QtXml&quot; -I&quot;$(QT_DIR)\include&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;c:\Qt\4.4.3\include\ActiveQt&quot; -I&quot;..\addon\doxywizard\moc&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;.&quot; -I$(QT_DIR)\mkspecs\win32-msvc2005 -D_MSC_VER=1400 -DWIN32 ..\addon\doxywizard\inputstring.h -o moc\moc_inputstring.cpp&#x0D;&#x0A;"
AdditionalDependencies="..\addon\doxywizard\inputstring.h;C:\Qt\4.4.3\bin\moc.exe" AdditionalDependencies="..\addon\doxywizard\inputstring.h;$(QT_DIR)\bin\moc.exe"
Outputs="moc\moc_inputstring.cpp" Outputs="moc\moc_inputstring.cpp"
/> />
</FileConfiguration> </FileConfiguration>
...@@ -420,8 +420,8 @@ ...@@ -420,8 +420,8 @@
<Tool <Tool
Name="VCCustomBuildTool" Name="VCCustomBuildTool"
Description="MOC ..\addon\doxywizard\inputstrlist.h" Description="MOC ..\addon\doxywizard\inputstrlist.h"
CommandLine="C:\Qt\4.4.3\bin\moc.exe -DUNICODE -DWIN32 -DQT_LARGEFILE_SUPPORT -DQT_NO_CAST_FROM_ASCII -DQT_NO_CAST_TO_ASCII -DQT_XML_LIB -DQT_GUI_LIB -DQT_CORE_LIB -DQT_THREAD_SUPPORT -I&quot;..\..\..\Qt\4.4.3\include\QtCore&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtCore&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtGui&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtGui&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtXml&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtXml&quot; -I&quot;..\..\..\Qt\4.4.3\include&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;c:\Qt\4.4.3\include\ActiveQt&quot; -I&quot;..\addon\doxywizard\moc&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;.&quot; -I..\..\..\Qt\4.4.3\mkspecs\win32-msvc2005 -D_MSC_VER=1400 -DWIN32 ..\addon\doxywizard\inputstrlist.h -o moc\moc_inputstrlist.cpp&#x0D;&#x0A;" CommandLine="$(QT_DIR)\bin\moc.exe -DUNICODE -DWIN32 -DQT_LARGEFILE_SUPPORT -DQT_NO_CAST_FROM_ASCII -DQT_NO_CAST_TO_ASCII -DQT_XML_LIB -DQT_GUI_LIB -DQT_CORE_LIB -DQT_THREAD_SUPPORT -I&quot;$(QT_DIR)\include\QtCore&quot; -I&quot;$(QT_DIR)\include\QtCore&quot; -I&quot;$(QT_DIR)\include\QtGui&quot; -I&quot;$(QT_DIR)\include\QtGui&quot; -I&quot;$(QT_DIR)\include\QtXml&quot; -I&quot;$(QT_DIR)\include\QtXml&quot; -I&quot;$(QT_DIR)\include&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;c:\Qt\4.4.3\include\ActiveQt&quot; -I&quot;..\addon\doxywizard\moc&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;.&quot; -I$(QT_DIR)\mkspecs\win32-msvc2005 -D_MSC_VER=1400 -DWIN32 ..\addon\doxywizard\inputstrlist.h -o moc\moc_inputstrlist.cpp&#x0D;&#x0A;"
AdditionalDependencies="..\addon\doxywizard\inputstrlist.h;C:\Qt\4.4.3\bin\moc.exe" AdditionalDependencies="..\addon\doxywizard\inputstrlist.h;$(QT_DIR)\bin\moc.exe"
Outputs="moc\moc_inputstrlist.cpp" Outputs="moc\moc_inputstrlist.cpp"
/> />
</FileConfiguration> </FileConfiguration>
...@@ -431,8 +431,8 @@ ...@@ -431,8 +431,8 @@
<Tool <Tool
Name="VCCustomBuildTool" Name="VCCustomBuildTool"
Description="MOC ..\addon\doxywizard\inputstrlist.h" Description="MOC ..\addon\doxywizard\inputstrlist.h"
CommandLine="C:\Qt\4.4.3\bin\moc.exe -DUNICODE -DWIN32 -DQT_LARGEFILE_SUPPORT -DQT_NO_CAST_FROM_ASCII -DQT_NO_CAST_TO_ASCII -DQT_NO_DEBUG -DQT_XML_LIB -DQT_GUI_LIB -DQT_CORE_LIB -DQT_THREAD_SUPPORT -I&quot;..\..\..\Qt\4.4.3\include\QtCore&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtCore&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtGui&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtGui&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtXml&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtXml&quot; -I&quot;..\..\..\Qt\4.4.3\include&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;c:\Qt\4.4.3\include\ActiveQt&quot; -I&quot;..\addon\doxywizard\moc&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;.&quot; -I..\..\..\Qt\4.4.3\mkspecs\win32-msvc2005 -D_MSC_VER=1400 -DWIN32 ..\addon\doxywizard\inputstrlist.h -o moc\moc_inputstrlist.cpp&#x0D;&#x0A;" CommandLine="$(QT_DIR)\bin\moc.exe -DUNICODE -DWIN32 -DQT_LARGEFILE_SUPPORT -DQT_NO_CAST_FROM_ASCII -DQT_NO_CAST_TO_ASCII -DQT_NO_DEBUG -DQT_XML_LIB -DQT_GUI_LIB -DQT_CORE_LIB -DQT_THREAD_SUPPORT -I&quot;$(QT_DIR)\include\QtCore&quot; -I&quot;$(QT_DIR)\include\QtCore&quot; -I&quot;$(QT_DIR)\include\QtGui&quot; -I&quot;$(QT_DIR)\include\QtGui&quot; -I&quot;$(QT_DIR)\include\QtXml&quot; -I&quot;$(QT_DIR)\include\QtXml&quot; -I&quot;$(QT_DIR)\include&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;c:\Qt\4.4.3\include\ActiveQt&quot; -I&quot;..\addon\doxywizard\moc&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;.&quot; -I$(QT_DIR)\mkspecs\win32-msvc2005 -D_MSC_VER=1400 -DWIN32 ..\addon\doxywizard\inputstrlist.h -o moc\moc_inputstrlist.cpp&#x0D;&#x0A;"
AdditionalDependencies="..\addon\doxywizard\inputstrlist.h;C:\Qt\4.4.3\bin\moc.exe" AdditionalDependencies="..\addon\doxywizard\inputstrlist.h;$(QT_DIR)\bin\moc.exe"
Outputs="moc\moc_inputstrlist.cpp" Outputs="moc\moc_inputstrlist.cpp"
/> />
</FileConfiguration> </FileConfiguration>
...@@ -450,8 +450,8 @@ ...@@ -450,8 +450,8 @@
<Tool <Tool
Name="VCCustomBuildTool" Name="VCCustomBuildTool"
Description="MOC ..\addon\doxywizard\wizard.h" Description="MOC ..\addon\doxywizard\wizard.h"
CommandLine="C:\Qt\4.4.3\bin\moc.exe -DUNICODE -DWIN32 -DQT_LARGEFILE_SUPPORT -DQT_NO_CAST_FROM_ASCII -DQT_NO_CAST_TO_ASCII -DQT_XML_LIB -DQT_GUI_LIB -DQT_CORE_LIB -DQT_THREAD_SUPPORT -I&quot;..\..\..\Qt\4.4.3\include\QtCore&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtCore&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtGui&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtGui&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtXml&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtXml&quot; -I&quot;..\..\..\Qt\4.4.3\include&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;c:\Qt\4.4.3\include\ActiveQt&quot; -I&quot;..\addon\doxywizard\moc&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;.&quot; -I..\..\..\Qt\4.4.3\mkspecs\win32-msvc2005 -D_MSC_VER=1400 -DWIN32 ..\addon\doxywizard\wizard.h -o moc\moc_wizard.cpp&#x0D;&#x0A;" CommandLine="$(QT_DIR)\bin\moc.exe -DUNICODE -DWIN32 -DQT_LARGEFILE_SUPPORT -DQT_NO_CAST_FROM_ASCII -DQT_NO_CAST_TO_ASCII -DQT_XML_LIB -DQT_GUI_LIB -DQT_CORE_LIB -DQT_THREAD_SUPPORT -I&quot;$(QT_DIR)\include\QtCore&quot; -I&quot;$(QT_DIR)\include\QtCore&quot; -I&quot;$(QT_DIR)\include\QtGui&quot; -I&quot;$(QT_DIR)\include\QtGui&quot; -I&quot;$(QT_DIR)\include\QtXml&quot; -I&quot;$(QT_DIR)\include\QtXml&quot; -I&quot;$(QT_DIR)\include&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;c:\Qt\4.4.3\include\ActiveQt&quot; -I&quot;..\addon\doxywizard\moc&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;.&quot; -I$(QT_DIR)\mkspecs\win32-msvc2005 -D_MSC_VER=1400 -DWIN32 ..\addon\doxywizard\wizard.h -o moc\moc_wizard.cpp&#x0D;&#x0A;"
AdditionalDependencies="..\addon\doxywizard\wizard.h;C:\Qt\4.4.3\bin\moc.exe" AdditionalDependencies="..\addon\doxywizard\wizard.h;$(QT_DIR)\bin\moc.exe"
Outputs="moc\moc_wizard.cpp" Outputs="moc\moc_wizard.cpp"
/> />
</FileConfiguration> </FileConfiguration>
...@@ -461,8 +461,8 @@ ...@@ -461,8 +461,8 @@
<Tool <Tool
Name="VCCustomBuildTool" Name="VCCustomBuildTool"
Description="MOC ..\addon\doxywizard\wizard.h" Description="MOC ..\addon\doxywizard\wizard.h"
CommandLine="C:\Qt\4.4.3\bin\moc.exe -DUNICODE -DWIN32 -DQT_LARGEFILE_SUPPORT -DQT_NO_CAST_FROM_ASCII -DQT_NO_CAST_TO_ASCII -DQT_NO_DEBUG -DQT_XML_LIB -DQT_GUI_LIB -DQT_CORE_LIB -DQT_THREAD_SUPPORT -I&quot;..\..\..\Qt\4.4.3\include\QtCore&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtCore&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtGui&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtGui&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtXml&quot; -I&quot;..\..\..\Qt\4.4.3\include\QtXml&quot; -I&quot;..\..\..\Qt\4.4.3\include&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;c:\Qt\4.4.3\include\ActiveQt&quot; -I&quot;..\addon\doxywizard\moc&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;.&quot; -I..\..\..\Qt\4.4.3\mkspecs\win32-msvc2005 -D_MSC_VER=1400 -DWIN32 ..\addon\doxywizard\wizard.h -o moc\moc_wizard.cpp&#x0D;&#x0A;" CommandLine="$(QT_DIR)\bin\moc.exe -DUNICODE -DWIN32 -DQT_LARGEFILE_SUPPORT -DQT_NO_CAST_FROM_ASCII -DQT_NO_CAST_TO_ASCII -DQT_NO_DEBUG -DQT_XML_LIB -DQT_GUI_LIB -DQT_CORE_LIB -DQT_THREAD_SUPPORT -I&quot;$(QT_DIR)\include\QtCore&quot; -I&quot;$(QT_DIR)\include\QtCore&quot; -I&quot;$(QT_DIR)\include\QtGui&quot; -I&quot;$(QT_DIR)\include\QtGui&quot; -I&quot;$(QT_DIR)\include\QtXml&quot; -I&quot;$(QT_DIR)\include\QtXml&quot; -I&quot;$(QT_DIR)\include&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;c:\Qt\4.4.3\include\ActiveQt&quot; -I&quot;..\addon\doxywizard\moc&quot; -I&quot;..\addon\doxywizard&quot; -I&quot;.&quot; -I$(QT_DIR)\mkspecs\win32-msvc2005 -D_MSC_VER=1400 -DWIN32 ..\addon\doxywizard\wizard.h -o moc\moc_wizard.cpp&#x0D;&#x0A;"
AdditionalDependencies="..\addon\doxywizard\wizard.h;C:\Qt\4.4.3\bin\moc.exe" AdditionalDependencies="..\addon\doxywizard\wizard.h;$(QT_DIR)\bin\moc.exe"
Outputs="moc\moc_wizard.cpp" Outputs="moc\moc_wizard.cpp"
/> />
</FileConfiguration> </FileConfiguration>
...@@ -477,6 +477,10 @@ ...@@ -477,6 +477,10 @@
RelativePath="config_lex.cpp" RelativePath="config_lex.cpp"
> >
</File> </File>
<File
RelativePath="..\addon\doxywizard\configdoc.cpp"
>
</File>
<File <File
RelativePath="moc\moc_doxywizard.cpp" RelativePath="moc\moc_doxywizard.cpp"
> >
...@@ -562,8 +566,8 @@ ...@@ -562,8 +566,8 @@
<Tool <Tool
Name="VCCustomBuildTool" Name="VCCustomBuildTool"
Description="RCC ..\addon\doxywizard\doxywizard.qrc" Description="RCC ..\addon\doxywizard\doxywizard.qrc"
CommandLine="C:\Qt\4.4.3\bin\rcc.exe -name doxywizard ..\addon\doxywizard\doxywizard.qrc -o rcc\qrc_doxywizard.cpp&#x0D;&#x0A;" CommandLine="$(QT_DIR)\bin\rcc.exe -name doxywizard ..\addon\doxywizard\doxywizard.qrc -o rcc\qrc_doxywizard.cpp&#x0D;&#x0A;"
AdditionalDependencies="..\addon\doxywizard\doxywizard.qrc;C:\Qt\4.4.3\bin\rcc.exe" AdditionalDependencies="..\addon\doxywizard\doxywizard.qrc;$(QT_DIR)\bin\rcc.exe"
Outputs="rcc\qrc_doxywizard.cpp" Outputs="rcc\qrc_doxywizard.cpp"
/> />
</FileConfiguration> </FileConfiguration>
...@@ -573,8 +577,8 @@ ...@@ -573,8 +577,8 @@
<Tool <Tool
Name="VCCustomBuildTool" Name="VCCustomBuildTool"
Description="RCC ..\addon\doxywizard\doxywizard.qrc" Description="RCC ..\addon\doxywizard\doxywizard.qrc"
CommandLine="C:\Qt\4.4.3\bin\rcc.exe -name doxywizard ..\addon\doxywizard\doxywizard.qrc -o rcc\qrc_doxywizard.cpp&#x0D;&#x0A;" CommandLine="$(QT_DIR)\bin\rcc.exe -name doxywizard ..\addon\doxywizard\doxywizard.qrc -o rcc\qrc_doxywizard.cpp&#x0D;&#x0A;"
AdditionalDependencies="..\addon\doxywizard\doxywizard.qrc;C:\Qt\4.4.3\bin\rcc.exe" AdditionalDependencies="..\addon\doxywizard\doxywizard.qrc;$(QT_DIR)\bin\rcc.exe"
Outputs="rcc\qrc_doxywizard.cpp" Outputs="rcc\qrc_doxywizard.cpp"
/> />
</FileConfiguration> </FileConfiguration>
......
...@@ -44,7 +44,7 @@ ...@@ -44,7 +44,7 @@
<Tool <Tool
Name="VCCLCompilerTool" Name="VCCLCompilerTool"
Optimization="0" Optimization="0"
AdditionalIncludeDirectories="&quot;S:\xapian\xapian-core-1.2.8\include&quot;,..\qtools" AdditionalIncludeDirectories="&quot;$(XAPIAN_DIR)\xapian-core-1.2.8\include&quot;,..\qtools"
PreprocessorDefinitions="_CRT_SECURE_NO_WARNINGS" PreprocessorDefinitions="_CRT_SECURE_NO_WARNINGS"
MinimalRebuild="true" MinimalRebuild="true"
BasicRuntimeChecks="3" BasicRuntimeChecks="3"
...@@ -67,7 +67,7 @@ ...@@ -67,7 +67,7 @@
AdditionalDependencies="qtools.lib xapian.lib uuid.lib rpcrt4.lib ws2_32.lib" AdditionalDependencies="qtools.lib xapian.lib uuid.lib rpcrt4.lib ws2_32.lib"
OutputFile="..\bin\doxyindexer.exe" OutputFile="..\bin\doxyindexer.exe"
LinkIncremental="1" LinkIncremental="1"
AdditionalLibraryDirectories="&quot;S:\xapian\Debug&quot;;Debug" AdditionalLibraryDirectories="&quot;$(XAPIAN_DIR)\Debug&quot;;Debug"
GenerateManifest="false" GenerateManifest="false"
IgnoreAllDefaultLibraries="false" IgnoreAllDefaultLibraries="false"
IgnoreDefaultLibraryNames="" IgnoreDefaultLibraryNames=""
...@@ -124,7 +124,7 @@ ...@@ -124,7 +124,7 @@
<Tool <Tool
Name="VCCLCompilerTool" Name="VCCLCompilerTool"
Optimization="0" Optimization="0"
AdditionalIncludeDirectories="&quot;S:\xapian\include&quot;,..\qtools" AdditionalIncludeDirectories="&quot;$(XAPIAN_DIR)\include&quot;,..\qtools"
PreprocessorDefinitions="_CRT_SECURE_NO_WARNINGS" PreprocessorDefinitions="_CRT_SECURE_NO_WARNINGS"
MinimalRebuild="true" MinimalRebuild="true"
BasicRuntimeChecks="3" BasicRuntimeChecks="3"
...@@ -147,7 +147,7 @@ ...@@ -147,7 +147,7 @@
AdditionalDependencies="qtools.lib xapian.lib uuid.lib rpcrt4.lib ws2_32.lib" AdditionalDependencies="qtools.lib xapian.lib uuid.lib rpcrt4.lib ws2_32.lib"
OutputFile="..\bin\doxyindexer.exe" OutputFile="..\bin\doxyindexer.exe"
LinkIncremental="2" LinkIncremental="2"
AdditionalLibraryDirectories="&quot;S:\xapian\Debug64&quot;;Debug64" AdditionalLibraryDirectories="&quot;$(XAPIAN_DIR)\Debug64&quot;;Debug64"
GenerateDebugInformation="true" GenerateDebugInformation="true"
ProgramDatabaseFile=".\Debug64\$(TargetName).pdb" ProgramDatabaseFile=".\Debug64\$(TargetName).pdb"
SubSystem="1" SubSystem="1"
...@@ -202,7 +202,7 @@ ...@@ -202,7 +202,7 @@
Name="VCCLCompilerTool" Name="VCCLCompilerTool"
Optimization="2" Optimization="2"
EnableIntrinsicFunctions="true" EnableIntrinsicFunctions="true"
AdditionalIncludeDirectories="&quot;S:\xapian\xapian-core-1.2.8\include&quot;,..\qtools" AdditionalIncludeDirectories="&quot;$(XAPIAN_DIR)\include&quot;,..\qtools"
PreprocessorDefinitions="_CRT_SECURE_NO_WARNINGS" PreprocessorDefinitions="_CRT_SECURE_NO_WARNINGS"
RuntimeLibrary="0" RuntimeLibrary="0"
EnableFunctionLevelLinking="true" EnableFunctionLevelLinking="true"
...@@ -224,7 +224,7 @@ ...@@ -224,7 +224,7 @@
AdditionalDependencies="qtools.lib xapian.lib uuid.lib rpcrt4.lib ws2_32.lib" AdditionalDependencies="qtools.lib xapian.lib uuid.lib rpcrt4.lib ws2_32.lib"
OutputFile="..\bin\Release\doxyindexer.exe" OutputFile="..\bin\Release\doxyindexer.exe"
LinkIncremental="1" LinkIncremental="1"
AdditionalLibraryDirectories="&quot;S:\xapian\Release&quot;;Release" AdditionalLibraryDirectories="&quot;$(XAPIAN_DIR)\Release&quot;;Release"
GenerateManifest="false" GenerateManifest="false"
GenerateDebugInformation="true" GenerateDebugInformation="true"
ProgramDatabaseFile=".\Release\$(TargetName).pdb" ProgramDatabaseFile=".\Release\$(TargetName).pdb"
...@@ -283,7 +283,7 @@ ...@@ -283,7 +283,7 @@
Name="VCCLCompilerTool" Name="VCCLCompilerTool"
Optimization="2" Optimization="2"
EnableIntrinsicFunctions="true" EnableIntrinsicFunctions="true"
AdditionalIncludeDirectories="&quot;S:\xapian\include&quot;,..\qtools" AdditionalIncludeDirectories="&quot;$(XAPIAN_DIR)\include&quot;,..\qtools"
PreprocessorDefinitions="_CRT_SECURE_NO_WARNINGS" PreprocessorDefinitions="_CRT_SECURE_NO_WARNINGS"
RuntimeLibrary="0" RuntimeLibrary="0"
EnableFunctionLevelLinking="true" EnableFunctionLevelLinking="true"
...@@ -305,7 +305,7 @@ ...@@ -305,7 +305,7 @@
AdditionalDependencies="qtools.lib xapian.lib uuid.lib rpcrt4.lib ws2_32.lib" AdditionalDependencies="qtools.lib xapian.lib uuid.lib rpcrt4.lib ws2_32.lib"
OutputFile="..\bin\Release64\doxyindexer.exe" OutputFile="..\bin\Release64\doxyindexer.exe"
LinkIncremental="1" LinkIncremental="1"
AdditionalLibraryDirectories="&quot;S:\xapian\Release64&quot;;Release64" AdditionalLibraryDirectories="&quot;$(XAPIAN_DIR)\Release64&quot;;Release64"
GenerateDebugInformation="true" GenerateDebugInformation="true"
ProgramDatabaseFile=".\Release64\$(TargetName).pdb" ProgramDatabaseFile=".\Release64\$(TargetName).pdb"
SubSystem="1" SubSystem="1"
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment