aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/empathy-ft-manager.c49
1 files changed, 28 insertions, 21 deletions
diff --git a/src/empathy-ft-manager.c b/src/empathy-ft-manager.c
index 3616d6306..3cdca9928 100644
--- a/src/empathy-ft-manager.c
+++ b/src/empathy-ft-manager.c
@@ -101,8 +101,6 @@ enum
G_DEFINE_TYPE (EmpathyFTManager, empathy_ft_manager, G_TYPE_OBJECT);
-static EmpathyFTManager *manager_p = NULL;
-
static gchar *
ft_manager_format_interval (gint interval)
{
@@ -599,7 +597,7 @@ ft_manager_stop (EmpathyFTManager *ft_manager)
}
static void
-ft_manager_response_cb (GtkWidget *dialog,
+ft_manager_response_cb (GtkWidget *widget,
gint response,
EmpathyFTManager *ft_manager)
{
@@ -623,26 +621,28 @@ ft_manager_delete_event_cb (GtkWidget *widget,
EmpathyFTManager *ft_manager)
{
ft_manager_clear (ft_manager);
- if (g_hash_table_size (ft_manager->priv->tp_file_to_row_ref) == 0)
- {
- DEBUG ("Destroying window");
- if (manager_p != NULL)
- g_object_unref (manager_p);
-
- manager_p = NULL;
- return FALSE;
- }
- else
+ if (g_hash_table_size (ft_manager->priv->tp_file_to_row_ref) > 0)
{
+ /* There is still FTs on flight, just hide the window */
DEBUG ("Hiding window");
gtk_widget_hide (widget);
return TRUE;
}
+
+ return FALSE;
+}
+
+static void
+ft_manager_destroy_cb (GtkWidget *widget,
+ EmpathyFTManager *ft_manager)
+{
+ g_object_unref (ft_manager);
}
static void
ft_manager_build_ui (EmpathyFTManager *ft_manager)
{
+ GladeXML *glade;
gint x, y, w, h;
GtkListStore *liststore;
GtkTreeViewColumn *column;
@@ -651,7 +651,7 @@ ft_manager_build_ui (EmpathyFTManager *ft_manager)
gchar *filename;
filename = empathy_file_lookup ("empathy-ft-manager.glade", "src");
- empathy_glade_get_file (filename,
+ glade = empathy_glade_get_file (filename,
"ft_manager_dialog", NULL,
"ft_manager_dialog", &ft_manager->priv->window,
"ft_list", &ft_manager->priv->treeview,
@@ -660,12 +660,14 @@ ft_manager_build_ui (EmpathyFTManager *ft_manager)
NULL);
g_free (filename);
- g_signal_connect (ft_manager->priv->window, "response",
- G_CALLBACK (ft_manager_response_cb), ft_manager);
- g_signal_connect (ft_manager->priv->window, "delete-event",
- G_CALLBACK (ft_manager_delete_event_cb), ft_manager);
- g_signal_connect (ft_manager->priv->window, "configure-event",
- G_CALLBACK (ft_manager_configure_event_cb), ft_manager);
+ empathy_glade_connect (glade, ft_manager,
+ "ft_manager_dialog", "destroy", ft_manager_destroy_cb,
+ "ft_manager_dialog", "response", ft_manager_response_cb,
+ "ft_manager_dialog", "delete-event", ft_manager_delete_event_cb,
+ "ft_manager_dialog", "configure-event", ft_manager_configure_event_cb,
+ NULL);
+
+ g_object_unref (glade);
/* Window geometry. */
empathy_geometry_load ("ft-manager", &x, &y, &w, &h);
@@ -808,8 +810,13 @@ empathy_ft_manager_class_init (EmpathyFTManagerClass *klass)
EmpathyFTManager *
empathy_ft_manager_get_default (void)
{
+ static EmpathyFTManager *manager_p = NULL;
+
if (!manager_p)
- manager_p = g_object_new (EMPATHY_TYPE_FT_MANAGER, NULL);
+ {
+ manager_p = g_object_new (EMPATHY_TYPE_FT_MANAGER, NULL);
+ g_object_add_weak_pointer (G_OBJECT (manager_p), (gpointer) &manager_p);
+ }
return manager_p;
}