From 9998ab6d850a6a1f4e338aa598943ef34c55fa7d Mon Sep 17 00:00:00 2001 From: Hanno Schwalm Date: Sun, 1 Dec 2024 08:02:28 +0100 Subject: [PATCH] Some extra dbus safety As dt_dbusinit() might fail we have to make sure dereferencing is ok in dt_dbus_destroy() and dt_dbus_connected() --- src/common/dbus.c | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/src/common/dbus.c b/src/common/dbus.c index 511770585be9..6349d9a9eb56 100644 --- a/src/common/dbus.c +++ b/src/common/dbus.c @@ -199,13 +199,16 @@ struct dt_dbus_t *dt_dbus_init() _on_name_lost, dbus, NULL); dbus->dbus_connection = g_bus_get_sync(G_BUS_TYPE_SESSION, NULL, NULL); - g_object_set(G_OBJECT(dbus->dbus_connection), "exit-on-close", FALSE, (gchar *)0); + if(dbus->dbus_connection) + g_object_set(G_OBJECT(dbus->dbus_connection), "exit-on-close", FALSE, (gchar *)0); return dbus; } void dt_dbus_destroy(const dt_dbus_t *dbus) { + if(!dbus) return; + g_bus_unown_name(dbus->owner_id); if(dbus->introspection_data) g_dbus_node_info_unref(dbus->introspection_data); @@ -217,7 +220,7 @@ void dt_dbus_destroy(const dt_dbus_t *dbus) gboolean dt_dbus_connected(const dt_dbus_t *dbus) { - return dbus->connected; + return dbus && dbus->connected; } // clang-format off