diff options
author | Kaz Kylheku <kaz@kylheku.com> | 2016-03-26 21:43:18 -0700 |
---|---|---|
committer | Kaz Kylheku <kaz@kylheku.com> | 2016-03-26 21:43:18 -0700 |
commit | 6597ea5e7359f3936d6e73cccc142cd107e17a9f (patch) | |
tree | ac2c5ca13a32878b876621ac740345795f2bee4a /eval.c | |
parent | e96cb9e2065a066ede10e3ce36eba828fd42a97b (diff) | |
download | txr-6597ea5e7359f3936d6e73cccc142cd107e17a9f.tar.gz txr-6597ea5e7359f3936d6e73cccc142cd107e17a9f.tar.bz2 txr-6597ea5e7359f3936d6e73cccc142cd107e17a9f.zip |
Bugfix in error location reporting across macro expansions.
* eval.c (do_expand, macroexpand_1): The original form
must have priority in providing source location info,
over the macro. Otherwise macro bodies may get reported as
locations of errors that occur in substituted code.
Diffstat (limited to 'eval.c')
-rw-r--r-- | eval.c | 4 |
1 files changed, 2 insertions, 2 deletions
@@ -3518,7 +3518,7 @@ tail: val mac_expand = expand_macro(form, macro, menv); if (mac_expand == form) return form; - form = rlcp_tree(rlcp_tree(mac_expand, macro), form); + form = rlcp_tree(rlcp_tree(mac_expand, form), macro); goto tail; } else if (sym == progn_s) { val args = rest(form); @@ -3587,7 +3587,7 @@ static val macroexpand_1(val form, val menv) val mac_expand = expand_macro(form, macro, menv); if (mac_expand == form) return form; - return rlcp_tree(rlcp_tree(mac_expand, macro), form); + return rlcp_tree(rlcp_tree(mac_expand, form), macro); } if (bindable(form) && (macro = lookup_symac(menv, form))) { |