gio: Use g_steal_handle_id() with signal unsubscriptions

This makes no functional changes, but does tidy the code up a bit and
means `g_steal_handle_id()` gets a bit more testing.

Signed-off-by: Philip Withnall <pwithnall@gnome.org>
This commit is contained in:
Philip Withnall 2024-10-08 13:55:22 +01:00
parent da5ce72171
commit 6b15af3c4c
No known key found for this signature in database
GPG Key ID: DCDF5885B1F3ED73
15 changed files with 38 additions and 62 deletions

View File

@ -544,10 +544,7 @@ g_application_impl_attempt_primary (GApplicationImpl *impl,
impl->primary = (rval != DBUS_REQUEST_NAME_REPLY_EXISTS); impl->primary = (rval != DBUS_REQUEST_NAME_REPLY_EXISTS);
if (!impl->primary && impl->name_lost_signal) if (!impl->primary && impl->name_lost_signal)
{ g_dbus_connection_signal_unsubscribe (impl->session_bus, g_steal_handle_id (&impl->name_lost_signal));
g_dbus_connection_signal_unsubscribe (impl->session_bus, impl->name_lost_signal);
impl->name_lost_signal = 0;
}
return TRUE; return TRUE;
} }
@ -592,10 +589,7 @@ g_application_impl_stop_primary (GApplicationImpl *impl)
} }
if (impl->name_lost_signal) if (impl->name_lost_signal)
{ g_dbus_connection_signal_unsubscribe (impl->session_bus, g_steal_handle_id (&impl->name_lost_signal));
g_dbus_connection_signal_unsubscribe (impl->session_bus, impl->name_lost_signal);
impl->name_lost_signal = 0;
}
if (impl->primary && impl->bus_name) if (impl->primary && impl->bus_name)
{ {

View File

@ -1984,10 +1984,7 @@ monitor_on_name_vanished (GDBusConnection *connection,
g_print ("The name %s does not have an owner\n", name); g_print ("The name %s does not have an owner\n", name);
if (monitor_filter_id != 0) if (monitor_filter_id != 0)
{ g_dbus_connection_signal_unsubscribe (connection, g_steal_handle_id (&monitor_filter_id));
g_dbus_connection_signal_unsubscribe (connection, monitor_filter_id);
monitor_filter_id = 0;
}
} }
static const GOptionEntry monitor_entries[] = static const GOptionEntry monitor_entries[] =

View File

@ -423,7 +423,7 @@ g_dbus_action_group_finalize (GObject *object)
GDBusActionGroup *group = G_DBUS_ACTION_GROUP (object); GDBusActionGroup *group = G_DBUS_ACTION_GROUP (object);
if (group->subscription_id) if (group->subscription_id)
g_dbus_connection_signal_unsubscribe (group->connection, group->subscription_id); g_dbus_connection_signal_unsubscribe (group->connection, g_steal_handle_id (&group->subscription_id));
if (group->actions) if (group->actions)
g_hash_table_unref (group->actions); g_hash_table_unref (group->actions);

View File

@ -306,7 +306,7 @@ static void
g_dbus_menu_path_deactivate (GDBusMenuPath *path) g_dbus_menu_path_deactivate (GDBusMenuPath *path)
{ {
if (--path->active == 0) if (--path->active == 0)
g_dbus_connection_signal_unsubscribe (path->id->connection, path->watch_id); g_dbus_connection_signal_unsubscribe (path->id->connection, g_steal_handle_id (&path->watch_id));
} }
static GDBusMenuPath * static GDBusMenuPath *

View File

@ -89,9 +89,9 @@ client_unref (Client *client)
if (client->disconnected_signal_handler_id > 0) if (client->disconnected_signal_handler_id > 0)
g_signal_handler_disconnect (client->connection, client->disconnected_signal_handler_id); g_signal_handler_disconnect (client->connection, client->disconnected_signal_handler_id);
if (client->name_acquired_subscription_id > 0) if (client->name_acquired_subscription_id > 0)
g_dbus_connection_signal_unsubscribe (client->connection, client->name_acquired_subscription_id); g_dbus_connection_signal_unsubscribe (client->connection, g_steal_handle_id (&client->name_acquired_subscription_id));
if (client->name_lost_subscription_id > 0) if (client->name_lost_subscription_id > 0)
g_dbus_connection_signal_unsubscribe (client->connection, client->name_lost_subscription_id); g_dbus_connection_signal_unsubscribe (client->connection, g_steal_handle_id (&client->name_lost_subscription_id));
g_object_unref (client->connection); g_object_unref (client->connection);
} }
g_main_context_unref (client->main_context); g_main_context_unref (client->main_context);
@ -357,11 +357,9 @@ request_name_cb (GObject *source_object,
if (connection != NULL) if (connection != NULL)
{ {
if (client->name_acquired_subscription_id > 0) if (client->name_acquired_subscription_id > 0)
g_dbus_connection_signal_unsubscribe (client->connection, client->name_acquired_subscription_id); g_dbus_connection_signal_unsubscribe (client->connection, g_steal_handle_id (&client->name_acquired_subscription_id));
if (client->name_lost_subscription_id > 0) if (client->name_lost_subscription_id > 0)
g_dbus_connection_signal_unsubscribe (client->connection, client->name_lost_subscription_id); g_dbus_connection_signal_unsubscribe (client->connection, g_steal_handle_id (&client->name_lost_subscription_id));
client->name_acquired_subscription_id = 0;
client->name_lost_subscription_id = 0;
g_object_unref (connection); g_object_unref (connection);
} }
@ -383,13 +381,11 @@ on_connection_disconnected (GDBusConnection *connection,
if (client->disconnected_signal_handler_id > 0) if (client->disconnected_signal_handler_id > 0)
g_signal_handler_disconnect (client->connection, client->disconnected_signal_handler_id); g_signal_handler_disconnect (client->connection, client->disconnected_signal_handler_id);
if (client->name_acquired_subscription_id > 0) if (client->name_acquired_subscription_id > 0)
g_dbus_connection_signal_unsubscribe (client->connection, client->name_acquired_subscription_id); g_dbus_connection_signal_unsubscribe (client->connection, g_steal_handle_id (&client->name_acquired_subscription_id));
if (client->name_lost_subscription_id > 0) if (client->name_lost_subscription_id > 0)
g_dbus_connection_signal_unsubscribe (client->connection, client->name_lost_subscription_id); g_dbus_connection_signal_unsubscribe (client->connection, g_steal_handle_id (&client->name_lost_subscription_id));
g_object_unref (client->connection); g_object_unref (client->connection);
client->disconnected_signal_handler_id = 0; client->disconnected_signal_handler_id = 0;
client->name_acquired_subscription_id = 0;
client->name_lost_subscription_id = 0;
client->connection = NULL; client->connection = NULL;
call_lost_handler (client); call_lost_handler (client);
@ -969,12 +965,10 @@ g_bus_unown_name (guint owner_id)
if (client->disconnected_signal_handler_id > 0) if (client->disconnected_signal_handler_id > 0)
g_signal_handler_disconnect (client->connection, client->disconnected_signal_handler_id); g_signal_handler_disconnect (client->connection, client->disconnected_signal_handler_id);
if (client->name_acquired_subscription_id > 0) if (client->name_acquired_subscription_id > 0)
g_dbus_connection_signal_unsubscribe (client->connection, client->name_acquired_subscription_id); g_dbus_connection_signal_unsubscribe (client->connection, g_steal_handle_id (&client->name_acquired_subscription_id));
if (client->name_lost_subscription_id > 0) if (client->name_lost_subscription_id > 0)
g_dbus_connection_signal_unsubscribe (client->connection, client->name_lost_subscription_id); g_dbus_connection_signal_unsubscribe (client->connection, g_steal_handle_id (&client->name_lost_subscription_id));
client->disconnected_signal_handler_id = 0; client->disconnected_signal_handler_id = 0;
client->name_acquired_subscription_id = 0;
client->name_lost_subscription_id = 0;
if (client->connection != NULL) if (client->connection != NULL)
{ {
g_object_unref (client->connection); g_object_unref (client->connection);

View File

@ -95,7 +95,7 @@ client_unref (Client *client)
if (client->connection != NULL) if (client->connection != NULL)
{ {
if (client->name_owner_changed_subscription_id > 0) if (client->name_owner_changed_subscription_id > 0)
g_dbus_connection_signal_unsubscribe (client->connection, client->name_owner_changed_subscription_id); g_dbus_connection_signal_unsubscribe (client->connection, g_steal_handle_id (&client->name_owner_changed_subscription_id));
if (client->disconnected_signal_handler_id > 0) if (client->disconnected_signal_handler_id > 0)
g_signal_handler_disconnect (client->connection, client->disconnected_signal_handler_id); g_signal_handler_disconnect (client->connection, client->disconnected_signal_handler_id);
g_object_unref (client->connection); g_object_unref (client->connection);
@ -306,12 +306,11 @@ on_connection_disconnected (GDBusConnection *connection,
return; return;
if (client->name_owner_changed_subscription_id > 0) if (client->name_owner_changed_subscription_id > 0)
g_dbus_connection_signal_unsubscribe (client->connection, client->name_owner_changed_subscription_id); g_dbus_connection_signal_unsubscribe (client->connection, g_steal_handle_id (&client->name_owner_changed_subscription_id));
if (client->disconnected_signal_handler_id > 0) if (client->disconnected_signal_handler_id > 0)
g_signal_handler_disconnect (client->connection, client->disconnected_signal_handler_id); g_signal_handler_disconnect (client->connection, client->disconnected_signal_handler_id);
g_object_unref (client->connection); g_object_unref (client->connection);
client->disconnected_signal_handler_id = 0; client->disconnected_signal_handler_id = 0;
client->name_owner_changed_subscription_id = 0;
client->connection = NULL; client->connection = NULL;
call_vanished_handler (client); call_vanished_handler (client);

View File

@ -1218,11 +1218,8 @@ maybe_unsubscribe_signals (GDBusObjectManagerClient *manager)
g_return_if_fail (G_IS_DBUS_OBJECT_MANAGER_CLIENT (manager)); g_return_if_fail (G_IS_DBUS_OBJECT_MANAGER_CLIENT (manager));
if (manager->priv->signal_subscription_id > 0) if (manager->priv->signal_subscription_id > 0)
{ g_dbus_connection_signal_unsubscribe (manager->priv->connection,
g_dbus_connection_signal_unsubscribe (manager->priv->connection, g_steal_handle_id (&manager->priv->signal_subscription_id));
manager->priv->signal_subscription_id);
manager->priv->signal_subscription_id = 0;
}
if (manager->priv->match_rule != NULL) if (manager->priv->match_rule != NULL)
{ {

View File

@ -198,15 +198,15 @@ g_dbus_proxy_finalize (GObject *object)
if (proxy->priv->name_owner_changed_subscription_id > 0) if (proxy->priv->name_owner_changed_subscription_id > 0)
g_dbus_connection_signal_unsubscribe (proxy->priv->connection, g_dbus_connection_signal_unsubscribe (proxy->priv->connection,
proxy->priv->name_owner_changed_subscription_id); g_steal_handle_id (&proxy->priv->name_owner_changed_subscription_id));
if (proxy->priv->properties_changed_subscription_id > 0) if (proxy->priv->properties_changed_subscription_id > 0)
g_dbus_connection_signal_unsubscribe (proxy->priv->connection, g_dbus_connection_signal_unsubscribe (proxy->priv->connection,
proxy->priv->properties_changed_subscription_id); g_steal_handle_id (&proxy->priv->properties_changed_subscription_id));
if (proxy->priv->signals_subscription_id > 0) if (proxy->priv->signals_subscription_id > 0)
g_dbus_connection_signal_unsubscribe (proxy->priv->connection, g_dbus_connection_signal_unsubscribe (proxy->priv->connection,
proxy->priv->signals_subscription_id); g_steal_handle_id (&proxy->priv->signals_subscription_id));
if (proxy->priv->connection != NULL) if (proxy->priv->connection != NULL)
g_object_unref (proxy->priv->connection); g_object_unref (proxy->priv->connection);

View File

@ -437,8 +437,7 @@ g_fdo_notification_backend_dispose (GObject *object)
GDBusConnection *session_bus; GDBusConnection *session_bus;
session_bus = G_NOTIFICATION_BACKEND (backend)->dbus_connection; session_bus = G_NOTIFICATION_BACKEND (backend)->dbus_connection;
g_dbus_connection_signal_unsubscribe (session_bus, backend->notify_subscription); g_dbus_connection_signal_unsubscribe (session_bus, g_steal_handle_id (&backend->notify_subscription));
backend->notify_subscription = 0;
} }
if (backend->notifications) if (backend->notifications)

View File

@ -177,8 +177,7 @@ response_received (GDBusConnection *connection,
guint32 response; guint32 response;
call_data = g_task_get_task_data (task); call_data = g_task_get_task_data (task);
g_dbus_connection_signal_unsubscribe (connection, call_data->response_signal_id); g_dbus_connection_signal_unsubscribe (connection, g_steal_handle_id (&call_data->response_signal_id));
call_data->response_signal_id = 0;
g_variant_get (parameters, "(u@a{sv})", &response, NULL); g_variant_get (parameters, "(u@a{sv})", &response, NULL);
@ -232,8 +231,7 @@ open_call_done (GObject *source,
{ {
guint signal_id; guint signal_id;
g_dbus_connection_signal_unsubscribe (connection, call_data->response_signal_id); g_dbus_connection_signal_unsubscribe (connection, g_steal_handle_id (&call_data->response_signal_id));
call_data->response_signal_id = 0;
signal_id = g_dbus_connection_signal_subscribe (connection, signal_id = g_dbus_connection_signal_subscribe (connection,
"org.freedesktop.portal.Desktop", "org.freedesktop.portal.Desktop",

View File

@ -371,8 +371,7 @@ test_dbus_properties (void)
g_signal_handler_disconnect (controller, notify_id); g_signal_handler_disconnect (controller, notify_id);
notify_id = 0; notify_id = 0;
g_dbus_connection_signal_unsubscribe (remote_connection, properties_changed_id); g_dbus_connection_signal_unsubscribe (remote_connection, g_steal_handle_id (&properties_changed_id));
properties_changed_id = 0;
g_debug_controller_dbus_stop (controller); g_debug_controller_dbus_stop (controller);
while (g_main_context_iteration (NULL, FALSE)); while (g_main_context_iteration (NULL, FALSE));

View File

@ -113,7 +113,7 @@ test_connection_flush (void)
g_source_remove (timeout_mainloop_id); g_source_remove (timeout_mainloop_id);
} }
g_dbus_connection_signal_unsubscribe (connection, signal_handler_id); g_dbus_connection_signal_unsubscribe (connection, g_steal_handle_id (&signal_handler_id));
g_object_unref (connection); g_object_unref (connection);
session_bus_down (); session_bus_down ();

View File

@ -793,12 +793,12 @@ test_connection_signals (void)
g_assert_cmpint (count_s4, ==, 2); g_assert_cmpint (count_s4, ==, 2);
g_assert_cmpint (count_s5, ==, 1); g_assert_cmpint (count_s5, ==, 1);
g_dbus_connection_signal_unsubscribe (c1, s1); g_dbus_connection_signal_unsubscribe (c1, g_steal_handle_id (&s1));
g_dbus_connection_signal_unsubscribe (c1, s2); g_dbus_connection_signal_unsubscribe (c1, g_steal_handle_id (&s2));
g_dbus_connection_signal_unsubscribe (c1, s3); g_dbus_connection_signal_unsubscribe (c1, g_steal_handle_id (&s3));
g_dbus_connection_signal_unsubscribe (c1, s1b); g_dbus_connection_signal_unsubscribe (c1, g_steal_handle_id (&s1b));
g_dbus_connection_signal_unsubscribe (c1, s4); g_dbus_connection_signal_unsubscribe (c1, g_steal_handle_id (&s4));
g_dbus_connection_signal_unsubscribe (c1, s5); g_dbus_connection_signal_unsubscribe (c1, g_steal_handle_id (&s5));
g_object_unref (c1); g_object_unref (c1);
g_object_unref (c2); g_object_unref (c2);
@ -852,8 +852,8 @@ test_match_rule (GDBusConnection *connection,
g_assert_cmpint (emissions, ==, 1); g_assert_cmpint (emissions, ==, 1);
g_assert_cmpint (matches, ==, should_match ? 1 : 0); g_assert_cmpint (matches, ==, should_match ? 1 : 0);
g_dbus_connection_signal_unsubscribe (connection, subscription_ids[0]); g_dbus_connection_signal_unsubscribe (connection, g_steal_handle_id (&subscription_ids[0]));
g_dbus_connection_signal_unsubscribe (connection, subscription_ids[1]); g_dbus_connection_signal_unsubscribe (connection, g_steal_handle_id (&subscription_ids[1]));
} }
static void static void
@ -1132,7 +1132,7 @@ test_connection_filter (void)
timeout_mainloop_id = g_timeout_add (30000, test_connection_filter_on_timeout, NULL); timeout_mainloop_id = g_timeout_add (30000, test_connection_filter_on_timeout, NULL);
g_main_loop_run (loop); g_main_loop_run (loop);
g_source_remove (timeout_mainloop_id); g_source_remove (timeout_mainloop_id);
g_dbus_connection_signal_unsubscribe (c, signal_handler_id); g_dbus_connection_signal_unsubscribe (c, g_steal_handle_id (&signal_handler_id));
/* now test some combinations... */ /* now test some combinations... */
filter_id = g_dbus_connection_add_filter (c, filter_id = g_dbus_connection_add_filter (c,

View File

@ -895,7 +895,7 @@ fixture_subscribe (Fixture *f,
if (subscribe->unsubscribe_immediately) if (subscribe->unsubscribe_immediately)
{ {
g_test_message ("\tImmediately unsubscribing"); g_test_message ("\tImmediately unsubscribing");
g_dbus_connection_signal_unsubscribe (subscriber, id); g_dbus_connection_signal_unsubscribe (subscriber, g_steal_handle_id (&id));
} }
else else
{ {
@ -1285,12 +1285,12 @@ teardown (Fixture *f,
g_ptr_array_unref (f->proxies); g_ptr_array_unref (f->proxies);
if (f->finished_subscription != 0) if (f->finished_subscription != 0)
g_dbus_connection_signal_unsubscribe (subscriber, f->finished_subscription); g_dbus_connection_signal_unsubscribe (subscriber, g_steal_handle_id (&f->finished_subscription));
for (i = 0; i < G_N_ELEMENTS (f->subscriptions); i++) for (i = 0; i < G_N_ELEMENTS (f->subscriptions); i++)
{ {
if (f->subscriptions[i] != 0) if (f->subscriptions[i] != 0)
g_dbus_connection_signal_unsubscribe (subscriber, f->subscriptions[i]); g_dbus_connection_signal_unsubscribe (subscriber, g_steal_handle_id (&f->subscriptions[i]));
} }
g_ptr_array_unref (f->received); g_ptr_array_unref (f->received);

View File

@ -306,8 +306,7 @@ test_delivery_in_thread_func (gpointer _data)
g_assert_cmpuint (data.signal_count, ==, 1); g_assert_cmpuint (data.signal_count, ==, 1);
g_dbus_connection_signal_unsubscribe (c, subscription_id); g_dbus_connection_signal_unsubscribe (c, g_steal_handle_id (&subscription_id));
subscription_id = 0;
while (!data.unsubscribe_complete) while (!data.unsubscribe_complete)
g_main_context_iteration (thread_context, TRUE); g_main_context_iteration (thread_context, TRUE);