Ruby 1.9.1p0's URI.decode() bug fix

backport to fix Ruby 1.9.1p0 bug on [ruby-dev:38005].

Signed-off-by: Jeremy Kemper <jeremy@bitsweat.net>
This commit is contained in:
moro
2009-02-15 19:34:04 +09:00
committed by Jeremy Kemper
parent 8c5cc66a83
commit 3b3dbd7973
2 changed files with 24 additions and 0 deletions

View File

@@ -0,0 +1,13 @@
require 'uri'
module ActiveSupport
if RUBY_VERSION == "1.9.1" && defined?(RUBY_PATCHLEVEL) && RUBY_PATCHLEVEL == 0
::URI::Parser.class_eval do
def unescape(str, escaped = @regexp[:ESCAPED])
enc = (str.encoding == Encoding::US_ASCII) ? Encoding::UTF_8 : str.encoding
str.gsub(escaped) { [$&[1, 2].hex].pack('C') }.force_encoding(enc)
end
end
end
end

View File

@@ -0,0 +1,11 @@
require 'abstract_unit'
class URITest < Test::Unit::TestCase
def test_uri_decode_handle_multibyte
str = "\xE6\x97\xA5\xE6\x9C\xAC\xE8\xAA\x9E" # Ni-ho-nn-go in UTF-8, means Japanese.
str.force_encoding(Encoding::UTF_8) if(defined? Encoding::UTF_8)
assert_equal str, ::URI.unescape( ::URI.escape(str) )
assert_equal str, ::URI.decode( ::URI.escape(str) )
end
end