diff options
author | Andrew White <andyw@pixeltrix.co.uk> | 2012-05-19 15:44:19 +0100 |
---|---|---|
committer | Andrew White <andyw@pixeltrix.co.uk> | 2012-05-19 15:47:35 +0100 |
commit | 3d0e4895cdc82bee9fb6ccc1208baa93fc5101ef (patch) | |
tree | 4a4ebb849e59f3f4cac2e417248e4ac43051a38b /activesupport | |
parent | eb09411460d11c7b1b1b54272ba345a1e1cf472d (diff) | |
download | rails-3d0e4895cdc82bee9fb6ccc1208baa93fc5101ef.tar.gz rails-3d0e4895cdc82bee9fb6ccc1208baa93fc5101ef.tar.bz2 rails-3d0e4895cdc82bee9fb6ccc1208baa93fc5101ef.zip |
Handle case where ancestor is not the end of the chain
Diffstat (limited to 'activesupport')
-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") } |