diff options
author | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2014-11-16 10:11:28 +0000 |
---|---|---|
committer | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2014-11-16 10:11:28 +0000 |
commit | b1acfbc121ad5eecaf315b6126f960894da1d83b (patch) | |
tree | 95dfcaa1bf3ec82f841b758a9a47cf679945e8bb /ext/-test-/proc/super.c | |
parent | f45e0d537ff0a902f3122eac47b809f3c6098dc4 (diff) |
ext/-test-/proc/super.c: rename
* ext/-test-/proc/super.c: renamed the file and maker method.
[Feature #10195]
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@48461 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'ext/-test-/proc/super.c')
-rw-r--r-- | ext/-test-/proc/super.c | 27 |
1 files changed, 27 insertions, 0 deletions
diff --git a/ext/-test-/proc/super.c b/ext/-test-/proc/super.c new file mode 100644 index 0000000000..dbe8af08f1 --- /dev/null +++ b/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); +} |