[gnome-software/gnome-40: 1/2] gs-remote-icon: Set icon dimensions when already downloaded
- From: Milan Crha <mcrha src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-software/gnome-40: 1/2] gs-remote-icon: Set icon dimensions when already downloaded
- Date: Thu, 20 May 2021 10:24:51 +0000 (UTC)
commit d9a092b66a394b1b854e50a452dfe400b57d5db9
Author: Milan Crha <mcrha redhat com>
Date: Wed May 19 18:06:02 2021 +0200
gs-remote-icon: Set icon dimensions when already downloaded
The code expects to have set icon dimensions to know whether it's usable,
but the remote icon sets it only if it downloads the icon. When it's already
downloaded the remote icon didn't set the dimensions, which resulted
in the icon not being considered as a usable icon.
Closes https://gitlab.gnome.org/GNOME/gnome-software/-/issues/1256
lib/gs-remote-icon.c | 10 +++++++++-
1 file changed, 9 insertions(+), 1 deletion(-)
---
diff --git a/lib/gs-remote-icon.c b/lib/gs-remote-icon.c
index e8455911a..061863333 100644
--- a/lib/gs-remote-icon.c
+++ b/lib/gs-remote-icon.c
@@ -339,8 +339,16 @@ gs_remote_icon_ensure_cached (GsRemoteIcon *self,
return FALSE;
/* Already in cache? */
- if (g_file_test (cache_filename, G_FILE_TEST_IS_REGULAR))
+ if (g_file_test (cache_filename, G_FILE_TEST_IS_REGULAR)) {
+ gint width = 0, height = 0;
+ /* Ensure the downloaded image dimensions are stored on the icon */
+ if (!g_object_get_data (G_OBJECT (self), "width") &&
+ gdk_pixbuf_get_file_info (cache_filename, &width, &height)) {
+ g_object_set_data (G_OBJECT (self), "width", GINT_TO_POINTER (width));
+ g_object_set_data (G_OBJECT (self), "height", GINT_TO_POINTER (height));
+ }
return TRUE;
+ }
cached_pixbuf = gs_icon_download (soup_session, uri, cache_filename, maximum_icon_size, cancellable,
error);
if (cached_pixbuf == NULL)
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]