[glib/gdbus-daemon] GDBusDaemon: Support timeout idle signal



commit 033da3090626ffb0335b9ee5bf31dd859be55301
Author: Alexander Larsson <alexl redhat com>
Date:   Wed Apr 18 17:08:46 2012 +0200

    GDBusDaemon: Support timeout idle signal

 gio/gdbusdaemon.c |   53 ++++++++++++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 52 insertions(+), 1 deletions(-)
---
diff --git a/gio/gdbusdaemon.c b/gio/gdbusdaemon.c
index fe02fa7..d780bdf 100644
--- a/gio/gdbusdaemon.c
+++ b/gio/gdbusdaemon.c
@@ -32,11 +32,14 @@
 #define DBUS_START_REPLY_SUCCESS         1 /**< Service was auto started */
 #define DBUS_START_REPLY_ALREADY_RUNNING 2 /**< Service was already running */
 
+#define IDLE_TIMEOUT_MSEC 3000
+
 struct _GDBusDaemon
 {
   _GFreedesktopDBusSkeleton parent_instance;
 
   gchar *address;
+  guint timeout;
   gchar *tmpdir;
   GDBusServer *server;
   gchar *guid;
@@ -53,9 +56,18 @@ struct _GDBusDaemonClass
 
 enum {
   PROP_0,
-  PROP_ADDRESS
+  PROP_ADDRESS,
+};
+
+enum
+{
+  SIGNAL_IDLE_TIMEOUT,
+  NR_SIGNALS
 };
 
+static guint g_dbus_daemon_signals[NR_SIGNALS];
+
+
 static void initable_iface_init      (GInitableIface         *initable_iface);
 static void g_dbus_daemon_iface_init (_GFreedesktopDBusIface *iface);
 
@@ -869,13 +881,34 @@ client_free (Client *client)
   g_free (client);
 }
 
+static gboolean
+idle_timeout_cb (gpointer user_data)
+{
+  GDBusDaemon *daemon = user_data;
+
+  daemon->timeout = 0;
+
+  g_signal_emit (daemon,
+                 g_dbus_daemon_signals[SIGNAL_IDLE_TIMEOUT],
+                 0);
+
+  return G_SOURCE_REMOVE;
+}
+
 static void
 connection_closed (GDBusConnection *connection,
 		   gboolean remote_peer_vanished,
 		   GError *error,
 		   Client *client)
 {
+  GDBusDaemon *daemon = client->daemon;
+
   client_free (client);
+
+  if (g_hash_table_size (daemon->clients) == 0)
+    daemon->timeout = g_timeout_add (IDLE_TIMEOUT_MSEC,
+				     idle_timeout_cb,
+				     daemon);
 }
 
 static gboolean
@@ -1473,6 +1506,12 @@ on_new_connection (GDBusServer *server,
 
   g_dbus_connection_set_exit_on_close (connection, FALSE);
 
+  if (daemon->timeout)
+    {
+      g_source_remove (daemon->timeout);
+      daemon->timeout = 0;
+    }
+
   client_new (daemon, connection);
 
   return TRUE;
@@ -1484,6 +1523,9 @@ g_dbus_daemon_finalize (GObject *object)
   GDBusDaemon *daemon = G_DBUS_DAEMON (object);
   GList *clients, *l;
 
+  if (daemon->timeout)
+    g_source_remove (daemon->timeout);
+
   clients = g_hash_table_get_values (daemon->clients);
   for (l = clients; l != NULL; l = l->next)
     client_free (l->data);
@@ -1606,6 +1648,15 @@ g_dbus_daemon_class_init (GDBusDaemonClass *klass)
   gobject_class->set_property = g_dbus_daemon_set_property;
   gobject_class->get_property = g_dbus_daemon_get_property;
 
+  g_dbus_daemon_signals[SIGNAL_IDLE_TIMEOUT] =
+    g_signal_new ("idle-timeout",
+                  G_TYPE_DBUS_DAEMON,
+                  G_SIGNAL_RUN_LAST,
+                  0,
+                  NULL, NULL,
+                  g_cclosure_marshal_VOID__VOID,
+                  G_TYPE_NONE, 0);
+
   g_object_class_install_property (gobject_class,
 				   PROP_ADDRESS,
 				   g_param_spec_string ("address",



[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]