X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=src%2Flanguage%2Fdata-io%2Fdata-writer.c;h=113be58805f979c63bd736a85f5c473e5595b006;hb=81579d9e9f994fb2908f50af41c3eb033d216e58;hp=32caa1e22d0475a51e9871a9847654410028a980;hpb=51d8c9b54d65bd0aa3944b8fb9d4460875048e14;p=pspp-builds.git diff --git a/src/language/data-io/data-writer.c b/src/language/data-io/data-writer.c index 32caa1e2..113be588 100644 --- a/src/language/data-io/data-writer.c +++ b/src/language/data-io/data-writer.c @@ -1,5 +1,5 @@ /* PSPP - a program for statistical analysis. - Copyright (C) 1997-2004, 2006 Free Software Foundation, Inc. + Copyright (C) 1997-2004, 2006, 2010, 2011 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 @@ -16,22 +16,24 @@ #include -#include +#include "language/data-io/data-writer.h" #include #include +#include #include #include -#include -#include -#include -#include -#include -#include +#include "data/file-name.h" +#include "data/make-file.h" +#include "language/data-io/file-handle.h" +#include "libpspp/assertion.h" +#include "libpspp/integer-format.h" +#include "libpspp/message.h" +#include "libpspp/str.h" -#include "minmax.h" -#include "xalloc.h" +#include "gl/minmax.h" +#include "gl/xalloc.h" #include "gettext.h" #define _(msgid) gettext (msgid) @@ -64,12 +66,11 @@ dfm_open_writer (struct file_handle *fh) w = xmalloc (sizeof *w); w->fh = fh_ref (fh); w->lock = lock; - w->rf = replace_file_start (fh_get_file_name (w->fh), "wb", - (S_IRUSR | S_IWUSR | S_IRGRP | S_IWGRP - | S_IROTH | S_IWOTH), &w->file, NULL); + w->rf = replace_file_start (fh_get_file_name (w->fh), "wb", 0666, + &w->file, NULL); if (w->rf == NULL) { - msg (ME, _("An error occurred while opening \"%s\" for writing " + msg (ME, _("An error occurred while opening `%s' for writing " "as a data file: %s."), fh_get_file_name (w->fh), strerror (errno)); dfm_close_writer (w); @@ -106,7 +107,7 @@ dfm_put_record (struct dfm_writer *w, const char *rec, size_t len) putc ('\n', w->file); break; - case FH_MODE_BINARY: + case FH_MODE_FIXED: { size_t record_width = fh_get_record_width (w->fh); size_t write_bytes = MIN (len, record_width); @@ -122,6 +123,45 @@ dfm_put_record (struct dfm_writer *w, const char *rec, size_t len) } break; + case FH_MODE_VARIABLE: + { + uint32_t size = len; + integer_convert (INTEGER_NATIVE, &size, INTEGER_LSB_FIRST, &size, + sizeof size); + fwrite (&size, sizeof size, 1, w->file); + fwrite (rec, len, 1, w->file); + fwrite (&size, sizeof size, 1, w->file); + } + break; + + case FH_MODE_360_VARIABLE: + case FH_MODE_360_SPANNED: + { + size_t ofs = 0; + if (fh_get_mode (w->fh) == FH_MODE_360_VARIABLE) + len = MIN (65527, len); + while (ofs < len) + { + size_t chunk = MIN (65527, len - ofs); + uint32_t bdw = (chunk + 8) << 16; + int scc = (ofs == 0 && chunk == len ? 0 + : ofs == 0 ? 1 + : ofs + chunk == len ? 2 + : 3); + uint32_t rdw = ((chunk + 4) << 16) | (scc << 8); + + integer_convert (INTEGER_NATIVE, &bdw, INTEGER_MSB_FIRST, &bdw, + sizeof bdw); + integer_convert (INTEGER_NATIVE, &rdw, INTEGER_MSB_FIRST, &rdw, + sizeof rdw); + fwrite (&bdw, 1, sizeof bdw, w->file); + fwrite (&rdw, 1, sizeof rdw, w->file); + fwrite (rec + ofs, 1, chunk, w->file); + ofs += chunk; + } + } + break; + default: NOT_REACHED (); } @@ -147,7 +187,7 @@ dfm_close_writer (struct dfm_writer *w) ok = !dfm_write_error (w) && !fn_close (file_name, w->file); if (!ok) - msg (ME, _("I/O error occurred writing data file \"%s\"."), file_name); + msg (ME, _("I/O error occurred writing data file `%s'."), file_name); if (ok ? !replace_file_commit (w->rf) : !replace_file_abort (w->rf)) ok = false; @@ -157,3 +197,10 @@ dfm_close_writer (struct dfm_writer *w) return ok; } + +/* Returns the legacy character encoding of data written to WRITER. */ +const char * +dfm_writer_get_legacy_encoding (const struct dfm_writer *writer) +{ + return fh_get_legacy_encoding (writer->fh); +}