summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/libs/installer/fileutils.cpp19
-rw-r--r--tools/binarycreator/binarycreator.cpp2
2 files changed, 16 insertions, 5 deletions
diff --git a/src/libs/installer/fileutils.cpp b/src/libs/installer/fileutils.cpp
index ece86aa5d..29baf4765 100644
--- a/src/libs/installer/fileutils.cpp
+++ b/src/libs/installer/fileutils.cpp
@@ -234,8 +234,13 @@ void QInstaller::removeFiles(const QString &path, bool ignoreErrors)
foreach (const QFileInfo &fi, entries) {
if (fi.isSymLink() || fi.isFile()) {
QFile f(fi.filePath());
- if (!f.remove() && !ignoreErrors)
- throw Error(QObject::tr("Could not remove file %1: %2").arg(f.fileName(), f.errorString()));
+ if (!f.remove()) {
+ QString errorMessage = QObject::tr("Could not remove file %1: %2").arg(f.fileName(), f.errorString());
+ if (ignoreErrors)
+ qWarning() << errorMessage;
+ else
+ throw Error(errorMessage);
+ }
}
}
}
@@ -259,8 +264,14 @@ void QInstaller::removeDirectory(const QString &path, bool ignoreErrors)
removeFiles(path, ignoreErrors);
foreach (const QString &dir, dirs) {
errno = 0;
- if (d.exists(path) && !d.rmdir(dir) && !ignoreErrors)
- throw Error(QObject::tr("Could not remove folder %1: %2").arg(dir, QLatin1String(strerror(errno))));
+ if (d.exists(path) && !d.rmdir(dir)) {
+ QString errorMessage = QObject::tr("Could not remove folder %1: %2").arg(dir,
+ QLatin1String(strerror(errno)));
+ if (ignoreErrors)
+ qWarning() << errorMessage;
+ else
+ throw Error(errorMessage);
+ }
}
}
diff --git a/tools/binarycreator/binarycreator.cpp b/tools/binarycreator/binarycreator.cpp
index aa64bf985..866b4a4a3 100644
--- a/tools/binarycreator/binarycreator.cpp
+++ b/tools/binarycreator/binarycreator.cpp
@@ -696,7 +696,7 @@ int main(int argc, char **argv)
foreach (const QString &resource, input.binaryResources)
QFile::remove(resource);
}
- removeDirectory(metaDir);
+ removeDirectory(metaDir, true);
return result;
} catch (const Error &e) {
std::cerr << e.message() << std::endl;