summaryrefslogtreecommitdiffstats
path: root/match.c
diff options
context:
space:
mode:
authorKaz Kylheku <kaz@kylheku.com>2014-10-17 21:17:11 -0700
committerKaz Kylheku <kaz@kylheku.com>2014-10-17 21:17:11 -0700
commit43b4d36e37ca650cdf70568240ccc041b20306bd (patch)
treecd2600fcd8f859636399e88eafbf55a11217a5b5 /match.c
parenta1b531c559cf06722ce30e04afe7295b2d143ce4 (diff)
downloadtxr-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.c16
1 files changed, 14 insertions, 2 deletions
diff --git a/match.c b/match.c
index 95328b32..9e699646 100644
--- a/match.c
+++ b/match.c
@@ -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))
{