aboutsummaryrefslogtreecommitdiffstats
path: root/src/plugins/clangtools/clangtoolrunner.cpp
diff options
context:
space:
mode:
authorJarek Kobus <[email protected]>2023-01-10 17:51:34 +0100
committerJarek Kobus <[email protected]>2023-01-11 09:15:28 +0000
commitc7b60e7d6b098a3b5ea343f7b3c9b1023247a3a2 (patch)
tree2435f0d7cefb778d1336a71ec69b408a22ed56e5 /src/plugins/clangtools/clangtoolrunner.cpp
parent0139690c2944a158f6de5bb56429fca8a2ce6b75 (diff)
ClangToolRunner: Flatten the class hierarchy
Instead of creating subclasses of ClangToolRunner configure the base class according to the tool specifics. Change-Id: I51b611b2375571453c7f9690499d744582f035c1 Reviewed-by: <[email protected]> Reviewed-by: David Schulz <[email protected]>
Diffstat (limited to 'src/plugins/clangtools/clangtoolrunner.cpp')
-rw-r--r--src/plugins/clangtools/clangtoolrunner.cpp63
1 files changed, 56 insertions, 7 deletions
diff --git a/src/plugins/clangtools/clangtoolrunner.cpp b/src/plugins/clangtools/clangtoolrunner.cpp
index 3a915a549e0..cc8a253df32 100644
--- a/src/plugins/clangtools/clangtoolrunner.cpp
+++ b/src/plugins/clangtools/clangtoolrunner.cpp
@@ -3,6 +3,11 @@
#include "clangtoolrunner.h"
+#include "clangtoolsutils.h"
+
+#include <cppeditor/clangdiagnosticconfigsmodel.h>
+#include <cppeditor/compileroptionsbuilder.h>
+
#include <utils/environment.h>
#include <utils/qtcassert.h>
#include <utils/qtcprocess.h>
@@ -15,11 +20,50 @@
static Q_LOGGING_CATEGORY(LOG, "qtc.clangtools.runner", QtWarningMsg)
+using namespace CppEditor;
using namespace Utils;
namespace ClangTools {
namespace Internal {
+static bool isClMode(const QStringList &options)
+{
+ return options.contains("--driver-mode=cl");
+}
+
+static QStringList checksArguments(ClangToolType tool,
+ const ClangDiagnosticConfig &diagnosticConfig)
+{
+ if (tool == ClangToolType::Tidy) {
+ const ClangDiagnosticConfig::TidyMode tidyMode = diagnosticConfig.clangTidyMode();
+ // The argument "-config={}" stops stating/evaluating the .clang-tidy file.
+ if (tidyMode == ClangDiagnosticConfig::TidyMode::UseDefaultChecks)
+ return {"-config={}", "-checks=-clang-diagnostic-*"};
+ if (tidyMode == ClangDiagnosticConfig::TidyMode::UseCustomChecks)
+ return {"-config=" + diagnosticConfig.clangTidyChecksAsJson()};
+ return {"--warnings-as-errors=-*", "-checks=-clang-diagnostic-*"};
+ }
+ const QString clazyChecks = diagnosticConfig.checks(ClangToolType::Clazy);
+ if (!clazyChecks.isEmpty())
+ return {"-checks=" + diagnosticConfig.checks(ClangToolType::Clazy)};
+ return {};
+}
+
+static QStringList clangArguments(const ClangDiagnosticConfig &diagnosticConfig,
+ const QStringList &baseOptions)
+{
+ QStringList arguments;
+ arguments << ClangDiagnosticConfigsModel::globalDiagnosticOptions()
+ << (isClMode(baseOptions) ? clangArgsForCl(diagnosticConfig.clangOptions())
+ : diagnosticConfig.clangOptions())
+ << baseOptions;
+
+ if (LOG().isDebugEnabled())
+ arguments << QLatin1String("-v");
+
+ return arguments;
+}
+
static QString generalProcessError(const QString &name)
{
return ClangToolRunner::tr("An error occurred with the %1 process.").arg(name);
@@ -35,16 +79,21 @@ static QString finishedWithBadExitCode(const QString &name, int exitCode)
return ClangToolRunner::tr("%1 finished with exit code: %2.").arg(name).arg(exitCode);
}
-ClangToolRunner::ClangToolRunner(QObject *parent)
+ClangToolRunner::ClangToolRunner(const AnalyzeInputData &input, QObject *parent)
: QObject(parent)
-{}
-
-void ClangToolRunner::init(const FilePath &outputDirPath, const Environment &environment)
{
- m_outputDirPath = outputDirPath;
+ m_name = input.tool == ClangToolType::Tidy ? tr("Clang-Tidy") : tr("Clazy");
+ m_executable = toolExecutable(input.tool);
+ m_argsCreator = [this, input](const QStringList &baseOptions) {
+ return QStringList() << checksArguments(input.tool, input.config)
+ << mainToolArguments()
+ << "--"
+ << clangArguments(input.config, baseOptions);
+ };
+ m_outputDirPath = input.outputDirPath;
QTC_CHECK(!m_outputDirPath.isEmpty());
- m_process.setEnvironment(environment);
+ m_process.setEnvironment(input.environment);
m_process.setUseCtrlCStub(true);
m_process.setWorkingDirectory(m_outputDirPath); // Current clang-cl puts log file into working dir.
connect(&m_process, &QtcProcess::done, this, &ClangToolRunner::onProcessDone);
@@ -85,7 +134,7 @@ static QString createOutputFilePath(const FilePath &dirPath, const QString &file
temporaryFile.close();
return temporaryFile.fileName();
}
- return QString();
+ return {};
}
bool ClangToolRunner::run(const QString &fileToAnalyze, const QStringList &compilerOptions)