Actually implement the new procedure code and adapt all of its clients
[pspp-builds.git] / src / ui / gui / psppire.c
index f0041eba4ec07b0f57ff072226a8695f54338600..d636ab4960781ddc911e0dc813917f9e85de58d4 100644 (file)
@@ -1,4 +1,4 @@
-/* 
+/*
    PSPPIRE --- A Graphical User Interface for PSPP
    Copyright (C) 2004, 2005, 2006  Free Software Foundation
 
 #include <assert.h>
 #include <libintl.h>
 
+#include "relocatable.h"
 
 #include "data-editor.h"
-#include <libpspp/version.h>
-#include <libpspp/copyleft.h>
+
+#include "psppire.h"
+
+
+#include <data/casereader.h>
+#include <data/datasheet.h>
 #include <data/file-handle-def.h>
 #include <data/format.h>
 #include <data/settings.h>
@@ -33,9 +38,8 @@
 #include <data/procedure.h>
 #include <libpspp/getl.h>
 #include <language/lexer/lexer.h>
+#include <libpspp/version.h>
 
-#include <getopt.h>
-#include <gtk/gtk.h>
 #include <gtk/gtk.h>
 #include <glade/glade.h>
 #include "psppire-dict.h"
 #include "data-sheet.h"
 #include "var-sheet.h"
 #include "message-dialog.h"
-#include "flexifile-factory.h"
 
 PsppireDataStore *the_data_store = 0;
+PsppireVarStore *the_var_store = 0;
 
+static void create_icon_factory (void);
 
-static bool parse_command_line (int *argc, char ***argv, 
-                               gchar **filename, GError **err);
-
-
-#define _(msgid) gettext (msgid)
-#define N_(msgid) msgid
+struct source_stream *the_source_stream ;
+struct dataset * the_dataset = NULL;
 
 static void
-give_help(void)
+replace_dictionary (struct dictionary *d)
 {
-  static struct msg m = {
-    MSG_GENERAL, 
-    MSG_NOTE,
-    {0, -1},
-    0, 
-  };
-
-  if (! m.text) 
-    m.text=g_strdup(_("Sorry. The help system hasn't yet been implemented."));
-
-  popup_message(&m);
+  psppire_dict_replace_dictionary (the_data_store->dict, d);
 }
 
-PsppireVarStore *the_var_store = 0;
-
-void create_icon_factory (void);
 
-struct source_stream *the_source_stream ;
-struct dataset * the_dataset = NULL;
+static void
+replace_casereader (struct casereader *s)
+{
+  struct datasheet *datasheet = datasheet_create (s);
 
+  psppire_case_file_replace_datasheet (the_data_store->case_file,
+                                       datasheet);
+}
 
-int 
-main(int argc, char *argv[]) 
+void
+initialize (void)
 {
-  struct casefile_factory *factory;
   PsppireDict *dictionary = 0;
 
-
-  GtkWidget *data_editor ;
-  GtkSheet *var_sheet ; 
-  GtkSheet *data_sheet ;
-
-  gchar *filename=0;
-  GError *err = 0;
-  gchar *vers;
-
-  gtk_init(&argc, &argv);
-  if ( (vers = gtk_check_version(GTK_MAJOR_VERSION, 
-                                GTK_MINOR_VERSION, 
-                                GTK_MICRO_VERSION)) )
-    {
-      g_critical(vers);
-    }
-       
-
-  /* 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");
 
@@ -113,174 +87,132 @@ main(int argc, char *argv[])
 
   textdomain (PACKAGE);
 
-  if ( ! parse_command_line(&argc, &argv, &filename, &err) ) 
-    {
-      g_clear_error(&err);
-      return 0;
-    }
+  glade_init ();
 
-  glade_init();
-
-  fmt_init();
-  settings_init();
+  fmt_init ();
+  settings_init ();
   fh_init ();
-  factory = flexifile_factory_create ();
-  the_source_stream = create_source_stream (
+  the_source_stream =
+    create_source_stream (
                          fn_getenv_default ("STAT_INCLUDE_PATH", include_path)
                          );
 
-  the_dataset = create_dataset (factory);
+  the_dataset = create_dataset (replace_casereader,
+                               replace_dictionary);
 
   message_dialog_init (the_source_stream);
 
-  dictionary =
-    psppire_dict_new_from_dict (
-                               dataset_dict (the_dataset)
-                               );
+  dictionary = psppire_dict_new_from_dict (
+                                          dataset_dict (the_dataset)
+                                          );
 
-  bind_textdomain_codeset(PACKAGE, "UTF-8");
+  bind_textdomain_codeset (PACKAGE, "UTF-8");
 
-  /* Create the model for the var_sheet */
-  the_var_store = psppire_var_store_new(dictionary);
 
