summaryrefslogtreecommitdiffstats
path: root/gdbus/mainloop.c
diff options
context:
space:
mode:
authorLuiz Augusto Von Dentz <luiz.dentz-von@nokia.com>2009-12-29 11:16:23 +0200
committerMarcel Holtmann <marcel@holtmann.org>2009-12-29 01:19:38 -0800
commitd897b24085dd2e83d21061efa4db7ac481278f9f (patch)
treeffa69f19860e850a5a07e2f41512507b40950cd2 /gdbus/mainloop.c
parente8111c822956a29103d53b1b7e75bcd6ccb6be62 (diff)
downloadofono-d897b24085dd2e83d21061efa4db7ac481278f9f.tar.bz2
Port gdbus to use g_dbus_add_signal_watch
Diffstat (limited to 'gdbus/mainloop.c')
-rw-r--r--gdbus/mainloop.c21
1 files changed, 10 insertions, 11 deletions
diff --git a/gdbus/mainloop.c b/gdbus/mainloop.c
index 7abdf478..994a8325 100644
--- a/gdbus/mainloop.c
+++ b/gdbus/mainloop.c
@@ -64,19 +64,16 @@ struct disconnect_data {
void *user_data;
};
-static DBusHandlerResult disconnect_filter(DBusConnection *conn,
+static gboolean disconnected_signal(DBusConnection *conn,
DBusMessage *msg, void *data)
{
struct disconnect_data *dc_data = data;
- if (dbus_message_is_signal(msg,
- DBUS_INTERFACE_LOCAL, "Disconnected") == TRUE) {
- error("Got disconnected from the system message bus");
- dc_data->disconnect_cb(conn, dc_data->user_data);
- dbus_connection_unref(conn);
- }
+ error("Got disconnected from the system message bus");
+ dc_data->disconnect_cb(conn, dc_data->user_data);
+ dbus_connection_unref(conn);
- return DBUS_HANDLER_RESULT_NOT_YET_HANDLED;
+ return TRUE;
}
static gboolean message_dispatch_cb(void *data)
@@ -312,9 +309,11 @@ gboolean g_dbus_set_disconnect_function(DBusConnection *connection,
dbus_connection_set_exit_on_disconnect(connection, FALSE);
- if (dbus_connection_add_filter(connection, disconnect_filter,
- dc_data, g_free) == FALSE) {
- error("Can't add D-Bus disconnect filter");
+ if (g_dbus_add_signal_watch(connection, NULL, NULL,
+ DBUS_INTERFACE_LOCAL, "Disconnected",
+ disconnected_signal, dc_data,
+ g_free) == 0) {
+ error("Can't add watch for D-Bus Disconnected signal\n");
g_free(dc_data);
return FALSE;
}