summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorDaniel Bovensiepen <[email protected]>2012-06-03 23:29:40 +0800
committerDaniel Bovensiepen <[email protected]>2012-06-03 23:29:40 +0800
commit5612d195ec39612b7216ff3f28d05ed089452767 (patch)
treebb851692e730eb32af3b1de2551e3e50e4c84caa
parent7009a1d8f5271fcd0b06a86645ad28e40c2bc5d9 (diff)
downloadmruby-5612d195ec39612b7216ff3f28d05ed089452767.tar.gz
mruby-5612d195ec39612b7216ff3f28d05ed089452767.zip
Improve Class#superclass to ISO
-rw-r--r--src/class.c12
-rw-r--r--test/t/class.rb10
2 files changed, 16 insertions, 6 deletions
diff --git a/src/class.c b/src/class.c
index c689552f5..594ed08bc 100644
--- a/src/class.c
+++ b/src/class.c
@@ -822,10 +822,16 @@ mrb_class_new_class(mrb_state *mrb, mrb_value cv)
mrb_value
mrb_class_superclass(mrb_state *mrb, mrb_value klass)
{
- struct RClass *c, *s;
+ struct RClass *c;
+ mrb_value superclass;
+
c = mrb_class_ptr(klass);
- s = mrb_class_real(c->super);
- return mrb_obj_value(s);
+ if (c->super)
+ superclass = mrb_obj_value(mrb_class_real(c->super));
+ else
+ superclass = mrb_nil_value();
+
+ return superclass;
}
static mrb_value
diff --git a/test/t/class.rb b/test/t/class.rb
index d252cf590..1b809a832 100644
--- a/test/t/class.rb
+++ b/test/t/class.rb
@@ -5,9 +5,8 @@ assert('Class', '15.2.3') do
Class.class == Class
end
-assert('Class#superclass', '15.2.3.3.4') do
- class SubClass < String; end
- SubClass.superclass == String
+assert('Class superclass', '15.2.3.2') do
+ Class.superclass == Module
end
assert('Class#new', '15.2.3.3.3') do
@@ -40,6 +39,11 @@ assert('Class#new', '15.2.3.3.3') do
# with block doesn't work yet
end
+assert('Class#superclass', '15.2.3.3.4') do
+ class SubClass < String; end
+ SubClass.superclass == String
+end
+
# Not ISO specified
assert('Class 1') do