Sha256: 9d5f875a653f5fe9fed296158540bbd0bcb50c0222c014ddae8125e5586441ec
Contents?: true
Size: 790 Bytes
Versions: 270
Compression:
Stored size: 790 Bytes
Contents
# encoding: utf-8 if RUBY_VERSION >= '1.9' require 'uri' str = "\xE6\x97\xA5\xE6\x9C\xAC\xE8\xAA\x9E" # Ni-ho-nn-go in UTF-8, means Japanese. parser = URI::Parser.new unless str == parser.unescape(parser.escape(str)) URI::Parser.class_eval do remove_method :unescape def unescape(str, escaped = /%[a-fA-F\d]{2}/) # TODO: Are we actually sure that ASCII == UTF-8? # YK: My initial experiments say yes, but let's be sure please enc = str.encoding enc = Encoding::UTF_8 if enc == Encoding::US_ASCII str.gsub(escaped) { [$&[1, 2].hex].pack('C') }.force_encoding(enc) end end end end module URI class << self def parser @parser ||= URI.const_defined?(:Parser) ? URI::Parser.new : URI end end end
Version data entries
270 entries across 226 versions & 25 rubygems