From dbd3965241eb7ed3a77ba288204c8f22aa24d29a Mon Sep 17 00:00:00 2001 From: Christian Kandeler <christian.kandeler@nokia.com> Date: Thu, 28 Oct 2010 09:22:19 +0200 Subject: [PATCH] Maemo: Remove additional parsing step. Instead, utilize the newly added INSTALLS information of Qt4ProFileNode. Task-number: QTCREATORBUG-2679 --- .../qt-maemo/maemodeployablelistmodel.cpp | 59 +--- .../qt-maemo/maemodeployablelistmodel.h | 12 +- .../qt-maemo/maemodeployables.cpp | 7 +- .../qt-maemo/maemodeployables.h | 3 - .../qt-maemo/maemopackagecreationstep.cpp | 1 - .../qt-maemo/maemoprofilewrapper.cpp | 302 ------------------ .../qt-maemo/maemoprofilewrapper.h | 81 ----- .../qt4projectmanager/qt-maemo/qt-maemo.pri | 2 - src/plugins/qt4projectmanager/qt4nodes.cpp | 5 +- 9 files changed, 13 insertions(+), 459 deletions(-) delete mode 100644 src/plugins/qt4projectmanager/qt-maemo/maemoprofilewrapper.cpp delete mode 100644 src/plugins/qt4projectmanager/qt-maemo/maemoprofilewrapper.h diff --git a/src/plugins/qt4projectmanager/qt-maemo/maemodeployablelistmodel.cpp b/src/plugins/qt4projectmanager/qt-maemo/maemodeployablelistmodel.cpp index 3326cc3ca4f..9803bce27f2 100644 --- a/src/plugins/qt4projectmanager/qt-maemo/maemodeployablelistmodel.cpp +++ b/src/plugins/qt4projectmanager/qt-maemo/maemodeployablelistmodel.cpp @@ -29,7 +29,6 @@ #include "maemodeployablelistmodel.h" -#include "maemoprofilewrapper.h" #include "maemotoolchain.h" #include <projectexplorer/projectexplorer.h> @@ -47,16 +46,15 @@ namespace Qt4ProjectManager { namespace Internal { MaemoDeployableListModel::MaemoDeployableListModel(const Qt4ProFileNode *proFileNode, - const QSharedPointer<ProFileOption> &proFileOption, ProFileUpdateSetting updateSetting, QObject *parent) : QAbstractTableModel(parent), m_projectType(proFileNode->projectType()), m_proFilePath(proFileNode->path()), m_projectName(proFileNode->displayName()), m_targetInfo(proFileNode->targetInformation()), + m_installsList(proFileNode->installsList()), + m_config(proFileNode->variableValue(ConfigVar)), m_modified(false), - m_proFileWrapper(new MaemoProFileWrapper(m_proFilePath, - proFileNode->buildDir(), proFileOption)), m_proFileUpdateSetting(updateSetting), m_hasTargetPath(false) { @@ -69,8 +67,7 @@ bool MaemoDeployableListModel::buildModel() { m_deployables.clear(); - const MaemoProFileWrapper::InstallsList &installs = m_proFileWrapper->installs(); - m_hasTargetPath = !installs.targetPath.isEmpty(); + m_hasTargetPath = !m_installsList.targetPath.isEmpty(); if (!m_hasTargetPath && m_proFileUpdateSetting == UpdateProFile) { const QString remoteDirSuffix = QLatin1String(m_projectType == LibraryTemplate @@ -98,14 +95,14 @@ bool MaemoDeployableListModel::buildModel() } } else { m_deployables.prepend(MaemoDeployable(localExecutableFilePath(), - installs.targetPath)); + m_installsList.targetPath)); } - foreach (const MaemoProFileWrapper::InstallsElem &elem, installs.normalElems) { + foreach (const InstallsItem &elem, m_installsList.items) { foreach (const QString &file, elem.files) m_deployables << MaemoDeployable(file, elem.path); } - m_modified = true; // ??? + m_modified = true; return true; } @@ -115,43 +112,6 @@ MaemoDeployable MaemoDeployableListModel::deployableAt(int row) const return m_deployables.at(row); } -bool MaemoDeployableListModel::addDeployable(const MaemoDeployable &deployable, - QString *error) -{ - if (m_deployables.contains(deployable)) { - *error = tr("File already in list."); - return false; - } - - if (!m_proFileWrapper->addInstallsElem(deployable.remoteDir, - deployable.localFilePath)) { - *error = tr("Failed to update .pro file."); - return false; - } - - beginInsertRows(QModelIndex(), rowCount(), rowCount()); - m_deployables << deployable; - endInsertRows(); - return true; -} - -bool MaemoDeployableListModel::removeDeployableAt(int row, QString *error) -{ - Q_ASSERT(row > 0 && row < rowCount()); - - const MaemoDeployable &deployable = deployableAt(row); - if (!m_proFileWrapper->removeInstallsElem(deployable.remoteDir, - deployable.localFilePath)) { - *error = tr("Could not update .pro file."); - return false; - } - - beginRemoveRows(QModelIndex(), row, row); - m_deployables.removeAt(row); - endRemoveRows(); - return true; -} - int MaemoDeployableListModel::rowCount(const QModelIndex &parent) const { return parent.isValid() ? 0 : m_deployables.count(); @@ -226,11 +186,8 @@ QString MaemoDeployableListModel::localExecutableFilePath() const QString fileName; if (isLib) { fileName += QLatin1String("lib"); - const QStringList &config - = m_proFileWrapper->varValues(QLatin1String("CONFIG")); - isStatic = config.contains(QLatin1String("static")) - || config.contains(QLatin1String("staticlib")) - || config.contains(QLatin1String("plugin")); + isStatic = m_config.contains(QLatin1String("static")) + || m_config.contains(QLatin1String("staticlib")); } fileName += m_targetInfo.target; if (isLib) diff --git a/src/plugins/qt4projectmanager/qt-maemo/maemodeployablelistmodel.h b/src/plugins/qt4projectmanager/qt-maemo/maemodeployablelistmodel.h index c8e32704e9c..20262b41fe5 100644 --- a/src/plugins/qt4projectmanager/qt-maemo/maemodeployablelistmodel.h +++ b/src/plugins/qt4projectmanager/qt-maemo/maemodeployablelistmodel.h @@ -38,16 +38,10 @@ #include <QtCore/QHash> #include <QtCore/QList> #include <QtCore/QScopedPointer> -#include <QtCore/QSharedPointer> #include <QtCore/QString> -QT_BEGIN_NAMESPACE -struct ProFileOption; -QT_END_NAMESPACE - namespace Qt4ProjectManager { namespace Internal { -class MaemoProFileWrapper; class MaemoToolChain; class MaemoDeployableListModel : public QAbstractTableModel @@ -59,15 +53,12 @@ public: }; MaemoDeployableListModel(const Qt4ProFileNode *proFileNode, - const QSharedPointer<ProFileOption> &proFileOption, ProFileUpdateSetting updateSetting, QObject *parent); ~MaemoDeployableListModel(); virtual int rowCount(const QModelIndex &parent = QModelIndex()) const; MaemoDeployable deployableAt(int row) const; - bool addDeployable(const MaemoDeployable &deployable, QString *error); - bool removeDeployableAt(int row, QString *error); bool isModified() const { return m_modified; } void setUnModified() { m_modified = false; } QString localExecutableFilePath() const; @@ -102,9 +93,10 @@ private: const QString m_proFilePath; const QString m_projectName; const TargetInformation m_targetInfo; + const InstallsList m_installsList; + const QStringList m_config; QList<MaemoDeployable> m_deployables; mutable bool m_modified; - const QScopedPointer<MaemoProFileWrapper> m_proFileWrapper; ProFileUpdateSetting m_proFileUpdateSetting; bool m_hasTargetPath; }; diff --git a/src/plugins/qt4projectmanager/qt-maemo/maemodeployables.cpp b/src/plugins/qt4projectmanager/qt-maemo/maemodeployables.cpp index d1e9d5d3d4f..9148b27df29 100644 --- a/src/plugins/qt4projectmanager/qt-maemo/maemodeployables.cpp +++ b/src/plugins/qt4projectmanager/qt-maemo/maemodeployables.cpp @@ -84,10 +84,6 @@ void MaemoDeployables::createModels() if (!rootNode) // Happens on project creation by wizard. return; m_updateTimer->stop(); - m_proFileOption = QSharedPointer<ProFileOption>(new ProFileOption); - m_proFileOption->properties - = qt4BuildConfiguration()->qtVersion()->versionInfo(); - m_proFileOption->target_mode = ProFileOption::TARG_UNIX_MODE; disconnect(qt4BuildConfiguration()->qt4Target()->qt4Project(), SIGNAL(proFileUpdated(Qt4ProjectManager::Internal::Qt4ProFileNode*)), m_updateTimer, SLOT(start())); @@ -137,8 +133,7 @@ void MaemoDeployables::createModels(const Qt4ProFileNode *proFileNode) = it != m_updateSettings.end() ? it.value() : MaemoDeployableListModel::AskToUpdateProFile; MaemoDeployableListModel *const newModel - = new MaemoDeployableListModel(proFileNode, m_proFileOption, - updateSetting, this); + = new MaemoDeployableListModel(proFileNode, updateSetting, this); m_listModels << newModel; break; } diff --git a/src/plugins/qt4projectmanager/qt-maemo/maemodeployables.h b/src/plugins/qt4projectmanager/qt-maemo/maemodeployables.h index c7c39218410..a62b5fc4f46 100644 --- a/src/plugins/qt4projectmanager/qt-maemo/maemodeployables.h +++ b/src/plugins/qt4projectmanager/qt-maemo/maemodeployables.h @@ -48,10 +48,8 @@ #include <QtCore/QAbstractListModel> #include <QtCore/QHash> #include <QtCore/QList> -#include <QtCore/QSharedPointer> QT_FORWARD_DECLARE_CLASS(QTimer); -QT_FORWARD_DECLARE_STRUCT(ProFileOption) namespace ProjectExplorer { class BuildStep; } @@ -88,7 +86,6 @@ private: const Qt4BuildConfiguration *qt4BuildConfiguration() const; QList<MaemoDeployableListModel *> m_listModels; - QSharedPointer<ProFileOption> m_proFileOption; UpdateSettingsMap m_updateSettings; const ProjectExplorer::BuildStep * const m_buildStep; QTimer *const m_updateTimer; diff --git a/src/plugins/qt4projectmanager/qt-maemo/maemopackagecreationstep.cpp b/src/plugins/qt4projectmanager/qt-maemo/maemopackagecreationstep.cpp index 38bd37b798e..461060e3826 100644 --- a/src/plugins/qt4projectmanager/qt-maemo/maemopackagecreationstep.cpp +++ b/src/plugins/qt4projectmanager/qt-maemo/maemopackagecreationstep.cpp @@ -46,7 +46,6 @@ #include "maemodeploystep.h" #include "maemoglobal.h" #include "maemopackagecreationwidget.h" -#include "maemoprofilewrapper.h" #include "maemotemplatesmanager.h" #include "maemotoolchain.h" diff --git a/src/plugins/qt4projectmanager/qt-maemo/maemoprofilewrapper.cpp b/src/plugins/qt4projectmanager/qt-maemo/maemoprofilewrapper.cpp deleted file mode 100644 index 2e70d891d13..00000000000 --- a/src/plugins/qt4projectmanager/qt-maemo/maemoprofilewrapper.cpp +++ /dev/null @@ -1,302 +0,0 @@ -#include "maemoprofilewrapper.h" - -#include <prowriter.h> -#include <qt4projectmanager/profilereader.h> - -#include <QtCore/QCryptographicHash> -#include <QtCore/QFile> -#include <QtCore/QFileInfo> - -namespace Qt4ProjectManager { -namespace Internal { - -namespace { - QString pathVar(const QString &var) - { - return var + QLatin1String(".path"); - } - - QString filesVar(const QString &var) - { - return var + QLatin1String(".files"); - } - - const QLatin1String InstallsVar("INSTALLS"); - const QLatin1String TargetVar("target"); -} - - -MaemoProFileWrapper::MaemoProFileWrapper(const QString &proFileName, - const QString &buildDir, const QSharedPointer<ProFileOption> &proFileOption) - : m_proFileName(proFileName), m_proDir(QFileInfo(m_proFileName).dir()), - m_buildDir(buildDir), m_proFileOption(proFileOption) -{ - parseProFile(ParseFromFile); -} - -MaemoProFileWrapper::~MaemoProFileWrapper() {} - -void MaemoProFileWrapper::reload() -{ - parseProFile(ParseFromFile); -} - -MaemoProFileWrapper::InstallsList MaemoProFileWrapper::installs() const -{ - InstallsList list; - - const QStringList &elemList = varValues(InstallsVar); - foreach (const QString &elem, elemList) { - const QStringList &paths = varValues(pathVar(elem)); - if (paths.count() != 1) { - qWarning("Error: Variable %s has %d values.", - qPrintable(pathVar(elem)), paths.count()); - continue; - } - - const QStringList &files - = m_proFileReader->absoluteFileValues(filesVar(elem), - m_proDir.path(), QStringList() << m_proDir.path(), 0); - - if (elem == TargetVar) { - if (!list.targetPath.isEmpty()) { - qWarning("Error: More than one target in INSTALLS list."); - continue; - } - list.targetPath = paths.first(); - } else { - if (files.isEmpty()) - continue; - list.normalElems << InstallsElem(elem, paths.first(), files); - } - } - - return list; -} - -bool MaemoProFileWrapper::addInstallsElem(const QString &path, - const QString &absFilePath, const QString &var) -{ - QString varName = var; - if (varName.isEmpty()) { - QCryptographicHash elemHash(QCryptographicHash::Md5); - elemHash.addData(absFilePath.toUtf8()); - varName = QString::fromAscii(elemHash.result().toHex()); - } - - // TODO: Use lower-level calls here to make operation atomic. - if (varName != TargetVar && !addFile(filesVar(varName), absFilePath)) - return false; - return addVarValue(pathVar(varName), path) - && addVarValue(InstallsVar, varName); -} - -bool MaemoProFileWrapper::addInstallsTarget(const QString &path) -{ - return addInstallsElem(path, QString(), TargetVar); -} - -bool MaemoProFileWrapper::removeInstallsElem(const QString &path, - const QString &file) -{ - const InstallsElem &elem = findInstallsElem(path, file); - if (elem.varName.isEmpty()) - return false; - - // TODO: Use lower-level calls here to make operation atomic. - if (elem.varName != TargetVar && !removeFile(filesVar(elem.varName), file)) - return false; - if (elem.files.count() <= 1) { - if (!removeVarValue(pathVar(elem.varName), path)) - return false; - if (!removeVarValue(InstallsVar, elem.varName)) - return false; - } - return true; -} - -bool MaemoProFileWrapper::replaceInstallPath(const QString &oldPath, - const QString &file, const QString &newPath) -{ - const InstallsElem &elem = findInstallsElem(oldPath, file); - if (elem.varName.isEmpty()) - return false; - - // Simple case: Variable has only one file, so just replace the path. - if (elem.varName == TargetVar || elem.files.count() == 1) - return replaceVarValue(pathVar(elem.varName), oldPath, newPath); - - // Complicated case: Variable has other files, so remove our file from it - // and introduce a new one. - if (!removeInstallsElem(oldPath, file)) - return false; - return addInstallsElem(newPath, file); -} - -QStringList MaemoProFileWrapper::varValues(const QString &var) const -{ - return m_proFileReader->values(var); -} - -bool MaemoProFileWrapper::addVarValue(const QString &var, const QString &value) -{ - if (varValues(var).contains(value)) - return true; - - if (!readProFileContents()) - return false; - ProWriter::addVarValues(m_proFile, &m_proFileContents, m_proDir, - QStringList(value), var); - parseProFile(ParseFromLines); - return writeProFileContents(); -} - -bool MaemoProFileWrapper::addFile(const QString &var, const QString &absFilePath) -{ - if (!readProFileContents()) - return false; - ProWriter::addFiles(m_proFile, &m_proFileContents, m_proDir, - QStringList(absFilePath), var); - parseProFile(ParseFromLines); - return writeProFileContents(); -} - -bool MaemoProFileWrapper::removeVarValue(const QString &var, const QString &value) -{ - if (!readProFileContents()) - return false; - const bool success = ProWriter::removeVarValues(m_proFile, - &m_proFileContents, m_proDir, QStringList(value), QStringList(var)) - .isEmpty(); - if (success) { - parseProFile(ParseFromLines); - return writeProFileContents(); - } else { - parseProFile(ParseFromFile); - return false; - } -} - -bool MaemoProFileWrapper::removeFile(const QString &var, const QString &absFilePath) -{ - if (!readProFileContents()) - return false; - const bool success = ProWriter::removeFiles(m_proFile, &m_proFileContents, - m_proDir, QStringList(absFilePath), QStringList(var)).isEmpty(); - if (success) { - parseProFile(ParseFromLines); - return writeProFileContents(); - } else { - parseProFile(ParseFromFile); - return false; - } -} - -bool MaemoProFileWrapper::replaceVarValue(const QString &var, - const QString &oldValue, const QString &newValue) -{ - if (!readProFileContents()) - return false; - const bool success = ProWriter::removeVarValues(m_proFile, - &m_proFileContents, m_proDir, QStringList(oldValue), QStringList(var)) - .isEmpty(); - if (!success) { - parseProFile(ParseFromFile); - return false; - } - ProWriter::addVarValues(m_proFile, &m_proFileContents, m_proDir, - QStringList(newValue), var); - parseProFile(ParseFromLines); - return writeProFileContents(); -} - -QString MaemoProFileWrapper::absFilePath(const QString &relFilePath) const -{ - // I'd rather use QDir::cleanPath(), but that doesn't work well - // enough for redundant ".." dirs. - QFileInfo fi(relFilePath); - return fi.isAbsolute() ? fi.canonicalFilePath() - : QFileInfo(m_proFile->directoryName() + '/' + relFilePath) - .canonicalFilePath(); -} - -void MaemoProFileWrapper::parseProFile(ParseType type) const -{ - if (m_proFileReader) - m_proFile->deref(); - m_proFileReader.reset(new ProFileReader(m_proFileOption.data())); - m_proFileReader->setOutputDir(m_buildDir); - m_proFileReader->setCumulative(false); - // TODO: Set output dir to build dir? - if (type == ParseFromLines) { - m_proFile = m_proFileReader->parsedProBlock(m_proFileName, - m_proFileContents.join("\n")); - } else { - m_proFileContents.clear(); - m_proFile = m_proFileReader->parsedProFile(m_proFileName); - } - - if (!m_proFile) { - qWarning("Fatal: Could not parse .pro file '%s'.", - qPrintable(m_proFileName)); - return; - } - - m_proFileReader->accept(m_proFile); -} - -bool MaemoProFileWrapper::writeProFileContents() -{ - QFile proFileOnDisk(m_proFileName); - if (!proFileOnDisk.open(QIODevice::WriteOnly)) { - parseProFile(ParseFromFile); - return false; - } - - // TODO: Disconnect and reconnect FS watcher here. - proFileOnDisk.write(m_proFileContents.join("\n").toLatin1()); - proFileOnDisk.close(); - if (proFileOnDisk.error() != QFile::NoError) { - parseProFile(ParseFromFile); - return false; - } - return true; -} - -bool MaemoProFileWrapper::readProFileContents() -{ - if (!m_proFileContents.isEmpty()) - return true; - - QFile proFileOnDisk(m_proFileName); - if (!proFileOnDisk.open(QIODevice::ReadOnly)) - return false; - const QString proFileContents - = QString::fromLatin1(proFileOnDisk.readAll()); - if (proFileOnDisk.error() != QFile::NoError) - return false; - m_proFileContents = proFileContents.split('\n'); - return true; -} - -MaemoProFileWrapper::InstallsElem MaemoProFileWrapper::findInstallsElem(const QString &path, - const QString &file) const -{ - const QStringList &elems = varValues(InstallsVar); - foreach (const QString &elem, elems) { - const QStringList &elemPaths = varValues(pathVar(elem)); - if (elemPaths.count() != 1 || elemPaths.first() != path) - continue; - if (elem == TargetVar) - return InstallsElem(elem, path, QStringList()); - const QStringList &elemFiles = varValues(filesVar(elem)); - foreach (const QString &elemFile, elemFiles) { - if (absFilePath(elemFile) == file) - return InstallsElem(elem, path, elemFiles); - } - } - return InstallsElem(QString(), QString(), QStringList()); -} - -} // namespace Internal -} // namespace Qt4ProjectManager diff --git a/src/plugins/qt4projectmanager/qt-maemo/maemoprofilewrapper.h b/src/plugins/qt4projectmanager/qt-maemo/maemoprofilewrapper.h deleted file mode 100644 index 58480fa3e26..00000000000 --- a/src/plugins/qt4projectmanager/qt-maemo/maemoprofilewrapper.h +++ /dev/null @@ -1,81 +0,0 @@ -#ifndef PROFILEWRAPPER_H -#define PROFILEWRAPPER_H - -#include <QtCore/QDir> -#include <QtCore/QScopedPointer> -#include <QtCore/QSharedPointer> -#include <QtCore/QString> -#include <QtCore/QString> - -QT_BEGIN_NAMESPACE -class ProFile; -struct ProFileOption; -QT_END_NAMESPACE - -namespace Qt4ProjectManager { -namespace Internal { -class ProFileReader; - -class MaemoProFileWrapper -{ -public: - MaemoProFileWrapper(const QString &proFileName, const QString &buildDir, - const QSharedPointer<ProFileOption> &proFileOption); - ~MaemoProFileWrapper(); - - void reload(); - - struct InstallsElem { - InstallsElem(QString v, QString p, QStringList f) - : varName(v), path(p), files(f) {} - QString varName; - QString path; - QStringList files; - }; - - struct InstallsList { - QString targetPath; - QList<InstallsElem> normalElems; - }; - - // High-level functions for dealing with INSTALLS stuff. - InstallsList installs() const; - bool addInstallsElem(const QString &path, const QString &file, - const QString &var = QString()); // Empty var means make the name up. - bool addInstallsTarget(const QString &path); - bool removeInstallsElem(const QString &path, const QString &file); - bool replaceInstallPath(const QString &oldPath, const QString &file, - const QString &newPath); - - // Lower-level functions working on arbitrary variables. - QStringList varValues(const QString &var) const; - bool addVarValue(const QString &var, const QString &value); - bool addFile(const QString &var, const QString &absFilePath); - bool removeVarValue(const QString &var, const QString &value); - bool removeFile(const QString &var, const QString &absFilePath); - bool replaceVarValue(const QString &var, const QString &oldValue, - const QString &newValue); - - QString absFilePath(const QString &relFilePath) const; - -private: - enum ParseType { ParseFromFile, ParseFromLines }; - void parseProFile(ParseType type) const; - bool writeProFileContents(); - bool readProFileContents(); - InstallsElem findInstallsElem(const QString &path, - const QString &file) const; - - const QString m_proFileName; - const QDir m_proDir; - const QString m_buildDir; - const QSharedPointer<ProFileOption> m_proFileOption; - mutable QStringList m_proFileContents; - mutable QScopedPointer<ProFileReader> m_proFileReader; - mutable ProFile *m_proFile; -}; - -} // namespace Internal -} // namespace Qt4ProjectManager - -#endif // PROFILEWRAPPER_H diff --git a/src/plugins/qt4projectmanager/qt-maemo/qt-maemo.pri b/src/plugins/qt4projectmanager/qt-maemo/qt-maemo.pri index ddf9f5723c7..f5bcbd8bdb5 100644 --- a/src/plugins/qt4projectmanager/qt-maemo/qt-maemo.pri +++ b/src/plugins/qt4projectmanager/qt-maemo/qt-maemo.pri @@ -16,7 +16,6 @@ HEADERS += \ $$PWD/maemopackagecreationwidget.h \ $$PWD/maemodeployablelistmodel.h \ $$PWD/maemoqemumanager.h \ - $$PWD/maemoprofilewrapper.h \ $$PWD/maemodeployables.h \ $$PWD/maemodeployable.h \ $$PWD/maemodeploystep.h \ @@ -53,7 +52,6 @@ SOURCES += \ $$PWD/maemopackagecreationwidget.cpp \ $$PWD/maemodeployablelistmodel.cpp \ $$PWD/maemoqemumanager.cpp \ - $$PWD/maemoprofilewrapper.cpp \ $$PWD/maemodeployables.cpp \ $$PWD/maemodeploystep.cpp \ $$PWD/maemodeploystepwidget.cpp \ diff --git a/src/plugins/qt4projectmanager/qt4nodes.cpp b/src/plugins/qt4projectmanager/qt4nodes.cpp index 2ec850951de..f68c76b9540 100644 --- a/src/plugins/qt4projectmanager/qt4nodes.cpp +++ b/src/plugins/qt4projectmanager/qt4nodes.cpp @@ -1942,7 +1942,7 @@ void Qt4ProFileNode::setupInstallsList(const ProFileReader *reader) const QStringList &itemList = reader->values(QLatin1String("INSTALLS")); foreach (const QString &item, itemList) { QString itemPath; - const QString pathVar = item + QLatin1String(".path"); + const QString pathVar = item + QLatin1String(".path"); const QStringList &itemPaths = reader->values(pathVar); if (itemPaths.count() != 1) { qDebug("Invalid RHS: Variable '%s' has %d values.", @@ -1951,10 +1951,9 @@ void Qt4ProFileNode::setupInstallsList(const ProFileReader *reader) qDebug("Ignoring INSTALLS item '%s', because it has no path.", qPrintable(item)); continue; - } else { - itemPath = itemPaths.last(); } } + itemPath = itemPaths.last(); const QStringList &itemFiles = reader->absoluteFileValues(item + QLatin1String(".files"), -- GitLab