diff options
author | usa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2017-12-14 15:09:35 +0000 |
---|---|---|
committer | usa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2017-12-14 15:09:35 +0000 |
commit | 1a74fa4b04da04bd2bb33103dd3cf431438df38e (patch) | |
tree | f4a1d6c2961339e0c1d653c0f8427a53315080f0 /ruby_2_2/ext/-test-/proc | |
parent | a5b755e50e2d9aabf28ba24bf58644ca22b01a4f (diff) |
add tag v2_2_9
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/tags/v2_2_9@61257 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'ruby_2_2/ext/-test-/proc')
-rw-r--r-- | ruby_2_2/ext/-test-/proc/extconf.rb | 7 | ||||
-rw-r--r-- | ruby_2_2/ext/-test-/proc/init.c | 11 | ||||
-rw-r--r-- | ruby_2_2/ext/-test-/proc/receiver.c | 21 | ||||
-rw-r--r-- | ruby_2_2/ext/-test-/proc/super.c | 27 |
4 files changed, 66 insertions, 0 deletions
diff --git a/ruby_2_2/ext/-test-/proc/extconf.rb b/ruby_2_2/ext/-test-/proc/extconf.rb new file mode 100644 index 0000000000..40741d07cc --- /dev/null +++ b/ruby_2_2/ext/-test-/proc/extconf.rb @@ -0,0 +1,7 @@ +$INCFLAGS << " -I$(topdir) -I$(top_srcdir)" +$srcs = Dir[File.join($srcdir, "*.{#{SRC_EXT.join(%q{,})}}")] +inits = $srcs.map {|s| File.basename(s, ".*")} +inits.delete("init") +inits.map! {|s|"X(#{s})"} +$defs << "-DTEST_INIT_FUNCS(X)=\"#{inits.join(' ')}\"" +create_makefile("-test-/proc") diff --git a/ruby_2_2/ext/-test-/proc/init.c b/ruby_2_2/ext/-test-/proc/init.c new file mode 100644 index 0000000000..814c55d98b --- /dev/null +++ b/ruby_2_2/ext/-test-/proc/init.c @@ -0,0 +1,11 @@ +#include "ruby.h" + +#define init(n) {void Init_##n(VALUE klass); Init_##n(klass);} + +void +Init_proc(void) +{ + VALUE mBug = rb_define_module("Bug"); + VALUE klass = rb_define_module_under(mBug, "Proc"); + TEST_INIT_FUNCS(init); +} diff --git a/ruby_2_2/ext/-test-/proc/receiver.c b/ruby_2_2/ext/-test-/proc/receiver.c new file mode 100644 index 0000000000..fe44a2246c --- /dev/null +++ b/ruby_2_2/ext/-test-/proc/receiver.c @@ -0,0 +1,21 @@ +#include "ruby.h" + +VALUE rb_current_receiver(void); + +static VALUE +bug_proc_call_receiver(RB_BLOCK_CALL_FUNC_ARGLIST(yieldarg, procarg)) +{ + return rb_current_receiver(); +} + +static VALUE +bug_proc_make_call_receiver(VALUE self, VALUE procarg) +{ + return rb_proc_new(bug_proc_call_receiver, procarg); +} + +void +Init_receiver(VALUE klass) +{ + rb_define_singleton_method(klass, "make_call_receiver", bug_proc_make_call_receiver, 1); +} diff --git a/ruby_2_2/ext/-test-/proc/super.c b/ruby_2_2/ext/-test-/proc/super.c new file mode 100644 index 0000000000..dbe8af08f1 --- /dev/null +++ b/ruby_2_2/ext/-test-/proc/super.c @@ -0,0 +1,27 @@ +#include "ruby.h" + +static VALUE +bug_proc_call_super(RB_BLOCK_CALL_FUNC_ARGLIST(yieldarg, procarg)) +{ + VALUE args[2]; + VALUE ret; + args[0] = yieldarg; + args[1] = procarg; + ret = rb_call_super(2, args); + if (!NIL_P(blockarg)) { + ret = rb_proc_call(blockarg, ret); + } + return ret; +} + +static VALUE +bug_proc_make_call_super(VALUE self, VALUE procarg) +{ + return rb_proc_new(bug_proc_call_super, procarg); +} + +void +Init_super(VALUE klass) +{ + rb_define_singleton_method(klass, "make_call_super", bug_proc_make_call_super, 1); +} |