X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=src%2Fdata%2Fcsv-file-writer.c;h=c01cb342318e32d9e12ad78505dee4c26a113a7c;hb=5882d195ad6891b87dba6ded8a5caa1a949f165f;hp=4ebff0bd001288e28ddf6d085cbc086632b72e88;hpb=6f3865480503c571963d8a2d1af858a4d72d4e88;p=pspp diff --git a/src/data/csv-file-writer.c b/src/data/csv-file-writer.c index 4ebff0bd00..c01cb34231 100644 --- a/src/data/csv-file-writer.c +++ b/src/data/csv-file-writer.c @@ -1,5 +1,5 @@ /* PSPP - a program for statistical analysis. - Copyright (C) 2010, 2011, 2012 Free Software Foundation, Inc. + Copyright (C) 2010, 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 @@ -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" @@ -97,7 +96,7 @@ csv_writer_options_init (struct csv_writer_options *opts) opts->use_value_labels = false; opts->use_print_formats = false; opts->decimal = settings_get_decimal_char (FMT_F); - opts->delimiter = 0; + opts->delimiter = ','; opts->qualifier = '"'; } @@ -154,8 +153,7 @@ csv_writer_open (struct file_handle *fh, const struct dictionary *dict, goto error; /* Create the file on disk. */ - w->rf = replace_file_start (fh_get_file_name (fh), "w", 0666, - &w->file, NULL); + 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."), @@ -200,6 +198,12 @@ csv_output_buffer (struct csv_writer *w, const char *s, size_t len) putc (w->opts.qualifier, w->file); for (p = s; p < &s[len]; p++) { + /* We are writing the output file in text mode, so transform any + explicit CR-LF line breaks into LF only, to allow the C library to + use correct system-specific new-lines. */ + if (*p == '\r' && p[1] == '\n') + continue; + if (*p == w->opts.qualifier) putc (w->opts.qualifier, w->file); putc (*p, w->file);