X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=src%2Fui%2Fgui%2Fpsppire-data-store.h;h=efeb886864e4ab1c2105bf563b407c56c0e2a017;hb=4eb2e820b01d92ef662c741f5ac30f08bedd1de6;hp=b6160651e535666f506b3ab83d5e80c7f4a484b7;hpb=e83fb395fe12187526f4bccb6638ef2764220b75;p=pspp diff --git a/src/ui/gui/psppire-data-store.h b/src/ui/gui/psppire-data-store.h index b6160651e5..efeb886864 100644 --- a/src/ui/gui/psppire-data-store.h +++ b/src/ui/gui/psppire-data-store.h @@ -1,5 +1,5 @@ /* PSPPIRE - a graphical user interface for PSPP. - Copyright (C) 2006 Free Software Foundation + Copyright (C) 2006, 2009, 2011, 2012 Free Software Foundation 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 @@ -17,36 +17,36 @@ #ifndef __PSPPIRE_DATA_STORE_H__ #define __PSPPIRE_DATA_STORE_H__ +#include #include "psppire-dict.h" -#include "psppire-case-file.h" #define FIRST_CASE_NUMBER 1 G_BEGIN_DECLS -#define GTK_TYPE_DATA_STORE (psppire_data_store_get_type ()) +#define PSPPIRE_TYPE_DATA_STORE (psppire_data_store_get_type ()) #define PSPPIRE_DATA_STORE(obj) \ - (G_TYPE_CHECK_INSTANCE_CAST ((obj), \ - GTK_TYPE_DATA_STORE, PsppireDataStore)) + (G_TYPE_CHECK_INSTANCE_CAST ((obj), \ + PSPPIRE_TYPE_DATA_STORE, PsppireDataStore)) #define PSPPIRE_DATA_STORE_CLASS(klass) \ - (G_TYPE_CHECK_CLASS_CAST ((klass), \ - GTK_TYPE_DATA_STORE, \ - PsppireDataStoreClass)) + (G_TYPE_CHECK_CLASS_CAST ((klass), \ + PSPPIRE_TYPE_DATA_STORE, \ + PsppireDataStoreClass)) #define PSPPIRE_IS_DATA_STORE(obj) \ - (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GTK_TYPE_DATA_STORE)) + (G_TYPE_CHECK_INSTANCE_TYPE ((obj), PSPPIRE_TYPE_DATA_STORE)) #define PSPPIRE_IS_DATA_STORE_CLASS(klass) \ - (G_TYPE_CHECK_CLASS_TYPE ((klass), GTK_TYPE_DATA_STORE)) + (G_TYPE_CHECK_CLASS_TYPE ((klass), PSPPIRE_TYPE_DATA_STORE)) #define PSPPIRE_DATA_STORE_GET_CLASS(obj) \ - (G_TYPE_INSTANCE_GET_CLASS ((obj), \ - GTK_TYPE_DATA_STORE, \ - PsppireDataStoreClass)) + (G_TYPE_INSTANCE_GET_CLASS ((obj), \ + PSPPIRE_TYPE_DATA_STORE, \ + PsppireDataStoreClass)) typedef struct _PsppireDataStore PsppireDataStore; typedef struct _PsppireDataStoreClass PsppireDataStoreClass; @@ -54,23 +54,17 @@ typedef struct _PsppireDataStoreClass PsppireDataStoreClass; struct dictionary; -enum cf_signal_handler { - CASES_DELETED, - CASE_INSERTED, - CASE_CHANGED, - n_cf_signals -}; - - enum dict_signal_handler { VARIABLE_INSERTED, VARIABLE_CHANGED, VARIABLE_DELETED, - SIZE_CHANGED, n_dict_signals }; +struct datasheet; +struct casereader; + struct _PsppireDataStore { GObject parent; @@ -78,14 +72,9 @@ struct _PsppireDataStore /*< private >*/ gboolean dispose_has_run ; PsppireDict *dict; - PsppireCaseFile *case_file; - - gboolean show_labels; - - /* Geometry */ - gint margin_width; + struct datasheet *datasheet; + gint stamp; - gint cf_handler_id [n_cf_signals]; gint dict_handler_id [n_dict_signals]; }; @@ -98,34 +87,72 @@ struct _PsppireDataStoreClass GType psppire_data_store_get_type (void) G_GNUC_CONST; PsppireDataStore *psppire_data_store_new (PsppireDict *dict); -void psppire_data_store_set_case_file (PsppireDataStore *data_store, - PsppireCaseFile *cf); + +void psppire_data_store_set_reader (PsppireDataStore *ds, + struct casereader *reader); void psppire_data_store_set_dictionary (PsppireDataStore *data_store, PsppireDict *dict); -void psppire_data_store_show_labels (PsppireDataStore *store, - gboolean show_labels); - void psppire_data_store_clear (PsppireDataStore *data_store); gboolean psppire_data_store_insert_new_case (PsppireDataStore *ds, casenumber posn); +gboolean psppire_data_store_insert_value (PsppireDataStore *ds, + gint width, gint where); gboolean psppire_data_store_delete_cases (PsppireDataStore *ds, casenumber first, casenumber count); struct casereader * psppire_data_store_get_reader (PsppireDataStore *ds); -gchar * psppire_data_store_get_string (PsppireDataStore *ds, - casenumber row, glong column); +gchar *psppire_data_store_get_string (PsppireDataStore *, + glong row, const struct variable *, + bool use_value_label); + +gchar * psppire_data_store_value_to_string (gpointer unused, PsppireDataStore *store, + gint col, gint row, + const GValue *v); + +gchar * psppire_data_store_value_to_string_with_labels (gpointer unused, + PsppireDataStore *store, + gint col, gint row, + const GValue *v); + +gboolean psppire_data_store_string_to_value (GtkTreeModel *model, gint col, gint row, + const gchar *in, GValue *out); + +gboolean psppire_data_store_get_value (PsppireDataStore *store, + glong row, const struct variable *var, + union value *val); + +gboolean psppire_data_store_set_value (PsppireDataStore *, + casenumber casenum, + const struct variable *, + const union value *); + gboolean psppire_data_store_set_string (PsppireDataStore *ds, const gchar *text, - glong row, glong column); + glong row, const struct variable *, + gboolean use_value_label); + + +gboolean psppire_data_store_filtered (PsppireDataStore *ds, + glong row); + casenumber psppire_data_store_get_case_count (const PsppireDataStore *ds); size_t psppire_data_store_get_value_count (const PsppireDataStore *ds); +const struct caseproto *psppire_data_store_get_proto (const PsppireDataStore *); + + + +struct ccase *psppire_data_store_get_case (const PsppireDataStore *ds, + casenumber casenum); + + + G_END_DECLS