1 /* PSPPIRE - a graphical user interface for PSPP.
2 Copyright (C) 2004, 2005, 2006, 2009, 2010, 2011, 2012, 2013, 2014, 2016 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/>. */
20 #include <gsl/gsl_errno.h>
25 #include "data/any-reader.h"
26 #include "data/casereader.h"
27 #include "data/dataset.h"
28 #include "data/datasheet.h"
29 #include "data/file-handle-def.h"
30 #include "data/session.h"
31 #include "data/settings.h"
33 #include "language/lexer/lexer.h"
34 #include "libpspp/i18n.h"
35 #include "libpspp/message.h"
36 #include "libpspp/version.h"
38 #include "output/driver.h"
39 #include "output/journal.h"
40 #include "output/message-item.h"
41 #include "output/spv/spv.h"
43 #include "ui/gui/dict-display.h"
44 #include "ui/gui/executor.h"
45 #include "ui/gui/psppire-data-store.h"
46 #include "ui/gui/psppire-data-window.h"
47 #include "ui/gui/psppire-dict.h"
48 #include "ui/gui/psppire.h"
49 #include "ui/gui/psppire-output-window.h"
50 #include "ui/gui/psppire-syntax-window.h"
51 #include "ui/gui/psppire-selector.h"
52 #include "ui/gui/psppire-var-view.h"
53 #include "ui/gui/psppire-means-layer.h"
54 #include "ui/gui/psppire-window-register.h"
55 #include "ui/gui/widgets.h"
56 #include "ui/source-init-opts.h"
57 #include "ui/syntax-gen.h"
60 #include "gl/configmake.h"
61 #include "gl/xalloc.h"
62 #include "gl/relocatable.h"
64 void create_icon_factory (void);
66 #define _(msgid) gettext (msgid)
67 #define N_(msgid) msgid
70 register_selection_functions (void)
72 psppire_selector_set_default_selection_func (GTK_TYPE_ENTRY, insert_source_row_into_entry);
73 psppire_selector_set_default_selection_func (PSPPIRE_VAR_VIEW_TYPE, insert_source_row_into_tree_view);
74 psppire_selector_set_default_selection_func (GTK_TYPE_TREE_VIEW, insert_source_row_into_tree_view);
75 psppire_selector_set_default_selection_func (PSPPIRE_TYPE_MEANS_LAYER, insert_source_row_into_layers);
79 initialize (const struct init_source *is)
87 preregister_widgets ();
90 gsl_set_error_handler_off ();
93 output_engine_push ();
102 psppire_set_lexer (NULL);
105 bind_textdomain_codeset (PACKAGE, "UTF-8");
108 if ( ! gtk_parse_args (is->argc, is->argv) )
110 perror ("Error parsing arguments");
118 textdomain (PACKAGE);
132 output_engine_pop ();
137 psppire_quit (GApplication *app)
139 g_application_quit (app);
144 int resolution; /* The dimension of the images which will be used */
145 size_t n_sizes; /* The number of items in the array below. */
146 const GtkIconSize *usage; /* An array determining for what the icon set is used */
150 handle_msg (const struct msg *m_, void *lexer_)
152 struct lexer *lexer = lexer_;
155 if (lexer != NULL && m.file_name == NULL)
157 m.file_name = CONST_CAST (char *, lex_get_file_name (lexer));
158 m.first_line = lex_get_first_line_number (lexer, 0);
159 m.last_line = lex_get_last_line_number (lexer, 0);
160 m.first_column = lex_get_first_column (lexer, 0);
161 m.last_column = lex_get_last_column (lexer, 0);
163 m.command_name = output_get_command_name ();
165 message_item_submit (message_item_create (&m));
167 free (m.command_name);
171 psppire_set_lexer (struct lexer *lexer)
173 msg_set_handler (handle_msg, lexer);
178 psppire_preload_file (const gchar *file)
180 const gchar *local_encoding = "UTF-8";
182 struct file_handle *fh = fh_create_file (NULL,
185 fh_default_properties ());
186 const char *filename = fh_get_file_name (fh);
188 int retval = any_reader_detect (fh, NULL);
191 /* Check to see if the file is a .sav or a .por file. If not
192 assume that it is a syntax file */
194 w = open_data_window (NULL, filename, NULL, NULL);
195 else if (retval == 0)
197 char *error = spv_detect (filename);
199 read_spv_file (filename);
203 create_data_window ();
204 open_syntax_window (filename, NULL);