diff options
author | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2009-10-23 23:37:14 +0000 |
---|---|---|
committer | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2009-10-23 23:37:14 +0000 |
commit | 4bb1f865fcfb5f6dda9fde30646e7a246f36361c (patch) | |
tree | b9be1d6ebb2bc3bdea7d47796b6af13b84235801 /class.c | |
parent | 9d919ae7bf4279b0ad25ff9622ff929849a3d3ba (diff) | |
download | ruby-4bb1f865fcfb5f6dda9fde30646e7a246f36361c.tar.gz ruby-4bb1f865fcfb5f6dda9fde30646e7a246f36361c.tar.xz ruby-4bb1f865fcfb5f6dda9fde30646e7a246f36361c.zip |
* class.c (rb_class_new): move class check to rb_check_inheritable().
* class.c (rb_check_inheritable): should not allow subclass of
class Class. [ruby-core:26225]
git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@25449 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'class.c')
-rw-r--r-- | class.c | 6 |
1 files changed, 3 insertions, 3 deletions
@@ -97,6 +97,9 @@ rb_check_inheritable(VALUE super) if (RBASIC(super)->flags & FL_SINGLETON) { rb_raise(rb_eTypeError, "can't make subclass of singleton class"); } + if (super == rb_cClass) { + rb_raise(rb_eTypeError, "can't make subclass of Class"); + } } @@ -111,9 +114,6 @@ rb_class_new(VALUE super) { Check_Type(super, T_CLASS); rb_check_inheritable(super); - if (super == rb_cClass) { - rb_raise(rb_eTypeError, "can't make subclass of Class"); - } return rb_class_boot(super); } |