#include <config.h>
-#include <locale.h>
+#include <libpspp/i18n.h>
#include <assert.h>
#include <libintl.h>
#include <gsl/gsl_errno.h>
+#include <xalloc.h>
#include <argp.h>
#include <ui/command-line.h>
#include "relocatable.h"
#include "psppire-data-window.h"
#include "psppire.h"
+#include "widgets.h"
#include <libpspp/getl.h>
#include <unistd.h>
#include <libpspp/getl.h>
#include <language/lexer/lexer.h>
#include <libpspp/version.h>
-#include <output/output.h>
+#include <output/driver.h>
#include <output/journal.h>
#include <language/syntax-string-source.h>
#include <gtk/gtk.h>
-#include <glade/glade.h>
#include "psppire-dict.h"
+#include "dict-display.h"
+#include "psppire-selector.h"
+#include "psppire-var-view.h"
#include "psppire-var-store.h"
#include "psppire-data-store.h"
-#include "helper.h"
+#include "executor.h"
#include "message-dialog.h"
#include <ui/syntax-gen.h>
-
+#include "psppire-window-register.h"
#include "psppire-output-window.h"
#include <data/sys-file-reader.h>
#include <ui/source-init-opts.h>
+GtkRecentManager *the_recent_mgr = 0;
PsppireDataStore *the_data_store = 0;
PsppireVarStore *the_var_store = 0;
#define N_(msgid) msgid
-const char * output_file_name (void);
void
{
PsppireDict *dictionary = 0;
- /* gtk_init messes with the locale.
- So unset the bits we want to control ourselves */
- setlocale (LC_NUMERIC, "C");
-
- bindtextdomain (PACKAGE, locale_dir);
-
+ i18n_init ();
- glade_init ();
+ preregister_widgets ();
gsl_set_error_handler_off ();
fn_init ();
- outp_init ();
settings_init (&viewer_width, &viewer_length);
fh_init ();
the_source_stream =
create_icon_factory ();
- {
- const char *filename = output_file_name ();
-
- struct string config_string;
+ psppire_output_window_setup ();
- ds_init_empty (&config_string);
-
- ds_put_format (&config_string,
- "gui:ascii:screen:squeeze=on headers=off top-margin=0 "
- "bottom-margin=0 paginate=off length=auto width=auto "
- "emphasis=none "
- "output-file=\"%s\" append=yes", filename);
+ journal_enable ();
+ textdomain (PACKAGE);
- outp_configure_driver_line (ds_ss (&config_string));
- unlink (filename);
+ the_recent_mgr = gtk_recent_manager_get_default ();
- ds_destroy (&config_string);
- }
-
- journal_enable ();
- textdomain (PACKAGE);
+ psppire_selector_set_default_selection_func (GTK_TYPE_ENTRY, insert_source_row_into_entry);
+ psppire_selector_set_default_selection_func (PSPPIRE_VAR_VIEW_TYPE, insert_source_row_into_tree_view);
+ psppire_selector_set_default_selection_func (GTK_TYPE_TREE_VIEW, insert_source_row_into_tree_view);
the_data_window = psppire_data_window_new ();
destroy_source_stream (the_source_stream);
message_dialog_done ();
settings_done ();
- outp_done ();
+ output_close ();
+ i18n_done ();
+}
+
+
+static void
+func (gpointer key, gpointer value, gpointer data)
+{
+ gboolean rv;
+ PsppireWindow *window = PSPPIRE_WINDOW (value);
+
+ g_signal_emit_by_name (window, "delete-event", 0, &rv);
}
+void
+psppire_quit (void)
+{
+ PsppireWindowRegister *reg = psppire_window_register_new ();
+ psppire_window_register_foreach (reg, func, NULL);
+
+ gtk_main_quit ();
+}
struct icon_info
{
case ARGP_KEY_ARG:
{
- struct string syntax;
- FILE *fp = fopen (arg, "r");
- if (NULL == fp)
+ gchar *filename = NULL;
+ gchar *utf8 = NULL;
+ const gchar *local_encoding = NULL;
+ gsize written = -1;
+ const gboolean local_is_utf8 = g_get_charset (&local_encoding);
+
+ /* There seems to be no Glib function to convert from local encoding
+ to filename encoding. Therefore it has to be done in two steps:
+ the intermediate encoding is UTF8.
+
+ Either step could fail. However, in many cases the file can still
+ be loaded even if the conversion fails. So in those cases, after showing
+ a warning, we simply copy the locally encoded filename to the destination
+ and hope for the best.
+ */
+
+ if ( local_is_utf8)
{
- const int errnum = errno;
- fprintf (state->err_stream, _("Cannot open %s: %s.\n"),
- arg, strerror (errnum));
- return 0;
+ utf8 = xstrdup (arg);
}
- if ( sfm_detect (fp))
+ else
{
- ds_init_cstr (&syntax, "GET FILE=");
- goto close;
+ GError *err = NULL;
+ utf8 = g_locale_to_utf8 (arg, -1, NULL, &written, &err);
+ if ( NULL == utf8)
+ {
+ g_warning ("Cannot convert filename from local encoding \"%s\" to UTF-8: %s",
+ local_encoding,
+ err->message);
+ g_clear_error (&err);
+ }
}
- rewind (fp);
- if (pfm_detect (fp))
+
+ if ( NULL != utf8)
{
- ds_init_cstr (&syntax, "IMPORT FILE=");
- goto close;
+ GError *err = NULL;
+ filename = g_filename_from_utf8 (utf8, written, NULL, NULL, &err);
+ if ( NULL == filename)
+ {
+ g_warning ("Cannot convert filename from UTF8 to filename encoding: %s",
+ err->message);
+ g_clear_error (&err);
+ }
}
- fclose (fp);
- msg (ME, _("%s is neither a system nor portable file"), arg);
- break;
-
- close:
- fclose (fp);
-
- syntax_gen_string (&syntax, ss_cstr (arg));
- ds_put_cstr (&syntax, ".");
+ g_free (utf8);
- getl_append_source (ss,
- create_syntax_string_source (ds_cstr (&syntax)),
- GETL_BATCH,
- ERRMODE_CONTINUE);
+ if ( filename == NULL)
+ filename = xstrdup (arg);
- ds_destroy (&syntax);
-
- psppire_window_set_filename (the_data_window, arg);
+ psppire_window_load (PSPPIRE_WINDOW (the_data_window), filename);
+ g_free (filename);
break;
}
default:
const struct argp non_option_argp = {NULL, parse_non_options, 0, 0, 0, 0, 0};
-
-
-const char *
-output_file_name (void)
-{
- const char *dir = default_output_path ();
- static char *filename = NULL;
-
- if ( NULL == filename )
- filename = xasprintf ("%s%s", dir, OUTPUT_FILE_NAME);
-
-
- return filename;
-}