X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=src%2Fui%2Fgui%2Fpsppire-dialog-action-sort.c;h=2a0be711a71670be60d73b5cb23c14ce15a1add1;hb=c115ee191738e0c382d151f10e96e255acc74d83;hp=29c3c8063edfd1c373c6e8a082330526548c0e8a;hpb=3a1a4a18f0371b955a91346df9c9958ccce0a14d;p=pspp diff --git a/src/ui/gui/psppire-dialog-action-sort.c b/src/ui/gui/psppire-dialog-action-sort.c index 29c3c8063e..2a0be711a7 100644 --- a/src/ui/gui/psppire-dialog-action-sort.c +++ b/src/ui/gui/psppire-dialog-action-sort.c @@ -30,7 +30,7 @@ static void psppire_dialog_action_sort_class_init (PsppireDialogActionSortC G_DEFINE_TYPE (PsppireDialogActionSort, psppire_dialog_action_sort, PSPPIRE_TYPE_DIALOG_ACTION); static char * -generate_syntax (PsppireDialogAction *act) +generate_syntax (const PsppireDialogAction *act) { PsppireDialogActionSort *scd = PSPPIRE_DIALOG_ACTION_SORT (act); gchar *text; @@ -90,16 +90,23 @@ dialog_state_valid (gpointer act) static void -psppire_dialog_action_sort_activate (GtkAction *a) +psppire_dialog_action_sort_activate (PsppireDialogAction *a) { PsppireDialogAction *pda = PSPPIRE_DIALOG_ACTION (a); PsppireDialogActionSort *act = PSPPIRE_DIALOG_ACTION_SORT (a); - GtkBuilder *xml = builder_new ("sort.ui"); - pda->dialog = get_widget_assert (xml, "sort-cases-dialog"); - pda->source = get_widget_assert (xml, "sort-cases-treeview1"); + GHashTable *thing = psppire_dialog_action_get_hash_table (pda); + GtkBuilder *xml = g_hash_table_lookup (thing, a); + if (!xml) + { + xml = builder_new ("sort.ui"); + g_hash_table_insert (thing, a, xml); + } + + pda->dialog = get_widget_assert (xml, "sort-cases-dialog"); + pda->source = get_widget_assert (xml, "sort-cases-treeview1"); - act->variables = get_widget_assert (xml, "sort-cases-treeview2"); + act->variables = get_widget_assert (xml, "sort-cases-treeview2"); act->ascending = get_widget_assert (xml, "sort-cases-radiobutton0"); psppire_dialog_action_set_refresh (pda, reset); @@ -107,17 +114,13 @@ psppire_dialog_action_sort_activate (GtkAction *a) psppire_dialog_action_set_valid_predicate (pda, dialog_state_valid); - if (PSPPIRE_DIALOG_ACTION_CLASS (psppire_dialog_action_sort_parent_class)->activate) - PSPPIRE_DIALOG_ACTION_CLASS (psppire_dialog_action_sort_parent_class)->activate (pda); } static void psppire_dialog_action_sort_class_init (PsppireDialogActionSortClass *class) { - GtkActionClass *action_class = GTK_ACTION_CLASS (class); - PsppireDialogActionClass *pdac = PSPPIRE_DIALOG_ACTION_CLASS (class); - - action_class->activate = psppire_dialog_action_sort_activate; + PsppireDialogActionClass *pdac = PSPPIRE_DIALOG_ACTION_CLASS (class); + psppire_dialog_action_set_activation (class, psppire_dialog_action_sort_activate); pdac->generate_syntax = generate_syntax; }