#include "psppire-dialog.h"
#include "builder-wrapper.h"
-#include "checkbox-treeview.h"
#include "psppire-dict.h"
#include "libpspp/str.h"
PsppireDialogAction *pda = PSPPIRE_DIALOG_ACTION (a);
GtkWidget *opts_button;
- GtkBuilder *xml = builder_new ("logistic.ui");
+ GHashTable *thing = psppire_dialog_action_get_hash_table (pda);
+ GtkBuilder *xml = g_hash_table_lookup (thing, a);
+ if (!xml)
+ {
+ xml = builder_new ("logistic.ui");
+ g_hash_table_insert (thing, a, xml);
+ }
pda->dialog = get_widget_assert (xml, "logistic-dialog");
pda->source = get_widget_assert (xml, "dict-view");
gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON(act->conf_checkbox), TRUE);
gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON(act->conf_checkbox), FALSE);
- g_object_unref (xml);
-
psppire_dialog_action_set_refresh (pda, refresh);
psppire_dialog_action_set_valid_predicate (pda,
{
PsppireDialogActionLogistic *rd = PSPPIRE_DIALOG_ACTION_LOGISTIC (a);
gchar *text = NULL;
+ struct string str;
+ const gchar *dep = gtk_entry_get_text (GTK_ENTRY (rd->dep_var));
- GString *string = g_string_new ("LOGISTIC REGRESSION ");
+ ds_init_cstr (&str, "LOGISTIC REGRESSION ");
- const gchar *dep = gtk_entry_get_text (GTK_ENTRY (rd->dep_var));
+ ds_put_cstr (&str, dep);
- g_string_append (string, dep);
+ ds_put_cstr (&str, " WITH ");
- g_string_append (string, " WITH ");
+ psppire_var_view_append_names_str (PSPPIRE_VAR_VIEW (rd->indep_vars), 0, &str);
- psppire_var_view_append_names (PSPPIRE_VAR_VIEW (rd->indep_vars), 0, string);
+ ds_put_cstr (&str, "\n\t/CRITERIA =");
- g_string_append (string, "\n\t/CRITERIA =");
+ syntax_gen_pspp (&str, " CUT(%g)", rd->cut_point);
- g_string_append_printf (string, " CUT(%g)", rd->cut_point);
- g_string_append_printf (string, " ITERATE(%d)", rd->max_iterations);
+ syntax_gen_pspp (&str, " ITERATE(%d)", rd->max_iterations);
if (rd->conf)
{
- g_string_append_printf (string, "\n\t/PRINT = CI(%g)", rd->conf_level);
+ syntax_gen_pspp (&str, "\n\t/PRINT = CI(%g)", rd->conf_level);
}
if (rd->constant)
- g_string_append (string, "\n\t/NOORIGIN");
+ ds_put_cstr (&str, "\n\t/NOORIGIN");
else
- g_string_append (string, "\n\t/ORIGIN");
+ ds_put_cstr (&str, "\n\t/ORIGIN");
- g_string_append (string, ".\n");
+ ds_put_cstr (&str, ".\n");
- text = string->str;
+ text = ds_steal_cstr (&str);
- g_string_free (string, FALSE);
+ ds_destroy (&str);
return text;
}
static void
psppire_dialog_action_logistic_class_init (PsppireDialogActionLogisticClass *class)
{
- GtkActionClass *action_class = GTK_ACTION_CLASS (class);
-
- action_class->activate = psppire_dialog_action_logistic_activate;
+ psppire_dialog_action_set_activation (class, psppire_dialog_action_logistic_activate);
PSPPIRE_DIALOG_ACTION_CLASS (class)->generate_syntax = generate_syntax;
}