summaryrefslogtreecommitdiffhomepage
path: root/src
diff options
context:
space:
mode:
authorskandhas <[email protected]>2012-12-21 16:17:13 +0800
committerskandhas <[email protected]>2012-12-21 16:17:13 +0800
commitf612f32aef65e5c1f16ebf50fcf9221309251d25 (patch)
tree4b0c7f1badda57591a6b68ff04ea419b519dcfa2 /src
parentd06512b093ebbbedb9affad263f4fd2e369166d0 (diff)
downloadmruby-f612f32aef65e5c1f16ebf50fcf9221309251d25.tar.gz
mruby-f612f32aef65e5c1f16ebf50fcf9221309251d25.zip
fix mrb_mod_cv_set and add test for Module#class_variable_set
Diffstat (limited to 'src')
-rw-r--r--src/variable.c8
1 files changed, 5 insertions, 3 deletions
diff --git a/src/variable.c b/src/variable.c
index 57a193109..7743c6309 100644
--- a/src/variable.c
+++ b/src/variable.c
@@ -698,6 +698,8 @@ mrb_cv_get(mrb_state *mrb, mrb_value mod, mrb_sym sym)
void
mrb_mod_cv_set(mrb_state *mrb, struct RClass * c, mrb_sym sym, mrb_value v)
{
+ struct RClass * cls = c;
+
while (c) {
if (c->iv) {
iv_tbl *t = c->iv;
@@ -710,11 +712,11 @@ mrb_mod_cv_set(mrb_state *mrb, struct RClass * c, mrb_sym sym, mrb_value v)
c = c->super;
}
- if (!c->iv) {
- c->iv = iv_new(mrb);
+ if (!cls->iv) {
+ cls->iv = iv_new(mrb);
}
- iv_put(mrb, c->iv, sym, v);
+ iv_put(mrb, cls->iv, sym, v);
}
void