X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=src%2Fui%2Fgui%2Fpsppire-dialog-action-paired.c;h=31ff2844cf9845ecbf0eead1a3f8f5a4e077a4f8;hb=258cbd9cdf386687122b0854274923acafc786d4;hp=fbd09b97c4f5e0806c01a2d613f33d6c8090cfb5;hpb=d71e22c69182aad3bf2ae0efde155be7c5819054;p=pspp diff --git a/src/ui/gui/psppire-dialog-action-paired.c b/src/ui/gui/psppire-dialog-action-paired.c index fbd09b97c4..31ff2844cf 100644 --- a/src/ui/gui/psppire-dialog-action-paired.c +++ b/src/ui/gui/psppire-dialog-action-paired.c @@ -124,7 +124,7 @@ select_as_pair_member (GtkTreeIter source_iter, static gchar * -generate_syntax (PsppireDialogAction *pda) +generate_syntax (const PsppireDialogAction *pda) { PsppireDialogActionPaired *d = PSPPIRE_DIALOG_ACTION_PAIRED (pda); gchar *text = NULL; @@ -150,52 +150,53 @@ generate_syntax (PsppireDialogAction *pda) } static void -psppire_dialog_action_paired_activate (GtkAction *a) +psppire_dialog_action_paired_activate (PsppireDialogAction *a) { PsppireDialogAction *pda = PSPPIRE_DIALOG_ACTION (a); PsppireDialogActionPaired *act = PSPPIRE_DIALOG_ACTION_PAIRED (a); - GtkBuilder *xml = builder_new ("paired-samples.ui"); - GtkWidget *selector = get_widget_assert (xml, "psppire-selector3"); - GtkWidget *bb = gtk_hbutton_box_new (); - GtkWidget *button = gtk_button_new_with_mnemonic (_("O_ptions...")); - GtkWidget *box = get_widget_assert (xml, "vbox3"); - - - pda->dialog = get_widget_assert (xml, "t-test-paired-samples-dialog"); - pda->source = get_widget_assert (xml, "paired-samples-t-test-treeview1"); + GHashTable *thing = psppire_dialog_action_get_hash_table (pda); + GtkBuilder *xml = g_hash_table_lookup (thing, a); + if (!xml) + { + xml = builder_new ("paired-samples.ui"); + g_hash_table_insert (thing, a, xml); + + GtkWidget *selector = get_widget_assert (xml, "psppire-selector3"); + GtkWidget *bb = gtk_button_box_new (GTK_ORIENTATION_HORIZONTAL); + GtkWidget *button = gtk_button_new_with_mnemonic (_("O_ptions...")); + GtkWidget *box = get_widget_assert (xml, "dynamic-populate"); - gtk_window_set_title (GTK_WINDOW (pda->dialog), _("Paired Samples T Test")); + pda->dialog = get_widget_assert (xml, "t-test-paired-samples-dialog"); + pda->source = get_widget_assert (xml, "paired-samples-t-test-treeview1"); - act->pairs_treeview = get_widget_assert (xml, "paired-samples-t-test-treeview2"); - act->list_store = GTK_LIST_STORE (gtk_tree_view_get_model (GTK_TREE_VIEW (act->pairs_treeview))); + gtk_window_set_title (GTK_WINDOW (pda->dialog), _("Paired Samples T Test")); - act->opt = tt_options_dialog_create (GTK_WINDOW (pda->toplevel)); + act->pairs_treeview = get_widget_assert (xml, "paired-samples-t-test-treeview2"); + act->list_store = GTK_LIST_STORE (gtk_tree_view_get_model (GTK_TREE_VIEW (act->pairs_treeview))); + act->opt = tt_options_dialog_create (GTK_WINDOW (pda->toplevel)); - g_signal_connect_swapped (button, "clicked", G_CALLBACK (tt_options_dialog_run), act->opt); + g_signal_connect_swapped (button, "clicked", G_CALLBACK (tt_options_dialog_run), act->opt); - gtk_box_pack_start (GTK_BOX (bb), button, TRUE, TRUE, 5); - gtk_box_pack_start (GTK_BOX (box), bb, FALSE, FALSE, 5); - gtk_widget_show_all (box); + gtk_box_pack_start (GTK_BOX (bb), button, TRUE, TRUE, 5); + gtk_box_pack_start (GTK_BOX (box), bb, FALSE, FALSE, 5); + gtk_widget_show_all (box); - psppire_dialog_action_set_valid_predicate (pda, dialog_state_valid); - psppire_dialog_action_set_refresh (pda, refresh); + psppire_dialog_action_set_valid_predicate (pda, dialog_state_valid); + psppire_dialog_action_set_refresh (pda, refresh); - g_object_set (pda->source, - "predicate", var_is_numeric, - NULL); + g_object_set (pda->source, + "predicate", var_is_numeric, + NULL); - psppire_selector_set_select_func (PSPPIRE_SELECTOR (selector), - select_as_pair_member, - act); + psppire_selector_set_select_func (PSPPIRE_SELECTOR (selector), + select_as_pair_member, + act); + } - g_object_unref (xml); - - if (PSPPIRE_DIALOG_ACTION_CLASS (psppire_dialog_action_paired_parent_class)->activate) - PSPPIRE_DIALOG_ACTION_CLASS (psppire_dialog_action_paired_parent_class)->activate (pda); } static void @@ -208,13 +209,11 @@ psppire_dialog_action_paired_finalize (GObject *o) static void psppire_dialog_action_paired_class_init (PsppireDialogActionPairedClass *class) { - GtkActionClass *action_class = GTK_ACTION_CLASS (class); GObjectClass *object_class = G_OBJECT_CLASS (class); - - action_class->activate = psppire_dialog_action_paired_activate; + psppire_dialog_action_set_activation (class, psppire_dialog_action_paired_activate); PSPPIRE_DIALOG_ACTION_CLASS (class)->generate_syntax = generate_syntax; - object_class->finalize = psppire_dialog_action_paired_finalize; + object_class->finalize = psppire_dialog_action_paired_finalize; }