diff options
| -rw-r--r-- | activesupport/lib/active_support/inflector/methods.rb | 19 | ||||
| -rw-r--r-- | activesupport/test/constantize_test_cases.rb | 2 | 
2 files changed, 14 insertions, 7 deletions
| diff --git a/activesupport/lib/active_support/inflector/methods.rb b/activesupport/lib/active_support/inflector/methods.rb index 11f3c4c46f..e5b0cf4f9e 100644 --- a/activesupport/lib/active_support/inflector/methods.rb +++ b/activesupport/lib/active_support/inflector/methods.rb @@ -198,21 +198,26 @@ module ActiveSupport      #      # NameError is raised when the name is not in CamelCase or the constant is      # unknown. -    def constantize(camel_cased_word) #:nodoc: +    def constantize(camel_cased_word)        names = camel_cased_word.split('::')        names.shift if names.empty? || names.first.empty?        names.inject(Object) do |constant, name| -        candidate = constant.const_get(name) -        if constant.const_defined?(name, false) || constant == Object || !Object.const_defined?(name) -          candidate +        if constant == Object +          constant.const_get(name)          else +          candidate = constant.const_get(name) +          next candidate if constant.const_defined?(name, false) +          next candidate unless Object.const_defined?(name) +            # Go down the ancestors to check it it's owned            # directly before we reach Object or the end of ancestors. -          constant.ancestors.each do |ancestor| -            break if ancestor == Object -            return candidate if ancestor.const_defined?(name, false) +          constant = constant.ancestors.inject do |constant, ancestor| +            break constant if ancestor == Object +            break ancestor if ancestor.const_defined?(name, false) +            constant            end +            # owner is in Object, so raise            constant.const_get(name, false)          end diff --git a/activesupport/test/constantize_test_cases.rb b/activesupport/test/constantize_test_cases.rb index 470213e9bd..ec05213409 100644 --- a/activesupport/test/constantize_test_cases.rb +++ b/activesupport/test/constantize_test_cases.rb @@ -29,6 +29,7 @@ module ConstantizeTestCases      assert_nothing_raised { assert_equal Ace::Base::Case::Dice, yield("Ace::Base::Case::Dice") }      assert_nothing_raised { assert_equal Ace::Base::Fase::Dice, yield("Ace::Base::Fase::Dice") }      assert_nothing_raised { assert_equal Ace::Gas::Case, yield("Ace::Gas::Case") } +    assert_nothing_raised { assert_equal Ace::Gas::Case::Dice, yield("Ace::Gas::Case::Dice") }      assert_nothing_raised { assert_equal Case::Dice, yield("Case::Dice") }      assert_nothing_raised { assert_equal Case::Dice, yield("Object::Case::Dice") }      assert_nothing_raised { assert_equal ConstantizeTestCases, yield("ConstantizeTestCases") } @@ -52,6 +53,7 @@ module ConstantizeTestCases      assert_nothing_raised { assert_equal Ace::Base::Case::Dice, yield("Ace::Base::Case::Dice") }      assert_nothing_raised { assert_equal Ace::Base::Fase::Dice, yield("Ace::Base::Fase::Dice") }      assert_nothing_raised { assert_equal Ace::Gas::Case, yield("Ace::Gas::Case") } +    assert_nothing_raised { assert_equal Ace::Gas::Case::Dice, yield("Ace::Gas::Case::Dice") }      assert_nothing_raised { assert_equal Case::Dice, yield("Case::Dice") }      assert_nothing_raised { assert_equal Case::Dice, yield("Object::Case::Dice") }      assert_nothing_raised { assert_equal ConstantizeTestCases, yield("ConstantizeTestCases") } | 
