mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
* variable.c (rb_const_defined_0): look up constants in Object as
well. [ruby-dev:21458] * test/ruby/test_defined.rb (TestDefined::test_defined): test for constants. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@4649 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
18ef8f1078
commit
83740fa4bd
3 changed files with 20 additions and 7 deletions
|
@ -1,3 +1,11 @@
|
|||
Thu Oct 2 12:00:18 2003 Nobuyoshi Nakada <nobu@ruby-lang.org>
|
||||
|
||||
* variable.c (rb_const_defined_0): look up constants in Object as
|
||||
well. [ruby-dev:21458]
|
||||
|
||||
* test/ruby/test_defined.rb (TestDefined::test_defined): test for
|
||||
constants.
|
||||
|
||||
Thu Oct 2 11:17:00 2003 Nathaniel Talbott <ntalbott@ruby-lang.org>
|
||||
|
||||
* lib/test/unit/assertions.rb: should not capture an
|
||||
|
|
|
@ -24,10 +24,13 @@ class TestDefined < Test::Unit::TestCase
|
|||
assert(defined?($x)) # global variable
|
||||
assert_equal('global-variable', defined?($x))# returns description
|
||||
|
||||
assert_nil(defined?(foo)) # undefined
|
||||
foo=5
|
||||
assert(defined?(foo)) # local variable
|
||||
|
||||
assert(defined?(::Array)) # constant !! Array -> ::Array
|
||||
assert(defined?(Array)) # constant
|
||||
assert(defined?(::Array)) # toplevel constant
|
||||
assert(defined?(File::Constants)) # nested constant
|
||||
assert(defined?(Object.new)) # method
|
||||
assert(!defined?(Object.print)) # private method
|
||||
assert(defined?(1 == 2)) # operator expression
|
||||
|
|
14
variable.c
14
variable.c
|
@ -1430,12 +1430,12 @@ rb_const_defined_0(klass, id, exclude, recurse)
|
|||
ID id;
|
||||
int exclude, recurse;
|
||||
{
|
||||
VALUE tmp = klass, value;
|
||||
VALUE value, tmp;
|
||||
int mod_retry = 0;
|
||||
|
||||
tmp = klass;
|
||||
retry:
|
||||
while (tmp) {
|
||||
if (tmp == rb_cObject && klass != rb_cObject) {
|
||||
break;
|
||||
}
|
||||
if (RCLASS(tmp)->iv_tbl && st_lookup(RCLASS(tmp)->iv_tbl, id, &value)) {
|
||||
if (value == Qundef && NIL_P(autoload_file(klass, id)))
|
||||
return Qfalse;
|
||||
|
@ -1444,8 +1444,10 @@ rb_const_defined_0(klass, id, exclude, recurse)
|
|||
if (!recurse && klass != rb_cObject) break;
|
||||
tmp = RCLASS(tmp)->super;
|
||||
}
|
||||
if (!exclude && BUILTIN_TYPE(klass) == T_MODULE) {
|
||||
return rb_const_defined(rb_cObject, id);
|
||||
if (!exclude && !mod_retry && BUILTIN_TYPE(klass) == T_MODULE) {
|
||||
mod_retry = 1;
|
||||
tmp = rb_cObject;
|
||||
goto retry;
|
||||
}
|
||||
return Qfalse;
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue