Added a basic output viewer.
[pspp-builds.git] / src / ui / gui / psppire.c
index 9a341ec424da1922d5246d2b9e1042f86c1c290a..0c60fbd2412f90ba360c5d6d753507a304fedc68 100644 (file)
@@ -1,11 +1,9 @@
-/* 
-   PSPPIRE --- A Graphical User Interface for PSPP
+/* PSPPIRE - a graphical user interface for PSPP.
    Copyright (C) 2004, 2005, 2006  Free Software Foundation
-   Written by John Darrington
 
-   This program is free software; you can redistribute it and/or modify
+   This program is free software: you can redistribute it and/or modify
    it under the terms of the GNU General Public License as published by
-   the Free Software Foundation; either version 2 of the License, or
+   the Free Software Foundation, either version 3 of the License, or
    (at your option) any later version.
 
    This program is distributed in the hope that it will be useful,
    GNU General Public License for more details.
 
    You should have received a copy of the GNU General Public License
-   along with this program; if not, write to the Free Software
-   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
-   02110-1301, USA. */
+   along with this program.  If not, see <http://www.gnu.org/licenses/>. */
+
+#include <config.h>
 
 #include <assert.h>
 #include <libintl.h>
 
-#include <libpspp/version.h>
-#include <libpspp/copyleft.h>
+#include "relocatable.h"
+
+#include "data-editor.h"
+#include "psppire.h"
+
+#include <unistd.h>
+#include <data/casereader.h>
+#include <data/datasheet.h>
+#include <data/file-handle-def.h>
+#include <data/format.h>
 #include <data/settings.h>
+#include <data/file-name.h>
+#include <data/procedure.h>
+#include <libpspp/getl.h>
+#include <language/lexer/lexer.h>
+#include <libpspp/version.h>
+#include <output/output.h>
 
-#include <getopt.h>
-#include <gtk/gtk.h>
 #include <gtk/gtk.h>
 #include <glade/glade.h>
-#include "menu-actions.h"
 #include "psppire-dict.h"
 #include "psppire-var-store.h"
 #include "psppire-data-store.h"
 #include "helper.h"
 #include "data-sheet.h"
 #include "var-sheet.h"
-#include "psppire-case-array.h"
 #include "message-dialog.h"
 
-GladeXML *xml;
-
-
-PsppireDict *the_dictionary = 0;
-PsppireCaseArray *the_cases = 0;
+#include "output-viewer.h"
 
+PsppireDataStore *the_data_store = 0;
+PsppireVarStore *the_var_store = 0;
 
-PsppireDataStore *data_store = 0;
+static void create_icon_factory (void);
 
+struct source_stream *the_source_stream ;
+struct dataset * the_dataset = NULL;
 
-static bool parse_command_line (int *argc, char ***argv, 
-                               gchar **filename, GError **err);
-
-
-#define _(msgid) gettext (msgid)
-#define N_(msgid) msgid
 
 static void
-give_help(void)
+replace_casereader (struct casereader *s)
 {
-  static struct msg m = {
-    MSG_GENERAL, 
-    MSG_NOTE,
-    {0, -1},
-    0, 
-  };
+  PsppireCaseFile *pcf = psppire_case_file_new (s);
 
-  if (! m.text) 
-    m.text=g_strdup(_("Sorry. The help system hasn't yet been implemented."));
-
-  popup_message(&m);
+  psppire_data_store_set_case_file (the_data_store, pcf);
 }
 
