summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorKouhei Sutou <[email protected]>2016-01-11 00:34:15 +0900
committerKouhei Sutou <[email protected]>2016-01-11 00:34:15 +0900
commitad492eb9f3f217f60fd539bc23cce10ad40a36d1 (patch)
tree5c690b2cf222ec558519ab0df93131e8188579f4
parente132de9e8eaf095f6f8b826e34a1c145403c3311 (diff)
downloadmruby-ad492eb9f3f217f60fd539bc23cce10ad40a36d1.tar.gz
mruby-ad492eb9f3f217f60fd539bc23cce10ad40a36d1.zip
Fix class variable reference in module
Fix #3079
-rw-r--r--src/variable.c2
-rw-r--r--test/t/class.rb13
2 files changed, 14 insertions, 1 deletions
diff --git a/src/variable.c b/src/variable.c
index bda7b2a98..3b5674923 100644
--- a/src/variable.c
+++ b/src/variable.c
@@ -773,7 +773,7 @@ mrb_mod_cv_get(mrb_state *mrb, struct RClass * c, mrb_sym sym)
klass = mrb_obj_iv_get(mrb, (struct RObject *)cls,
mrb_intern_lit(mrb, "__attached__"));
c = mrb_class_ptr(klass);
- if (c->tt == MRB_TT_CLASS) {
+ if (c->tt == MRB_TT_CLASS || c->tt == MRB_TT_MODULE) {
while (c) {
if (c->iv && iv_get(mrb, c->iv, sym, &v)) {
return v;
diff --git a/test/t/class.rb b/test/t/class.rb
index 720fd37fa..7bcaaf90d 100644
--- a/test/t/class.rb
+++ b/test/t/class.rb
@@ -384,6 +384,19 @@ assert('class variable and class << self style class method') do
assert_equal("value", ClassVariableTest.class_variable)
end
+assert('class variable in module and class << self style class method') do
+ module ClassVariableInModuleTest
+ @@class_variable = "value"
+ class << self
+ def class_variable
+ @@class_variable
+ end
+ end
+ end
+
+ assert_equal("value", ClassVariableInModuleTest.class_variable)
+end
+
assert('class with non-class/module outer raises TypeError') do
assert_raise(TypeError) { class 0::C1; end }
assert_raise(TypeError) { class []::C2; end }