Fewer memory leaks
[pspp] / src / data / spreadsheet-reader.h
index 765f3ca953705af2cfe849f5a445cad1b6d41790..9a46b35e9eb6a255e78403e9cfa242f6c133a754 100644 (file)
@@ -19,6 +19,8 @@
 
 #include <stdbool.h>
 
+struct casereeader;
+
 /* Default width of string variables. */
 #define SPREADSHEET_DEFAULT_WIDTH 8
 
@@ -31,11 +33,6 @@ struct spreadsheet_read_options
   char *sheet_name ;       /* The name of the sheet to open (in UTF-8) */
   int sheet_index ;        /* The index of the sheet to open (only used if sheet_name is NULL) */
   char *cell_range ;       /* The cell range (in UTF-8) */
-};
-
-
-struct spreadsheet_read_info
-{
   bool read_names ;        /* True if the first row is to be used as the names of the variables */
   int asw ;                /* The width of string variables in the created dictionary */
 };
@@ -59,9 +56,10 @@ enum spreadsheet_type
     SPREADSHEET_ODS
   };
 
+
 struct spreadsheet
 {
-  char *file_name;
+  const char *file_name;
 
   enum spreadsheet_type type;
 
@@ -73,20 +71,18 @@ struct spreadsheet
 };
 
 
+struct casereader * spreadsheet_make_reader (struct spreadsheet *, const struct spreadsheet_read_options *);
+
+const char * spreadsheet_get_sheet_name (struct spreadsheet *s, int n);
+char * spreadsheet_get_sheet_range (struct spreadsheet *s, int n);
+
+
 char *create_cell_ref (int col0, int row0, int coli, int rowi);
 
-/* 
-   Attempt to open the file called FILENAME as a spreadsheet.
-   It is not known a priori, what type of spreadsheet FILENAME is, or
-   even if it is a spreadsheet at all.
-   If it fails to open, then it will return NULL without any error or
-   warning messages.
- */
-struct spreadsheet * spreadsheet_open (const char *filename);
-void spreadsheet_close (struct spreadsheet *);
+void spreadsheet_destroy (struct spreadsheet *);
+
+
 
-struct casereeader;
-struct casereader * spreadsheet_make_reader (struct spreadsheet *s);
 
 
 #define SPREADSHEET_CAST(X) ((struct spreadsheet *)(X))