2 PSPPIRE --- A Graphical User Interface for PSPP
3 Copyright (C) 2007 Free Software Foundation
5 This program is free software; you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation; either version 2 of the License, or
8 (at your option) any later version.
10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU General Public License for more details.
15 You should have received a copy of the GNU General Public License
16 along with this program; if not, write to the Free Software
17 Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
22 #include "transpose-dialog.h"
23 #include "psppire-selector.h"
24 #include "psppire-dialog.h"
26 #include "data-editor.h"
27 #include "dict-display.h"
28 #include <language/syntax-string-source.h>
29 #include "syntax-editor.h"
32 #include <glade/glade.h>
36 #define _(msgid) gettext (msgid)
37 #define N_(msgid) msgid
40 /* FIXME: These shouldn't be here */
41 #include <gtksheet/gtksheet.h>
42 #include "psppire-var-store.h"
46 static struct variable *
47 get_selected_variable (GtkTreeModel *treemodel,
54 GtkTreePath *path = gtk_tree_model_get_path (treemodel, iter);
56 gtk_tree_model_get_value (treemodel, iter, 0, &value);
58 gtk_tree_path_free (path);
60 var = psppire_dict_get_variable (dict, g_value_get_int (&value));
62 g_value_unset (&value);
68 /* A (*GtkTreeCellDataFunc) function.
69 This function expects TREEMODEL to hold G_TYPE_INT. The ints it holds
70 are the indices of the variables in the dictionary, which DATA points to.
71 It renders the name of the variable into CELL.
74 cell_var_name (GtkTreeViewColumn *tree_column,
75 GtkCellRenderer *cell,
76 GtkTreeModel *tree_model,
80 PsppireDict *dict = data;
84 var = get_selected_variable (tree_model, iter, dict);
86 name = pspp_locale_to_utf8 (var_get_name (var), -1, NULL);
87 g_object_set (cell, "text", name, NULL);
91 static gchar * generate_syntax (PsppireDict *dict, GladeXML *xml);
94 transpose_dialog (GObject *o, gpointer data)
97 struct data_editor *de = data;
99 GladeXML *xml = XML_NEW ("psppire.glade");
101 GtkSheet *var_sheet =
102 GTK_SHEET (get_widget_assert (de->xml, "variable_sheet"));
104 PsppireVarStore *vs = PSPPIRE_VAR_STORE (gtk_sheet_get_model (var_sheet));
106 GtkWidget *dialog = get_widget_assert (xml, "transpose-dialog");
107 GtkWidget *source = get_widget_assert (xml, "source-treeview");
108 GtkWidget *dest = get_widget_assert (xml, "variables-treeview");
109 GtkWidget *selector1 = get_widget_assert (xml, "psppire-selector2");
110 GtkWidget *selector2 = get_widget_assert (xml, "psppire-selector3");
111 GtkWidget *new_name_entry = get_widget_assert (xml, "new-name-entry");
113 attach_dictionary_to_treeview (GTK_TREE_VIEW (source),
115 GTK_SELECTION_MULTIPLE, NULL);
117 GtkTreeViewColumn *col;
118 GtkListStore *dest_list = gtk_list_store_new (1, G_TYPE_INT);
119 GtkCellRenderer *renderer = gtk_cell_renderer_text_new ();
121 gtk_tree_view_set_model (GTK_TREE_VIEW (dest), GTK_TREE_MODEL (dest_list));
123 col = gtk_tree_view_column_new_with_attributes (_("Var"),
129 gtk_tree_view_column_set_cell_data_func (col, renderer,
133 /* FIXME: make this a value in terms of character widths */
134 g_object_set (col, "min-width", 100, NULL);
136 gtk_tree_view_column_set_sizing (col, GTK_TREE_VIEW_COLUMN_FIXED);
138 gtk_tree_view_append_column (GTK_TREE_VIEW(dest), col);
142 psppire_selector_set_subjects (PSPPIRE_SELECTOR (selector1),
144 insert_source_row_into_tree_view,
148 psppire_selector_set_subjects (PSPPIRE_SELECTOR (selector2),
149 source, new_name_entry,
150 insert_source_row_into_entry,
151 is_currently_in_entry);
154 response = psppire_dialog_run (PSPPIRE_DIALOG (dialog));
158 case GTK_RESPONSE_OK:
160 gchar *syntax = generate_syntax (vs->dict, xml);
161 struct getl_interface *sss = create_syntax_string_source (syntax);
162 execute_syntax (sss);
167 case PSPPIRE_RESPONSE_PASTE:
169 gchar *syntax = generate_syntax (vs->dict, xml);
171 struct syntax_editor *se =
172 (struct syntax_editor *) window_create (WINDOW_SYNTAX, NULL);
174 gtk_text_buffer_insert_at_cursor (se->buffer, syntax, -1);
183 g_object_unref (xml);
188 FLIP /VARIABLES=var_list /NEWNAMES=var_name.
191 generate_syntax (PsppireDict *dict, GladeXML *xml)
195 GString *string = g_string_new ("FLIP");
198 GtkWidget *dest = get_widget_assert (xml, "variables-treeview");
199 GtkWidget *entry = get_widget_assert (xml, "new-name-entry");
201 GtkTreeModel *list_store = gtk_tree_view_get_model (GTK_TREE_VIEW (dest));
203 if ( gtk_tree_model_get_iter_first (list_store, &iter) )
205 g_string_append (string, " /VARIABLES =");
209 struct variable *var;
210 GtkTreePath *path = gtk_tree_model_get_path (list_store, &iter);
212 gtk_tree_model_get_value (list_store, &iter, 0, &value);
214 var = psppire_dict_get_variable (dict, g_value_get_int (&value));
215 g_value_unset (&value);
217 g_string_append (string, " ");
218 g_string_append (string, var_get_name (var));
220 gtk_tree_path_free (path);
222 while (gtk_tree_model_iter_next (list_store, &iter));
225 text = gtk_entry_get_text (GTK_ENTRY (entry));
228 g_string_append_printf (string, " /NEWNAME = %s", text);
230 g_string_append (string, ".");
232 syntax = string->str;
234 g_string_free (string, FALSE);