diff options
| author | Yukihiro "Matz" Matsumoto <[email protected]> | 2014-11-17 17:55:23 +0900 |
|---|---|---|
| committer | Yukihiro "Matz" Matsumoto <[email protected]> | 2014-11-17 17:55:23 +0900 |
| commit | 9980bc20bb9a2149c975dd25b4eb2cab664f99d0 (patch) | |
| tree | 4e459e553b371456ada48988a2b9e71ca07578dd /src | |
| parent | 70c98667512b9301e577aafc912a35208ad471c9 (diff) | |
| parent | 9a06cfa9d8511377523072c823b1c269d092cb25 (diff) | |
| download | mruby-9980bc20bb9a2149c975dd25b4eb2cab664f99d0.tar.gz mruby-9980bc20bb9a2149c975dd25b4eb2cab664f99d0.zip | |
Merge pull request #2636 from ksss/mrb_notimplement
Implement C API mrb_notimplement
Diffstat (limited to 'src')
| -rw-r--r-- | src/class.c | 16 |
1 files changed, 16 insertions, 0 deletions
diff --git a/src/class.c b/src/class.c index 2af140b30..d46862baf 100644 --- a/src/class.c +++ b/src/class.c @@ -363,6 +363,22 @@ mrb_define_method_vm(mrb_state *mrb, struct RClass *c, mrb_sym name, mrb_value b } } +MRB_API mrb_value +mrb_notimplement(mrb_state *mrb, mrb_value self) +{ + const char *str; + mrb_int len; + mrb_callinfo *ci = mrb->c->ci; + + if (ci->mid) { + str = mrb_sym2name_len(mrb, ci->mid, &len); + mrb_raisef(mrb, E_NOTIMP_ERROR, + "%S() function is unimplemented on this machine not implemented", + mrb_str_new_static(mrb, str, (size_t)len)); + } + return mrb_nil_value(); +} + static mrb_value check_type(mrb_state *mrb, mrb_value val, enum mrb_vtype t, const char *c, const char *m) { |
