summaryrefslogtreecommitdiff
path: root/src/plugins/cpptools/clangdiagnosticconfig.cpp
diff options
context:
space:
mode:
authorChristian Kandeler <christian.kandeler@qt.io>2020-12-16 10:48:36 +0100
committerChristian Kandeler <christian.kandeler@qt.io>2021-01-06 12:39:41 +0000
commit1a09f816a38cd4672172229971784d6bf9969846 (patch)
treed1394fcec763377a6b98f8eeec196b230d5c9841 /src/plugins/cpptools/clangdiagnosticconfig.cpp
parent13c9b42a216f56c33da57f54ecdae5797271407e (diff)
downloadqt-creator-1a09f816a38cd4672172229971784d6bf9969846.tar.gz
ClangTools: Support clang-tidy check options
Fixes: QTCREATORBUG-24977 Change-Id: I33ea247ba98788245ae1264262f60d084b73778c Reviewed-by: Alessandro Portale <alessandro.portale@qt.io>
Diffstat (limited to 'src/plugins/cpptools/clangdiagnosticconfig.cpp')
-rw-r--r--src/plugins/cpptools/clangdiagnosticconfig.cpp63
1 files changed, 63 insertions, 0 deletions
diff --git a/src/plugins/cpptools/clangdiagnosticconfig.cpp b/src/plugins/cpptools/clangdiagnosticconfig.cpp
index 3c3758c37a..c31fc4f8ce 100644
--- a/src/plugins/cpptools/clangdiagnosticconfig.cpp
+++ b/src/plugins/cpptools/clangdiagnosticconfig.cpp
@@ -79,6 +79,7 @@ bool ClangDiagnosticConfig::operator==(const ClangDiagnosticConfig &other) const
&& m_clangOptions == other.m_clangOptions
&& m_clangTidyMode == other.m_clangTidyMode
&& m_clangTidyChecks == other.m_clangTidyChecks
+ && m_tidyChecksOptions == other.m_tidyChecksOptions
&& m_clazyMode == other.m_clazyMode
&& m_clazyChecks == other.m_clazyChecks
&& m_isReadOnly == other.m_isReadOnly
@@ -125,6 +126,28 @@ QString ClangDiagnosticConfig::clangTidyChecks() const
return m_clangTidyChecks;
}
+QString ClangDiagnosticConfig::clangTidyChecksAsJson() const
+{
+ QString jsonString = "{Checks: '" + clangTidyChecks()
+ + ",-clang-diagnostic-*', CheckOptions: [";
+ for (auto it = m_tidyChecksOptions.cbegin(); it != m_tidyChecksOptions.cend(); ++it) {
+ const int idx = m_clangTidyChecks.indexOf(it.key());
+ if (idx == -1)
+ continue;
+ if (idx > 0 && m_clangTidyChecks.at(idx - 1) == '-')
+ continue;
+ QString optionString;
+ for (auto optIt = it.value().begin(); optIt != it.value().end(); ++optIt) {
+ if (!optionString.isEmpty())
+ optionString += ',';
+ optionString += "{key: '" + it.key() + '.' + optIt.key()
+ + "', value: '" + optIt.value() + "'}";
+ }
+ jsonString += optionString;
+ }
+ return jsonString += "]}";
+}
+
void ClangDiagnosticConfig::setClangTidyChecks(const QString &checks)
{
m_clangTidyChecks = checks;
@@ -135,6 +158,42 @@ bool ClangDiagnosticConfig::isClangTidyEnabled() const
return m_clangTidyMode != TidyMode::UseCustomChecks || clangTidyChecks() != "-*";
}
+void ClangDiagnosticConfig::setTidyCheckOptions(const QString &check,
+ const TidyCheckOptions &options)
+{
+ m_tidyChecksOptions[check] = options;
+}
+
+ClangDiagnosticConfig::TidyCheckOptions
+ClangDiagnosticConfig::tidyCheckOptions(const QString &check) const
+{
+ return m_tidyChecksOptions.value(check);
+}
+
+void ClangDiagnosticConfig::setTidyChecksOptionsFromSettings(const QVariant &options)
+{
+ const QVariantMap topLevelMap = options.toMap();
+ for (auto it = topLevelMap.begin(); it != topLevelMap.end(); ++it) {
+ const QVariantMap optionsMap = it.value().toMap();
+ TidyCheckOptions options;
+ for (auto optIt = optionsMap.begin(); optIt != optionsMap.end(); ++optIt)
+ options.insert(optIt.key(), optIt.value().toString());
+ m_tidyChecksOptions.insert(it.key(), options);
+ }
+}
+
+QVariant ClangDiagnosticConfig::tidyChecksOptionsForSettings() const
+{
+ QVariantMap topLevelMap;
+ for (auto it = m_tidyChecksOptions.cbegin(); it != m_tidyChecksOptions.cend(); ++it) {
+ QVariantMap optionsMap;
+ for (auto optIt = it.value().begin(); optIt != it.value().end(); ++optIt)
+ optionsMap.insert(optIt.key(), optIt.value());
+ topLevelMap.insert(it.key(), optionsMap);
+ }
+ return topLevelMap;
+}
+
QString ClangDiagnosticConfig::clazyChecks() const
{
return m_clazyChecks;
@@ -168,6 +227,7 @@ static const char diagnosticConfigDisplayNameKey[] = "displayName";
static const char diagnosticConfigWarningsKey[] = "diagnosticOptions";
static const char useBuildSystemFlagsKey[] = "useBuildSystemFlags";
static const char diagnosticConfigsTidyChecksKey[] = "clangTidyChecks";
+static const char diagnosticConfigsTidyChecksOptionsKey[] = "clangTidyChecksOptions";
static const char diagnosticConfigsTidyModeKey[] = "clangTidyMode";
static const char diagnosticConfigsClazyModeKey[] = "clazyMode";
static const char diagnosticConfigsClazyChecksKey[] = "clazyChecks";
@@ -184,6 +244,7 @@ void diagnosticConfigsToSettings(QSettings *s, const ClangDiagnosticConfigs &con
s->setValue(useBuildSystemFlagsKey, config.useBuildSystemWarnings());
s->setValue(diagnosticConfigsTidyModeKey, int(config.clangTidyMode()));
s->setValue(diagnosticConfigsTidyChecksKey, config.clangTidyChecks());
+ s->setValue(diagnosticConfigsTidyChecksOptionsKey, config.tidyChecksOptionsForSettings());
s->setValue(diagnosticConfigsClazyModeKey, int(config.clazyMode()));
s->setValue(diagnosticConfigsClazyChecksKey, config.clazyChecks());
}
@@ -210,6 +271,8 @@ ClangDiagnosticConfigs diagnosticConfigsFromSettings(QSettings *s)
} else {
config.setClangTidyMode(static_cast<ClangDiagnosticConfig::TidyMode>(tidyModeValue));
config.setClangTidyChecks(s->value(diagnosticConfigsTidyChecksKey).toString());
+ config.setTidyChecksOptionsFromSettings(
+ s->value(diagnosticConfigsTidyChecksOptionsKey));
}
config.setClazyMode(static_cast<ClangDiagnosticConfig::ClazyMode>(