forked from qt-creator/qt-creator
ClangTools: Remove clang executable settings
We use custom clang executable and it does not make sense anymore to give a choice of changing it. Change-Id: Icf86042ac3fcd08c320ef2bbdaabef1102b023b5 Reviewed-by: Nikolai Kosjar <nikolai.kosjar@qt.io>
This commit is contained in:
@@ -28,6 +28,8 @@
|
||||
#include "clangtoolsdiagnostic.h"
|
||||
#include "clangtoolssettings.h"
|
||||
|
||||
#include <coreplugin/icore.h>
|
||||
|
||||
#include <projectexplorer/projectexplorerconstants.h>
|
||||
|
||||
#include <utils/hostosinfo.h>
|
||||
@@ -38,118 +40,14 @@
|
||||
#include <QFileInfo>
|
||||
#include <QRegularExpression>
|
||||
|
||||
static bool isFileExecutable(const QString &executablePath)
|
||||
{
|
||||
if (executablePath.isEmpty())
|
||||
return false;
|
||||
|
||||
const QFileInfo fileInfo(executablePath);
|
||||
return fileInfo.isFile() && fileInfo.isExecutable();
|
||||
}
|
||||
|
||||
namespace ClangTools {
|
||||
namespace Internal {
|
||||
|
||||
QString clangExecutableFromSettings(bool *isValid)
|
||||
{
|
||||
QString executable = ClangToolsSettings::instance()->clangExecutable();
|
||||
if (executable.isEmpty()) {
|
||||
*isValid = false;
|
||||
return executable;
|
||||
}
|
||||
|
||||
const QString hostExeSuffix = QLatin1String(QTC_HOST_EXE_SUFFIX);
|
||||
const Qt::CaseSensitivity caseSensitivity = Utils::HostOsInfo::fileNameCaseSensitivity();
|
||||
const bool hasSuffix = executable.endsWith(hostExeSuffix, caseSensitivity);
|
||||
|
||||
const QFileInfo fileInfo = QFileInfo(executable);
|
||||
if (fileInfo.isAbsolute()) {
|
||||
if (!hasSuffix)
|
||||
executable.append(hostExeSuffix);
|
||||
} else {
|
||||
const Utils::Environment &environment = Utils::Environment::systemEnvironment();
|
||||
const QString executableFromPath = environment.searchInPath(executable).toString();
|
||||
if (executableFromPath.isEmpty()) {
|
||||
*isValid = false;
|
||||
return executable;
|
||||
}
|
||||
executable = executableFromPath;
|
||||
}
|
||||
|
||||
*isValid = isFileExecutable(executable) && isClangExecutableUsable(executable);
|
||||
return executable;
|
||||
}
|
||||
|
||||
QString createFullLocationString(const Debugger::DiagnosticLocation &location)
|
||||
{
|
||||
return location.filePath + QLatin1Char(':') + QString::number(location.line)
|
||||
+ QLatin1Char(':') + QString::number(location.column);
|
||||
}
|
||||
|
||||
bool isClangExecutableUsable(const QString &filePath, QString *errorMessage)
|
||||
{
|
||||
const QFileInfo fi(filePath);
|
||||
if (fi.isSymLink() && fi.symLinkTarget().contains(QLatin1String("icecc"))) {
|
||||
if (errorMessage) {
|
||||
*errorMessage = QCoreApplication::translate("ClangTools",
|
||||
"The chosen file \"%1\" seems to point to an icecc binary not suitable "
|
||||
"for analyzing.\nPlease set a real Clang executable.")
|
||||
.arg(filePath);
|
||||
}
|
||||
return false;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
ClangExecutableVersion clangExecutableVersion(const QString &executable)
|
||||
{
|
||||
const ClangExecutableVersion invalidVersion;
|
||||
|
||||
// Sanity checks
|
||||
const QFileInfo fileInfo(executable);
|
||||
const bool isExecutableFile = fileInfo.isFile() && fileInfo.isExecutable();
|
||||
if (!isExecutableFile)
|
||||
return invalidVersion;
|
||||
|
||||
// Get version output
|
||||
Utils::Environment environment = Utils::Environment::systemEnvironment();
|
||||
Utils::Environment::setupEnglishOutput(&environment);
|
||||
Utils::SynchronousProcess runner;
|
||||
runner.setEnvironment(environment.toStringList());
|
||||
runner.setTimeoutS(10);
|
||||
// We would prefer "-dumpversion", but that one is only there for GCC compatibility
|
||||
// and returns some static/old version.
|
||||
// See also https://bugs.llvm.org/show_bug.cgi?id=28597
|
||||
const QStringList arguments(QLatin1String(("--version")));
|
||||
const Utils::SynchronousProcessResponse response = runner.runBlocking(executable, arguments);
|
||||
if (response.result != Utils::SynchronousProcessResponse::Finished)
|
||||
return invalidVersion;
|
||||
const QString output = response.stdOut();
|
||||
|
||||
// Parse version output
|
||||
const QRegularExpression re(QLatin1String("clang version (\\d+)\\.(\\d+)\\.(\\d+)"));
|
||||
const QRegularExpressionMatch reMatch = re.match(output);
|
||||
if (re.captureCount() != 3)
|
||||
return invalidVersion;
|
||||
|
||||
const QString majorString = reMatch.captured(1);
|
||||
bool convertedSuccessfully = false;
|
||||
const int major = majorString.toInt(&convertedSuccessfully);
|
||||
if (!convertedSuccessfully)
|
||||
return invalidVersion;
|
||||
|
||||
const QString minorString = reMatch.captured(2);
|
||||
const int minor = minorString.toInt(&convertedSuccessfully);
|
||||
if (!convertedSuccessfully)
|
||||
return invalidVersion;
|
||||
|
||||
const QString patchString = reMatch.captured(3);
|
||||
const int patch = patchString.toInt(&convertedSuccessfully);
|
||||
if (!convertedSuccessfully)
|
||||
return invalidVersion;
|
||||
|
||||
return ClangExecutableVersion(major, minor, patch);
|
||||
}
|
||||
|
||||
} // namespace Internal
|
||||
} // namespace ClangTools
|
||||
|
||||
Reference in New Issue
Block a user