summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/libs/installer/fileutils.cpp19
1 files changed, 15 insertions, 4 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);
+ }
}
}