diff options
author | Kaz Kylheku <kaz@kylheku.com> | 2014-01-28 22:29:02 -0800 |
---|---|---|
committer | Kaz Kylheku <kaz@kylheku.com> | 2014-01-28 22:29:43 -0800 |
commit | b8966f0bf73f01e1e380a08e6949ccc9ddd45637 (patch) | |
tree | 432fb8cd11319e84500103158bfe482f15b340b1 /stream.c | |
parent | 1f4a36cb97cb259ce8209de52229f33b341af9cd (diff) | |
download | txr-b8966f0bf73f01e1e380a08e6949ccc9ddd45637.tar.gz txr-b8966f0bf73f01e1e380a08e6949ccc9ddd45637.tar.bz2 txr-b8966f0bf73f01e1e380a08e6949ccc9ddd45637.zip |
* eval.c (eval_init): Registered existing make_catenated_stream as
intrinsic.
* stream.c (cat_get_line, cat_get_char, cat_get_byte): Do not
remove the last stream from the stream list, so that there is
some stream object there which can take the unget-char or
unget-byte operations.
(cat_unget_byte, cat_unget_char): New static functions.
(cat_stream_ops): unget_char and unget_byte function pointers
filled in.
* txr.1: Documented catenated-streams.
Diffstat (limited to 'stream.c')
-rw-r--r-- | stream.c | 43 |
1 files changed, 38 insertions, 5 deletions
@@ -2253,7 +2253,8 @@ static val cat_get_line(val stream) val line = get_line(first(streams)); if (line) return line; - stream->co.handle = (mem_t *) (streams = rest(streams)); + if ((streams = rest(streams)) != nil) + stream->co.handle = (mem_t *) streams; } return nil; @@ -2267,7 +2268,8 @@ static val cat_get_char(val stream) val ch = get_char(first(streams)); if (ch) return ch; - stream->co.handle = (mem_t *) (streams = rest(streams)); + if ((streams = rest(streams)) != nil) + stream->co.handle = (mem_t *) streams; } return nil; @@ -2281,12 +2283,43 @@ static val cat_get_byte(val stream) val byte = get_byte(first(streams)); if (byte) return byte; - stream->co.handle = (mem_t *) (streams = rest(streams)); + if ((streams = rest(streams)) != nil) + stream->co.handle = (mem_t *) streams; } return nil; } +static val cat_unget_byte(val stream, int byte) +{ + val streams = (val) stream->co.handle; + + if (!streams) { + uw_throwf(file_error_s, + lit("unget-byte on catenated stream ~a: stream list empty"), + stream, nao); + } else { + val stream = car(streams); + return unget_byte(stream, num_fast(byte)); + } + + return nil; +} + +static val cat_unget_char(val stream, val ch) +{ + val streams = (val) stream->co.handle; + + if (!streams) { + uw_throwf(file_error_s, + lit("unget-char on catenated stream ~a: stream list empty"), + stream, nao); + } else { + val stream = car(streams); + return unget_char(stream, ch); + } +} + static val cat_get_prop(val stream, val ind) { val streams = (val) stream->co.handle; @@ -2307,8 +2340,8 @@ static struct strm_ops cat_stream_ops = { cat_get_line, cat_get_char, cat_get_byte, - 0, /* unget_char, */ - 0, /* unget_byte, */ + cat_unget_char, + cat_unget_byte, 0, /* close, */ 0, /* flush, */ 0, /* seek, */ |