X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=src%2Fdata%2Fsys-file-reader.h;h=849da670fce2f1f0ebe21b830dd41386eee536e0;hb=e9bebe68e0285273d0e37af5d548a9b2c26951e1;hp=749565165ff5259f8ca741eafa19c66d9995ab47;hpb=81579d9e9f994fb2908f50af41c3eb033d216e58;p=pspp diff --git a/src/data/sys-file-reader.h b/src/data/sys-file-reader.h index 749565165f..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, 2009, 2011 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 @@ -21,21 +21,59 @@ #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. */ + enum sfm_compression compression; casenumber case_cnt; /* -1 if unknown. */ - char product[61]; /* Product name plus a null. */ + 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 @@ -45,11 +83,6 @@ struct sfm_read_info int version_revision; /* Z. */ }; -struct dictionary; -struct file_handle; -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 */