summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorFriedemann Kleint <Friedemann.Kleint@digia.com>2014-09-01 13:58:13 +0200
committerFriedemann Kleint <Friedemann.Kleint@digia.com>2014-09-02 17:14:23 +0200
commitf2acb103678791a92d259cf8f743c9edbc038816 (patch)
treec501295a672d389805e77fcf2c199c27c0de2860
parentea7dd054c8afb0e1cede0eafb0ee3b0042a87a15 (diff)
windeployqt: Special case non-standard modules.v5.4.0-alpha1
Task-number: QTBUG-40670 Change-Id: I3897b4149587cf4e90cbdaf6d54ef8cff70d22d2 Reviewed-by: Andrew Knight <andrew.knight@digia.com>
-rw-r--r--src/windeployqt/main.cpp18
1 files changed, 13 insertions, 5 deletions
diff --git a/src/windeployqt/main.cpp b/src/windeployqt/main.cpp
index eacb236ad..be450dbd7 100644
--- a/src/windeployqt/main.cpp
+++ b/src/windeployqt/main.cpp
@@ -579,6 +579,13 @@ static inline QString helpText(const QCommandLineParser &p)
return result;
}
+static inline bool isQtModule(const QString &libName)
+{
+ return libName.startsWith(QLatin1String("Qt"), Qt::CaseInsensitive) // Standard modules, Qt5XX.dll, Qt[Commercial]Charts.dll
+ || libName.startsWith(QLatin1String("DataVisualization"), Qt::CaseInsensitive)
+ || libName.startsWith(QLatin1String("Enginio"), Qt::CaseInsensitive);
+}
+
// Helper for recursively finding all dependent Qt libraries.
static bool findDependentQtLibraries(const QString &qtBinDir, const QString &binary, Platform platform,
QString *errorMessage, QStringList *result,
@@ -596,11 +603,12 @@ static bool findDependentQtLibraries(const QString &qtBinDir, const QString &bin
// Filter out the Qt libraries. Note that depends.exe finds libs from optDirectory if we
// are run the 2nd time (updating). We want to check against the Qt bin dir libraries
const int start = result->size();
- const QRegExp filterRegExp(QStringLiteral("Qt5"), Qt::CaseInsensitive, QRegExp::FixedString);
- foreach (const QString &qtLib, dependentLibs.filter(filterRegExp)) {
- const QString path = normalizeFileName(qtBinDir + QLatin1Char('/') + QFileInfo(qtLib).fileName());
- if (!result->contains(path))
- result->append(path);
+ foreach (const QString &lib, dependentLibs) {
+ if (isQtModule(lib)) {
+ const QString path = normalizeFileName(qtBinDir + QLatin1Char('/') + QFileInfo(lib).fileName());
+ if (!result->contains(path))
+ result->append(path);
+ }
}
const int end = result->size();
if (directDependencyCount)