X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=src%2Fui%2Fgui%2Fpsppire-acr.c;h=0b397fe3dcbd97edc8a65462a4294a42a3d255b6;hb=2501627caac743acbfcc97480f15344f8a393a6e;hp=13b5803e5e2d1bc64beccdeced1f8fba58ed8163;hpb=eec7dc24096e5786220276183d62166e5db4b583;p=pspp diff --git a/src/ui/gui/psppire-acr.c b/src/ui/gui/psppire-acr.c index 13b5803e5e..0b397fe3dc 100644 --- a/src/ui/gui/psppire-acr.c +++ b/src/ui/gui/psppire-acr.c @@ -50,6 +50,11 @@ static void psppire_acr_dispose (GObject *obj) { PsppireAcr *acr = PSPPIRE_ACR (obj); + + if (acr->dispose_has_run) + return; + acr->dispose_has_run = TRUE; + psppire_acr_set_model (acr, NULL); G_OBJECT_CLASS (psppire_acr_parent_class)->dispose (obj); @@ -135,7 +140,7 @@ on_add_button_clicked (PsppireAcr *acr) ++i) { static GValue value; - if ( ! acr->get_value (i, &value, acr->get_value_data) ) + if (! acr->get_value (i, &value, acr->get_value_data)) continue; gtk_list_store_set_value (acr->list_store, &iter, @@ -170,7 +175,7 @@ on_change_button_clicked (PsppireAcr *acr) ++i) { static GValue value; - if ( ! acr->get_value (i, &value, acr->get_value_data) ) + if (! acr->get_value (i, &value, acr->get_value_data)) continue; gtk_list_store_set_value (acr->list_store, &iter, @@ -178,10 +183,10 @@ on_change_button_clicked (PsppireAcr *acr) g_value_unset (&value); } - g_list_foreach (l, (GFunc) gtk_tree_path_free, NULL); + g_list_foreach (l, GFUNC_COMPAT_CAST (gtk_tree_path_free), NULL); g_list_free (l); - if ( acr->update) acr->update (acr->update_data); + if (acr->update) acr->update (acr->update_data); } @@ -204,7 +209,7 @@ on_remove_button_clicked (PsppireAcr *acr) gtk_list_store_remove (acr->list_store, &iter); - g_list_foreach (l, (GFunc) gtk_tree_path_free, NULL); + g_list_foreach (l, GFUNC_COMPAT_CAST (gtk_tree_path_free), NULL); g_list_free (l); } @@ -220,7 +225,7 @@ row_is_selected (const PsppireAcr *acr) result = (l != NULL); - g_list_foreach (l, (GFunc) gtk_tree_path_free, NULL); + g_list_foreach (l, GFUNC_COMPAT_CAST (gtk_tree_path_free), NULL); g_list_free (l); return result; @@ -238,7 +243,7 @@ on_select (GtkTreeSelection *selection, gpointer data) gtk_widget_set_sensitive (acr->change_button, row_is_selected (acr) - ); + ); } @@ -255,10 +260,12 @@ psppire_acr_set_enabled (PsppireAcr *acr, gboolean status) static void psppire_acr_init (PsppireAcr *acr) { - GtkWidget *bb = gtk_vbutton_box_new (); + GtkWidget *bb = gtk_button_box_new (GTK_ORIENTATION_VERTICAL); GtkWidget *sw = gtk_scrolled_window_new (NULL, NULL); + acr->dispose_has_run = FALSE; + gtk_orientable_set_orientation (GTK_ORIENTABLE (acr), GTK_ORIENTATION_HORIZONTAL); acr->tv = GTK_TREE_VIEW (gtk_tree_view_new ());