diff options
author | Dirk Hohndel <dirk@hohndel.org> | 2016-12-30 14:27:04 -0800 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2016-12-30 14:27:04 -0800 |
commit | 47d5dc9681361c56da5b37788371689be5ab7bc4 (patch) | |
tree | 819d85295031cf84959b5ec61760c4d009f63ac8 /core | |
parent | b5f0a4a02519aba130b8e061f222cb4ae46444ef (diff) | |
parent | 529a4d499b8dad35de6cd43e3004017ccfd288aa (diff) | |
download | subsurface-47d5dc9681361c56da5b37788371689be5ab7bc4.tar.gz |
Merge branch 'webengine' of https://github.com/atdotde/subsurface
Diffstat (limited to 'core')
-rw-r--r-- | core/imagedownloader.cpp | 2 | ||||
-rw-r--r-- | core/qthelper.cpp | 6 |
2 files changed, 7 insertions, 1 deletions
diff --git a/core/imagedownloader.cpp b/core/imagedownloader.cpp index d4dd85922..16c48a00e 100644 --- a/core/imagedownloader.cpp +++ b/core/imagedownloader.cpp @@ -100,6 +100,8 @@ SHashedImage::SHashedImage(struct picture *picture) : QImage() // This did not load anything. Let's try to get the image from other sources // Let's try to load it locally via its hash QString filename = fileFromHash(picture->hash); + if (filename.isNull()) + filename = QString(picture->filename); if (filename.isNull()) { // That didn't produce a local filename. // Try the cloud server diff --git a/core/qthelper.cpp b/core/qthelper.cpp index 885e89d98..088067f26 100644 --- a/core/qthelper.cpp +++ b/core/qthelper.cpp @@ -1075,6 +1075,8 @@ QByteArray hashFile(const QString filename) void learnHash(struct picture *picture, QByteArray hash) { + if (hash.isNull()) + return; if (picture->hash) free(picture->hash); QMutexLocker locker(&hashOfMutex); @@ -1100,6 +1102,8 @@ QString localFilePath(const QString originalFilename) QString fileFromHash(char *hash) { + if (!hash || !*hash) + return ""; QMutexLocker locker(&hashOfMutex); return localFilenameOf[QByteArray::fromHex(hash)]; @@ -1120,7 +1124,7 @@ void hashPicture(struct picture *picture) if (!picture) return; char *oldHash = copy_string(picture->hash); - learnHash(picture, hashFile(QString(picture->filename))); + learnHash(picture, hashFile(localFilePath(picture->filename))); if (!same_string(picture->hash, "") && !same_string(picture->hash, oldHash)) mark_divelist_changed((true)); free(oldHash); |