diff options
author | Berthold Stoeger <bstoeger@mail.tuwien.ac.at> | 2018-02-08 22:05:29 +0100 |
---|---|---|
committer | Lubomir I. Ivanov <neolit123@gmail.com> | 2018-03-05 18:04:57 +0200 |
commit | c1cd2e0f0295c569644c6d5ff186e00b4ce82d30 (patch) | |
tree | 1454513d8c5b56e12127c74c275ad1828a274861 | |
parent | 93ddcce6fad7912af579acb6a0697d3574dd35b3 (diff) | |
download | subsurface-c1cd2e0f0295c569644c6d5ff186e00b4ce82d30.tar.gz |
core/imagedownloader.cpp: Fix memory leak
A cloned picture struct would not be freed if the filename was already
in the queued-for-download set.
Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
-rw-r--r-- | core/imagedownloader.cpp | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/core/imagedownloader.cpp b/core/imagedownloader.cpp index 05900c40d..cdaa7fc90 100644 --- a/core/imagedownloader.cpp +++ b/core/imagedownloader.cpp @@ -86,8 +86,10 @@ static void loadPicture(struct picture *picture, bool fromHash) if (!picture) return; QMutexLocker locker(&pictureQueueMutex); - if (queuedPictures.contains(QString(picture->filename))) + if (queuedPictures.contains(QString(picture->filename))) { + picture_free(picture); return; + } queuedPictures.insert(QString(picture->filename)); locker.unlock(); |