summaryrefslogtreecommitdiff
path: root/src/plugins/cpptools/clangdiagnosticconfig.cpp
diff options
context:
space:
mode:
authorChristian Kandeler <christian.kandeler@qt.io>2021-08-30 10:58:08 +0200
committerChristian Kandeler <christian.kandeler@qt.io>2021-09-01 14:53:58 +0000
commit284817fae6514701902ccdb834c2faa46462f2e8 (patch)
tree44a8c7d9813dc110b61c4639036366c7696bd7e9 /src/plugins/cpptools/clangdiagnosticconfig.cpp
parent3e1fa0f170d523971d2c3c12da15a6e291f56511 (diff)
downloadqt-creator-284817fae6514701902ccdb834c2faa46462f2e8.tar.gz
Merge CppTools into CppEditor
There was no proper separation of responsibilities between these plugins. In particular, CppTools had lots of editor-related functionality, so it's not clear why it was separated out in the first place. In fact, for a lot of code, it seemed quite arbitrary where it was put (just one example: switchHeaderSource() was in CppTools, wheras switchDeclarationDefinition() was in CppEditor). Merging the plugins will enable us to get rid of various convoluted pseudo-abstractions that were only introduced to keep up the artificial separation. Change-Id: Iafc3bce625b4794f6d4aa03df6cddc7f2d26716a Reviewed-by: Christian Stenger <christian.stenger@qt.io>
Diffstat (limited to 'src/plugins/cpptools/clangdiagnosticconfig.cpp')
-rw-r--r--src/plugins/cpptools/clangdiagnosticconfig.cpp304
1 files changed, 0 insertions, 304 deletions
diff --git a/src/plugins/cpptools/clangdiagnosticconfig.cpp b/src/plugins/cpptools/clangdiagnosticconfig.cpp
deleted file mode 100644
index e4ad6ed114..0000000000
--- a/src/plugins/cpptools/clangdiagnosticconfig.cpp
+++ /dev/null
@@ -1,304 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2016 The Qt Company Ltd.
-** Contact: https://www.qt.io/licensing/
-**
-** This file is part of Qt Creator.
-**
-** Commercial License Usage
-** Licensees holding valid commercial Qt licenses may use this file in
-** accordance with the commercial license agreement provided with the
-** Software or, alternatively, in accordance with the terms contained in
-** a written agreement between you and The Qt Company. For licensing terms
-** and conditions see https://www.qt.io/terms-conditions. For further
-** information use the contact form at https://www.qt.io/contact-us.
-**
-** GNU General Public License Usage
-** Alternatively, this file may be used under the terms of the GNU
-** General Public License version 3 as published by the Free Software
-** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT
-** included in the packaging of this file. Please review the following
-** information to ensure the GNU General Public License requirements will
-** be met: https://www.gnu.org/licenses/gpl-3.0.html.
-**
-****************************************************************************/
-
-#include "clangdiagnosticconfig.h"
-#include "cpptoolsreuse.h"
-
-#include <utils/qtcassert.h>
-
-#include <QSettings>
-
-namespace CppTools {
-
-Utils::Id ClangDiagnosticConfig::id() const
-{
- return m_id;
-}
-
-void ClangDiagnosticConfig::setId(const Utils::Id &id)
-{
- m_id = id;
-}
-
-QString ClangDiagnosticConfig::displayName() const
-{
- return m_displayName;
-}
-
-void ClangDiagnosticConfig::setDisplayName(const QString &displayName)
-{
- m_displayName = displayName;
-}
-
-QStringList ClangDiagnosticConfig::clangOptions() const
-{
- return m_clangOptions;
-}
-
-void ClangDiagnosticConfig::setClangOptions(const QStringList &options)
-{
- m_clangOptions = options;
-}
-
-bool ClangDiagnosticConfig::isReadOnly() const
-{
- return m_isReadOnly;
-}
-
-void ClangDiagnosticConfig::setIsReadOnly(bool isReadOnly)
-{
- m_isReadOnly = isReadOnly;
-}
-
-bool ClangDiagnosticConfig::operator==(const ClangDiagnosticConfig &other) const
-{
- return m_id == other.m_id
- && m_displayName == other.m_displayName
- && 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
- && m_useBuildSystemWarnings == other.m_useBuildSystemWarnings;
-}
-
-bool ClangDiagnosticConfig::operator!=(const ClangDiagnosticConfig &other) const
-{
- return !(*this == other);
-}
-
-ClangDiagnosticConfig::ClazyMode ClangDiagnosticConfig::clazyMode() const
-{
- return m_clazyMode;
-}
-
-void ClangDiagnosticConfig::setClazyMode(const ClazyMode &clazyMode)
-{
- m_clazyMode = clazyMode;
-}
-
-bool ClangDiagnosticConfig::useBuildSystemWarnings() const
-{
- return m_useBuildSystemWarnings;
-}
-
-void ClangDiagnosticConfig::setUseBuildSystemWarnings(bool useBuildSystemWarnings)
-{
- m_useBuildSystemWarnings = useBuildSystemWarnings;
-}
-
-ClangDiagnosticConfig::TidyMode ClangDiagnosticConfig::clangTidyMode() const
-{
- return m_clangTidyMode;
-}
-
-void ClangDiagnosticConfig::setClangTidyMode(TidyMode mode)
-{
- m_clangTidyMode = mode;
-}
-
-QString ClangDiagnosticConfig::clangTidyChecks() const
-{
- return m_clangTidyChecks;
-}
-
-QString ClangDiagnosticConfig::clangTidyChecksAsJson() const
-{
- QString jsonString = "{Checks: '" + clangTidyChecks()
- + ",-clang-diagnostic-*', CheckOptions: [";
-
- // The check is either listed verbatim or covered by the "<prefix>-*" pattern.
- const auto checkIsEnabled = [this](const QString &check) {
- for (QString subString = check; !subString.isEmpty();
- subString.chop(subString.length() - subString.lastIndexOf('-'))) {
- const int idx = m_clangTidyChecks.indexOf(subString);
- if (idx == -1)
- continue;
- if (idx > 0 && m_clangTidyChecks.at(idx - 1) == '-')
- continue;
- if (subString == check || QStringView(m_clangTidyChecks)
- .mid(idx + subString.length()).startsWith(QLatin1String("-*"))) {
- return true;
- }
- }
- return false;
- };
-
- QString optionString;
- for (auto it = m_tidyChecksOptions.cbegin(); it != m_tidyChecksOptions.cend(); ++it) {
- if (!checkIsEnabled(it.key()))
- continue;
- 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;
-}
-
-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;
-}
-
-void ClangDiagnosticConfig::setClazyChecks(const QString &checks)
-{
- m_clazyChecks = checks;
-}
-
-bool ClangDiagnosticConfig::isClazyEnabled() const
-{
- return m_clazyMode != ClazyMode::UseCustomChecks || !m_clazyChecks.isEmpty();
-}
-
-static QString convertToNewClazyChecksFormat(const QString &checks)
-{
- // Before Qt Creator 4.9 valid values for checks were: "", "levelN".
- // Starting with Qt Creator 4.9, checks are a comma-separated string of checks: "x,y,z".
-
- if (checks.isEmpty())
- return {};
- if (checks.size() == 6 && checks.startsWith("level"))
- return {};
- return checks;
-}
-
-static const char diagnosticConfigsArrayKey[] = "ClangDiagnosticConfigs";
-static const char diagnosticConfigIdKey[] = "id";
-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";
-
-void diagnosticConfigsToSettings(QSettings *s, const ClangDiagnosticConfigs &configs)
-{
- s->beginWriteArray(diagnosticConfigsArrayKey);
- for (int i = 0, size = configs.size(); i < size; ++i) {
- const ClangDiagnosticConfig &config = configs.at(i);
- s->setArrayIndex(i);
- s->setValue(diagnosticConfigIdKey, config.id().toSetting());
- s->setValue(diagnosticConfigDisplayNameKey, config.displayName());
- s->setValue(diagnosticConfigWarningsKey, config.clangOptions());
- 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());
- }
- s->endArray();
-}
-
-ClangDiagnosticConfigs diagnosticConfigsFromSettings(QSettings *s)
-{
- ClangDiagnosticConfigs configs;
-
- const int size = s->beginReadArray(diagnosticConfigsArrayKey);
- for (int i = 0; i < size; ++i) {
- s->setArrayIndex(i);
-
- ClangDiagnosticConfig config;
- config.setId(Utils::Id::fromSetting(s->value(diagnosticConfigIdKey)));
- config.setDisplayName(s->value(diagnosticConfigDisplayNameKey).toString());
- config.setClangOptions(s->value(diagnosticConfigWarningsKey).toStringList());
- config.setUseBuildSystemWarnings(s->value(useBuildSystemFlagsKey, false).toBool());
- const int tidyModeValue = s->value(diagnosticConfigsTidyModeKey).toInt();
- if (tidyModeValue == 0) { // Convert from settings of <= Qt Creator 4.10
- config.setClangTidyMode(ClangDiagnosticConfig::TidyMode::UseCustomChecks);
- config.setClangTidyChecks("-*");
- } 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>(
- s->value(diagnosticConfigsClazyModeKey).toInt()));
- const QString clazyChecks = s->value(diagnosticConfigsClazyChecksKey).toString();
- config.setClazyChecks(convertToNewClazyChecksFormat(clazyChecks));
- configs.append(config);
- }
- s->endArray();
-
- return configs;
-}
-
-} // namespace CppTools