summaryrefslogtreecommitdiffhomepage
path: root/mrbgems
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2014-03-19 07:54:22 +0900
committerYukihiro "Matz" Matsumoto <[email protected]>2014-03-19 07:54:22 +0900
commit2f4eed25017903ab525e881107817024d36e3c66 (patch)
tree1a72a6a265f5a54be0b3f5bb257b201a848b4e01 /mrbgems
parent792c1add0cc44a60ecad661b86fd16bf773a5d58 (diff)
parent40c18fca77175a9e2882baa1975d4460412a4d28 (diff)
downloadmruby-2f4eed25017903ab525e881107817024d36e3c66.tar.gz
mruby-2f4eed25017903ab525e881107817024d36e3c66.zip
Merge pull request #1889 from iij/pr-struct-new-block-def
Set the newly created Struct object to self in its initialization block.
Diffstat (limited to 'mrbgems')
-rw-r--r--mrbgems/mruby-object-ext/src/object.c3
-rw-r--r--mrbgems/mruby-struct/src/struct.c2
2 files changed, 1 insertions, 4 deletions
diff --git a/mrbgems/mruby-object-ext/src/object.c b/mrbgems/mruby-object-ext/src/object.c
index 927a23d66..3f30dfa12 100644
--- a/mrbgems/mruby-object-ext/src/object.c
+++ b/mrbgems/mruby-object-ext/src/object.c
@@ -59,9 +59,6 @@ nil_to_i(mrb_state *mrb, mrb_value obj)
* k.instance_exec(5) {|x| @secret+x } #=> 104
*/
-mrb_value
-mrb_yield_internal(mrb_state *mrb, mrb_value b, int argc, mrb_value *argv, mrb_value self, struct RClass *c);
-
static mrb_value
mrb_obj_instance_exec(mrb_state *mrb, mrb_value self)
{
diff --git a/mrbgems/mruby-struct/src/struct.c b/mrbgems/mruby-struct/src/struct.c
index 34db4c40f..05fc2485d 100644
--- a/mrbgems/mruby-struct/src/struct.c
+++ b/mrbgems/mruby-struct/src/struct.c
@@ -382,7 +382,7 @@ mrb_struct_s_def(mrb_state *mrb, mrb_value klass)
}
st = make_struct(mrb, name, rest, struct_class(mrb));
if (!mrb_nil_p(b)) {
- mrb_funcall(mrb, b, "call", 1, st);
+ mrb_yield_internal(mrb, b, 1, &st, st, mrb_class_ptr(klass));
}
return st;