summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDimitri van Heesch <doxygen@gmail.com>2021-01-06 14:27:53 (GMT)
committerDimitri van Heesch <doxygen@gmail.com>2021-01-22 20:45:18 (GMT)
commit1b4a1663ebc436f37158b8a7bb5443841f06e069 (patch)
tree7157e7db0961517b755e190749a394e867a876b6
parentcfc139ab8f24b602d43923a2cd06e20605896cd5 (diff)
downloadDoxygen-1b4a1663ebc436f37158b8a7bb5443841f06e069.zip
Doxygen-1b4a1663ebc436f37158b8a7bb5443841f06e069.tar.gz
Doxygen-1b4a1663ebc436f37158b8a7bb5443841f06e069.tar.bz2
Refactoring: modernize configimpl
-rw-r--r--src/configimpl.h93
-rw-r--r--src/configimpl.l102
2 files changed, 77 insertions, 118 deletions
diff --git a/src/configimpl.h b/src/configimpl.h
index a267cc6..a34c45b 100644
--- a/src/configimpl.h
+++ b/src/configimpl.h
@@ -19,10 +19,11 @@
#ifndef CONFIGIMPL_H
#define CONFIGIMPL_H
-#include <qstrlist.h>
-#include <qdict.h>
-#include <qlist.h>
-#include <qregexp.h>
+#include <vector>
+#include <unordered_map>
+#include <string>
+#include <memory>
+
#include "ftextstream.h"
#include "containers.h"
@@ -151,11 +152,8 @@ class ConfigEnum : public ConfigOption
m_value = defVal;
m_defValue = defVal;
}
- void addValue(const char *v) { m_valueRange.append(v); }
- QStrListIterator iterator()
- {
- return QStrListIterator(m_valueRange);
- }
+ void addValue(const char *v) { m_valueRange.push_back(v); }
+ const std::vector<QCString> &values() const { return m_valueRange; }
QCString *valueRef() { return &m_value; }
void substEnvVars();
void writeTemplate(FTextStream &t,bool sl,bool);
@@ -164,7 +162,7 @@ class ConfigEnum : public ConfigOption
void init() { m_value = m_defValue.copy(); }
private:
- QStrList m_valueRange;
+ std::vector<QCString> m_valueRange;
QCString m_value;
QCString m_defValue;
};
@@ -292,6 +290,9 @@ class ConfigDisabled : public ConfigOption
#define ConfigImpl_getBool(val) ConfigImpl::instance()->getBool(__FILE__,__LINE__,val)
+using ConfigOptionList = std::vector< std::unique_ptr<ConfigOption> >;
+using ConfigOptionMap = std::unordered_map< std::string, ConfigOption* >;
+
/** Singleton for configuration variables.
*
* This object holds the global static variables
@@ -323,14 +324,6 @@ class ConfigImpl
m_instance=0;
}
- /*! Returns an iterator that can by used to iterate over the
- * configuration options.
- */
- QListIterator<ConfigOption> iterator()
- {
- return QListIterator<ConfigOption>(*m_options);
- }
-
/*!
* @name Getting configuration values.
* @{
@@ -371,7 +364,8 @@ class ConfigImpl
*/
ConfigOption *get(const char *name) const
{
- return m_dict->find(name);
+ auto it = m_dict.find(name);
+ return it!=m_dict.end() ? it->second : nullptr;
}
/* @} */
@@ -386,7 +380,7 @@ class ConfigImpl
ConfigInfo *addInfo(const char *name,const char *doc)
{
ConfigInfo *result = new ConfigInfo(name,doc);
- m_options->append(result);
+ m_options.push_back(std::unique_ptr<ConfigOption>(result));
return result;
}
@@ -397,8 +391,8 @@ class ConfigImpl
const char *doc)
{
ConfigString *result = new ConfigString(name,doc);
- m_options->append(result);
- m_dict->insert(name,result);
+ m_options.push_back(std::unique_ptr<ConfigOption>(result));
+ m_dict.insert(std::make_pair(name,result));
return result;
}
@@ -411,8 +405,8 @@ class ConfigImpl
const char *defVal)
{
ConfigEnum *result = new ConfigEnum(name,doc,defVal);
- m_options->append(result);
- m_dict->insert(name,result);
+ m_options.push_back(std::unique_ptr<ConfigOption>(result));
+ m_dict.insert(std::make_pair(name,result));
return result;
}
@@ -423,8 +417,8 @@ class ConfigImpl
const char *doc)
{
ConfigList *result = new ConfigList(name,doc);
- m_options->append(result);
- m_dict->insert(name,result);
+ m_options.push_back(std::unique_ptr<ConfigOption>(result));
+ m_dict.insert(std::make_pair(name,result));
return result;
}
@@ -438,8 +432,8 @@ class ConfigImpl
int minVal,int maxVal,int defVal)
{
ConfigInt *result = new ConfigInt(name,doc,minVal,maxVal,defVal);
- m_options->append(result);
- m_dict->insert(name,result);
+ m_options.push_back(std::unique_ptr<ConfigOption>(result));
+ m_dict.insert(std::make_pair(name,result));
return result;
}
@@ -452,25 +446,25 @@ class ConfigImpl
bool defVal)
{
ConfigBool *result = new ConfigBool(name,doc,defVal);
- m_options->append(result);
- m_dict->insert(name,result);
+ m_options.push_back(std::unique_ptr<ConfigOption>(result));
+ m_dict.insert(std::make_pair(name,result));
return result;
}
/*! Adds an option that has become obsolete. */
ConfigOption *addObsolete(const char *name)
{
- ConfigObsolete *option = new ConfigObsolete(name);
- m_dict->insert(name,option);
- m_obsolete->append(option);
- return option;
+ ConfigObsolete *result = new ConfigObsolete(name);
+ m_obsolete.push_back(std::unique_ptr<ConfigOption>(result));
+ m_dict.insert(std::make_pair(name,result));
+ return result;
}
/*! Adds an option that has been disabled at compile time. */
ConfigOption *addDisabled(const char *name)
{
- ConfigDisabled *option = new ConfigDisabled(name);
- m_dict->insert(name,option);
- m_disabled->append(option);
- return option;
+ ConfigDisabled *result = new ConfigDisabled(name);
+ m_disabled.push_back(std::unique_ptr<ConfigOption>(result));
+ m_dict.insert(std::make_pair(name,result));
+ return result;
}
/*! @} */
@@ -545,7 +539,7 @@ class ConfigImpl
{
QCString result=m_startComment;
m_startComment.resize(0);
- return result.replace(QRegExp("\r"),"");
+ return substitute(result,"\r","");
}
/*! Take the user comment and reset it internally
* \returns user comment
@@ -554,36 +548,25 @@ class ConfigImpl
{
QCString result=m_userComment;
m_userComment.resize(0);
- return result.replace(QRegExp("\r"),"");
+ return substitute(result,"\r","");
}
protected:
ConfigImpl()
{
- m_options = new QList<ConfigOption>;
- m_obsolete = new QList<ConfigOption>;
- m_disabled = new QList<ConfigOption>;
- m_dict = new QDict<ConfigOption>(257);
- m_options->setAutoDelete(TRUE);
- m_obsolete->setAutoDelete(TRUE);
- m_disabled->setAutoDelete(TRUE);
m_initialized = FALSE;
create();
}
~ConfigImpl()
{
- delete m_options;
- delete m_obsolete;
- delete m_disabled;
- delete m_dict;
}
private:
- QList<ConfigOption> *m_options;
- QList<ConfigOption> *m_obsolete;
- QList<ConfigOption> *m_disabled;
- QDict<ConfigOption> *m_dict;
+ ConfigOptionList m_options;
+ ConfigOptionList m_obsolete;
+ ConfigOptionList m_disabled;
+ ConfigOptionMap m_dict;
static ConfigImpl *m_instance;
QCString m_startComment;
QCString m_userComment;
diff --git a/src/configimpl.l b/src/configimpl.l
index 25a32b8..83c4c89 100644
--- a/src/configimpl.l
+++ b/src/configimpl.l
@@ -30,8 +30,6 @@
#include <qfileinfo.h>
#include <qdir.h>
#include <qregexp.h>
-#include <qstack.h>
-#include <qglobal.h>
#include <thread>
#include <algorithm>
@@ -39,7 +37,6 @@
#include "configimpl.h"
#include "version.h"
#include "portable.h"
-#include "util.h"
#include "message.h"
#include "lang_cfg.h"
@@ -239,15 +236,13 @@ void ConfigEnum::convertStrToVal()
return;
}
QCString val = m_value.stripWhiteSpace().lower();
- const char *s=m_valueRange.first();
- while (s)
+ for (const auto &s : m_valueRange)
{
- if (QCString(s).lower() == val)
+ if (s.lower() == val)
{
m_value = s;
return;
}
- s = m_valueRange.next();
}
config_warn("argument '%s' for option %s is not a valid enum value\n"
@@ -257,72 +252,72 @@ void ConfigEnum::convertStrToVal()
QCString &ConfigImpl::getString(const char *fileName,int num,const char *name) const
{
- ConfigOption *opt = m_dict->find(name);
- if (opt==0)
+ auto it = m_dict.find(name);
+ if (it==m_dict.end())
{
config_term("%s<%d>: Internal error: Requested unknown option %s!\n",fileName,num,name);
}
- else if (opt->kind()!=ConfigOption::O_String)
+ else if (it->second->kind()!=ConfigOption::O_String)
{
config_term("%s<%d>: Internal error: Requested option %s not of string type!\n",fileName,num,name);
}
- return *((ConfigString *)opt)->valueRef();
+ return *((ConfigString *)it->second)->valueRef();
}
StringVector &ConfigImpl::getList(const char *fileName,int num,const char *name) const
{
- ConfigOption *opt = m_dict->find(name);
- if (opt==0)
+ auto it = m_dict.find(name);
+ if (it==m_dict.end())
{
config_term("%s<%d>: Internal error: Requested unknown option %s!\n",fileName,num,name);
}
- else if (opt->kind()!=ConfigOption::O_List)
+ else if (it->second->kind()!=ConfigOption::O_List)
{
config_term("%s<%d>: Internal error: Requested option %s not of list type!\n",fileName,num,name);
}
- return *((ConfigList *)opt)->valueRef();
+ return *((ConfigList *)it->second)->valueRef();
}
QCString &ConfigImpl::getEnum(const char *fileName,int num,const char *name) const
{
- ConfigOption *opt = m_dict->find(name);
- if (opt==0)
+ auto it = m_dict.find(name);
+ if (it==m_dict.end())
{
config_term("%s<%d>: Internal error: Requested unknown option %s!\n",fileName,num,name);
}
- else if (opt->kind()!=ConfigOption::O_Enum)
+ else if (it->second->kind()!=ConfigOption::O_Enum)
{
config_term("%s<%d>: Internal error: Requested option %s not of enum type!\n",fileName,num,name);
}
- return *((ConfigEnum *)opt)->valueRef();
+ return *((ConfigEnum *)it->second)->valueRef();
}
int &ConfigImpl::getInt(const char *fileName,int num,const char *name) const
{
- ConfigOption *opt = m_dict->find(name);
- if (opt==0)
+ auto it = m_dict.find(name);
+ if (it==m_dict.end())
{
config_term("%s<%d>: Internal error: Requested unknown option %s!\n",fileName,num,name);
}
- else if (opt->kind()!=ConfigOption::O_Int)
+ else if (it->second->kind()!=ConfigOption::O_Int)
{
config_term("%s<%d>: Internal error: Requested option %s not of integer type!\n",fileName,num,name);
}
- return *((ConfigInt *)opt)->valueRef();
+ return *((ConfigInt *)it->second)->valueRef();
}
bool &ConfigImpl::getBool(const char *fileName,int num,const char *name) const
{
- ConfigOption *opt = m_dict->find(name);
- if (opt==0)
+ auto it = m_dict.find(name);
+ if (it==m_dict.end())
{
config_term("%s<%d>: Internal error: Requested unknown option %s!\n",fileName,num,name);
}
- else if (opt->kind()!=ConfigOption::O_Bool)
+ else if (it->second->kind()!=ConfigOption::O_Bool)
{
config_term("%s<%d>: Internal error: Requested option %s not of boolean type!\n",fileName,num,name);
}
- return *((ConfigBool *)opt)->valueRef();
+ return *((ConfigBool *)it->second)->valueRef();
}
/* ------------------------------------------ */
@@ -516,8 +511,7 @@ static QCString *g_string=0;
static StringVector *g_list=0;
static QCString g_listStr;
static StringVector g_includePathList;
-static QStack<ConfigFileState> g_includeStack;
-static int g_includeDepth;
+static std::vector< std::unique_ptr<ConfigFileState> > g_includeStack;
static bool g_configUpdate = FALSE;
static QCString g_encoding;
static ConfigImpl *g_config;
@@ -530,7 +524,7 @@ static ConfigImpl *g_config;
static yy_size_t yyread(char *buf,yy_size_t max_size)
{
// no file included
- if (g_includeStack.isEmpty())
+ if (g_includeStack.empty())
{
yy_size_t c=0;
if (g_inputString==0) return c;
@@ -544,7 +538,7 @@ static yy_size_t yyread(char *buf,yy_size_t max_size)
else
{
//assert(g_includeStack.current()->newState==YY_CURRENT_BUFFER);
- return (yy_size_t)fread(buf,1,max_size,g_includeStack.current()->filePtr);
+ return (yy_size_t)fread(buf,1,max_size,g_includeStack.back()->filePtr);
}
}
@@ -807,7 +801,7 @@ static FILE *findFile(const char *fileName)
static void readIncludeFile(const char *incName)
{
- if (g_includeDepth==MAX_INCLUDE_DEPTH) {
+ if (g_includeStack.size()==MAX_INCLUDE_DEPTH) {
config_term("maximum include depth (%d) reached, %s is not included. Aborting...\n",
MAX_INCLUDE_DEPTH,incName);
}
@@ -827,7 +821,7 @@ static void readIncludeFile(const char *incName)
{
// For debugging
#if SHOW_INCLUDES
- for (i=0;i<g_includeStack.count();i++) msg(" ");
+ for (size_t i=0;i<g_includeStack.size();i++) msg(" ");
msg("@INCLUDE = %s: parsing...\n",inc.data());
#endif
@@ -838,12 +832,11 @@ static void readIncludeFile(const char *incName)
fs->fileName=g_yyFileName;
fs->filePtr=f;
// push the state on the stack
- g_includeStack.push(fs);
+ g_includeStack.push_back(std::unique_ptr<ConfigFileState>(fs));
// set the scanner to the include file
yy_switch_to_buffer(yy_create_buffer(f, YY_BUF_SIZE));
fs->newState=YY_CURRENT_BUFFER;
g_yyFileName=inc;
- g_includeDepth++;
}
else
{
@@ -1014,22 +1007,21 @@ static void readIncludeFile(const char *incName)
<<EOF>> {
//printf("End of include file\n");
//printf("Include stack depth=%d\n",g_includeStack.count());
- if (g_includeStack.isEmpty())
+ if (g_includeStack.empty())
{
//printf("Terminating scanner!\n");
yyterminate();
}
else
{
- ConfigFileState *fs=g_includeStack.pop();
+ auto &fs=g_includeStack.back();
fclose(fs->filePtr);
YY_BUFFER_STATE oldBuf = YY_CURRENT_BUFFER;
yy_switch_to_buffer( fs->oldState );
yy_delete_buffer( oldBuf );
g_yyLineNr=fs->lineNr;
g_yyFileName=fs->fileName;
- delete fs; fs=0;
- g_includeDepth--;
+ g_includeStack.pop_back();
}
}
@@ -1102,9 +1094,7 @@ void ConfigImpl::writeTemplate(FTextStream &t,bool sl,bool upd)
{
t << convertToComment(m_header,"");
}
- QListIterator<ConfigOption> it = iterator();
- ConfigOption *option;
- for (;(option=it.current());++it)
+ for (const auto &option : m_options)
{
option->writeTemplate(t,sl,upd);
}
@@ -1120,9 +1110,7 @@ void ConfigImpl::compareDoxyfile(FTextStream &t)
{
t << "# Difference with default Doxyfile " << getFullVersion();
t << endl;
- QListIterator<ConfigOption> it = iterator();
- ConfigOption *option;
- for (;(option=it.current());++it)
+ for (const auto &option : m_options)
{
option->m_userComment = "";
option->compareDoxyfile(t);
@@ -1131,18 +1119,14 @@ void ConfigImpl::compareDoxyfile(FTextStream &t)
void ConfigImpl::convertStrToVal()
{
- QListIterator<ConfigOption> it = iterator();
- ConfigOption *option;
- for (;(option=it.current());++it)
+ for (const auto &option : m_options)
{
option->convertStrToVal();
}
}
void ConfigImpl::emptyValueToDefault()
{
- QListIterator<ConfigOption> it = iterator();
- ConfigOption *option;
- for (;(option=it.current());++it)
+ for (const auto &option : m_options)
{
option->emptyValueToDefault();
}
@@ -1268,9 +1252,7 @@ void ConfigEnum::substEnvVars()
void ConfigImpl::substituteEnvironmentVars()
{
- QListIterator<ConfigOption> it = iterator();
- ConfigOption *option;
- for (;(option=it.current());++it)
+ for (const auto &option : m_options)
{
option->substEnvVars();
}
@@ -1278,15 +1260,13 @@ void ConfigImpl::substituteEnvironmentVars()
void ConfigImpl::init()
{
- QListIterator<ConfigOption> it = iterator();
- ConfigOption *option;
- for (;(option=it.current());++it)
+ for (const auto &option : m_options)
{
option->init();
}
// sanity check if all depends relations are valid
- for (it.toFirst();(option=it.current());++it)
+ for (const auto &option : m_options)
{
QCString depName = option->dependsOn();
if (!depName.isEmpty())
@@ -1373,9 +1353,7 @@ bool ConfigImpl::parseString(const char *fn,const char *str,bool update)
g_inputPosition = 0;
g_yyFileName = fn;
g_yyLineNr = 1;
- g_includeStack.setAutoDelete(TRUE);
g_includeStack.clear();
- g_includeDepth = 0;
configimplYYrestart( configimplYYin );
BEGIN( Start );
g_configUpdate = update;
@@ -2079,9 +2057,7 @@ void Config::checkAndCorrect()
#if 0 // TODO: this breaks test 25; SOURCEBROWSER = NO and SOURCE_TOOLTIPS = YES.
// So this and other regressions should be analysed and fixed before this can be enabled
// disable any boolean options that depend on disabled options
- QListIterator<ConfigOption> it = iterator();
- ConfigOption *option;
- for (it.toFirst();(option=it.current());++it)
+ for (const auto &option : m_options)
{
QCString depName = option->dependsOn(); // option has a dependency
if (!depName.isEmpty())