summaryrefslogtreecommitdiffstats
path: root/match.c
diff options
context:
space:
mode:
authorKaz Kylheku <kaz@kylheku.com>2014-10-03 07:34:44 -0700
committerKaz Kylheku <kaz@kylheku.com>2014-10-03 08:35:02 -0700
commit090f4dee78f7a7239ebd515993412f9505001fa9 (patch)
treec8d9bd28101968b1d37e1d28f949941d34a3a034 /match.c
parent54f09626d4a93296f002ed5956de008fb59a200b (diff)
downloadtxr-090f4dee78f7a7239ebd515993412f9505001fa9.tar.gz
txr-090f4dee78f7a7239ebd515993412f9505001fa9.tar.bz2
txr-090f4dee78f7a7239ebd515993412f9505001fa9.zip
* match.c (h_var): Fix regression introduced in 2014-08-11
commit. The incompleteness of that change broke the case of an unbound variable followed by a bound variable. The value of the second variable was still being wrapped in the old complicated representation before being pushed to the front of the spec. * txr.1: Replace bogus text which says that variables are not bound to regexes, and so regex matches from variable substitutions do not arise. This works fine after this change.
Diffstat (limited to 'match.c')
-rw-r--r--match.c7
1 files changed, 3 insertions, 4 deletions
diff --git a/match.c b/match.c
index ce21d66a..df25c6eb 100644
--- a/match.c
+++ b/match.c
@@ -632,10 +632,9 @@ static val h_var(match_line_ctx *c)
} else if (!pair) {
sem_error(elem, lit("consecutive unbound variables"), nao);
} else {
- /* Re-generate a new spec with an edited version of
- the element we just processed, and repeat. */
- val new_elem = list(var_s, sym, cdr(pair), modifier, nao);
- c->specline = cons(elem, cons(new_elem, rest(c->specline)));
+ /* Re-generate a new spec in which the next variable
+ is replaced by its value, and repeat. */
+ c->specline = cons(elem, cons(cdr(pair), rest(c->specline)));
return repeat_spec_k;
}
} else if (op == text_s) {