* lib/rexml/encoding.rb (encoding=): give priority to particular
conversion to iconv. [ruby-core:06520] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@9661 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
c7143d7779
commit
2eac4d0fb4
@ -1,3 +1,8 @@
|
|||||||
|
Fri Dec 9 23:31:02 2005 Nobuyoshi Nakada <nobu@ruby-lang.org>
|
||||||
|
|
||||||
|
* lib/rexml/encoding.rb (encoding=): give priority to particular
|
||||||
|
conversion to iconv. [ruby-core:06520]
|
||||||
|
|
||||||
Fri Dec 9 23:16:51 2005 Nobuyoshi Nakada <nobu@ruby-lang.org>
|
Fri Dec 9 23:16:51 2005 Nobuyoshi Nakada <nobu@ruby-lang.org>
|
||||||
|
|
||||||
* range.c (range_include): return false unless included in numeric
|
* range.c (range_include): return false unless included in numeric
|
||||||
|
@ -25,28 +25,22 @@ module REXML
|
|||||||
begin
|
begin
|
||||||
$VERBOSE = false
|
$VERBOSE = false
|
||||||
return if defined? @encoding and enc == @encoding
|
return if defined? @encoding and enc == @encoding
|
||||||
if enc and enc != UTF_8
|
if enc
|
||||||
@encoding = enc.upcase
|
raise ArgumentError, "Bad encoding name #{enc}" unless /\A[\w-]+\z/n =~ enc
|
||||||
begin
|
@encoding = enc.upcase.untaint
|
||||||
require 'rexml/encodings/ICONV.rb'
|
|
||||||
Encoding.apply(self, "ICONV")
|
|
||||||
rescue LoadError, Exception => err
|
|
||||||
raise ArgumentError, "Bad encoding name #@encoding" unless @encoding =~ /^[\w-]+$/
|
|
||||||
@encoding.untaint
|
|
||||||
enc_file = File.join( "rexml", "encodings", "#@encoding.rb" )
|
|
||||||
begin
|
|
||||||
require enc_file
|
|
||||||
Encoding.apply(self, @encoding)
|
|
||||||
rescue LoadError
|
|
||||||
puts $!.message
|
|
||||||
raise ArgumentError, "No decoder found for encoding #@encoding. Please install iconv."
|
|
||||||
end
|
|
||||||
end
|
|
||||||
else
|
else
|
||||||
@encoding = UTF_8
|
@encoding = UTF_8
|
||||||
require 'rexml/encodings/UTF-8.rb'
|
|
||||||
Encoding.apply(self, @encoding)
|
|
||||||
end
|
end
|
||||||
|
err = nil
|
||||||
|
[@encoding, "ICONV"].each do |enc|
|
||||||
|
begin
|
||||||
|
require File.join("rexml", "encodings", "#{enc}.rb")
|
||||||
|
return Encoding.apply(self, enc)
|
||||||
|
rescue LoadError, Exception => err
|
||||||
|
end
|
||||||
|
end
|
||||||
|
puts err.message
|
||||||
|
raise ArgumentError, "No decoder found for encoding #@encoding. Please install iconv."
|
||||||
ensure
|
ensure
|
||||||
$VERBOSE = old_verbosity
|
$VERBOSE = old_verbosity
|
||||||
end
|
end
|
||||||
|
@ -1,13 +1,28 @@
|
|||||||
require 'uconv'
|
|
||||||
|
|
||||||
module REXML
|
module REXML
|
||||||
module Encoding
|
module Encoding
|
||||||
def decode_eucjp(str)
|
begin
|
||||||
Uconv::euctou8(str)
|
require 'uconv'
|
||||||
end
|
|
||||||
|
|
||||||
def encode_eucjp content
|
def decode_eucjp(str)
|
||||||
Uconv::u8toeuc(content)
|
Uconv::euctou8(str)
|
||||||
|
end
|
||||||
|
|
||||||
|
def encode_eucjp content
|
||||||
|
Uconv::u8toeuc(content)
|
||||||
|
end
|
||||||
|
rescue LoadError
|
||||||
|
require 'nkf'
|
||||||
|
|
||||||
|
EUCTOU8 = '-Ewm0'
|
||||||
|
U8TOEUC = '-Wem0'
|
||||||
|
|
||||||
|
def decode_eucjp(str)
|
||||||
|
NKF.nkf(EUCTOU8, str)
|
||||||
|
end
|
||||||
|
|
||||||
|
def encode_eucjp content
|
||||||
|
NKF.nkf(U8TOEUC, content)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
register("EUC-JP") do |obj|
|
register("EUC-JP") do |obj|
|
||||||
|
@ -1,13 +1,28 @@
|
|||||||
require 'uconv'
|
|
||||||
|
|
||||||
module REXML
|
module REXML
|
||||||
module Encoding
|
module Encoding
|
||||||
def decode_sjis content
|
begin
|
||||||
Uconv::sjistou8(content)
|
require 'uconv'
|
||||||
end
|
|
||||||
|
|
||||||
def encode_sjis(str)
|
def decode_sjis content
|
||||||
Uconv::u8tosjis(str)
|
Uconv::sjistou8(content)
|
||||||
|
end
|
||||||
|
|
||||||
|
def encode_sjis(str)
|
||||||
|
Uconv::u8tosjis(str)
|
||||||
|
end
|
||||||
|
rescue LoadError
|
||||||
|
require 'nkf'
|
||||||
|
|
||||||
|
SJISTOU8 = '-Swm0'
|
||||||
|
U8TOSJIS = '-Wsm0'
|
||||||
|
|
||||||
|
def decode_sjis(str)
|
||||||
|
NKF.nkf(SJISTOU8, str)
|
||||||
|
end
|
||||||
|
|
||||||
|
def encode_sjis content
|
||||||
|
NKF.nkf(U8TOSJIS, content)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
b = proc do |obj|
|
b = proc do |obj|
|
||||||
|
@ -1 +1 @@
|
|||||||
load 'rexml/encodings/SHIFT-JIS.rb'
|
require 'rexml/encodings/SHIFT-JIS'
|
||||||
|
Loading…
x
Reference in New Issue
Block a user