diff options
author | Kaz Kylheku <kaz@kylheku.com> | 2015-07-22 07:43:33 -0700 |
---|---|---|
committer | Kaz Kylheku <kaz@kylheku.com> | 2015-07-22 07:43:33 -0700 |
commit | 183e90ee84334efe3f27ddaa21ea5bb0355dc15d (patch) | |
tree | 8905856ce6569bd6284fec40ed60452167c1ec5a /eval.c | |
parent | 420a230dbae897ee32c03297f7e4bb18f683a8b1 (diff) | |
download | txr-183e90ee84334efe3f27ddaa21ea5bb0355dc15d.tar.gz txr-183e90ee84334efe3f27ddaa21ea5bb0355dc15d.tar.bz2 txr-183e90ee84334efe3f27ddaa21ea5bb0355dc15d.zip |
Improve bad argument diagnosis for place macros.
* eval.c (op_mac_param_bind): New static function.
(eval_init): Register mac-param-bind operator.
* share/txr/stdlib/place.tl (define-place-macro): Use
mac-param-bind inside a lambda instead of tb macro.
* txr.1: Document mac-param-bind.
Diffstat (limited to 'eval.c')
-rw-r--r-- | eval.c | 13 |
1 files changed, 13 insertions, 0 deletions
@@ -1667,6 +1667,18 @@ static val op_tree_bind(val form, val env) return eval_progn(body, new_env, body); } +static val op_mac_param_bind(val form, val env) +{ + val body = cdr(form); + val ctx_form = pop(&body); + val params = pop(&body); + val expr = pop(&body); + val ctx_val = eval(ctx_form, env, ctx_form); + val expr_val = eval(expr, env, expr); + val new_env = bind_macro_params(env, nil, params, expr_val, nil, ctx_val); + return eval_progn(body, new_env, body); +} + static val op_setq(val form, val env) { val args = rest(form); @@ -4031,6 +4043,7 @@ void eval_init(void) reg_op(defsymacro_s, op_defsymacro); reg_op(tree_case_s, op_tree_case); reg_op(tree_bind_s, op_tree_bind); + reg_op(intern(lit("mac-param-bind"), user_package), op_mac_param_bind); reg_op(setq_s, op_setq); reg_op(intern(lit("lisp1-setq"), system_package), op_lisp1_setq); reg_op(sys_lisp1_value_s, op_lisp1_value); |