diff options
author | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2002-09-25 07:07:43 +0000 |
---|---|---|
committer | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2002-09-25 07:07:43 +0000 |
commit | f33958990a43b8a20ad7ed7eb1d30ec211b46f85 (patch) | |
tree | f962530dd96d7c293cba9d8f4bd6318d688c33f2 /object.c | |
parent | d65fac5daa6838c9c56c6b6dd2f3127fe229d4e8 (diff) |
* eval.c (ruby_run): should set toplevel visibility again here.
* eval.c (rb_eval): should not rely on ruby_class == rb_cObject
check. Besides allow implicit publicity for attribute set
methods.
* parse.y (primary): need not to check class_nest, just set
whether method is an attrset or not.
* string.c (rb_str_each_line): p might be at the top of the
string.
* variable.c (rb_path2class): should not use rb_eval_string().
* parse.y (str_extend): expression substitution can contain string
terminator again.
* parse.y (yylex): the warning message "invalid
character syntax" was never issued.
* file.c (rb_find_file): $LOAD_PATH must not be empty.
* file.c (rb_find_file_ext): ditto.
* range.c (range_eq): class check should be based on range.class,
instead of Range to work with Range.dup.
* range.c (range_eql): ditto.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_6@2888 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'object.c')
-rw-r--r-- | object.c | 4 |
1 files changed, 2 insertions, 2 deletions
@@ -114,8 +114,8 @@ rb_obj_dup(obj) VALUE dup; dup = rb_funcall(obj, clone, 0, 0); - if (TYPE(dup) != TYPE(obj)) { - rb_raise(rb_eTypeError, "dupulicated object must be same type"); + if (TYPE(dup) != TYPE(obj) || rb_obj_class(dup) != rb_obj_class(obj)) { + rb_raise(rb_eTypeError, "dupulicated object must be same class"); } if (!SPECIAL_CONST_P(dup)) { OBJSETUP(dup, rb_obj_class(obj), BUILTIN_TYPE(obj)); |