diff options
-rw-r--r-- | eval.c | 21 | ||||
-rw-r--r-- | share/txr/stdlib/compiler.tl | 9 |
2 files changed, 16 insertions, 14 deletions
@@ -109,7 +109,7 @@ val whole_k, form_k, symacro_k; val last_form_evaled; -val call_f; +val call_f, get_iter_f; val origin_hash; @@ -1840,23 +1840,23 @@ static val op_each(val form, val env) val bindings = if3(vars, get_bindings(vars, env), env->e.vbindings); - val lists = mapcar(cdr_f, bindings); + val iters = mapcar(get_iter_f, bindings); list_collect_decl (collection, ptail); uw_block_begin (nil, result); for (;;) { - val biter, liter; + val biter, iiter; - for (biter = bindings, liter = lists; biter; - biter = cdr(biter), liter = cdr(liter)) + for (biter = bindings, iiter = iters; biter; + biter = cdr(biter), iiter = cdr(iiter)) { val binding = car(biter); - val list = car(liter); - if (!list) + val iter = car(iiter); + if (!iter_more(iter)) goto out; - rplacd(binding, car(list)); - rplaca(liter, cdr(list)); + rplacd(binding, iter_item(iter)); + rplaca(iiter, iter_step(iter)); } { @@ -6262,7 +6262,7 @@ void eval_init(void) protect(&top_vb, &top_fb, &top_mb, &top_smb, &special, &builtin, &dyn_env, &op_table, &pm_table, &last_form_evaled, - &call_f, &unbound_s, &origin_hash, convert(val *, 0)); + &call_f, &get_iter_f, &unbound_s, &origin_hash, convert(val *, 0)); top_fb = make_hash(t, nil, nil); top_vb = make_hash(t, nil, nil); top_mb = make_hash(t, nil, nil); @@ -6273,6 +6273,7 @@ void eval_init(void) pm_table = make_hash(nil, nil, nil); call_f = func_n1v(generic_funcall); + get_iter_f = chain(cdr_f, func_n1(iter_begin), nao); origin_hash = make_eq_hash(t, nil); diff --git a/share/txr/stdlib/compiler.tl b/share/txr/stdlib/compiler.tl index 3b5caffe..36e33007 100644 --- a/share/txr/stdlib/compiler.tl +++ b/share/txr/stdlib/compiler.tl @@ -1385,12 +1385,13 @@ (out (if (member each-type '(collect-each append-each)) (gensym))) (accum (if out (gensym)))) - ^(let* (,*(zip gens vars) ,*(if accum ^((,out (cons nil nil)) (,accum ,out)))) + ^(let* (,*(mapcar (ret ^(,@1 (iter-begin ,@2))) gens vars) + ,*(if accum ^((,out (cons nil nil)) (,accum ,out)))) (block nil (sys:for-op () - ((and ,*gens) ,*(if accum ^((cdr ,out)))) - (,*(mapcar (ret ^(sys:setq ,@1 (cdr ,@1))) gens)) - ,*(mapcar (ret ^(sys:setq ,@1 (car ,@2))) vars gens) + ((and ,*(mapcar (op list 'iter-more) gens)) ,*(if accum ^((cdr ,out)))) + (,*(mapcar (ret ^(sys:setq ,@1 (iter-step ,@1))) gens)) + ,*(mapcar (ret ^(sys:setq ,@1 (iter-item ,@2))) vars gens) ,*(caseq each-type (collect-each ^((rplacd ,accum (cons (progn ,*body) nil)) (sys:setq ,accum (cdr ,accum)))) |