diff options
author | Kaz Kylheku <kaz@kylheku.com> | 2011-12-06 15:40:47 -0800 |
---|---|---|
committer | Kaz Kylheku <kaz@kylheku.com> | 2011-12-06 15:40:47 -0800 |
commit | 6f051c69587d159cafbb6bcf79ba245e8ca0d6c0 (patch) | |
tree | 9f32f483a41807787a4c6b864d65404de4fd043d /match.c | |
parent | 6cf90c4dc732318823adf7ec96e88e9e7772d4cf (diff) | |
download | txr-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.c | 16 |
1 files changed, 8 insertions, 8 deletions
@@ -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)) |