From 1d777b5010809a01d3dd903f1b7e66b1eae4c4f1 Mon Sep 17 00:00:00 2001 From: Evangelos Ribeiro Tzaras Date: Wed, 11 Jan 2023 18:50:22 +0100 Subject: [PATCH] application: Remove and destroy application windows on shutdown The windows need to be removed from the GtkApplication because they are holding references to the application which prevents proper cleanup. Fixes: #508 --- src/calls-application.c | 17 ++++++++++++++--- 1 file changed, 14 insertions(+), 3 deletions(-) diff --git a/src/calls-application.c b/src/calls-application.c index f05cc37..46fe746 100644 --- a/src/calls-application.c +++ b/src/calls-application.c @@ -79,15 +79,25 @@ G_DEFINE_TYPE (CallsApplication, calls_application, GTK_TYPE_APPLICATION); static void start_proper (CallsApplication *self); + +static void +quit_calls (CallsApplication *self) +{ + gtk_application_remove_window (GTK_APPLICATION (self), GTK_WINDOW (self->main_window)); + gtk_application_remove_window (GTK_APPLICATION (self), GTK_WINDOW (self->call_window)); +} + + static gboolean on_int_or_term_signal (CallsApplication *self) { g_debug ("Received SIGTERM/SIGINT, shutting down gracefully"); - g_application_quit (G_APPLICATION (self)); self->id_sigint = 0; self->id_sigterm = 0; + quit_calls (self); + return G_SOURCE_REMOVE; } @@ -676,8 +686,9 @@ finalize (GObject *object) g_clear_handle_id (&self->id_sigterm, g_source_remove); g_clear_handle_id (&self->id_sigint, g_source_remove); - g_clear_object (&self->call_window); - g_clear_object (&self->main_window); + gtk_widget_destroy (GTK_WIDGET (self->main_window)); + gtk_widget_destroy (GTK_WIDGET (self->call_window)); + g_clear_object (&self->record_store); g_clear_object (&self->ringer); g_clear_object (&self->notifier);