[gnome-maps/wip/contacts: 68/81] utils: Handle all loadable icons
- From: Jonas Danielsson <jonasdn src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-maps/wip/contacts: 68/81] utils: Handle all loadable icons
- Date: Sat, 31 Jan 2015 17:01:02 +0000 (UTC)
commit 2c44bb6c64d2c26d18a9e18532fb6e16f0fac22e
Author: Jonas Danielsson <jonas threetimestwo org>
Date: Tue Dec 16 03:33:27 2014 -0500
utils: Handle all loadable icons
https://bugzilla.gnome.org/show_bug.cgi?id=741591
src/utils.js | 31 ++++++++++++-------------------
1 files changed, 12 insertions(+), 19 deletions(-)
---
diff --git a/src/utils.js b/src/utils.js
index 485785e..e088064 100644
--- a/src/utils.js
+++ b/src/utils.js
@@ -40,9 +40,6 @@ const IMPERIAL_LOCALES = ['unm_US', 'es_US', 'es_PR', 'en_US', 'yi_US'];
let debugInit = false;
let debugEnabled = false;
-
-let _iconStore = {};
-
let measurementSystem = null;
function debug(str) {
@@ -260,37 +257,31 @@ function getAccuracyDescription(accuracy) {
}
function load_icon(icon, size, loadCompleteCallback) {
- if (icon instanceof Gio.FileIcon) {
- _load_file_icon(icon, loadCompleteCallback);
+ if (icon instanceof Gio.FileIcon || icon instanceof Gio.BytesIcon) {
+ _load_icon(icon, loadCompleteCallback);
} else if (icon instanceof Gio.ThemedIcon) {
_load_themed_icon(icon, size, loadCompleteCallback);
}
}
-function _load_file_icon(icon, loadCompleteCallback) {
- let pixbuf = _iconStore[icon.file.get_uri()];
-
- if (pixbuf) { // check if the icon is cached
- loadCompleteCallback(pixbuf);
- return;
- }
+function _load_icon(icon, loadCompleteCallback) {
- if (icon.file.has_uri_scheme ("http") || icon.file.has_uri_scheme ("https")) {
- _load_http_icon(icon, loadCompleteCallback);
- return;
+ if (icon.file) {
+ if (icon.file.has_uri_scheme ("http") || icon.file.has_uri_scheme ("https")) {
+ _load_http_icon(icon, loadCompleteCallback);
+ return;
+ }
}
icon.load_async(-1, null, function(icon, res) {
try {
let stream = icon.load_finish(res, null)[0];
+ let pixbuf = GdkPixbuf.Pixbuf.new_from_stream(stream, null);
- pixbuf =
- GdkPixbuf.Pixbuf.new_from_stream(stream, null);
-
- _iconStore[icon.file.get_uri()] = pixbuf;
loadCompleteCallback(pixbuf);
} catch(e) {
log("Failed to load pixbuf: " + e);
+ loadCompleteCallback(null);
}
});
}
@@ -302,6 +293,7 @@ function _load_http_icon(icon, loadCompleteCallback) {
soup_session.queue_message(msg, function(session, msg) {
if (msg.status_code !== Soup.KnownStatusCode.OK) {
log("Failed to load pixbuf: " + msg.reason_phrase);
+ loadCompleteCallback(null);
return;
}
@@ -315,6 +307,7 @@ function _load_http_icon(icon, loadCompleteCallback) {
loadCompleteCallback(pixbuf);
} catch(e) {
log("Failed to load pixbuf: " + e);
+ loadCompleteCallback(null);
}
});
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]