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 /txr.1 | |
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 'txr.1')
-rw-r--r-- | txr.1 | 40 |
1 files changed, 40 insertions, 0 deletions
@@ -10983,6 +10983,46 @@ the stream-real-time-p function above), and also for setting the priority at which messages are reported to syslog by the *stdlog* stream (see *stdlog* in the UNIX SYSLOG section). +If <stream> is a catenated stream (see the function make-catenated-stream) +then these functions transparently operate on the current head stream of the +catenation. + +.SS Function make-catenated-stream + +.TP +Syntax: + + (make-catenated-stream . streams) + +.TP +Description + +The make-catenated-stream function takes zero or more arguments which +are input streams of the same type. + +A concatenaed stream does not support seeking operations or output, +regardless of the capabilities of the streams in the list. + +If the stream list is not empty, then the leftmost element of the +list is called the head stream. + +The get-char, get-byte, get-line, unget-char and unget-byte delegate +to the corresponding operations on the head stream, if it exists. +If the stream list is empty, they return nil to the caller. + +The a get-char, get-byte or get-line operation on the head stream yields nil, +and there are more lists in the stream, then the stream is removed from the +list, and the next stream, if any, becomes the head list. The operation is then +tried again. If any of these operations fail on the last list, it is not +removed from the list, so that a stream remains in place which can take +the unget-char or unget-byte operations. + +In this manner, the catenated streams appear to be a single stream. + +Note that the operations can fail due to being unsupported. It is +the caller's responsibility to make sure all of the streams in the list +are compatible with the intended operations. + .SS Function read .TP |