diff options
author | Kaz Kylheku <kaz@kylheku.com> | 2021-01-15 06:42:53 -0800 |
---|---|---|
committer | Kaz Kylheku <kaz@kylheku.com> | 2021-01-15 06:42:53 -0800 |
commit | 68ac0d194820fe9091fb4720b74ed1782767daee (patch) | |
tree | 7477aed5e7e099c21eeccc0a2d3706127027f0dc /share | |
parent | 8dd229be2aedaf93d92f5515bc40c86cd9942a4d (diff) | |
download | txr-68ac0d194820fe9091fb4720b74ed1782767daee.tar.gz txr-68ac0d194820fe9091fb4720b74ed1782767daee.tar.bz2 txr-68ac0d194820fe9091fb4720b74ed1782767daee.zip |
matcher: fix semantics of empty @(all ...) match.
* lisplib.c (match_set_entries): Ensure usr:all* is interned.
* share/txr/stdlib/match.tl (compile-all-match): When the
operator is the existing all, we must listp as a guard, not
consp, because an empty list must match vacuously by virtue of
not containing any counterexample to the pattern. For
situations when a vacuous empty match is not desired, we
support the all* alternative operator, which uses consp.
(compile-match): Wire in the all* operator.
Diffstat (limited to 'share')
-rw-r--r-- | share/txr/stdlib/match.tl | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/share/txr/stdlib/match.tl b/share/txr/stdlib/match.tl index 4fd3ad41..dd917786 100644 --- a/share/txr/stdlib/match.tl +++ b/share/txr/stdlib/match.tl @@ -163,7 +163,8 @@ (defun compile-all-match (exp obj-var) (tree-bind (op match) exp - (let* ((item-var (gensym "item-")) + (let* ((list-test (if (eq op 'all) 'listp 'consp)) + (item-var (gensym "item-")) (cm (compile-match match item-var)) (all-match-p-var (gensym "all-match-p-")) (matched-p-var (gensym "matched-p-")) @@ -188,7 +189,7 @@ (guard (new match-guard vars (cons all-match-p-var collect-vars) var-exprs (list loop) - guard-expr ^(consp ,obj-var)))) + guard-expr ^(,list-test ,obj-var)))) (new compiled-match pattern exp obj-var obj-var @@ -209,6 +210,7 @@ (require (compile-require-match exp obj-var)) (let (compile-let-match exp obj-var)) (all (compile-all-match exp obj-var)) + (usr:all* (compile-all-match exp obj-var)) (t (compile-predicate-match exp obj-var))) (compile-error *match-form* "unrecognized pattern syntax ~s" pat)))) |