diff options
| author | Yukihiro Matsumoto <[email protected]> | 2012-07-17 02:05:39 +0900 |
|---|---|---|
| committer | Yukihiro Matsumoto <[email protected]> | 2012-07-17 02:05:39 +0900 |
| commit | 094fdc43671eb4914f69aa519439e3ba3ad0879f (patch) | |
| tree | 468a00d2986f43ba1a9daedec602b9fe006c3866 /src/class.c | |
| parent | 6696876e729a99a0a54e0989ef38361687fb0b5d (diff) | |
| parent | 8020c280aa88354d797bdaf754c7beeb42dabab4 (diff) | |
| download | mruby-094fdc43671eb4914f69aa519439e3ba3ad0879f.tar.gz mruby-094fdc43671eb4914f69aa519439e3ba3ad0879f.zip | |
resolve conflict
Diffstat (limited to 'src/class.c')
| -rw-r--r-- | src/class.c | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/src/class.c b/src/class.c index 976642224..2784327f3 100644 --- a/src/class.c +++ b/src/class.c @@ -741,6 +741,17 @@ mrb_mod_ancestors(mrb_state *mrb, mrb_value self) } static mrb_value +mrb_mod_extend_object(mrb_state *mrb, mrb_value mod) +{ + mrb_value obj; + + mrb_check_type(mrb, mod, MRB_TT_MODULE); + mrb_get_args(mrb, "o", &obj); + mrb_include_module(mrb, mrb_class_ptr(mrb_singleton_class(mrb, obj)), mrb_class_ptr(mod)); + return mod; +} + +static mrb_value mrb_mod_included_modules(mrb_state *mrb, mrb_value self) { mrb_value result; @@ -1413,6 +1424,8 @@ mrb_init_class(mrb_state *mrb) mrb_define_method(mrb, cls, "superclass", mrb_class_superclass, ARGS_NONE()); /* 15.2.3.3.4 */ mrb_define_method(mrb, cls, "new", mrb_instance_new, ARGS_ANY()); /* 15.2.3.3.3 */ mrb_define_method(mrb, cls, "inherited", mrb_bob_init, ARGS_REQ(1)); + mrb_define_method(mrb, mod, "extend_object", mrb_mod_extend_object, ARGS_REQ(1)); /* 15.2.2.4.25 */ + mrb_define_method(mrb, mod, "extended", mrb_bob_init, ARGS_REQ(1)); /* 15.2.2.4.26 */ mrb_define_method(mrb, mod, "include", mrb_mod_include, ARGS_ANY()); /* 15.2.2.4.27 */ mrb_define_method(mrb, mod, "append_features", mrb_mod_append_features, ARGS_REQ(1)); /* 15.2.2.4.10 */ mrb_define_method(mrb, mod, "included", mrb_bob_init, ARGS_REQ(1)); /* 15.2.2.4.29 */ |
