X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=src%2Fui%2Fgui%2Fpsppire-data-store.h;h=55dcf0683d7e49e96d699b870487244207367027;hb=015e221b0f8578afee769528572c76387f26c629;hp=9857a7b1cfcfe85d81f3d7b8d52892d3ecab4a63;hpb=82d3fc0e14c1465eb2d1de00796317d062151fe0;p=pspp diff --git a/src/ui/gui/psppire-data-store.h b/src/ui/gui/psppire-data-store.h index 9857a7b1cf..55dcf0683d 100644 --- a/src/ui/gui/psppire-data-store.h +++ b/src/ui/gui/psppire-data-store.h @@ -30,18 +30,24 @@ extern "C" { #define GTK_TYPE_DATA_STORE (psppire_data_store_get_type ()) -#define PSPPIRE_DATA_STORE(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), \ +#define PSPPIRE_DATA_STORE(obj) \ + (G_TYPE_CHECK_INSTANCE_CAST ((obj), \ GTK_TYPE_DATA_STORE, PsppireDataStore)) -#define PSPPIRE_DATA_STORE_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), \ +#define PSPPIRE_DATA_STORE_CLASS(klass) \ + (G_TYPE_CHECK_CLASS_CAST ((klass), \ GTK_TYPE_DATA_STORE, \ PsppireDataStoreClass)) -#define PSPPIRE_IS_DATA_STORE(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GTK_TYPE_DATA_STORE)) -#define PSPPIRE_IS_DATA_STORE_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GTK_TYPE_DATA_STORE)) +#define PSPPIRE_IS_DATA_STORE(obj) \ + (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GTK_TYPE_DATA_STORE)) -#define PSPPIRE_DATA_STORE_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), \ +#define PSPPIRE_IS_DATA_STORE_CLASS(klass) \ + (G_TYPE_CHECK_CLASS_TYPE ((klass), GTK_TYPE_DATA_STORE)) + +#define PSPPIRE_DATA_STORE_GET_CLASS(obj) \ + (G_TYPE_INSTANCE_GET_CLASS ((obj), \ GTK_TYPE_DATA_STORE, \ PsppireDataStoreClass)) @@ -50,11 +56,32 @@ 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 +}; + +void do_this_thing (PsppireDict *, struct dictionary *, void *); + + struct _PsppireDataStore { GObject parent; /*< private >*/ + gboolean dispose_has_run ; PsppireDict *dict; PsppireCaseFile *case_file; const PangoFontDescription *font_desc; @@ -66,6 +93,9 @@ struct _PsppireDataStore /* Geometry */ gint margin_width; + + gint cf_handler_id [n_cf_signals]; + gint dict_handler_id [n_dict_signals]; }; struct _PsppireDataStoreClass @@ -97,19 +127,23 @@ void psppire_data_store_show_labels (PsppireDataStore *store, void psppire_data_store_clear (PsppireDataStore *data_store); -gboolean psppire_data_store_insert_new_case (PsppireDataStore *ds, gint posn); +gboolean psppire_data_store_insert_new_case (PsppireDataStore *ds, casenumber posn); + + +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, - gint row, gint column); + casenumber row, glong column); gboolean psppire_data_store_set_string (PsppireDataStore *ds, const gchar *text, - gint row, gint column); - -casenumber psppire_data_store_get_case_count (PsppireDataStore *store); + glong row, glong column); +inline casenumber psppire_data_store_get_case_count (const PsppireDataStore *ds); +size_t psppire_data_store_get_value_count (const PsppireDataStore *ds); #ifdef __cplusplus }