aboutsummaryrefslogtreecommitdiffstats
path: root/lib/egg/eggsmclient-xsmp.c
diff options
context:
space:
mode:
authorChristian Persch <chpe@src.gnome.org>2009-04-09 05:28:07 +0800
committerChristian Persch <chpe@src.gnome.org>2009-04-09 05:28:07 +0800
commit98a77d35bedf5beff0f0dfef29674430f74c0102 (patch)
tree0915def203adcd2f3fb548e4d3592af99bdaba82 /lib/egg/eggsmclient-xsmp.c
parent7f0ac8bada128d5b6c51952613d2786a951f1e75 (diff)
downloadgsoc2013-epiphany-98a77d35bedf5beff0f0dfef29674430f74c0102.tar.gz
gsoc2013-epiphany-98a77d35bedf5beff0f0dfef29674430f74c0102.tar.zst
gsoc2013-epiphany-98a77d35bedf5beff0f0dfef29674430f74c0102.zip
Update smclient from libegg master
svn path=/trunk/; revision=8952
Diffstat (limited to 'lib/egg/eggsmclient-xsmp.c')
-rw-r--r--lib/egg/eggsmclient-xsmp.c13
1 files changed, 10 insertions, 3 deletions
diff --git a/lib/egg/eggsmclient-xsmp.c b/lib/egg/eggsmclient-xsmp.c
index dcaf36b98..81af7d2b6 100644
--- a/lib/egg/eggsmclient-xsmp.c
+++ b/lib/egg/eggsmclient-xsmp.c
@@ -830,10 +830,14 @@ save_state (EggSMClientXSMP *xsmp)
if (desktop_file)
{
GKeyFile *merged_file;
+ char *desktop_file_path;
merged_file = g_key_file_new ();
- if (g_key_file_load_from_file (merged_file,
- egg_desktop_file_get_source (desktop_file),
+ desktop_file_path =
+ g_filename_from_uri (egg_desktop_file_get_source (desktop_file),
+ NULL, NULL);
+ if (desktop_file_path &&
+ g_key_file_load_from_file (merged_file, desktop_file_path,
G_KEY_FILE_KEEP_COMMENTS |
G_KEY_FILE_KEEP_TRANSLATIONS, NULL))
{
@@ -876,8 +880,11 @@ save_state (EggSMClientXSMP *xsmp)
EGG_DESKTOP_FILE_KEY_EXEC,
exec);
g_free (exec);
-
}
+ else
+ desktop_file = NULL;
+
+ g_free (desktop_file_path);
}
/* Now write state_file to disk. (We can't use mktemp(), because