-PsppireVarStore *var_store = 0;
-
-int 
-main(int argc, char *argv[]) 
+void
+initialize (void)
 {
+  PsppireDict *dictionary = 0;
 
-  GtkWidget *data_editor ;
-  GtkSheet *var_sheet ; 
-  GtkSheet *data_sheet ;
-
-  gchar *filename=0;
-  GError *err = 0;
-
-  gtk_init(&argc, &argv);
-
-  /* gtk_init messes with the locale. 
+  /* gtk_init messes with the locale.
      So unset the bits we want to control ourselves */
   setlocale (LC_NUMERIC, "C");
 
@@ -95,124 +79,136 @@ main(int argc, char *argv[])
 
   textdomain (PACKAGE);
 
-  if ( ! parse_command_line(&argc, &argv, &filename, &err) ) 
-    {
-      g_clear_error(&err);
-      return 1;
-    }
-
+  glade_init ();
 
-  glade_init();
+  fmt_init ();
+  fn_init ();
+  outp_init ();
+  settings_init ();
+  fh_init ();
+  the_source_stream =
+    create_source_stream (
+                         fn_getenv_default ("STAT_INCLUDE_PATH", include_path)
+                         );
 
+  the_dataset = create_dataset (NULL, NULL);
 
-  settings_init();
 
-  /* 
-  set_pspp_locale("da_DK");
-  */
+  message_dialog_init (the_source_stream);
 
-  message_dialog_init();
+  dictionary = psppire_dict_new_from_dict (dataset_dict (the_dataset));
 
-  the_dictionary = psppire_dict_new();
-
-  bind_textdomain_codeset(PACKAGE, "UTF-8");
+  bind_textdomain_codeset (PACKAGE, "UTF-8");
 
   /* Create the model for the var_sheet */
-  var_store = psppire_var_store_new(the_dictionary);
-
-  /* Create the model for the data sheet */
-  the_cases = psppire_case_array_new(100000, 20);
-
-  data_store = psppire_data_store_new(the_dictionary, the_cases);
-
-  /* load the interface */
-  xml = glade_xml_new(PKGDATADIR "/psppire.glade", NULL, NULL);
-
-  if ( !xml ) return 1;
-
-  data_editor = get_widget_assert(xml, "data_editor");
-  gtk_window_set_icon_from_file(GTK_WINDOW(data_editor), 
-                               PKGDATADIR "/psppicon.png",0);
-
-  /* connect the signals in the interface */
-  glade_xml_signal_autoconnect(xml);
-
-  var_sheet  = GTK_SHEET(get_widget_assert(xml, "variable_sheet"));
-  data_sheet = GTK_SHEET(get_widget_assert(xml, "data_sheet"));
+  the_var_store = psppire_var_store_new (dictionary);
 
-  gtk_sheet_set_model(var_sheet, G_SHEET_MODEL(var_store));
-  
-  gtk_sheet_set_model(data_sheet, G_SHEET_MODEL(data_store));
+  the_data_store = psppire_data_store_new (dictionary);
+  replace_casereader (NULL);
 
-  if (filename)
-    gtk_init_add((GtkFunction)load_system_file, filename);
-  else
-    gtk_init_add((GtkFunction)clear_file, 0);
+  create_icon_factory ();
 
-  var_data_selection_init();
+  outp_configure_driver_line (
+    ss_cstr ("gui:ascii:screen:squeeze=on headers=off top-margin=0 "
+             "bottom-margin=0 paginate=off length=50 "
+            "width=" OUTPUT_LINE_WIDTH_str " emphasis=none "
+             "output-file=\"" OUTPUT_FILE_NAME "\" append=yes"));
 
-  {
-  GList *helps = glade_xml_get_widget_prefix(xml, "help_button_");
+  unlink (OUTPUT_FILE_NAME);
 
-  GList *i;
-  for ( i = g_list_first(helps); i ; i = g_list_next(i))
-      g_signal_connect(GTK_WIDGET(i->data), "clicked", give_help, 0);
-  }
+  new_data_window (NULL, NULL);
+}
 
 
-  /* start the event loop */
-  gtk_main();
+void
+de_initialize (void)
+{
+  destroy_source_stream (the_source_stream);
+  message_dialog_done ();
+  settings_done ();
+  outp_done ();
+}
 
-  message_dialog_done();
 
-  settings_done();
+#define PIXBUF_NEW_FROM_FILE(FILE) \
+  gdk_pixbuf_new_from_file (relocate (PKGDATADIR "/" FILE), 0)
 
-  return 0;
-}
 
