diff options
| author | Yukihiro "Matz" Matsumoto <[email protected]> | 2017-11-04 11:49:25 +0900 |
|---|---|---|
| committer | Yukihiro "Matz" Matsumoto <[email protected]> | 2017-11-04 11:49:25 +0900 |
| commit | de2363a9f0c7d368ee9002f86931d124e644a243 (patch) | |
| tree | 2112928a80786a109ecac4b3ce200f45ac75e2cb /src/kernel.c | |
| parent | 388d26d77027feaa3e107abf7209e2681868bbe6 (diff) | |
| parent | 625f9f6fa314872968632c5adbee7fb3823268b8 (diff) | |
| download | mruby-de2363a9f0c7d368ee9002f86931d124e644a243.tar.gz mruby-de2363a9f0c7d368ee9002f86931d124e644a243.zip | |
Merge branch 'mrb_without_float' of https://github.com/pandax381/mruby into pandax381-mrb_without_float
Diffstat (limited to 'src/kernel.c')
| -rw-r--r-- | src/kernel.c | 16 |
1 files changed, 16 insertions, 0 deletions
diff --git a/src/kernel.c b/src/kernel.c index ec95b04ba..4a20e18c1 100644 --- a/src/kernel.c +++ b/src/kernel.c @@ -442,7 +442,9 @@ mrb_obj_freeze(mrb_state *mrb, mrb_value self) case MRB_TT_TRUE: case MRB_TT_FIXNUM: case MRB_TT_SYMBOL: +#ifndef MRB_WITHOUT_FLOAT case MRB_TT_FLOAT: +#endif return self; default: break; @@ -465,7 +467,9 @@ mrb_obj_frozen(mrb_state *mrb, mrb_value self) case MRB_TT_TRUE: case MRB_TT_FIXNUM: case MRB_TT_SYMBOL: +#ifndef MRB_WITHOUT_FLOAT case MRB_TT_FLOAT: +#endif return mrb_true_value(); default: break; @@ -894,6 +898,16 @@ mrb_f_raise(mrb_state *mrb, mrb_value self) return mrb_nil_value(); /* not reached */ } +static mrb_value +mrb_krn_class_defined(mrb_state *mrb, mrb_value self) +{ + mrb_value str; + + mrb_get_args(mrb, "S", &str); + return mrb_bool_value(mrb_class_defined(mrb, RSTRING_PTR(str))); +} + + /* 15.3.1.3.41 */ /* * call-seq: @@ -1252,6 +1266,8 @@ mrb_init_kernel(mrb_state *mrb) mrb_define_method(mrb, krn, "to_s", mrb_any_to_s, MRB_ARGS_NONE()); /* 15.3.1.3.46 */ mrb_define_method(mrb, krn, "__case_eqq", mrb_obj_ceqq, MRB_ARGS_REQ(1)); /* internal */ + mrb_define_method(mrb, krn, "class_defined?", mrb_krn_class_defined, MRB_ARGS_REQ(1)); + mrb_include_module(mrb, mrb->object_class, mrb->kernel_module); mrb_alias_method(mrb, mrb->module_class, mrb_intern_lit(mrb, "dup"), mrb_intern_lit(mrb, "clone")); } |
