diff options
-rw-r--r-- | eval.c | 2 | ||||
-rw-r--r-- | share/txr/stdlib/compiler.tl | 2 |
2 files changed, 3 insertions, 1 deletions
@@ -6062,6 +6062,8 @@ void eval_init(void) reg_op(prof_s, op_prof); reg_op(switch_s, op_switch); reg_op(intern(lit("upenv"), system_package), op_upenv); + reg_op(intern(lit("compile-only"), user_package), op_progn); + reg_op(intern(lit("eval-only"), user_package), op_progn); reg_mac(defvar_s, func_n2(me_def_variable)); reg_mac(defparm_s, func_n2(me_def_variable)); diff --git a/share/txr/stdlib/compiler.tl b/share/txr/stdlib/compiler.tl index 907055ad..04ba74ac 100644 --- a/share/txr/stdlib/compiler.tl +++ b/share/txr/stdlib/compiler.tl @@ -216,7 +216,7 @@ (fun me.(comp-fun oreg env form)) (sys:for-op me.(comp-for oreg env form)) (sys:each-op me.(compile oreg env (expand-each form env))) - (progn me.(comp-progn oreg env (cdr form))) + ((progn eval-only compile-only) me.(comp-progn oreg env (cdr form))) (and me.(comp-and-or oreg env form)) (or me.(comp-and-or oreg env form)) (prog1 me.(comp-prog1 oreg env form)) |