X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=src%2Fdata%2Fsys-file-reader.h;h=849da670fce2f1f0ebe21b830dd41386eee536e0;hb=8e4a0daa2b60e5ebf6fa4ff83ad98d78a8de0dff;hp=5bd87fc326f49ffbcc6b6effaee7dda97ab72be4;hpb=43b1296aafe7582e7dbe6c2b6a8b478d7d9b0fcf;p=pspp diff --git a/src/data/sys-file-reader.h b/src/data/sys-file-reader.h index 5bd87fc326..849da670fc 100644 --- a/src/data/sys-file-reader.h +++ b/src/data/sys-file-reader.h @@ -1,5 +1,5 @@ /* PSPP - a program for statistical analysis. - Copyright (C) 1997-9, 2000 Free Software Foundation, Inc. + Copyright (C) 1997-9, 2000, 2009, 2011, 2012, 2013, 2014 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 @@ -20,29 +20,69 @@ #include #include -#include -#include +#include "data/case.h" +#include "data/sys-file.h" +#include "libpspp/float-format.h" +#include "libpspp/integer-format.h" -/* Reading system files. */ +/* Reading system files. -/* System file info that doesn't fit in struct dictionary. */ + To read a system file: + + 1. Open it with sfm_open(). + + 2. Figure out what encoding to read it with. sfm_get_encoding() can + help. + + 3. Obtain a casereader with sfm_decode(). + + If, after step 1 or 2, you decide that you don't want the system file + anymore, you can close it with sfm_close(). Otherwise, don't call + sfm_close(), because sfm_decode() consumes it. */ + +struct dictionary; +struct file_handle; +struct sfm_read_info; + +/* Opening and closing an sfm_reader. */ +struct sfm_reader *sfm_open (struct file_handle *); +bool sfm_close (struct sfm_reader *); + +/* Obtaining information about an sfm_reader before . */ +const char *sfm_get_encoding (const struct sfm_reader *); +size_t sfm_get_strings (const struct sfm_reader *, struct pool *pool, + char ***labels, bool **ids, char ***values); + +/* Decoding a system file's dictionary and obtaining a casereader. */ +struct casereader *sfm_decode (struct sfm_reader *, const char *encoding, + struct dictionary **, struct sfm_read_info *); + +/* Detecting whether a file is a system file. */ +bool sfm_detect (FILE *); + +/* System file info that doesn't fit in struct dictionary. + + The strings in this structure are encoded in UTF-8. (They are normally in + the ASCII subset of UTF-8.) */ struct sfm_read_info { - char creation_date[10]; /* `dd mmm yy' plus a null. */ - char creation_time[9]; /* `hh:mm:ss' plus a null. */ + char *creation_date; /* "dd mmm yy". */ + char *creation_time; /* "hh:mm:ss". */ enum integer_format integer_format; enum float_format float_format; - bool compressed; /* 0=no, 1=yes. */ - int case_cnt; /* -1 if unknown. */ - char product[61]; /* Product name plus a null. */ + enum sfm_compression compression; + casenumber case_cnt; /* -1 if unknown. */ + char *product; /* Product name. */ + char *product_ext; /* Extra product info. */ + + /* Writer's version number in X.Y.Z format. + The version number is not always present; if not, then + all of these are set to 0. */ + int version_major; /* X. */ + int version_minor; /* Y. */ + int version_revision; /* Z. */ }; -struct dictionary; -struct file_handle; -struct ccase; -struct casereader *sfm_open_reader (struct file_handle *, - struct dictionary **, - struct sfm_read_info *); -bool sfm_detect (FILE *); +void sfm_read_info_destroy (struct sfm_read_info *); #endif /* sys-file-reader.h */