+  /* Create the model for the var_sheet */
+  the_var_store = psppire_var_store_new (dictionary);
 
   the_data_store = psppire_data_store_new (dictionary);
 
-  create_icon_factory();
-
-#if 0
-  /* load the interface */
-  data_editor_xml = glade_xml_new(PKGDATADIR "/data-editor.glade", NULL, NULL);
-
-  if ( !data_editor_xml ) return 1;
-
-  data_editor = get_widget_assert(data_editor_xml, "data_editor");
-
-  /* connect the signals in the interface */
-  glade_xml_signal_autoconnect(data_editor_xml);
-
-  var_sheet  = GTK_SHEET(get_widget_assert(data_editor_xml, "variable_sheet"));
-  data_sheet = GTK_SHEET(get_widget_assert(data_editor_xml, "data_sheet"));
 
-  gtk_sheet_set_model(var_sheet, G_SHEET_MODEL(the_var_store));
+  proc_set_active_file_data (the_dataset,
+                            datasheet_make_reader (the_data_store->case_file->datasheet));
 
-  gtk_sheet_set_model(data_sheet, G_SHEET_MODEL(the_data_store));
 
-  var_data_selection_init();
-
-  {
-  GList *helps = glade_xml_get_widget_prefix(data_editor_xml, "help_button_");
-
-  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);
-  }
-
-#endif
+  create_icon_factory ();
 
   new_data_window (NULL, NULL);
-
-  /* start the event loop */
-  gtk_main();
-
-  destroy_source_stream (the_source_stream);
-  message_dialog_done();
-
-  settings_done();
-
-  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)
+void
+de_initialize (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_print ("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;
+  destroy_source_stream (the_source_stream);
+  message_dialog_done ();
+  settings_done ();
 }
 
 
+#define PIXBUF_NEW_FROM_FILE(FILE) \
+  gdk_pixbuf_new_from_file (relocate (PKGDATADIR "/" FILE), 0)
+
 
-void 
+static void
 create_icon_factory (void)
 {
-  GtkIconFactory *factory = gtk_icon_factory_new();
+  GtkIconFactory *factory = gtk_icon_factory_new ();
 
   GtkIconSet *icon_set;
-  
+
   GdkPixbuf *pixbuf;
 
-  pixbuf = gdk_pixbuf_new_from_file (PKGDATADIR "/value-labels.png", 0);
+  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 = gdk_pixbuf_new_from_file (PKGDATADIR "/weight-cases.png", 0);
+  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 = gdk_pixbuf_new_from_file (PKGDATADIR "/goto-variable.png", 0);
+  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 = gdk_pixbuf_new_from_file (PKGDATADIR "/insert-variable.png", 0);
+  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 = gdk_pixbuf_new_from_file (PKGDATADIR "/insert-case.png", 0);
+  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 = gdk_pixbuf_new_from_file (PKGDATADIR "/split-file.png", 0);
+  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 = gdk_pixbuf_new_from_file (PKGDATADIR "/select-cases.png", 0);
+  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);
 }
+