2010-04-13 19:25:08 +02:00
|
|
|
/*
|
|
|
|
* Cppcheck - A tool for static C/C++ code analysis
|
2023-01-28 10:16:34 +01:00
|
|
|
* Copyright (C) 2007-2023 Cppcheck team.
|
2010-04-13 19:25:08 +02:00
|
|
|
*
|
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
2013-09-04 20:59:49 +02:00
|
|
|
//---------------------------------------------------------------------------
|
2010-04-17 09:23:54 +02:00
|
|
|
#ifndef settingsH
|
|
|
|
#define settingsH
|
2013-09-04 20:59:49 +02:00
|
|
|
//---------------------------------------------------------------------------
|
2010-04-13 19:25:08 +02:00
|
|
|
|
2023-10-08 21:28:57 +02:00
|
|
|
#include "addoninfo.h"
|
2012-06-10 14:19:09 +02:00
|
|
|
#include "config.h"
|
2022-01-27 19:03:20 +01:00
|
|
|
#include "errortypes.h"
|
2013-07-08 18:26:18 +02:00
|
|
|
#include "library.h"
|
2016-08-13 10:50:03 +02:00
|
|
|
#include "platform.h"
|
2011-10-22 09:45:48 +02:00
|
|
|
#include "standards.h"
|
2017-05-27 04:33:47 +02:00
|
|
|
#include "suppressions.h"
|
2010-04-13 19:25:08 +02:00
|
|
|
|
2020-05-19 08:38:51 +02:00
|
|
|
#include <algorithm>
|
2019-12-19 18:37:51 +01:00
|
|
|
#include <atomic>
|
2023-03-02 21:50:14 +01:00
|
|
|
#include <cstddef>
|
2022-01-27 19:03:20 +01:00
|
|
|
#include <cstdint>
|
2017-05-27 04:33:47 +02:00
|
|
|
#include <list>
|
|
|
|
#include <set>
|
|
|
|
#include <string>
|
2023-01-21 10:39:44 +01:00
|
|
|
#include <tuple>
|
2017-05-27 04:33:47 +02:00
|
|
|
#include <vector>
|
2022-10-31 15:04:16 +01:00
|
|
|
#include <unordered_set>
|
2017-05-27 04:33:47 +02:00
|
|
|
|
2023-04-08 16:08:47 +02:00
|
|
|
enum class SHOWTIME_MODES;
|
2017-05-15 20:05:11 +02:00
|
|
|
namespace ValueFlow {
|
|
|
|
class Value;
|
|
|
|
}
|
|
|
|
|
2010-04-13 19:25:08 +02:00
|
|
|
/// @addtogroup Core
|
|
|
|
/// @{
|
|
|
|
|
2021-02-24 22:00:06 +01:00
|
|
|
template<typename T>
|
|
|
|
class SimpleEnableGroup {
|
2021-02-25 10:54:13 +01:00
|
|
|
uint32_t mFlags = 0;
|
2021-02-24 22:00:06 +01:00
|
|
|
public:
|
|
|
|
uint32_t intValue() const {
|
2021-02-25 10:54:13 +01:00
|
|
|
return mFlags;
|
2021-02-24 22:00:06 +01:00
|
|
|
}
|
|
|
|
void clear() {
|
2021-02-25 10:54:13 +01:00
|
|
|
mFlags = 0;
|
2021-02-24 22:00:06 +01:00
|
|
|
}
|
|
|
|
void fill() {
|
2021-02-25 10:54:13 +01:00
|
|
|
mFlags = 0xFFFFFFFF;
|
2021-02-24 22:00:06 +01:00
|
|
|
}
|
|
|
|
bool isEnabled(T flag) const {
|
2021-02-25 10:54:13 +01:00
|
|
|
return (mFlags & (1U << (uint32_t)flag)) != 0;
|
2021-02-24 22:00:06 +01:00
|
|
|
}
|
|
|
|
void enable(T flag) {
|
2021-02-25 10:54:13 +01:00
|
|
|
mFlags |= (1U << (uint32_t)flag);
|
2021-02-24 22:00:06 +01:00
|
|
|
}
|
2023-01-21 10:39:44 +01:00
|
|
|
void enable(SimpleEnableGroup<T> group) {
|
|
|
|
mFlags |= group.intValue();
|
|
|
|
}
|
2021-02-24 22:00:06 +01:00
|
|
|
void disable(T flag) {
|
2021-02-25 10:54:13 +01:00
|
|
|
mFlags &= ~(1U << (uint32_t)flag);
|
2021-02-24 22:00:06 +01:00
|
|
|
}
|
2023-01-21 10:39:44 +01:00
|
|
|
void disable(SimpleEnableGroup<T> group) {
|
|
|
|
mFlags &= ~(group.intValue());
|
|
|
|
}
|
2021-02-24 22:00:06 +01:00
|
|
|
void setEnabled(T flag, bool enabled) {
|
|
|
|
if (enabled)
|
|
|
|
enable(flag);
|
|
|
|
else
|
|
|
|
disable(flag);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2010-04-13 19:25:08 +02:00
|
|
|
/**
|
|
|
|
* @brief This is just a container for general settings so that we don't need
|
|
|
|
* to pass individual values to functions or constructors now or in the
|
|
|
|
* future when we might have even more detailed settings.
|
|
|
|
*/
|
2023-08-09 12:43:55 +02:00
|
|
|
class CPPCHECKLIB WARN_UNUSED Settings {
|
2010-04-13 19:25:08 +02:00
|
|
|
private:
|
|
|
|
|
|
|
|
/** @brief terminate checking */
|
2019-12-19 18:37:51 +01:00
|
|
|
static std::atomic<bool> mTerminated;
|
2010-04-13 19:25:08 +02:00
|
|
|
|
|
|
|
public:
|
|
|
|
Settings();
|
|
|
|
|
2023-12-01 16:34:14 +01:00
|
|
|
std::string loadCppcheckCfg();
|
2021-10-13 20:02:48 +02:00
|
|
|
|
2020-05-17 16:50:02 +02:00
|
|
|
/** @brief addons, either filename of python/json file or json data */
|
2022-10-31 15:04:16 +01:00
|
|
|
std::unordered_set<std::string> addons;
|
2019-04-13 15:34:50 +02:00
|
|
|
|
2023-10-08 21:28:57 +02:00
|
|
|
/** @brief the loaded addons infos */
|
|
|
|
std::vector<AddonInfo> addonInfos;
|
|
|
|
|
2020-04-05 10:57:28 +02:00
|
|
|
/** @brief Path to the python interpreter to be used to run addons. */
|
|
|
|
std::string addonPython;
|
|
|
|
|
2019-04-13 15:34:50 +02:00
|
|
|
/** @brief Paths used as base for conversion to relative paths. */
|
|
|
|
std::vector<std::string> basePaths;
|
|
|
|
|
2021-07-06 12:18:03 +02:00
|
|
|
/** @brief --cppcheck-build-dir. Always uses / as path separator. No trailing path separator. */
|
2016-10-29 12:18:11 +02:00
|
|
|
std::string buildDir;
|
|
|
|
|
2020-04-26 10:20:56 +02:00
|
|
|
/** @brief check all configurations (false if -D or --max-configs is used */
|
2023-08-08 11:05:02 +02:00
|
|
|
bool checkAllConfigurations = true;
|
2020-01-10 08:57:37 +01:00
|
|
|
|
2019-04-13 15:34:50 +02:00
|
|
|
/** Is the 'configuration checking' wanted? */
|
2023-08-08 11:05:02 +02:00
|
|
|
bool checkConfiguration{};
|
2019-04-13 15:34:50 +02:00
|
|
|
|
2020-04-26 15:24:25 +02:00
|
|
|
/**
|
|
|
|
* Check code in the headers, this is on by default but can
|
|
|
|
* be turned off to save CPU */
|
2023-08-08 11:05:02 +02:00
|
|
|
bool checkHeaders = true;
|
2020-04-26 15:24:25 +02:00
|
|
|
|
2019-04-13 15:34:50 +02:00
|
|
|
/** Check for incomplete info in library files? */
|
2023-08-08 11:05:02 +02:00
|
|
|
bool checkLibrary{};
|
2019-04-13 15:34:50 +02:00
|
|
|
|
2022-12-30 21:21:05 +01:00
|
|
|
/** @brief The maximum time in seconds for the checks of a single file */
|
2023-08-08 11:05:02 +02:00
|
|
|
int checksMaxTime{};
|
2022-12-30 21:21:05 +01:00
|
|
|
|
2023-08-29 12:00:52 +02:00
|
|
|
/** @brief --checkers-report=<filename> : Generate report of executed checkers */
|
|
|
|
std::string checkersReportFilename;
|
|
|
|
|
2020-04-26 10:20:56 +02:00
|
|
|
/** @brief check unknown function return values */
|
|
|
|
std::set<std::string> checkUnknownFunctionReturn;
|
|
|
|
|
2020-04-20 20:48:22 +02:00
|
|
|
/** Check unused/uninstantiated templates */
|
2023-08-08 11:05:02 +02:00
|
|
|
bool checkUnusedTemplates = true;
|
2019-04-13 15:34:50 +02:00
|
|
|
|
2021-04-30 16:47:02 +02:00
|
|
|
/** Use Clang */
|
2023-08-08 11:05:02 +02:00
|
|
|
bool clang{};
|
2021-04-30 16:47:02 +02:00
|
|
|
|
|
|
|
/** Custom Clang executable */
|
2023-08-08 11:05:02 +02:00
|
|
|
std::string clangExecutable = "clang";
|
2021-04-30 16:47:02 +02:00
|
|
|
|
2020-01-30 07:14:17 +01:00
|
|
|
/** Use clang-tidy */
|
2023-08-08 11:05:02 +02:00
|
|
|
bool clangTidy{};
|
2020-01-30 07:14:17 +01:00
|
|
|
|
2023-02-07 22:02:12 +01:00
|
|
|
/** Internal: Clear the simplecpp non-existing include cache */
|
2023-08-08 11:05:02 +02:00
|
|
|
bool clearIncludeCache{};
|
2023-02-07 22:02:12 +01:00
|
|
|
|
2019-04-13 15:34:50 +02:00
|
|
|
/** @brief include paths excluded from checking the configuration */
|
|
|
|
std::set<std::string> configExcludePaths;
|
|
|
|
|
2022-03-24 22:44:47 +01:00
|
|
|
/** cppcheck.cfg: Custom product name */
|
|
|
|
std::string cppcheckCfgProductName;
|
|
|
|
|
|
|
|
/** cppcheck.cfg: About text */
|
|
|
|
std::string cppcheckCfgAbout;
|
|
|
|
|
2020-03-31 11:33:22 +02:00
|
|
|
/** @brief Are we running from DACA script? */
|
2023-08-08 11:05:02 +02:00
|
|
|
bool daca{};
|
2020-03-31 11:33:22 +02:00
|
|
|
|
2015-07-28 12:46:32 +02:00
|
|
|
/** @brief Is --debug-normal given? */
|
2023-08-08 11:05:02 +02:00
|
|
|
bool debugnormal{};
|
2015-07-28 12:46:32 +02:00
|
|
|
|
2020-05-30 11:23:22 +02:00
|
|
|
/** @brief Is --debug-simplified given? */
|
2023-08-08 11:05:02 +02:00
|
|
|
bool debugSimplified{};
|
2020-05-30 11:23:22 +02:00
|
|
|
|
2019-01-14 08:29:32 +01:00
|
|
|
/** @brief Is --debug-template given? */
|
2023-08-08 11:05:02 +02:00
|
|
|
bool debugtemplate{};
|
2019-01-14 08:29:32 +01:00
|
|
|
|
2020-04-26 10:20:56 +02:00
|
|
|
/** @brief Is --debug-warnings given? */
|
2023-08-08 11:05:02 +02:00
|
|
|
bool debugwarnings{};
|
2020-04-26 10:20:56 +02:00
|
|
|
|
2014-07-14 15:51:45 +02:00
|
|
|
/** @brief Is --dump given? */
|
2023-08-08 11:05:02 +02:00
|
|
|
bool dump{};
|
2017-08-03 22:54:38 +02:00
|
|
|
std::string dumpFile;
|
2014-07-14 15:51:45 +02:00
|
|
|
|
2019-04-13 15:34:50 +02:00
|
|
|
enum Language {
|
|
|
|
None, C, CPP
|
|
|
|
};
|
|
|
|
|
|
|
|
/** @brief Name of the language that is enforced. Empty per default. */
|
2023-08-08 11:05:02 +02:00
|
|
|
Language enforcedLang{};
|
2019-04-13 15:34:50 +02:00
|
|
|
|
2023-10-21 09:12:59 +02:00
|
|
|
#if defined(USE_WINDOWS_SEH) || defined(USE_UNIX_SIGNAL_HANDLING)
|
2014-03-16 12:04:13 +01:00
|
|
|
/** @brief Is --exception-handling given */
|
2023-08-08 11:05:02 +02:00
|
|
|
bool exceptionHandling{};
|
2023-10-21 09:12:59 +02:00
|
|
|
#endif
|
2014-03-16 12:04:13 +01:00
|
|
|
|
2019-04-14 15:00:03 +02:00
|
|
|
// argv[0]
|
|
|
|
std::string exename;
|
|
|
|
|
2019-04-13 15:34:50 +02:00
|
|
|
/** @brief If errors are found, this value is returned from main().
|
|
|
|
Default value is 0. */
|
2023-08-08 11:05:02 +02:00
|
|
|
int exitCode{};
|
2015-01-07 19:26:16 +01:00
|
|
|
|
2021-11-23 22:51:45 +01:00
|
|
|
/** @brief List of --file-filter for analyzing special files */
|
|
|
|
std::vector<std::string> fileFilters;
|
2020-04-26 10:20:56 +02:00
|
|
|
|
2010-04-13 19:25:08 +02:00
|
|
|
/** @brief Force checking the files with "too many" configurations (--force). */
|
2023-08-08 11:05:02 +02:00
|
|
|
bool force{};
|
2010-04-13 19:25:08 +02:00
|
|
|
|
2019-04-13 15:34:50 +02:00
|
|
|
/** @brief List of include paths, e.g. "my/includes/" which should be used
|
|
|
|
for finding include files inside source files. (-I) */
|
|
|
|
std::list<std::string> includePaths;
|
2017-05-16 14:07:23 +02:00
|
|
|
|
2019-04-13 15:34:50 +02:00
|
|
|
/** @brief Is --inline-suppr given? */
|
2023-08-08 11:05:02 +02:00
|
|
|
bool inlineSuppressions{};
|
2010-12-01 21:24:17 +01:00
|
|
|
|
2010-04-13 19:25:08 +02:00
|
|
|
/** @brief How many processes/threads should do checking at the same
|
|
|
|
time. Default is 1. (-j N) */
|
2023-08-08 11:05:02 +02:00
|
|
|
unsigned int jobs = 1;
|
2010-04-13 19:25:08 +02:00
|
|
|
|
2019-04-13 15:34:50 +02:00
|
|
|
/** @brief --library= */
|
|
|
|
std::list<std::string> libraries;
|
2016-01-02 11:48:36 +01:00
|
|
|
|
2019-04-13 15:34:50 +02:00
|
|
|
/** Library */
|
|
|
|
Library library;
|
2019-04-12 06:47:28 +02:00
|
|
|
|
2019-04-13 15:34:50 +02:00
|
|
|
/** @brief Load average value */
|
2023-08-08 11:05:02 +02:00
|
|
|
int loadAverage{};
|
2010-04-13 19:25:08 +02:00
|
|
|
|
2011-10-22 11:11:54 +02:00
|
|
|
/** @brief Maximum number of configurations to check before bailing.
|
2011-10-05 07:37:43 +02:00
|
|
|
Default is 12. (--max-configs=N) */
|
2023-08-08 11:05:02 +02:00
|
|
|
int maxConfigs = 12;
|
2011-10-05 07:37:43 +02:00
|
|
|
|
2019-04-13 15:34:50 +02:00
|
|
|
/** @brief --max-ctu-depth */
|
2023-08-08 11:05:02 +02:00
|
|
|
int maxCtuDepth = 2;
|
2012-09-11 08:53:27 +02:00
|
|
|
|
2020-06-24 20:30:03 +02:00
|
|
|
/** @brief max template recursion */
|
2023-08-08 11:05:02 +02:00
|
|
|
int maxTemplateRecursion = 100;
|
2020-06-24 20:30:03 +02:00
|
|
|
|
2019-04-13 15:34:50 +02:00
|
|
|
/** @brief suppress exitcode */
|
|
|
|
Suppressions nofail;
|
2012-09-10 18:51:32 +02:00
|
|
|
|
2010-04-13 19:25:08 +02:00
|
|
|
/** @brief suppress message (--suppressions) */
|
|
|
|
Suppressions nomsg;
|
|
|
|
|
2019-04-13 15:34:50 +02:00
|
|
|
/** @brief write results (--output-file=<file>) */
|
|
|
|
std::string outputFile;
|
2010-05-16 07:38:29 +02:00
|
|
|
|
2023-10-13 16:02:04 +02:00
|
|
|
Platform platform;
|
2023-03-03 18:36:27 +01:00
|
|
|
|
2022-10-04 14:02:55 +02:00
|
|
|
/** @brief Experimental: --performance-valueflow-max-time=T */
|
2023-08-08 11:05:02 +02:00
|
|
|
int performanceValueFlowMaxTime = -1;
|
2022-10-04 14:02:55 +02:00
|
|
|
|
2023-04-01 20:58:15 +02:00
|
|
|
/** @brief --performance-valueflow-max-if-count=C */
|
2023-04-09 13:48:13 +02:00
|
|
|
int performanceValueFlowMaxIfCount;
|
2023-04-01 20:58:15 +02:00
|
|
|
|
2023-04-12 22:09:48 +02:00
|
|
|
/** @brief max number of sets of arguments to pass to subfuncions in valueflow */
|
|
|
|
int performanceValueFlowMaxSubFunctionArgs;
|
|
|
|
|
2019-04-13 15:34:50 +02:00
|
|
|
/** @brief plist output (--plist-output=<dir>) */
|
|
|
|
std::string plistOutput;
|
2010-05-21 19:35:18 +02:00
|
|
|
|
2022-08-22 21:11:28 +02:00
|
|
|
/** @brief Extra arguments for Cppcheck Premium addon */
|
|
|
|
std::string premiumArgs;
|
|
|
|
|
2019-04-13 15:34:50 +02:00
|
|
|
/** @brief Using -E for debugging purposes */
|
2023-08-08 11:05:02 +02:00
|
|
|
bool preprocessOnly{};
|
2011-11-30 20:24:01 +01:00
|
|
|
|
2019-04-13 15:34:50 +02:00
|
|
|
/** @brief Is --quiet given? */
|
2023-08-08 11:05:02 +02:00
|
|
|
bool quiet{};
|
2014-03-10 15:49:02 +01:00
|
|
|
|
2019-04-13 15:34:50 +02:00
|
|
|
/** @brief Use relative paths in output. */
|
2023-08-08 11:05:02 +02:00
|
|
|
bool relativePaths{};
|
2014-03-10 15:49:02 +01:00
|
|
|
|
2012-01-02 07:42:39 +01:00
|
|
|
/** @brief --report-progress */
|
2023-08-23 11:20:20 +02:00
|
|
|
int reportProgress{-1};
|
2010-08-12 21:03:33 +02:00
|
|
|
|
2023-10-21 09:12:59 +02:00
|
|
|
#ifdef HAVE_RULES
|
2010-12-12 11:56:22 +01:00
|
|
|
/** Rule */
|
2023-08-08 11:05:02 +02:00
|
|
|
struct CPPCHECKLIB Rule {
|
|
|
|
std::string tokenlist = "normal"; // use normal tokenlist
|
2010-12-12 11:56:22 +01:00
|
|
|
std::string pattern;
|
2023-08-08 11:05:02 +02:00
|
|
|
std::string id = "rule"; // default id
|
2010-12-12 11:56:22 +01:00
|
|
|
std::string summary;
|
2023-10-12 11:58:39 +02:00
|
|
|
Severity severity = Severity::style; // default severity
|
2010-12-12 11:56:22 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Extra rules
|
|
|
|
*/
|
2015-10-09 21:56:19 +02:00
|
|
|
std::list<Rule> rules;
|
2023-05-04 10:54:19 +02:00
|
|
|
#endif
|
2011-05-02 14:58:16 +02:00
|
|
|
|
2020-04-26 10:20:56 +02:00
|
|
|
/** Do not only check how interface is used. Also check that interface is safe. */
|
2023-08-08 11:05:02 +02:00
|
|
|
struct CPPCHECKLIB SafeChecks {
|
2020-04-26 10:20:56 +02:00
|
|
|
|
|
|
|
static const char XmlRootName[];
|
|
|
|
static const char XmlClasses[];
|
|
|
|
static const char XmlExternalFunctions[];
|
|
|
|
static const char XmlInternalFunctions[];
|
|
|
|
static const char XmlExternalVariables[];
|
|
|
|
|
|
|
|
void clear() {
|
|
|
|
classes = externalFunctions = internalFunctions = externalVariables = false;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Public interface of classes
|
|
|
|
* - public function parameters can have any value
|
|
|
|
* - public functions can be called in any order
|
|
|
|
* - public variables can have any value
|
|
|
|
*/
|
2023-08-08 11:05:02 +02:00
|
|
|
bool classes{};
|
2020-04-26 10:20:56 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* External functions
|
|
|
|
* - external functions can be called in any order
|
|
|
|
* - function parameters can have any values
|
|
|
|
*/
|
2023-08-08 11:05:02 +02:00
|
|
|
bool externalFunctions{};
|
2020-04-26 10:20:56 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Experimental: assume that internal functions can be used in any way
|
|
|
|
* This is only available in the GUI.
|
|
|
|
*/
|
2023-08-08 11:05:02 +02:00
|
|
|
bool internalFunctions{};
|
2020-04-26 10:20:56 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Global variables that can be modified outside the TU.
|
|
|
|
* - Such variable can have "any" value
|
|
|
|
*/
|
2023-08-08 11:05:02 +02:00
|
|
|
bool externalVariables{};
|
2020-04-26 10:20:56 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
SafeChecks safeChecks;
|
|
|
|
|
2023-10-12 11:58:39 +02:00
|
|
|
SimpleEnableGroup<Severity> severity;
|
2023-01-08 19:31:54 +01:00
|
|
|
SimpleEnableGroup<Certainty> certainty;
|
|
|
|
SimpleEnableGroup<Checks> checks;
|
2021-02-24 22:00:06 +01:00
|
|
|
|
2019-04-13 15:34:50 +02:00
|
|
|
/** @brief show timing information (--showtime=file|summary|top5) */
|
2023-08-08 11:05:02 +02:00
|
|
|
SHOWTIME_MODES showtime{};
|
2019-04-07 17:01:59 +02:00
|
|
|
|
2019-04-13 15:34:50 +02:00
|
|
|
/** Struct contains standards settings */
|
|
|
|
Standards standards;
|
2011-08-14 09:45:27 +02:00
|
|
|
|
2019-04-13 15:34:50 +02:00
|
|
|
/** @brief The output format in which the errors are printed in text mode,
|
|
|
|
e.g. "{severity} {file}:{line} {message} {id}" */
|
|
|
|
std::string templateFormat;
|
2013-07-08 18:26:18 +02:00
|
|
|
|
2019-04-13 15:34:50 +02:00
|
|
|
/** @brief The output format in which the error locations are printed in
|
|
|
|
* text mode, e.g. "{file}:{line} {info}" */
|
|
|
|
std::string templateLocation;
|
2019-03-02 19:52:15 +01:00
|
|
|
|
2023-01-10 15:15:27 +01:00
|
|
|
/** @brief The maximum time in seconds for the template instantiation */
|
2023-08-08 11:05:02 +02:00
|
|
|
std::size_t templateMaxTime{};
|
2022-12-30 21:21:05 +01:00
|
|
|
|
|
|
|
/** @brief The maximum time in seconds for the typedef simplification */
|
2023-08-08 11:05:02 +02:00
|
|
|
std::size_t typedefMaxTime{};
|
2022-12-30 21:21:05 +01:00
|
|
|
|
2023-12-17 15:42:17 +01:00
|
|
|
/** @brief Unsafe exitcode => do not force non-zero exitcode when there are critical errors */
|
|
|
|
bool unsafeExitCode = false;
|
|
|
|
|
2019-04-13 15:34:50 +02:00
|
|
|
/** @brief defines given by the user */
|
|
|
|
std::string userDefines;
|
2019-03-04 19:10:16 +01:00
|
|
|
|
2019-04-13 15:34:50 +02:00
|
|
|
/** @brief undefines given by the user */
|
|
|
|
std::set<std::string> userUndefs;
|
2011-10-16 12:54:58 +02:00
|
|
|
|
2019-04-13 15:34:50 +02:00
|
|
|
/** @brief forced includes given by the user */
|
|
|
|
std::list<std::string> userIncludes;
|
|
|
|
|
2022-12-20 20:51:08 +01:00
|
|
|
/** @brief the maximum iterations of valueflow (--valueflow-max-iterations=T) */
|
2023-08-08 11:05:02 +02:00
|
|
|
std::size_t valueFlowMaxIterations = 4;
|
2022-12-20 20:51:08 +01:00
|
|
|
|
2019-04-13 15:34:50 +02:00
|
|
|
/** @brief Is --verbose given? */
|
2023-08-08 11:05:02 +02:00
|
|
|
bool verbose{};
|
2019-04-13 15:34:50 +02:00
|
|
|
|
|
|
|
/** @brief write XML results (--xml) */
|
2023-08-08 11:05:02 +02:00
|
|
|
bool xml{};
|
2019-04-13 15:34:50 +02:00
|
|
|
|
|
|
|
/** @brief XML version (--xml-version=..) */
|
2023-08-08 11:05:02 +02:00
|
|
|
int xml_version = 2;
|
2016-07-31 19:47:34 +02:00
|
|
|
|
2014-03-10 15:49:02 +01:00
|
|
|
/**
|
2016-09-30 08:00:06 +02:00
|
|
|
* @brief return true if a included file is to be excluded in Preprocessor::getConfigs
|
2014-03-10 15:49:02 +01:00
|
|
|
* @return true for the file to be excluded.
|
|
|
|
*/
|
2014-11-20 14:20:09 +01:00
|
|
|
bool configurationExcluded(const std::string &file) const {
|
2023-03-04 11:58:12 +01:00
|
|
|
return std::any_of(configExcludePaths.begin(), configExcludePaths.end(), [&file](const std::string& path) {
|
|
|
|
return file.length() >= path.length() && file.compare(0, path.length(), path) == 0;
|
|
|
|
});
|
2014-03-10 15:49:02 +01:00
|
|
|
}
|
2019-04-13 15:34:50 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Enable extra checks by id. See isEnabled()
|
|
|
|
* @param str single id or list of id values to be enabled
|
|
|
|
* or empty string to enable all. e.g. "style,possibleError"
|
|
|
|
* @return error message. empty upon success
|
|
|
|
*/
|
|
|
|
std::string addEnabled(const std::string &str);
|
|
|
|
|
2023-01-21 10:39:44 +01:00
|
|
|
/**
|
|
|
|
* @brief Disable extra checks by id
|
|
|
|
* @param str single id or list of id values to be enabled
|
|
|
|
* or empty string to enable all. e.g. "style,possibleError"
|
|
|
|
* @return error message. empty upon success
|
|
|
|
*/
|
|
|
|
std::string removeEnabled(const std::string &str);
|
|
|
|
|
2019-04-13 15:34:50 +02:00
|
|
|
/**
|
2021-08-07 20:51:18 +02:00
|
|
|
* @brief Returns true if given value can be shown
|
|
|
|
* @return true if the value can be shown
|
|
|
|
*/
|
2019-04-13 15:34:50 +02:00
|
|
|
bool isEnabled(const ValueFlow::Value *value, bool inconclusiveCheck=false) const;
|
|
|
|
|
2023-03-02 21:10:51 +01:00
|
|
|
/** Is library specified? */
|
|
|
|
bool hasLib(const std::string &lib) const {
|
|
|
|
return std::find(libraries.cbegin(), libraries.cend(), lib) != libraries.cend();
|
2019-04-13 15:34:50 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/** @brief Request termination of checking */
|
|
|
|
static void terminate(bool t = true) {
|
|
|
|
Settings::mTerminated = t;
|
|
|
|
}
|
|
|
|
|
|
|
|
/** @brief termination requested? */
|
|
|
|
static bool terminated() {
|
|
|
|
return Settings::mTerminated;
|
|
|
|
}
|
2020-12-19 19:02:42 +01:00
|
|
|
|
2020-12-20 14:49:34 +01:00
|
|
|
std::set<std::string> summaryReturn;
|
2020-12-19 19:02:42 +01:00
|
|
|
|
|
|
|
void loadSummaries();
|
2023-01-21 10:39:44 +01:00
|
|
|
|
2023-04-08 18:06:38 +02:00
|
|
|
bool useSingleJob() const {
|
|
|
|
return jobs == 1;
|
|
|
|
}
|
|
|
|
|
2023-04-09 13:48:13 +02:00
|
|
|
void setCheckLevelExhaustive();
|
|
|
|
void setCheckLevelNormal();
|
|
|
|
|
2023-01-21 10:39:44 +01:00
|
|
|
private:
|
2023-10-12 11:58:39 +02:00
|
|
|
static std::string parseEnabled(const std::string &str, std::tuple<SimpleEnableGroup<Severity>, SimpleEnableGroup<Checks>> &groups);
|
2023-01-21 10:39:44 +01:00
|
|
|
std::string applyEnabled(const std::string &str, bool enable);
|
2010-04-13 19:25:08 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
/// @}
|
2013-09-04 20:59:49 +02:00
|
|
|
//---------------------------------------------------------------------------
|
|
|
|
#endif // settingsH
|