4a89ace5f65920089a8c2fbd56730dd324ffb8bc
[pspp-builds.git] / src / ui / gui / transpose-dialog.c
1 /*
2     PSPPIRE --- A Graphical User Interface for PSPP
3     Copyright (C) 2007  Free Software Foundation
4
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.
9
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.
14
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
18     02110-1301, USA. */
19
20 #include <config.h>
21
22 #include "transpose-dialog.h"
23 #include "psppire-selector.h"
24 #include "psppire-dialog.h"
25 #include "helper.h"
26 #include "data-editor.h"
27 #include "dict-display.h"
28 #include <language/syntax-string-source.h>
29 #include "syntax-editor.h"
30
31 #include <gtk/gtk.h>
32 #include <glade/glade.h>
33
34 #include <gettext.h>
35
36 #define _(msgid) gettext (msgid)
37 #define N_(msgid) msgid
38
39
40 /* FIXME: These shouldn't be here */
41 #include <gtksheet/gtksheet.h>
42 #include "psppire-var-store.h"
43
44
45
46 static struct variable *
47 get_selected_variable (GtkTreeModel *treemodel,
48                        GtkTreeIter *iter,
49                        PsppireDict *dict)
50 {
51   struct variable *var;
52   GValue value = {0};
53
54   GtkTreePath *path = gtk_tree_model_get_path (treemodel, iter);
55
56   gtk_tree_model_get_value (treemodel, iter, 0, &value);
57
58   gtk_tree_path_free (path);
59
60   var =  psppire_dict_get_variable (dict, g_value_get_int (&value));
61
62   g_value_unset (&value);
63
64   return var;
65 }
66
67
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.
72 */
73 static void
74 cell_var_name (GtkTreeViewColumn *tree_column,
75                GtkCellRenderer *cell,
76                GtkTreeModel *tree_model,
77                GtkTreeIter *iter,
78                gpointer data)
79 {
80   PsppireDict *dict = data;
81   struct variable *var;
82   gchar *name;
83
84   var = get_selected_variable (tree_model, iter, dict);
85
86   name = pspp_locale_to_utf8 (var_get_name (var), -1, NULL);
87   g_object_set (cell, "text", name, NULL);
88   g_free (name);
89 }
90
91 static gchar * generate_syntax (PsppireDict *dict, GladeXML *xml);
92
93 void
94 transpose_dialog (GObject *o, gpointer data)
95 {
96   gint response ;
97   struct data_editor *de = data;
98
99   GladeXML *xml = XML_NEW ("psppire.glade");
100
101   GtkSheet *var_sheet =
102     GTK_SHEET (get_widget_assert (de->xml, "variable_sheet"));
103
104   PsppireVarStore *vs = PSPPIRE_VAR_STORE (gtk_sheet_get_model (var_sheet));
105
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");
112
113   attach_dictionary_to_treeview (GTK_TREE_VIEW (source),
114                                  vs->dict,
115                                  GTK_SELECTION_MULTIPLE, NULL);
116   {
117     GtkTreeViewColumn *col;
118     GtkListStore *dest_list = gtk_list_store_new (1, G_TYPE_INT);
119     GtkCellRenderer *renderer = gtk_cell_renderer_text_new ();
120
121     gtk_tree_view_set_model (GTK_TREE_VIEW (dest), GTK_TREE_MODEL (dest_list));
122
123     col = gtk_tree_view_column_new_with_attributes (_("Var"),
124                                                     renderer,
125                                                     "text",
126                                                     0,
127                                                     NULL);
128
129     gtk_tree_view_column_set_cell_data_func (col, renderer,
130                                              cell_var_name,
131                                              vs->dict, 0);
132
133     /* FIXME: make this a value in terms of character widths */
134     g_object_set (col, "min-width",  100, NULL);
135
136     gtk_tree_view_column_set_sizing (col, GTK_TREE_VIEW_COLUMN_FIXED);
137
138     gtk_tree_view_append_column (GTK_TREE_VIEW(dest), col);
139   }
140
141
142   psppire_selector_set_subjects (PSPPIRE_SELECTOR (selector1),
143                                  source, dest,
144                                  insert_source_row_into_tree_view,
145                                  NULL);
146
147
148   psppire_selector_set_subjects (PSPPIRE_SELECTOR (selector2),
149                                  source, new_name_entry,
150                                  insert_source_row_into_entry,
151                                  is_currently_in_entry);
152
153
154   response = psppire_dialog_run (PSPPIRE_DIALOG (dialog));
155
156   switch (response)
157     {
158     case GTK_RESPONSE_OK:
159       {
160         gchar *syntax = generate_syntax (vs->dict, xml);
161         struct getl_interface *sss = create_syntax_string_source (syntax);
162         execute_syntax (sss);
163
164         g_free (syntax);
165       }
166       break;
167     case PSPPIRE_RESPONSE_PASTE:
168       {
169         gchar *syntax = generate_syntax (vs->dict, xml);
170
171         struct syntax_editor *se =
172           (struct syntax_editor *) window_create (WINDOW_SYNTAX, NULL);
173
174         gtk_text_buffer_insert_at_cursor (se->buffer, syntax, -1);
175
176         g_free (syntax);
177       }
178       break;
179     default:
180       break;
181     }
182
183   g_object_unref (xml);
184 }
185
186
187   /*
188      FLIP /VARIABLES=var_list /NEWNAMES=var_name.
189   */
190 static gchar *
191 generate_syntax (PsppireDict *dict, GladeXML *xml)
192 {
193   GtkTreeIter iter;
194   const gchar *text;
195   GString *string = g_string_new ("FLIP");
196   gchar *syntax ;
197
198   GtkWidget *dest = get_widget_assert (xml, "variables-treeview");
199   GtkWidget *entry = get_widget_assert (xml, "new-name-entry");
200
201   GtkTreeModel *list_store = gtk_tree_view_get_model (GTK_TREE_VIEW (dest));
202
203   if ( gtk_tree_model_get_iter_first (list_store, &iter) )
204     {
205       g_string_append (string, " /VARIABLES =");
206       do
207         {
208           GValue value = {0};
209           struct variable *var;
210           GtkTreePath *path = gtk_tree_model_get_path (list_store, &iter);
211
212           gtk_tree_model_get_value (list_store, &iter, 0, &value);
213
214           var = psppire_dict_get_variable (dict, g_value_get_int (&value));
215           g_value_unset (&value);
216
217           g_string_append (string, " ");
218           g_string_append (string, var_get_name (var));
219
220           gtk_tree_path_free (path);
221         }
222       while (gtk_tree_model_iter_next (list_store, &iter));
223     }
224
225   text = gtk_entry_get_text (GTK_ENTRY (entry));
226
227   if ( text)
228     g_string_append_printf (string, " /NEWNAME = %s", text);
229
230   g_string_append (string, ".");
231
232   syntax = string->str;
233
234   g_string_free (string, FALSE);
235
236   return syntax;
237 }