diff options
author | James Le Cuirot <james.le-cuirot@yakara.com> | 2014-10-03 22:45:40 +0100 |
---|---|---|
committer | James Le Cuirot <chewi@aura-online.co.uk> | 2014-10-03 22:45:40 +0100 |
commit | 6a8464fa4f50a0fce3ce245f717b813712ea27a8 (patch) | |
tree | 2a68543951d7785aba163a6a728b5321e4c2c178 /activesupport/lib/active_support/inflector | |
parent | 1609ec9879d0011f31f0ae90cf3b2bc8b1833390 (diff) | |
download | rails-6a8464fa4f50a0fce3ce245f717b813712ea27a8.tar.gz rails-6a8464fa4f50a0fce3ce245f717b813712ea27a8.tar.bz2 rails-6a8464fa4f50a0fce3ce245f717b813712ea27a8.zip |
Fix underscore inflector handling of adjacent acronyms
I suspect that positive lookbehind would have been used in the
original implementation had it been available in supported Ruby
versions at the time. Now that Rails requires Ruby 1.9.2 or above,
this is no longer an issue.
This fixes #14146 for acronyms such as APIRESTful. This technique also
addresses namespaced acronyms that are not entirely uppercased. This
was broken when the commit was originally written but has since been
fixed in ccbb481. The latter does not deal with adjacent acronyms so
this commit wins.
Diffstat (limited to 'activesupport/lib/active_support/inflector')
-rw-r--r-- | activesupport/lib/active_support/inflector/methods.rb | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/activesupport/lib/active_support/inflector/methods.rb b/activesupport/lib/active_support/inflector/methods.rb index f35e71ce81..72da0dd189 100644 --- a/activesupport/lib/active_support/inflector/methods.rb +++ b/activesupport/lib/active_support/inflector/methods.rb @@ -91,7 +91,7 @@ module ActiveSupport def underscore(camel_cased_word) return camel_cased_word unless camel_cased_word =~ /[A-Z-]|::/ word = camel_cased_word.to_s.gsub('::', '/') - word.gsub!(/(?:([A-Za-z\d])|\b)(#{inflections.acronym_regex})(?=\b|[^a-z])/) { "#{$1}#{$1 && '_'}#{$2.downcase}" } + word.gsub!(/(?<=[A-Za-z\d\/]|^)(#{inflections.acronym_regex})(?=\b|[^a-z])/) { "#{'_' unless $`.empty? or $`[-1] == '/'}#{$1.downcase}" } word.gsub!(/([A-Z\d]+)([A-Z][a-z])/,'\1_\2') word.gsub!(/([a-z\d])([A-Z])/,'\1_\2') word.tr!("-", "_") |