parent
ce607c10ce
commit
a0eb7e4da8
@ -0,0 +1,100 @@
|
||||
From d9e9fe3d550693c530658583b73212ce94bf3f21 Mon Sep 17 00:00:00 2001
|
||||
From: Ray Strode <rstrode@redhat.com>
|
||||
Date: Thu, 13 Sep 2012 18:18:48 -0400
|
||||
Subject: [PATCH] daemon: don't exit on timeout
|
||||
|
||||
The client library isn't robust enough to handle the daemon going away,
|
||||
so don't make it go away automatically.
|
||||
---
|
||||
gconf/gconfd.c | 68 ----------------------------------------------------------
|
||||
1 file changed, 68 deletions(-)
|
||||
|
||||
diff --git a/gconf/gconfd.c b/gconf/gconfd.c
|
||||
index d42ce1e..557e906 100644
|
||||
--- a/gconf/gconfd.c
|
||||
+++ b/gconf/gconfd.c
|
||||
@@ -1053,63 +1053,6 @@ static GSList* main_loops = NULL;
|
||||
static guint timeout_id = 0;
|
||||
static gboolean need_log_cleanup = FALSE;
|
||||
|
||||
-static gboolean
|
||||
-periodic_cleanup_timeout(gpointer data)
|
||||
-{
|
||||
- if (need_db_reload)
|
||||
- {
|
||||
- gconf_log (GCL_INFO, _("SIGHUP received, reloading all databases"));
|
||||
-
|
||||
- need_db_reload = FALSE;
|
||||
-#ifdef HAVE_CORBA
|
||||
- logfile_save ();
|
||||
- shutdown_databases ();
|
||||
- init_databases ();
|
||||
- gconf_server_load_sources ();
|
||||
- logfile_read ();
|
||||
-#endif
|
||||
-#ifdef HAVE_DBUS
|
||||
- reload_databases ();
|
||||
-#endif
|
||||
- }
|
||||
-
|
||||
- gconf_log (GCL_DEBUG, "Performing periodic cleanup, expiring cache cruft");
|
||||
-
|
||||
-#ifdef HAVE_CORBA
|
||||
- drop_old_clients ();
|
||||
-#endif
|
||||
- drop_old_databases ();
|
||||
-
|
||||
-#ifdef HAVE_DBUS
|
||||
- if (no_databases_in_use () && gconfd_dbus_client_count () == 0)
|
||||
-#else
|
||||
- if (no_databases_in_use () && client_count () == 0)
|
||||
-#endif
|
||||
- {
|
||||
- gconf_log (GCL_INFO, _("GConf server is not in use, shutting down."));
|
||||
- gconfd_main_quit ();
|
||||
- return FALSE;
|
||||
- }
|
||||
-
|
||||
- /* expire old locale cache entries */
|
||||
- gconfd_locale_cache_expire ();
|
||||
-
|
||||
-#ifdef HAVE_CORBA
|
||||
- if (!need_log_cleanup)
|
||||
- {
|
||||
- gconf_log (GCL_DEBUG, "No log file saving needed in periodic cleanup handler");
|
||||
- return TRUE;
|
||||
- }
|
||||
-
|
||||
- /* Compress the running state file */
|
||||
- logfile_save ();
|
||||
-#endif
|
||||
-
|
||||
- need_log_cleanup = FALSE;
|
||||
-
|
||||
- return TRUE;
|
||||
-}
|
||||
-
|
||||
void
|
||||
gconfd_need_log_cleanup (void)
|
||||
{
|
||||
@@ -1123,17 +1066,6 @@ gconf_main(void)
|
||||
|
||||
loop = g_main_loop_new (NULL, TRUE);
|
||||
|
||||
- if (main_loops == NULL)
|
||||
- {
|
||||
- gulong timeout_len = 60*0.5; /* 60 s/min * .5 min */
|
||||
-
|
||||
- g_assert(timeout_id == 0);
|
||||
- timeout_id = g_timeout_add_seconds (timeout_len,
|
||||
- periodic_cleanup_timeout,
|
||||
- NULL);
|
||||
-
|
||||
- }
|
||||
-
|
||||
main_loops = g_slist_prepend(main_loops, loop);
|
||||
|
||||
g_main_loop_run (loop);
|
||||
--
|
||||
1.7.12
|
||||
|
Loading…
Reference in new issue