diff options
author | Michael Koziarski <michael@koziarski.com> | 2007-08-05 00:51:16 +0000 |
---|---|---|
committer | Michael Koziarski <michael@koziarski.com> | 2007-08-05 00:51:16 +0000 |
commit | 73f72eeec2d0cc689735f52de4a5c3c80c4c1e85 (patch) | |
tree | 1a996f0bd7b8b022116beb722096fef40dd7b237 | |
parent | fe3e03e7708c576d5b09fb161e68d715796eae67 (diff) | |
download | rails-73f72eeec2d0cc689735f52de4a5c3c80c4c1e85.tar.gz rails-73f72eeec2d0cc689735f52de4a5c3c80c4c1e85.tar.bz2 rails-73f72eeec2d0cc689735f52de4a5c3c80c4c1e85.zip |
Make the utf-handler return the correct value for non-matching regular expressions. Closes #9049 [manfred]
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@7273 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
-rw-r--r-- | activesupport/CHANGELOG | 2 | ||||
-rw-r--r-- | activesupport/lib/active_support/multibyte/handlers/utf8_handler.rb | 2 | ||||
-rw-r--r-- | activesupport/test/multibyte_chars_test.rb | 4 |
3 files changed, 6 insertions, 2 deletions
diff --git a/activesupport/CHANGELOG b/activesupport/CHANGELOG index d00be783e1..6366a11237 100644 --- a/activesupport/CHANGELOG +++ b/activesupport/CHANGELOG @@ -1,5 +1,7 @@ *SVN* +* Make the utf-handler return the correct value for non-matching regular expressions. Closes #9049 [manfred] + * Add ljust, rjust and center to utf8-handler. Closes #9165 [manfred] * Fix Time#advance bug when trying to advance a year from leap day. Closes #8655 [gbuesing] diff --git a/activesupport/lib/active_support/multibyte/handlers/utf8_handler.rb b/activesupport/lib/active_support/multibyte/handlers/utf8_handler.rb index 6ca043ae21..e4ef98f1b6 100644 --- a/activesupport/lib/active_support/multibyte/handlers/utf8_handler.rb +++ b/activesupport/lib/active_support/multibyte/handlers/utf8_handler.rb @@ -316,8 +316,8 @@ module ActiveSupport::Multibyte::Handlers #:nodoc: # Used to translate an offset from bytes to characters, for instance one received from a regular expression match def translate_offset(str, byte_offset) - return 0 if str == '' return nil if byte_offset.nil? + return 0 if str == '' chunk = str[0..byte_offset] begin begin diff --git a/activesupport/test/multibyte_chars_test.rb b/activesupport/test/multibyte_chars_test.rb index d8766af3b8..6e87ea8851 100644 --- a/activesupport/test/multibyte_chars_test.rb +++ b/activesupport/test/multibyte_chars_test.rb @@ -81,6 +81,8 @@ class CharsTest < Test::Unit::TestCase with_kcode('UTF8') do assert_equal 9, (@s[:utf8].chars =~ /ffi/), "Regex matching should be unicode aware" + assert_nil((''.chars =~ /\d+/), + "Non-matching regular expressions should return nil") end end @@ -118,7 +120,7 @@ class CharsTest < Test::Unit::TestCase def test_passthrough_on_kcode # The easiest way to check if the passthrough is in place is through #size - with_kcode('nonce') do + with_kcode('none') do assert_equal 26, @s[:utf8].chars.size end with_kcode('UTF8') do |