diff options
author | Iain Holmes <iain@src.gnome.org> | 2001-07-06 00:40:17 +0800 |
---|---|---|
committer | Iain Holmes <iain@src.gnome.org> | 2001-07-06 00:40:17 +0800 |
commit | fb6a190f0085747e1146bc2f9153753fb95dd94b (patch) | |
tree | fbb86f401c8e3b93260373d76310644d3e9fad6d /my-evolution/e-summary-preferences.c | |
parent | b0be7c3db2510c0d836c5cf1138588cb9810b974 (diff) | |
download | gsoc2013-evolution-fb6a190f0085747e1146bc2f9153753fb95dd94b.tar.gz gsoc2013-evolution-fb6a190f0085747e1146bc2f9153753fb95dd94b.tar.zst gsoc2013-evolution-fb6a190f0085747e1146bc2f9153753fb95dd94b.zip |
Fixed memory corruption, restoring settings reenabled.
svn path=/trunk/; revision=10810
Diffstat (limited to 'my-evolution/e-summary-preferences.c')
-rw-r--r-- | my-evolution/e-summary-preferences.c | 91 |
1 files changed, 74 insertions, 17 deletions
diff --git a/my-evolution/e-summary-preferences.c b/my-evolution/e-summary-preferences.c index 44c5b49fdb..be460a1f75 100644 --- a/my-evolution/e-summary-preferences.c +++ b/my-evolution/e-summary-preferences.c @@ -114,7 +114,6 @@ str_list_from_vector (const char *vector) gboolean e_summary_preferences_restore (ESummaryPrefs *prefs) { -#if 0 Bonobo_ConfigDatabase db; CORBA_Environment ev; char *vector; @@ -130,46 +129,104 @@ e_summary_preferences_restore (ESummaryPrefs *prefs) } CORBA_exception_free (&ev); - vector = bonobo_config_get_string (db, "Mail/display_folders", NULL); - if (vector == NULL) { + vector = bonobo_config_get_string (db, "Mail/display_folders", &ev); + if (BONOBO_EX (&ev) || vector == NULL) { + g_warning ("Error getting Mail/display_folders"); + CORBA_exception_free (&ev); bonobo_object_release_unref (db, NULL); return FALSE; } prefs->display_folders = str_list_from_vector (vector); g_free (vector); - prefs->show_full_path = bonobo_config_get_boolean (db, "Mail/show_full_path", NULL); + prefs->show_full_path = bonobo_config_get_boolean (db, "Mail/show_full_path", &ev); + if (BONOBO_EX (&ev) || db == CORBA_OBJECT_NIL) { + g_warning ("Error getting Mail/show_full_path. Using defaults"); + bonobo_object_release_unref (db, NULL); + CORBA_exception_free (&ev); + return FALSE; + } + - vector = bonobo_config_get_string (db, "RDF/rdf_urls", NULL); - if (vector == NULL) { + vector = bonobo_config_get_string (db, "RDF/rdf_urls", &ev); + if (BONOBO_EX (&ev) || vector == NULL) { + g_warning ("Error getting RDF/rdf_urls"); + CORBA_exception_free (&ev); bonobo_object_release_unref (db, NULL); return FALSE; } prefs->rdf_urls = str_list_from_vector (vector); g_free (vector); - prefs->rdf_refresh_time = bonobo_config_get_long_with_default (db, "RDF/rdf_refresh_time", 600, NULL); - prefs->limit = bonobo_config_get_long_with_default (db, "RDF/limit", 10, NULL); - prefs->wipe_trackers = bonobo_config_get_boolean_with_default (db, "RDF/wipe_trackers", FALSE, NULL); + prefs->rdf_refresh_time = bonobo_config_get_long_with_default (db, "RDF/rdf_refresh_time", 600, &ev); + if (BONOBO_EX (&ev) || db == CORBA_OBJECT_NIL) { + g_warning ("Error getting RDF/rdf_refresh_time. Using defaults"); + bonobo_object_release_unref (db, NULL); + CORBA_exception_free (&ev); + return FALSE; + } - vector = bonobo_config_get_string (db, "Weather/stations", NULL); - if (vector == NULL) { + prefs->limit = bonobo_config_get_long_with_default (db, "RDF/limit", 10, &ev); + if (BONOBO_EX (&ev) || db == CORBA_OBJECT_NIL) { + g_warning ("Error getting RDF/limit. Using defaults"); + bonobo_object_release_unref (db, NULL); + CORBA_exception_free (&ev); + return FALSE; + } + + prefs->wipe_trackers = bonobo_config_get_boolean_with_default (db, "RDF/wipe_trackers", FALSE, &ev); + if (BONOBO_EX (&ev) || db == CORBA_OBJECT_NIL) { + g_warning ("Error getting RDF/wipe_trackers. Using defaults"); + bonobo_object_release_unref (db, NULL); + CORBA_exception_free (&ev); + return FALSE; + } + + vector = bonobo_config_get_string (db, "Weather/stations", &ev); + if (BONOBO_EX (&ev) || vector == NULL) { + g_warning ("Error getting Weather/stations"); + CORBA_exception_free (&ev); bonobo_object_release_unref (db, NULL); return FALSE; } prefs->stations = str_list_from_vector (vector); g_free (vector); - prefs->units = bonobo_config_get_long (db, "Weather/units", NULL); - prefs->weather_refresh_time = bonobo_config_get_long (db, "Weather/weather_refresh_time", NULL); + prefs->units = bonobo_config_get_long (db, "Weather/units", &ev); + if (BONOBO_EX (&ev) || db == CORBA_OBJECT_NIL) { + g_warning ("Error getting Weather/units. Using defaults"); + bonobo_object_release_unref (db, NULL); + CORBA_exception_free (&ev); + return FALSE; + } + + prefs->weather_refresh_time = bonobo_config_get_long (db, "Weather/weather_refresh_time", &ev); + if (BONOBO_EX (&ev) || db == CORBA_OBJECT_NIL) { + g_warning ("Error getting Weather/weather_refresh_time. Using defaults"); + bonobo_object_release_unref (db, NULL); + CORBA_exception_free (&ev); + return FALSE; + } + - prefs->days = bonobo_config_get_long (db, "Schedule/days", NULL); - prefs->show_tasks = bonobo_config_get_long (db, "Schedule/show_tasks", NULL); + prefs->days = bonobo_config_get_long (db, "Schedule/days", &ev); + if (BONOBO_EX (&ev) || db == CORBA_OBJECT_NIL) { + g_warning ("Error getting Schedule/days. Using defaults"); + bonobo_object_release_unref (db, NULL); + CORBA_exception_free (&ev); + return FALSE; + } + + prefs->show_tasks = bonobo_config_get_long (db, "Schedule/show_tasks", &ev); + if (BONOBO_EX (&ev) || db == CORBA_OBJECT_NIL) { + g_warning ("Error getting Schedule/show_tasks. Using defaults"); + bonobo_object_release_unref (db, NULL); + CORBA_exception_free (&ev); + return FALSE; + } bonobo_object_release_unref (db, NULL); return TRUE; -#endif - return FALSE; } /* Write prefs to disk */ |