summaryrefslogtreecommitdiff
path: root/proc.c
diff options
context:
space:
mode:
authorJeremy Evans <code@jeremyevans.net>2019-09-25 11:22:14 -0700
committerJeremy Evans <code@jeremyevans.net>2019-09-26 08:01:53 -0700
commit760893d2f85682a3c8c00be4b29dea0f6b2bb4f8 (patch)
treec08a72928c4e5145422cd2f452fa4baebc9c9399 /proc.c
parent0aa267f985084e69c3e45cc3e94698eaacab5c36 (diff)
Fix keyword argument separation issues in Proc#{<<,>>}
This requires adding rb_proc_call_with_block_kw.
Notes
Notes: Merged: https://github.com/ruby/ruby/pull/2484
Diffstat (limited to 'proc.c')
-rw-r--r--proc.c20
1 files changed, 18 insertions, 2 deletions
diff --git a/proc.c b/proc.c
index 62b8eadb8f..91f58785d9 100644
--- a/proc.c
+++ b/proc.c
@@ -954,6 +954,22 @@ proc_to_block_handler(VALUE procval)
return NIL_P(procval) ? VM_BLOCK_HANDLER_NONE : procval;
}
+extern VALUE rb_adjust_argv_kw_splat(int *argc, const VALUE **argv, int *kw_splat);
+
+VALUE
+rb_proc_call_with_block_kw(VALUE self, int argc, const VALUE *argv, VALUE passed_procval, int kw_splat)
+{
+ rb_execution_context_t *ec = GET_EC();
+ VALUE vret;
+ rb_proc_t *proc;
+ VALUE v = rb_adjust_argv_kw_splat(&argc, &argv, &kw_splat);
+ GetProcPtr(self, proc);
+ vret = rb_vm_invoke_proc(ec, proc, argc, argv, kw_splat, proc_to_block_handler(passed_procval));
+ rb_free_tmp_buffer(&v);
+ RB_GC_GUARD(self);
+ return vret;
+}
+
VALUE
rb_proc_call_with_block(VALUE self, int argc, const VALUE *argv, VALUE passed_procval)
{
@@ -3215,9 +3231,9 @@ compose(RB_BLOCK_CALL_FUNC_ARGLIST(_, args))
g = RARRAY_AREF(args, 1);
if (rb_obj_is_proc(g))
- fargs = rb_proc_call_with_block(g, argc, argv, blockarg);
+ fargs = rb_proc_call_with_block_kw(g, argc, argv, blockarg, RB_PASS_CALLED_KEYWORDS);
else
- fargs = rb_funcall_with_block(g, idCall, argc, argv, blockarg);
+ fargs = rb_funcall_with_block_kw(g, idCall, argc, argv, blockarg, RB_PASS_CALLED_KEYWORDS);
if (rb_obj_is_proc(f))
return rb_proc_call(f, rb_ary_new3(1, fargs));