summaryrefslogtreecommitdiffhomepage
path: root/src/class.c
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2014-11-17 17:55:23 +0900
committerYukihiro "Matz" Matsumoto <[email protected]>2014-11-17 17:55:23 +0900
commit9980bc20bb9a2149c975dd25b4eb2cab664f99d0 (patch)
tree4e459e553b371456ada48988a2b9e71ca07578dd /src/class.c
parent70c98667512b9301e577aafc912a35208ad471c9 (diff)
parent9a06cfa9d8511377523072c823b1c269d092cb25 (diff)
downloadmruby-9980bc20bb9a2149c975dd25b4eb2cab664f99d0.tar.gz
mruby-9980bc20bb9a2149c975dd25b4eb2cab664f99d0.zip
Merge pull request #2636 from ksss/mrb_notimplement
Implement C API mrb_notimplement
Diffstat (limited to 'src/class.c')
-rw-r--r--src/class.c16
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)
{