X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=src%2Fui%2Fgui%2Fpsppire-dialog-action-runs.c;h=a0e9e30357410839736e64a1f318ddbe794577da;hb=57f24fe728f73ba7021f658e4888dd0412b040ba;hp=d1cd70ce84e350909a08644d4b5df380ddfc2762;hpb=e2da62d735c597afeef2e0e9b36e5a4a83d7da94;p=pspp diff --git a/src/ui/gui/psppire-dialog-action-runs.c b/src/ui/gui/psppire-dialog-action-runs.c index d1cd70ce84..a0e9e30357 100644 --- a/src/ui/gui/psppire-dialog-action-runs.c +++ b/src/ui/gui/psppire-dialog-action-runs.c @@ -51,7 +51,7 @@ append_fragment (GString *string, const gchar *cut, PsppireVarView *vv) } static char * -generate_syntax (PsppireDialogAction *act) +generate_syntax (const PsppireDialogAction *act) { PsppireDialogActionRuns *rd = PSPPIRE_DIALOG_ACTION_RUNS (act); gchar *text; @@ -128,12 +128,19 @@ refresh (PsppireDialogAction *rd_) } static void -psppire_dialog_action_runs_activate (GtkAction *a) +psppire_dialog_action_runs_activate (PsppireDialogAction *a) { PsppireDialogAction *pda = PSPPIRE_DIALOG_ACTION (a); PsppireDialogActionRuns *act = PSPPIRE_DIALOG_ACTION_RUNS (a); - GtkBuilder *xml = builder_new ("runs.ui"); + GHashTable *thing = psppire_dialog_action_get_hash_table (pda); + GtkBuilder *xml = g_hash_table_lookup (thing, a); + if (!xml) + { + xml = builder_new ("runs.ui"); + g_hash_table_insert (thing, a, xml); + } + pda->dialog = get_widget_assert (xml, "runs-dialog"); pda->source = get_widget_assert (xml, "dict-view"); @@ -144,22 +151,15 @@ psppire_dialog_action_runs_activate (GtkAction *a) act->cb[CB_CUSTOM] = get_widget_assert (xml, "checkbutton3"); act->variables = get_widget_assert (xml, "psppire-var-view1"); - psppire_dialog_action_set_valid_predicate (pda, dialog_state_valid); psppire_dialog_action_set_refresh (pda, refresh); - g_object_unref (xml); - - if (PSPPIRE_DIALOG_ACTION_CLASS (psppire_dialog_action_runs_parent_class)->activate) - PSPPIRE_DIALOG_ACTION_CLASS (psppire_dialog_action_runs_parent_class)->activate (pda); } static void psppire_dialog_action_runs_class_init (PsppireDialogActionRunsClass *class) { - GtkActionClass *action_class = GTK_ACTION_CLASS (class); - - action_class->activate = psppire_dialog_action_runs_activate; + psppire_dialog_action_set_activation (class, psppire_dialog_action_runs_activate); PSPPIRE_DIALOG_ACTION_CLASS (class)->generate_syntax = generate_syntax; }