summaryrefslogtreecommitdiffstats
path: root/tools
diff options
context:
space:
mode:
authorFriedemann Kleint <Friedemann.Kleint@qt.io>2016-10-27 12:51:43 +0200
committerFriedemann Kleint <Friedemann.Kleint@qt.io>2016-10-27 12:03:22 +0000
commit1bd53131d83cdf595f95f82f0c049d2d68957159 (patch)
treea753e28438bcd0baa32199e1b5aed4e3933f7406 /tools
parent456f0e0f1a4fb422b029c5abd30e2e622435f76a (diff)
configure: Determine MSVC version by evaluating macro _MSC_FULL_VER
The previously used regular expression failed for messages in local languages, particularly for the French message containing a non-breaking space. Task-number: QTBUG-56388 Change-Id: Ie757617f1b3a31820d0ed274c4b157d544ac1ea6 Reviewed-by: Oswald Buddenhagen <oswald.buddenhagen@qt.io>
Diffstat (limited to 'tools')
-rw-r--r--tools/configure/environment.cpp35
1 files changed, 17 insertions, 18 deletions
diff --git a/tools/configure/environment.cpp b/tools/configure/environment.cpp
index 60616f35e7..153a141d7a 100644
--- a/tools/configure/environment.cpp
+++ b/tools/configure/environment.cpp
@@ -40,6 +40,7 @@
#include <qfile.h>
#include <qfileinfo.h>
#include <qstandardpaths.h>
+#include <qtemporaryfile.h>
#include <process.h>
#include <errno.h>
@@ -172,25 +173,23 @@ QString Environment::gccVersion()
QString Environment::msvcVersion()
{
int returnValue = 0;
- // Extract version from standard error output of "cl /?"
- const QString command = QFile::decodeName(qgetenv("ComSpec"))
- + QLatin1String(" /c ") + QLatin1String(compilerInfo(CC_MSVC2015)->executable)
- + QLatin1String(" /? 2>&1");
- SetEnvironmentVariable(L"CL", NULL); // May contain /nologo, which suppresses the version.
- QString version = execute(command, &returnValue);
- if (returnValue != 0) {
- cout << "Could not get cl version" << returnValue << qPrintable(version) << '\n';;
- version.clear();
- } else {
- QRegExp versionRegexp(QStringLiteral("^.*\\b(\\d{2,2}\\.\\d{2,2}\\.\\d{5,5})\\b.*$"));
- Q_ASSERT(versionRegexp.isValid());
- if (versionRegexp.exactMatch(version)) {
- version = versionRegexp.cap(1);
- } else {
- cout << "Unable to determine cl version from the output of \""
- << qPrintable(command) << "\"\n";
- }
+ QString tempSourceName;
+ { // QTemporaryFile needs to go out of scope, otherwise cl.exe refuses to open it.
+ QTemporaryFile tempSource(QDir::tempPath() + QLatin1String("/XXXXXX.cpp"));
+ tempSource.setAutoRemove(false);
+ if (!tempSource.open())
+ return QString();
+ tempSource.write("_MSC_FULL_VER\n");
+ tempSourceName = tempSource.fileName();
}
+ QString version = execute(QLatin1String("cl /nologo /EP \"")
+ + QDir::toNativeSeparators(tempSourceName) + QLatin1Char('"'),
+ &returnValue).trimmed();
+ QFile::remove(tempSourceName);
+ if (returnValue || version.size() < 9 || !version.at(0).isDigit())
+ return QString();
+ version.insert(4, QLatin1Char('.'));
+ version.insert(2, QLatin1Char('.'));
return version;
}