summaryrefslogtreecommitdiffstats
path: root/match.c
diff options
context:
space:
mode:
authorKaz Kylheku <kaz@kylheku.com>2011-12-06 15:40:47 -0800
committerKaz Kylheku <kaz@kylheku.com>2011-12-06 15:40:47 -0800
commit6f051c69587d159cafbb6bcf79ba245e8ca0d6c0 (patch)
tree9f32f483a41807787a4c6b864d65404de4fd043d /match.c
parent6cf90c4dc732318823adf7ec96e88e9e7772d4cf (diff)
downloadtxr-6f051c69587d159cafbb6bcf79ba245e8ca0d6c0.tar.gz
txr-6f051c69587d159cafbb6bcf79ba245e8ca0d6c0.tar.bz2
txr-6f051c69587d159cafbb6bcf79ba245e8ca0d6c0.zip
* eval.c (op_unwind_protect): Fixed uninitialized variable
warning. (eval_init): New functions registered: typeof and vector functions, as well as length_list. * lib.c (length): Function renamed to length_list, because it is list specific. (length_vec, size_vec, vector_list): New functions. (length): New function, generic over lists, vectors and strings. * lib.h (length_list, length_vec, size_vec, vector_list): Declared. * match.c (h_var, h_fun, robust_length, v_deffilter, v_fun): Use length_list instead of length. * parser.l: Introduced # token. * parser.y (vector): New nonterminal. (expr): vector is a kind of expr. (chrlist): Bugfix: single-character syntax was not working; for instance #\x to denote the charcter x. (lit_char_helper): Use length_list instead of length. * stream.c (string_in_get_line): Bugfix: this was using the wrong length function: length was being applied to a string. The genericity of length makes that correct now, but changing to length_str anyway. * txr.1: Blank sections created for functions. Vector syntax documented.
Diffstat (limited to 'match.c')
-rw-r--r--match.c16
1 files changed, 8 insertions, 8 deletions
diff --git a/match.c b/match.c
index 1777dd6d..3071844b 100644
--- a/match.c
+++ b/match.c
@@ -447,7 +447,7 @@ static val h_var(match_line_ctx c, match_line_ctx *cout)
val modifier = first(modifiers);
val pair = assoc(c.bindings, sym); /* var exists already? */
- if (gt(length(modifiers), one)) {
+ if (gt(length_list(modifiers), one)) {
sem_error(elem, lit("multiple modifiers on variable ~s"),
sym, nao);
}
@@ -556,7 +556,7 @@ static val h_var(match_line_ctx c, match_line_ctx *cout)
val next_modifier = first(fourth(pat));
val pair = assoc(c.bindings, second_sym); /* var exists already? */
- if (gt(length(next_modifiers), one)) {
+ if (gt(length_list(next_modifiers), one)) {
sem_error(elem, lit("multiple modifiers on variable ~s"),
second_sym, nao);
}
@@ -994,9 +994,9 @@ static val h_fun(match_line_ctx c, match_line_ctx *cout)
val piter, aiter;
val bindings_cp = copy_list(c.bindings);
- if (!equal(length(args), length(params)))
+ if (!equal(length(args), length_list(params)))
sem_error(elem, lit("function ~a takes ~a argument(s)"),
- sym, length(params), nao);
+ sym, length_list(params), nao);
for (piter = params, aiter = args; piter;
piter = cdr(piter), aiter = cdr(aiter))
@@ -1462,7 +1462,7 @@ static val robust_length(val obj)
return zero;
if (atom(obj))
return negone;
- return length(obj);
+ return length_list(obj);
}
static val bind_car(val bind_cons)
@@ -2948,7 +2948,7 @@ static val v_deffilter(match_files_ctx *c)
val table_evaled = txeval(specline, table, c->bindings);
if (!all_satisfy(table_evaled, andf(func_n1(listp),
- chain(func_n1(length),
+ chain(func_n1(length_list),
curry_12_1(func_n2(ge), two), nao),
chain(func_n1(rest),
curry_123_1(func_n3(all_satisfy),
@@ -3025,9 +3025,9 @@ static val v_fun(match_files_ctx *c)
debug_check(specline, c->bindings, if2(consp(c->data), car(c->data)), c->data_lineno, nil);
- if (!equal(length(args), length(params)))
+ if (!equal(length_list(args), length_list(params)))
sem_error(specline, lit("function ~a takes ~a argument(s)"),
- sym, length(params), nao);
+ sym, length_list(params), nao);
for (piter = params, aiter = args; piter;
piter = cdr(piter), aiter = cdr(aiter))