diff options
author | Kaz Kylheku <kaz@kylheku.com> | 2015-12-04 06:01:22 -0800 |
---|---|---|
committer | Kaz Kylheku <kaz@kylheku.com> | 2015-12-04 06:01:22 -0800 |
commit | a4d8692c9d23fed82f6f594ead826af83608f1c2 (patch) | |
tree | 610d817c1a8d830d769de209295858345fb389ec /stream.c | |
parent | c790707d517dbf4fa6a8b2695a35b3bc3b784556 (diff) | |
download | txr-a4d8692c9d23fed82f6f594ead826af83608f1c2.tar.gz txr-a4d8692c9d23fed82f6f594ead826af83608f1c2.tar.bz2 txr-a4d8692c9d23fed82f6f594ead826af83608f1c2.zip |
Large file support.
* stream.h (struct strm_ops): seek operation's second argument
is now just a val.
* stream.c (unimpl_seek, null_seek): Second argument is a val,
not cnum, to conform with function pointer in stream
structure.
(stdio_seek): Accept offset as val, which could be a fixnum
or bignum. Use new stdio_ftell and stdio_fseek functions
so large values work.
(seek_stream): No need to convert offset argument to cnum;
pass the val directly to seek virtual function.
* sysif.c (off_t_num, num_off_t, stdio_ftell,
stdio_fseek): New functions.
* sysif.h (OFF_T_MAX, OFF_T_MIN): New preprocessor symbols.
(off_t_num, num_off_t, stdio_ftell, stdio_fseek): Declared.
Diffstat (limited to 'stream.c')
-rw-r--r-- | stream.c | 18 |
1 files changed, 8 insertions, 10 deletions
@@ -55,6 +55,7 @@ #include "signal.h" #include "unwind.h" #include "args.h" +#include "sysif.h" #include "stream.h" #include "utf8.h" #include "eval.h" @@ -152,7 +153,7 @@ static noreturn val unimpl_unget_byte(val stream, int byte) unimpl(stream, lit("unget-byte")); } -static noreturn val unimpl_seek(val stream, cnum off, enum strm_whence whence) +static noreturn val unimpl_seek(val stream, val off, enum strm_whence whence) { unimpl(stream, lit("seek-stream")); } @@ -202,7 +203,7 @@ static val null_flush(val stream) return nil; } -static val null_seek(val stream, cnum off, enum strm_whence whence) +static val null_seek(val stream, val off, enum strm_whence whence) { return nil; } @@ -466,19 +467,17 @@ static val stdio_flush(val stream) ? t : stdio_maybe_error(stream, lit("flushing")); } -static val stdio_seek(val stream, cnum offset, enum strm_whence whence) +static val stdio_seek(val stream, val offset, enum strm_whence whence) { struct stdio_handle *h = coerce(struct stdio_handle *, stream->co.handle); errno = 0; if (h->f != 0) { - if (offset == 0 && whence == strm_cur) { - long where = ftell(h->f); - if (where >= 0) - return num(where); + if (offset == zero && whence == strm_cur) { + return stdio_ftell(h->f); } else { - if (fseek(h->f, offset, whence) == 0) { + if (stdio_fseek(h->f, offset, whence) != negone) { utf8_decoder_init(&h->ud); h->unget_c = nil; return t; @@ -2754,7 +2753,6 @@ val seek_stream(val stream, val offset, val whence) { struct strm_ops *ops = coerce(struct strm_ops *, cobj_ops(stream, stream_s)); enum strm_whence w; - cnum off = c_num(offset); if (whence == from_start_k) w = strm_start; @@ -2766,7 +2764,7 @@ val seek_stream(val stream, val offset, val whence) uw_throwf(file_error_s, lit("seek: ~a is not a valid whence argument"), whence, nao); - return ops->seek(stream, off, w); + return ops->seek(stream, offset, w); } val truncate_stream(val stream, val len) |