diff options
author | Kaz Kylheku <kaz@kylheku.com> | 2014-10-17 21:17:11 -0700 |
---|---|---|
committer | Kaz Kylheku <kaz@kylheku.com> | 2014-10-17 21:17:11 -0700 |
commit | 43b4d36e37ca650cdf70568240ccc041b20306bd (patch) | |
tree | cd2600fcd8f859636399e88eafbf55a11217a5b5 /match.c | |
parent | a1b531c559cf06722ce30e04afe7295b2d143ce4 (diff) | |
download | txr-43b4d36e37ca650cdf70568240ccc041b20306bd.tar.gz txr-43b4d36e37ca650cdf70568240ccc041b20306bd.tar.bz2 txr-43b4d36e37ca650cdf70568240ccc041b20306bd.zip |
* match.c (dest_bind): Remove the restriction of not allowing
@(expr ...) and @var on the left side of a bind. This
is useful, and necessary for @(line @(lisp expr)) to work:
matching computed line numbers and character positions.
* txr.1: Document use of Lisp on left hand side of bind,
that there is a restriction on the left hand side of a set,
and that Lisp can be used in a line or chr directive for
computed matches.
Diffstat (limited to 'match.c')
-rw-r--r-- | match.c | 16 |
1 files changed, 14 insertions, 2 deletions
@@ -296,15 +296,27 @@ static val dest_bind(val spec, val bindings, val pattern, } } else if (consp(pattern)) { val piter = pattern, viter = value; + val lisp_evaled = nil; + val ret; if (first(pattern) == var_s) { - sem_error(spec, lit("metavariable @~a syntax cannot be used here"), second(pattern), nao); + uw_env_begin; + uw_set_match_context(cons(spec, bindings)); + ret = eval(second(pattern), make_env(bindings, nil, nil), pattern); + lisp_evaled = t; + uw_env_end; } if (first(pattern) == expr_s) { - sem_error(spec, lit("the @~s syntax cannot be used here"), rest(pattern), nao); + uw_env_begin; + uw_set_match_context(cons(spec, bindings)); + ret = eval(rest(pattern), make_env(bindings, nil, nil), pattern); + lisp_evaled = t; + uw_env_end; } + if (lisp_evaled) + return if3(tree_find(value, ret, swap_12_21(testfun)), bindings, t); while (consp(piter) && consp(viter)) { |