diff options
author | Kaz Kylheku <kaz@kylheku.com> | 2021-06-16 06:14:29 -0700 |
---|---|---|
committer | Kaz Kylheku <kaz@kylheku.com> | 2021-06-16 06:14:29 -0700 |
commit | 60301ab68ec6a6b7ecb72f83d411c651e029a587 (patch) | |
tree | 9682a11bc65ebb42ef012a13c10b6f61cfff08df /txr.1 | |
parent | 40c1dee7647ddb7d4768a2eadf9915ab29e62f59 (diff) | |
download | txr-60301ab68ec6a6b7ecb72f83d411c651e029a587.tar.gz txr-60301ab68ec6a6b7ecb72f83d411c651e029a587.tar.bz2 txr-60301ab68ec6a6b7ecb72f83d411c651e029a587.zip |
txr-case: upkeep.
* share/txr/stdlib/txr-case.tl (txr-case-impl): If the input
is a stream, then convert it to a lazy list of lines, so that
running multiple functions against it produces sane,
backtracking behavior, like a @(cases) construct.
* tests/011/txr-case.expected: Updated.
* tests/011/txr-case.txr: Now actually contains a test case
for txr-case.
* txr.1: Address an issue reported by Paul A. Patience: the
input to match-fun, txr-if and txr-when may be a stream. That
has always been the case in the implementation. Also document
that when the input is a single string, it is treated as a
list. Document the new requirement in txr-case that a stream
is converted into lazy list of lines.
Diffstat (limited to 'txr.1')
-rw-r--r-- | txr.1 | 38 |
1 files changed, 33 insertions, 5 deletions
@@ -71237,11 +71237,17 @@ which will be interpreted as pattern variables, and may be bound or unbound. If they are not symbols, then they are treated as expressions (of the pattern language, not \*(TL) and evaluated accordingly. -The +The optional .meta input -argument is a list of strings, which may be lazy. It represents the -lines of the text stream to be processed. If omitted, it defaults to -.codn nil . +argument is an object of one of several types. It may be a stream, +character string or list of strings. If it is a string, then +it is converted to a list containing that string. +A list of strings represents zero or more lines of text to be +processed. If the +.meta input +argument is omitted, then it defaults to +.codn nil , +interpreted as an empty list of lines. The .meta files @@ -71353,7 +71359,11 @@ macro invokes the \*(TX pattern matching function .meta name on some input given by the .meta input -parameter, which is a list of strings, or a single string. +parameter, whose semantics are the same as the +.meta input +argument of the +.code match-fun +funtion. If .meta name @@ -71515,6 +71525,24 @@ otherwise the forms are evaluated in order and the value of the last one specifies the result of .codn txr-case . +The value of the input +.meta input-form +is expected to be one of the same kinds of objects as given by the +requirements for the +.meta input +argument of the +.code match-fun +functions. + +If +.meta input-form +evaluates to a stream object according to the +.code streamp +function, then the stream is converted to a lazy list of lines, +as if by invoking the +.code get-lines +function on that stream; that list then serves as input to the clauses. + .coNP Function @ txr-parse .synb .mets (txr-parse >> [ source >> [ error-stream |