X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=src%2Fdata%2Fcsv-file-writer.c;h=279c63685d15c0b150862b17cc49072c6f353f7b;hb=95cde62bdf5210c1c60dad5598a888b864f93161;hp=7a437c5947a2d49c561ad22babed47dcf18c955c;hpb=f93d0472eae9d03fb4bcd26a3d7a6301e32fbdde;p=pspp diff --git a/src/data/csv-file-writer.c b/src/data/csv-file-writer.c index 7a437c5947..279c63685d 100644 --- a/src/data/csv-file-writer.c +++ b/src/data/csv-file-writer.c @@ -33,7 +33,6 @@ #include "data/data-out.h" #include "data/dictionary.h" #include "data/file-handle-def.h" -#include "data/file-name.h" #include "data/format.h" #include "data/make-file.h" #include "data/missing-values.h" @@ -88,19 +87,6 @@ static void write_var_names (struct csv_writer *, const struct dictionary *); static bool write_error (const struct csv_writer *); static bool close_writer (struct csv_writer *); -/* Initializes OPTS with default options for writing a CSV file. */ -void -csv_writer_options_init (struct csv_writer_options *opts) -{ - opts->recode_user_missing = false; - opts->include_var_names = false; - opts->use_value_labels = false; - opts->use_print_formats = false; - opts->decimal = settings_get_decimal_char (FMT_F); - opts->delimiter = ','; - opts->qualifier = '"'; -} - /* Opens the CSV file designated by file handle FH for writing cases from dictionary DICT according to the given OPTS. @@ -124,7 +110,7 @@ csv_writer_open (struct file_handle *fh, const struct dictionary *dict, w->encoding = xstrdup (dict_get_encoding (dict)); - w->n_csv_vars = dict_get_var_cnt (dict); + w->n_csv_vars = dict_get_n_vars (dict); w->csv_vars = xnmalloc (w->n_csv_vars, sizeof *w->csv_vars); for (i = 0; i < w->n_csv_vars; i++) { @@ -132,9 +118,9 @@ csv_writer_open (struct file_handle *fh, const struct dictionary *dict, struct csv_var *cv = &w->csv_vars[i]; cv->width = var_get_width (var); - cv->case_index = var_get_case_index (var); + cv->case_index = var_get_dict_index (var); - cv->format = *var_get_print_format (var); + cv->format = var_get_print_format (var); if (opts->recode_user_missing) mv_copy (&cv->missing, var_get_missing_values (var)); else @@ -157,7 +143,7 @@ csv_writer_open (struct file_handle *fh, const struct dictionary *dict, w->rf = replace_file_start (fh, "w", 0666, &w->file); if (w->rf == NULL) { - msg (ME, _("Error opening `%s' for writing as a system file: %s."), + msg (ME, _("Error opening `%s' for writing as a CSV file: %s."), fh_get_file_name (fh), strerror (errno)); goto error; } @@ -239,7 +225,8 @@ static void csv_output_format (struct csv_writer *w, const struct csv_var *cv, const union value *value) { - char *s = data_out (value, w->encoding, &cv->format); + char *s = data_out (value, w->encoding, cv->format, + settings_get_fmt_settings ()); struct substring ss = ss_cstr (s); if (cv->format.type != FMT_A) ss_trim (&ss, ss_cstr (" ")); @@ -338,6 +325,7 @@ csv_write_var__ (struct csv_writer *w, const struct csv_var *cv, break; case FMT_DATETIME: + case FMT_YMDHMS: if (value->f < 0) strcpy (s, " "); else @@ -351,6 +339,7 @@ csv_write_var__ (struct csv_writer *w, const struct csv_var *cv, } break; + case FMT_MTIME: case FMT_TIME: case FMT_DTIME: { @@ -379,7 +368,7 @@ static void csv_write_var (struct csv_writer *w, const struct csv_var *cv, const union value *value) { - if (mv_is_value_missing (&cv->missing, value, MV_USER)) + if (mv_is_value_missing (&cv->missing, value) == MV_USER) { union value missing;