summaryrefslogtreecommitdiffstats
path: root/eval.c
diff options
context:
space:
mode:
authorKaz Kylheku <kaz@kylheku.com>2015-07-22 07:43:33 -0700
committerKaz Kylheku <kaz@kylheku.com>2015-07-22 07:43:33 -0700
commit183e90ee84334efe3f27ddaa21ea5bb0355dc15d (patch)
tree8905856ce6569bd6284fec40ed60452167c1ec5a /eval.c
parent420a230dbae897ee32c03297f7e4bb18f683a8b1 (diff)
downloadtxr-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.c13
1 files changed, 13 insertions, 0 deletions
diff --git a/eval.c b/eval.c
index 0a9e89de..67ac400d 100644
--- a/eval.c
+++ b/eval.c
@@ -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);