summaryrefslogtreecommitdiff
path: root/spec/ruby/optional/capi/ext
diff options
context:
space:
mode:
authorNobuyoshi Nakada <nobu@ruby-lang.org>2021-07-18 11:40:21 +0900
committerNobuyoshi Nakada <nobu@ruby-lang.org>2021-07-18 11:40:21 +0900
commite0e12202c7688881b8fcdad96669ca0cd7be8622 (patch)
tree6b3aa1ebb6bdf9089b92f7450773deb093375e60 /spec/ruby/optional/capi/ext
parent4885c44bca25346716969a3a0732c1bfea60f508 (diff)
Use rb_block_call() instead of the deprecated rb_iterate()
Diffstat (limited to 'spec/ruby/optional/capi/ext')
-rw-r--r--spec/ruby/optional/capi/ext/array_spec.c22
1 files changed, 9 insertions, 13 deletions
diff --git a/spec/ruby/optional/capi/ext/array_spec.c b/spec/ruby/optional/capi/ext/array_spec.c
index 39ed1ed18b..9386239813 100644
--- a/spec/ruby/optional/capi/ext/array_spec.c
+++ b/spec/ruby/optional/capi/ext/array_spec.c
@@ -196,10 +196,10 @@ static VALUE copy_ary(RB_BLOCK_CALL_FUNC_ARGLIST(el, new_ary)) {
return rb_ary_push(new_ary, el);
}
-static VALUE array_spec_rb_iterate(VALUE self, VALUE ary) {
+static VALUE array_spec_rb_block_call(VALUE self, VALUE ary) {
VALUE new_ary = rb_ary_new();
- rb_iterate(rb_each, ary, copy_ary, new_ary);
+ rb_block_call(ary, rb_intern("each"), 0, 0, copy_ary, new_ary);
return new_ary;
}
@@ -208,14 +208,10 @@ static VALUE sub_pair(RB_BLOCK_CALL_FUNC_ARGLIST(el, holder)) {
return rb_ary_push(holder, rb_ary_entry(el, 1));
}
-static VALUE each_pair(VALUE obj) {
- return rb_funcall(obj, rb_intern("each_pair"), 0);
-}
-
-static VALUE array_spec_rb_iterate_each_pair(VALUE self, VALUE obj) {
+static VALUE array_spec_rb_block_call_each_pair(VALUE self, VALUE obj) {
VALUE new_ary = rb_ary_new();
- rb_iterate(each_pair, obj, sub_pair, new_ary);
+ rb_block_call(obj, rb_intern("each_pair"), 0, 0, sub_pair, new_ary);
return new_ary;
}
@@ -225,8 +221,8 @@ static VALUE iter_yield(RB_BLOCK_CALL_FUNC_ARGLIST(el, ary)) {
return Qnil;
}
-static VALUE array_spec_rb_iterate_then_yield(VALUE self, VALUE obj) {
- rb_iterate(rb_each, obj, iter_yield, obj);
+static VALUE array_spec_rb_block_call_then_yield(VALUE self, VALUE obj) {
+ rb_block_call(obj, rb_intern("each"), 0, 0, iter_yield, obj);
return Qnil;
}
@@ -287,9 +283,9 @@ void Init_array_spec(void) {
rb_define_method(cls, "rb_ary_plus", array_spec_rb_ary_plus, 2);
rb_define_method(cls, "rb_ary_unshift", array_spec_rb_ary_unshift, 2);
rb_define_method(cls, "rb_assoc_new", array_spec_rb_assoc_new, 2);
- rb_define_method(cls, "rb_iterate", array_spec_rb_iterate, 1);
- rb_define_method(cls, "rb_iterate_each_pair", array_spec_rb_iterate_each_pair, 1);
- rb_define_method(cls, "rb_iterate_then_yield", array_spec_rb_iterate_then_yield, 1);
+ rb_define_method(cls, "rb_block_call", array_spec_rb_block_call, 1);
+ rb_define_method(cls, "rb_block_call_each_pair", array_spec_rb_block_call_each_pair, 1);
+ rb_define_method(cls, "rb_block_call_then_yield", array_spec_rb_block_call_then_yield, 1);
rb_define_method(cls, "rb_mem_clear", array_spec_rb_mem_clear, 1);
rb_define_method(cls, "rb_ary_freeze", array_spec_rb_ary_freeze, 1);
rb_define_method(cls, "rb_ary_to_ary", array_spec_rb_ary_to_ary, 1);