diff options
author | James MacAulay <james@jadedpixel.com> | 2010-05-18 15:19:53 -0400 |
---|---|---|
committer | José Valim <jose.valim@gmail.com> | 2010-06-30 13:22:28 +0200 |
commit | 16cef77d37ffe3e2cdc6f7db76b4ae59ce4cbc5b (patch) | |
tree | fb07349ae7acfc86a924dbdd8efe351b58bc75d0 /activesupport | |
parent | 13a36902718d452b31d13f2f7aba5770e51844a9 (diff) | |
download | rails-16cef77d37ffe3e2cdc6f7db76b4ae59ce4cbc5b.tar.gz rails-16cef77d37ffe3e2cdc6f7db76b4ae59ce4cbc5b.tar.bz2 rails-16cef77d37ffe3e2cdc6f7db76b4ae59ce4cbc5b.zip |
Fix AS::MB::Chars#+ to not alter self [#4646 state:resolved]
Signed-off-by: José Valim <jose.valim@gmail.com>
Diffstat (limited to 'activesupport')
-rw-r--r-- | activesupport/lib/active_support/multibyte/chars.rb | 2 | ||||
-rw-r--r-- | activesupport/test/multibyte_chars_test.rb | 16 |
2 files changed, 10 insertions, 8 deletions
diff --git a/activesupport/lib/active_support/multibyte/chars.rb b/activesupport/lib/active_support/multibyte/chars.rb index c107aad6bb..1134d1ccc6 100644 --- a/activesupport/lib/active_support/multibyte/chars.rb +++ b/activesupport/lib/active_support/multibyte/chars.rb @@ -105,7 +105,7 @@ module ActiveSupport #:nodoc: # Example: # ('Café'.mb_chars + ' périferôl').to_s #=> "Café périferôl" def +(other) - self << other + chars(@wrapped_string + other) end # Like <tt>String#=~</tt> only it returns the character offset (in codepoints) instead of the byte offset. diff --git a/activesupport/test/multibyte_chars_test.rb b/activesupport/test/multibyte_chars_test.rb index 602828ef5f..66aa22ec20 100644 --- a/activesupport/test/multibyte_chars_test.rb +++ b/activesupport/test/multibyte_chars_test.rb @@ -49,13 +49,15 @@ class MultibyteCharsTest < Test::Unit::TestCase end def test_should_concatenate - assert_equal 'ab', 'a'.mb_chars + 'b' - assert_equal 'ab', 'a' + 'b'.mb_chars - assert_equal 'ab', 'a'.mb_chars + 'b'.mb_chars - - assert_equal 'ab', 'a'.mb_chars << 'b' - assert_equal 'ab', 'a' << 'b'.mb_chars - assert_equal 'ab', 'a'.mb_chars << 'b'.mb_chars + mb_a = 'a'.mb_chars + mb_b = 'b'.mb_chars + assert_equal 'ab', mb_a + 'b' + assert_equal 'ab', 'a' + mb_b + assert_equal 'ab', mb_a + mb_b + + assert_equal 'ab', mb_a << 'b' + assert_equal 'ab', 'a' << mb_b + assert_equal 'abb', mb_a << mb_b end def test_consumes_utf8_strings |