summaryrefslogtreecommitdiffstats
path: root/src/device.c
diff options
context:
space:
mode:
authorGravatar Nikias Bassen2010-07-09 02:51:45 +0200
committerGravatar Nikias Bassen2010-07-09 02:51:45 +0200
commit445026e4728feef1295d6d47ba8e873e87fdec41 (patch)
tree2913d1882b159345e6b2e254e1692ff001874837 /src/device.c
parentd16ba43dcea96e4a27be04c0532d712c659a8089 (diff)
downloadsbmanager-445026e4728feef1295d6d47ba8e873e87fdec41.tar.gz
sbmanager-445026e4728feef1295d6d47ba8e873e87fdec41.tar.bz2
Display home screen wallpaper if available
Diffstat (limited to 'src/device.c')
-rw-r--r--src/device.c22
1 files changed, 22 insertions, 0 deletions
diff --git a/src/device.c b/src/device.c
index 3d42419..a76b6e7 100644
--- a/src/device.c
+++ b/src/device.c
@@ -169,6 +169,28 @@ gboolean device_sbs_set_iconstate(sbservices_client_t sbc, plist_t iconstate, GE
return result;
}
+gboolean device_sbs_save_wallpaper(sbservices_client_t sbc, const char *filename, GError **error)
+{
+ gboolean res = FALSE;
+ char *png = NULL;
+ uint64_t pngsize = 0;
+
+ if ((sbservices_get_home_screen_wallpaper_pngdata(sbc, &png, &pngsize) == SBSERVICES_E_SUCCESS) && (pngsize > 0)) {
+ /* save png icon to disk */
+ FILE *f = fopen(filename, "w");
+ fwrite(png, 1, pngsize, f);
+ fclose(f);
+ res = TRUE;
+ } else {
+ if (error)
+ *error = g_error_new(device_domain, EIO, _("Could not get wallpaper png data"));
+ }
+ if (png) {
+ free(png);
+ }
+ return res;
+}
+
device_info_t device_info_new()
{
return g_new0(struct device_info_int, 1);