X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=src%2Fdata%2Fdatasheet.h;h=ab6c28d80af56697d18151ac7884106487b7ebfb;hb=81579d9e9f994fb2908f50af41c3eb033d216e58;hp=3d106193d1cd393bec14297a392bb68bac983604;hpb=43b1296aafe7582e7dbe6c2b6a8b478d7d9b0fcf;p=pspp-builds.git diff --git a/src/data/datasheet.h b/src/data/datasheet.h index 3d106193..ab6c28d8 100644 --- a/src/data/datasheet.h +++ b/src/data/datasheet.h @@ -1,5 +1,5 @@ /* PSPP - a program for statistical analysis. - Copyright (C) 2007 Free Software Foundation, Inc. + Copyright (C) 2007, 2009, 2011 Free Software Foundation, Inc. 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,20 +17,24 @@ #ifndef DATA_DATASHEET_H #define DATA_DATASHEET_H 1 -#include -#include +#include "data/case.h" +#include "data/value.h" +struct caseproto; struct casereader; -/* A datasheet is a 2-d array of data that may be stored in - memory or on disk. It efficiently supports data storage and - retrieval, as well as adding, removing, and rearranging both - rows and columns. */ +/* A datasheet is a 2-d array of "union value"s that may be + stored in memory or on disk. It efficiently supports data + storage and retrieval, as well as adding, removing, and + rearranging both rows and columns. */ struct datasheet *datasheet_create (struct casereader *); void datasheet_destroy (struct datasheet *); struct datasheet *datasheet_rename (struct datasheet *); +const struct caseproto *datasheet_get_proto (const struct datasheet *); +int datasheet_get_column_width (const struct datasheet *, size_t column); + bool datasheet_error (const struct datasheet *); void datasheet_force_error (struct datasheet *); const struct taint *datasheet_get_taint (const struct datasheet *); @@ -38,19 +42,22 @@ const struct taint *datasheet_get_taint (const struct datasheet *); struct casereader *datasheet_make_reader (struct datasheet *); /* Columns. */ -size_t datasheet_get_column_cnt (const struct datasheet *); -bool datasheet_insert_columns (struct datasheet *, - const union value[], size_t cnt, - size_t before); +size_t datasheet_get_n_columns (const struct datasheet *); +bool datasheet_insert_column (struct datasheet *, + const union value *, int width, size_t before); void datasheet_delete_columns (struct datasheet *, size_t start, size_t cnt); void datasheet_move_columns (struct datasheet *, size_t old_start, size_t new_start, size_t cnt); +bool datasheet_resize_column (struct datasheet *, size_t column, int new_width, + void (*resize_cb) (const union value *, + union value *, void *aux), + void *aux); /* Rows. */ -casenumber datasheet_get_row_cnt (const struct datasheet *); +casenumber datasheet_get_n_rows (const struct datasheet *); bool datasheet_insert_rows (struct datasheet *, - casenumber before, struct ccase[], + casenumber before, struct ccase *[], casenumber cnt); void datasheet_delete_rows (struct datasheet *, casenumber first, casenumber cnt); @@ -59,28 +66,15 @@ void datasheet_move_rows (struct datasheet *, size_t cnt); /* Data. */ -bool datasheet_get_row (const struct datasheet *, casenumber, struct ccase *); +struct ccase *datasheet_get_row (const struct datasheet *, casenumber); bool datasheet_put_row (struct datasheet *, casenumber, struct ccase *); bool datasheet_get_value (const struct datasheet *, casenumber, size_t column, - union value *, int width); + union value *); bool datasheet_put_value (struct datasheet *, casenumber, size_t column, - const union value *, int width); - -/* Testing. */ -struct mc_options; - -struct datasheet_test_params - { - /* Parameters. */ - int max_rows; - int max_cols; - int backing_rows; - int backing_cols; + const union value *); - /* State. */ - int next_value; - }; -struct mc_results *datasheet_test (struct mc_options *options, void *params); +unsigned int hash_datasheet (const struct datasheet *ds); +struct datasheet *clone_datasheet (const struct datasheet *ds); #endif /* data/datasheet.h */