1 /* PSPPIRE - a graphical user interface for PSPP.
2 Copyright (C) 2010 Free Software Foundation
4 This program is free software: you can redistribute it and/or modify
5 it under the terms of the GNU General Public License as published by
6 the Free Software Foundation, either version 3 of the License, or
7 (at your option) any later version.
9 This program is distributed in the hope that it will be useful,
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 GNU General Public License for more details.
14 You should have received a copy of the GNU General Public License
15 along with this program. If not, see <http://www.gnu.org/licenses/>. */
19 #include "k-related-dialog.h"
21 #include <language/syntax-string-source.h>
23 #include "psppire-dialog.h"
24 #include "psppire-var-view.h"
25 #include "psppire-acr.h"
26 #include "dialog-common.h"
34 struct k_related_dialog
45 dialog_state_valid (gpointer data)
47 struct k_related_dialog *krd = data;
50 gtk_tree_view_get_model (GTK_TREE_VIEW (krd->var_view));
52 /* Tests using less than 3 variables are not useful */
53 if (gtk_tree_model_iter_n_children (vars, NULL) < 3)
56 /* At least one checkbutton must be active */
58 ! gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (krd->friedman))
60 ! gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (krd->kendal))
62 ! gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (krd->cochran))
71 refresh (struct k_related_dialog *krd)
73 GtkTreeModel *liststore =
74 gtk_tree_view_get_model (GTK_TREE_VIEW (krd->var_view));
76 gtk_list_store_clear (GTK_LIST_STORE (liststore));
79 gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (krd->friedman), TRUE);
80 gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (krd->kendal), FALSE);
81 gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (krd->cochran), FALSE);
86 generate_syntax (const struct k_related_dialog *krd)
91 string = g_string_new ("NPAR TEST");
93 if ( gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (krd->friedman)))
95 g_string_append (string, "\n\t/FRIEDMAN = ");
96 psppire_var_view_append_names (PSPPIRE_VAR_VIEW (krd->var_view), 0, string);
99 if ( gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (krd->kendal)))
101 g_string_append (string, "\n\t/KENDAL = ");
102 psppire_var_view_append_names (PSPPIRE_VAR_VIEW (krd->var_view), 0, string);
105 if ( gtk_toggle_button_get_active (GTK_TOGGLE_BUTTON (krd->cochran)))
107 g_string_append (string, "\n\t/COCHRAN = ");
108 psppire_var_view_append_names (PSPPIRE_VAR_VIEW (krd->var_view), 0, string);
111 g_string_append (string, ".\n");
115 g_string_free (string, FALSE);
122 /* Pops up the K-Related dialog box */
124 k_related_dialog (PsppireDataWindow *dw)
128 struct k_related_dialog krd;
130 GtkBuilder *xml = builder_new ("k-related.ui");
133 GtkWidget *dialog = get_widget_assert (xml, "k-related-dialog");
135 GtkWidget *dict_view = get_widget_assert (xml, "dict-view");
137 g_object_get (dw->data_editor, "var-store", &vs, NULL);
139 gtk_window_set_transient_for (GTK_WINDOW (dialog), GTK_WINDOW (dw));
141 krd.var_view = get_widget_assert (xml, "variables-treeview");
143 krd.friedman = get_widget_assert (xml, "friedman-checkbutton");
144 krd.kendal = get_widget_assert (xml, "kendal-checkbutton");
145 krd.cochran = get_widget_assert (xml, "cochran-checkbutton");
147 g_object_get (vs, "dictionary", &krd.dict, NULL);
148 g_object_set (dict_view,
150 "predicate", var_is_numeric,
154 g_signal_connect_swapped (dialog, "refresh", G_CALLBACK (refresh), &krd);
156 psppire_dialog_set_valid_predicate (PSPPIRE_DIALOG (dialog),
157 dialog_state_valid, &krd);
159 response = psppire_dialog_run (PSPPIRE_DIALOG (dialog));
164 case GTK_RESPONSE_OK:
166 gchar *syntax = generate_syntax (&krd);
168 struct getl_interface *sss = create_syntax_string_source (syntax);
169 execute_syntax (sss);
174 case PSPPIRE_RESPONSE_PASTE:
176 gchar *syntax = generate_syntax (&krd);
177 paste_syntax_to_window (syntax);
185 g_object_unref (xml);