File PreviewJob-clean-up-empty-temp-file-when-get-fails.patch of Package kio.7470

From 78c45a1ea0e28a98f34c6d113c807f14700b22d4 Mon Sep 17 00:00:00 2001
From: David Faure <faure@kde.org>
Date: Sun, 14 May 2017 15:40:02 +0200
Subject: PreviewJob: clean up empty temp file when get() fails.

(e.g. because it's a directory)

CCBUG: 208625
---
 src/widgets/previewjob.cpp | 17 +++++++++++++----
 1 file changed, 13 insertions(+), 4 deletions(-)

diff --git a/src/widgets/previewjob.cpp b/src/widgets/previewjob.cpp
index 9eae346..e836f7d 100644
--- a/src/widgets/previewjob.cpp
+++ b/src/widgets/previewjob.cpp
@@ -143,6 +143,7 @@ public:
     void getOrCreateThumbnail();
     bool statResultThumbnail();
     void createThumbnail(const QString &);
+    void cleanupTempFile();
     void determineNextFile();
     void emitPreview(const QImage &thumb);
 
@@ -409,6 +410,16 @@ void PreviewJob::setIgnoreMaximumSize(bool ignoreSize)
     d_func()->ignoreMaximumSize = ignoreSize;
 }
 
+void PreviewJobPrivate::cleanupTempFile()
+{
+    if (!tempName.isEmpty()) {
+        Q_ASSERT(!QFileInfo(tempName).isDir());
+        Q_ASSERT(QFileInfo(tempName).isFile());
+        QFile::remove(tempName);
+        tempName.clear();
+    }
+}
+
 void PreviewJobPrivate::determineNextFile()
 {
     Q_Q(PreviewJob);
@@ -491,6 +502,7 @@ void PreviewJob::slotResult(KJob *job)
     }
     case PreviewJobPrivate::STATE_GETORIG: {
         if (job->error()) {
+            d->cleanupTempFile();
             d->determineNextFile();
             return;
         }
@@ -499,10 +511,7 @@ void PreviewJob::slotResult(KJob *job)
         return;
     }
     case PreviewJobPrivate::STATE_CREATETHUMB: {
-        if (!d->tempName.isEmpty()) {
-            QFile::remove(d->tempName);
-            d->tempName.clear();
-        }
+        d->cleanupTempFile();
         d->determineNextFile();
         return;
     }
-- 
cgit v0.11.2

openSUSE Build Service is sponsored by