summaryrefslogtreecommitdiffstats
path: root/core
diff options
context:
space:
mode:
authorGravatar Dirk Hohndel <dirk@hohndel.org>2016-12-30 14:27:04 -0800
committerGravatar Dirk Hohndel <dirk@hohndel.org>2016-12-30 14:27:04 -0800
commit47d5dc9681361c56da5b37788371689be5ab7bc4 (patch)
tree819d85295031cf84959b5ec61760c4d009f63ac8 /core
parentb5f0a4a02519aba130b8e061f222cb4ae46444ef (diff)
parent529a4d499b8dad35de6cd43e3004017ccfd288aa (diff)
downloadsubsurface-47d5dc9681361c56da5b37788371689be5ab7bc4.tar.gz
Merge branch 'webengine' of https://github.com/atdotde/subsurface
Diffstat (limited to 'core')
-rw-r--r--core/imagedownloader.cpp2
-rw-r--r--core/qthelper.cpp6
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);