summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorYukihiro Matz Matsumoto <[email protected]>2013-02-15 10:20:55 +0900
committerYukihiro Matz Matsumoto <[email protected]>2013-02-15 10:20:55 +0900
commit37fe3d666f12f4dbd0e2fc1688d83ece94667f4e (patch)
tree695e54e43f56162d9dc6d49016dcfc0f78b5dd93
parent8578cd622ba6644a0421bcb35e44e0f7b2927a54 (diff)
downloadmruby-37fe3d666f12f4dbd0e2fc1688d83ece94667f4e.tar.gz
mruby-37fe3d666f12f4dbd0e2fc1688d83ece94667f4e.zip
add Module#remove_const
-rw-r--r--include/mruby/variable.h1
-rw-r--r--src/class.c15
-rw-r--r--src/variable.c9
3 files changed, 24 insertions, 1 deletions
diff --git a/include/mruby/variable.h b/include/mruby/variable.h
index f2f22e65a..a1f52217d 100644
--- a/include/mruby/variable.h
+++ b/include/mruby/variable.h
@@ -37,6 +37,7 @@ void mrb_vm_const_set(mrb_state*, mrb_sym, mrb_value);
mrb_value mrb_const_get(mrb_state*, mrb_value, mrb_sym);
void mrb_const_set(mrb_state*, mrb_value, mrb_sym, mrb_value);
int mrb_const_defined(mrb_state*, mrb_value, mrb_sym);
+void mrb_const_remove(mrb_state*, mrb_value, mrb_sym);
mrb_value mrb_obj_iv_get(mrb_state *mrb, struct RObject *obj, mrb_sym sym);
void mrb_obj_iv_set(mrb_state *mrb, struct RObject *obj, mrb_sym sym, mrb_value v);
diff --git a/src/class.c b/src/class.c
index 136a07cb6..e2ee288f4 100644
--- a/src/class.c
+++ b/src/class.c
@@ -1748,6 +1748,20 @@ mrb_mod_const_set(mrb_state *mrb, mrb_value mod)
return value;
}
+mrb_value
+mrb_mod_remove_const(mrb_state *mrb, mrb_value mod)
+{
+ mrb_sym sym;
+ mrb_value val;
+
+ mrb_get_args(mrb, "n", &sym);
+ check_const_name(mrb, sym);
+ val = mrb_iv_remove(mrb, mod, sym);
+ if (mrb_undef_p(val)) {
+ mrb_name_error(mrb, sym, "instance variable %s not defined", mrb_sym2name(mrb, sym));
+ }
+ return val;
+}
static mrb_value
mrb_mod_eqq(mrb_state *mrb, mrb_value mod)
@@ -1828,6 +1842,7 @@ mrb_init_class(mrb_state *mrb)
mrb_define_method(mrb, mod, "const_defined?", mrb_mod_const_defined, ARGS_REQ(1)); /* 15.2.2.4.20 */
mrb_define_method(mrb, mod, "const_get", mrb_mod_const_get, ARGS_REQ(1)); /* 15.2.2.4.21 */
mrb_define_method(mrb, mod, "const_set", mrb_mod_const_set, ARGS_REQ(2)); /* 15.2.2.4.23 */
+ mrb_define_method(mrb, mod, "remove_const", mrb_mod_remove_const, ARGS_REQ(1)); /* 15.2.2.4.40 */
mrb_define_method(mrb, mod, "define_method", mod_define_method, ARGS_REQ(1));
mrb_define_method(mrb, mod, "class_variables", mrb_mod_class_variables, ARGS_NONE()); /* 15.2.2.4.19 */
diff --git a/src/variable.c b/src/variable.c
index 6aa6e71bd..a5ff36f6f 100644
--- a/src/variable.c
+++ b/src/variable.c
@@ -889,7 +889,7 @@ mrb_const_set(mrb_state *mrb, mrb_value mod, mrb_sym sym, mrb_value v)
mrb_iv_set(mrb, mod, sym, v);
}
-void
+ void
mrb_vm_const_set(mrb_state *mrb, mrb_sym sym, mrb_value v)
{
struct RClass *c = mrb->ci->proc->target_class;
@@ -899,6 +899,13 @@ mrb_vm_const_set(mrb_state *mrb, mrb_sym sym, mrb_value v)
}
void
+mrb_const_remove(mrb_state *mrb, mrb_value mod, mrb_sym sym)
+{
+ mod_const_check(mrb, mod);
+ mrb_iv_remove(mrb, mod, sym);
+}
+
+void
mrb_define_const(mrb_state *mrb, struct RClass *mod, const char *name, mrb_value v)
{
mrb_obj_iv_set(mrb, (struct RObject*)mod, mrb_intern(mrb, name), v);