From e7bdd9e498306a64c5785bdb642d192e1f513c84 Mon Sep 17 00:00:00 2001 From: Matt Valentine-House Date: Mon, 6 Nov 2023 22:14:50 +0000 Subject: [PRISM] Move Local table setup into EnsureNode compilation --- prism_compile.c | 13 +++++-------- 1 file changed, 5 insertions(+), 8 deletions(-) diff --git a/prism_compile.c b/prism_compile.c index 32d5a07aa0..d64c60f588 100644 --- a/prism_compile.c +++ b/prism_compile.c @@ -1079,15 +1079,7 @@ pm_scope_node_init(const pm_node_t *node, pm_scope_node_t *scope, pm_scope_node_ } case PM_ENSURE_NODE: { pm_ensure_node_t *cast = (pm_ensure_node_t *)node; - - // HAXXX - pm_constant_id_t err_info = 3863; - pm_constant_id_list_t locals; - pm_constant_id_list_init(&locals); - pm_constant_id_list_append(&locals, err_info); - scope->body = (pm_node_t *)cast->statements; - scope->locals = locals; break; } case PM_FOR_NODE: { @@ -1591,6 +1583,11 @@ pm_compile_node(rb_iseq_t *iseq, const pm_node_t *node, LINK_ANCHOR *const ret, pm_scope_node_t next_scope_node; pm_scope_node_init((pm_node_t *)begin_node->ensure_clause, &next_scope_node, scope_node, parser); + pm_constant_id_list_t locals; + pm_constant_id_list_init(&locals); + pm_constant_id_list_append(&locals, idERROR_INFO); + next_scope_node.locals = locals; + child_iseq = NEW_CHILD_ISEQ(next_scope_node, rb_str_new2("ensure in"), ISEQ_TYPE_ENSURE, lineno); -- cgit v1.2.3