Encoding::UndefinedConversionError
class Encoding::UndefinedConversionError
Parent:rb_eEncodingError
当代码转换操作失败时,由编码和字符串方法引发。
公共实例方法
destination_encoding → string Show source
作为编码对象返回目标编码。
static VALUE
ecerr_destination_encoding(VALUE self)
{
return rb_attr_get(self, rb_intern("destination_encoding")
}
destination_encoding_name → string Show source
以字符串形式返回目标编码名称。
static VALUE
ecerr_destination_encoding_name(VALUE self)
{
return rb_attr_get(self, rb_intern("destination_encoding_name")
}
error_char → string Show source
返回导致Encoding :: UndefinedConversionError的一个字符的字符串。
ec = Encoding::Converter.new("ISO-8859-1", "EUC-JP")
begin
ec.convert("\xa0")
rescue Encoding::UndefinedConversionError
puts $!.error_char.dump #=> "\xC2\xA0"
p $!.error_char.encoding #=> #<Encoding:UTF-8>
end
static VALUE
ecerr_error_char(VALUE self)
{
return rb_attr_get(self, rb_intern("error_char")
}
source_encoding → encoding Show source
作为编码对象返回源编码。
请注意,如果转换具有多个步骤,结果可能不等于编码转换器的源编码。
ec = Encoding::Converter.new("ISO-8859-1", "EUC-JP") # ISO-8859-1 -> UTF-8 -> EUC-JP
begin
ec.convert("\xa0") # NO-BREAK SPACE, which is available in UTF-8 but not in EUC-JP.
rescue Encoding::UndefinedConversionError
p $!.source_encoding #=> #<Encoding:UTF-8>
p $!.destination_encoding #=> #<Encoding:EUC-JP>
p $!.source_encoding_name #=> "UTF-8"
p $!.destination_encoding_name #=> "EUC-JP"
end
static VALUE
ecerr_source_encoding(VALUE self)
{
return rb_attr_get(self, rb_intern("source_encoding")
}
source_encoding_name → string Show source
以字符串形式返回源编码名称。
static VALUE
ecerr_source_encoding_name(VALUE self)
{
return rb_attr_get(self, rb_intern("source_encoding_name")
}