aboutsummaryrefslogtreecommitdiffstats
path: root/prism_compile.c
diff options
context:
space:
mode:
authorJemma Issroff <jemmaissroff@gmail.com>2023-12-06 09:45:04 -0500
committerJemma Issroff <jemmaissroff@gmail.com>2023-12-06 13:05:03 -0500
commit9620ca678929f28dd8dab8e278e438a430a85022 (patch)
tree46c3eddecd3f27755371c3b2d28c4238d6688870 /prism_compile.c
parent0316e666c07d020fac267e0a76952cf0dae07190 (diff)
downloadruby-9620ca678929f28dd8dab8e278e438a430a85022.tar.gz
[PRISM] Extract a PM_NOP helper
Diffstat (limited to 'prism_compile.c')
-rw-r--r--prism_compile.c13
1 files changed, 8 insertions, 5 deletions
diff --git a/prism_compile.c b/prism_compile.c
index 3843cfb9ea..e70fa75aae 100644
--- a/prism_compile.c
+++ b/prism_compile.c
@@ -54,6 +54,9 @@
#define PM_SWAP_UNLESS_POPPED \
if (!popped) PM_SWAP;
+#define PM_NOP \
+ ADD_INSN(ret, &dummy_line_node, nop);
+
/**
* We're using the top most bit of a pm_constant_id_t as a tag to represent an
* anonymous local. When a child iseq is created and needs access to a value
@@ -1904,7 +1907,7 @@ pm_compile_node(rb_iseq_t *iseq, const pm_node_t *node, LINK_ANCHOR *const ret,
}
ADD_LABEL(ret, lend);
- ADD_INSN(ret, &dummy_line_node, nop);
+ PM_NOP;
ADD_LABEL(ret, lcont);
PM_POP_IF_POPPED;
@@ -1925,7 +1928,7 @@ pm_compile_node(rb_iseq_t *iseq, const pm_node_t *node, LINK_ANCHOR *const ret,
}
}
ADD_LABEL(ret, eend);
- ADD_INSN(ret, &dummy_line_node, nop);
+ PM_NOP;
pm_statements_node_t *statements = begin_node->ensure_clause->statements;
if (statements) {
PM_COMPILE((pm_node_t *)statements);
@@ -3890,7 +3893,7 @@ pm_compile_node(rb_iseq_t *iseq, const pm_node_t *node, LINK_ANCHOR *const ret,
ADD_LABEL(ret, lstart);
PM_COMPILE_NOT_POPPED((pm_node_t *)rescue_node->expression);
ADD_LABEL(ret, lend);
- ADD_INSN(ret, &dummy_line_node, nop);
+ PM_NOP;
ADD_LABEL(ret, lcont);
PM_POP_IF_POPPED;
@@ -4236,7 +4239,7 @@ pm_compile_node(rb_iseq_t *iseq, const pm_node_t *node, LINK_ANCHOR *const ret,
ADD_TRACE(ret, RUBY_EVENT_B_CALL);
NODE dummy_line_node = generate_dummy_line_node(body->location.first_lineno, -1);
- ADD_INSN (ret, &dummy_line_node, nop);
+ PM_NOP;
ADD_LABEL(ret, start);
if (scope_node->body) {
@@ -4260,7 +4263,7 @@ pm_compile_node(rb_iseq_t *iseq, const pm_node_t *node, LINK_ANCHOR *const ret,
ADD_GETLOCAL(ret, &dummy_line_node, 1, 0);
PM_COMPILE(for_node->index);
- ADD_INSN(ret, &dummy_line_node, nop);
+ PM_NOP;
pm_compile_node(iseq, (pm_node_t *)(scope_node->body), ret, src, popped, scope_node);
break;
}