-
-/* Parses the command line specified by ARGC and ARGV as received by
-   main().  Returns true if normal execution should proceed,
-   false if the command-line indicates that PSPP should exit. */
-static bool
-parse_command_line (int *argc, char ***argv, gchar **filename, GError **err)
+static void
+create_icon_factory (void)
 {
-  static struct option long_options[] =
-    {
-      {"help", no_argument, NULL, 'h'},
-      {"version", no_argument, NULL, 'V'},
-      {0, 0, 0, 0},
-    };
-
-  int c;
-
-  for (;;)
-    {
-      c = getopt_long (*argc, *argv, "hV", long_options, NULL);
-      if (c == -1)
-       break;
-
-      switch (c)
-       {
-       case 'h':
-         g_printerr("Usage: psppire {|--help|--version}\n");
-          return false;
-       case 'V':
-         g_print(version);
-         g_print("\n");
-         g_print(legal);
-         return false;
-       default:
-         return false;
-       }
-    }
-
-  if ( optind < *argc) 
-    {
-      *filename = (*argv)[optind];
-    }
-
-  return true;
+  GtkIconFactory *factory = gtk_icon_factory_new ();
+
+  GtkIconSet *icon_set;
+
+  GdkPixbuf *pixbuf;
+
+  pixbuf = PIXBUF_NEW_FROM_FILE ("value-labels.png");
+  icon_set = gtk_icon_set_new_from_pixbuf (pixbuf);
+  g_object_unref (pixbuf);
+  gtk_icon_factory_add ( factory, "pspp-value-labels", icon_set);
+
+  pixbuf = PIXBUF_NEW_FROM_FILE ("weight-cases.png");
+  icon_set = gtk_icon_set_new_from_pixbuf (pixbuf);
+  g_object_unref (pixbuf);
+  gtk_icon_factory_add ( factory, "pspp-weight-cases", icon_set);
+
+  pixbuf = PIXBUF_NEW_FROM_FILE ("goto-variable.png");
+  icon_set = gtk_icon_set_new_from_pixbuf (pixbuf);
+  g_object_unref (pixbuf);
+  gtk_icon_factory_add ( factory, "pspp-goto-variable", icon_set);
+
+  pixbuf = PIXBUF_NEW_FROM_FILE ("insert-variable.png");
+  icon_set = gtk_icon_set_new_from_pixbuf (pixbuf);
+  g_object_unref (pixbuf);
+  gtk_icon_factory_add ( factory, "pspp-insert-variable", icon_set);
+
+  pixbuf = PIXBUF_NEW_FROM_FILE ("insert-case.png");
+  icon_set = gtk_icon_set_new_from_pixbuf (pixbuf);
+  g_object_unref (pixbuf);
+  gtk_icon_factory_add ( factory, "pspp-insert-case", icon_set);
+
+  pixbuf = PIXBUF_NEW_FROM_FILE ("split-file.png");
+  icon_set = gtk_icon_set_new_from_pixbuf (pixbuf);
+  g_object_unref (pixbuf);
+  gtk_icon_factory_add ( factory, "pspp-split-file", icon_set);
+
+  pixbuf = PIXBUF_NEW_FROM_FILE ("select-cases.png");
+  icon_set = gtk_icon_set_new_from_pixbuf (pixbuf);
+  g_object_unref (pixbuf);
+  gtk_icon_factory_add ( factory, "pspp-select-cases", icon_set);
+
+  pixbuf = PIXBUF_NEW_FROM_FILE ("recent-dialogs.png");
+  icon_set = gtk_icon_set_new_from_pixbuf (pixbuf);
+  g_object_unref (pixbuf);
+  gtk_icon_factory_add ( factory, "pspp-recent-dialogs", icon_set);
+
+  pixbuf = PIXBUF_NEW_FROM_FILE ("nominal.png");
+  icon_set = gtk_icon_set_new_from_pixbuf (pixbuf);
+  g_object_unref (pixbuf);
+  gtk_icon_factory_add ( factory, "var-nominal", icon_set);
+
+  pixbuf = PIXBUF_NEW_FROM_FILE ("ordinal.png");
+  icon_set = gtk_icon_set_new_from_pixbuf (pixbuf);
+  g_object_unref (pixbuf);
+  gtk_icon_factory_add ( factory, "var-ordinal", icon_set);
+
+  pixbuf = PIXBUF_NEW_FROM_FILE ("scale.png");
+  icon_set = gtk_icon_set_new_from_pixbuf (pixbuf);
+  g_object_unref (pixbuf);
+  gtk_icon_factory_add ( factory, "var-scale", icon_set);
+
+  pixbuf = PIXBUF_NEW_FROM_FILE ("string.png");
+  icon_set = gtk_icon_set_new_from_pixbuf (pixbuf);
+  g_object_unref (pixbuf);
+  gtk_icon_factory_add ( factory, "var-string", icon_set);
+
+  pixbuf = PIXBUF_NEW_FROM_FILE ("date-scale.png");
+  icon_set = gtk_icon_set_new_from_pixbuf (pixbuf);
+  g_object_unref (pixbuf);
+  gtk_icon_factory_add ( factory, "var-date-scale", icon_set);
+
+
+  gtk_icon_factory_add_default (factory);
 }
 
-