类 Encoding::InvalidByteSequenceError
公共实例方法
destination_encoding → string 点击切换源代码
以编码对象形式返回目标编码。
static VALUE ecerr_destination_encoding(VALUE self) { return rb_attr_get(self, id_destination_encoding); }
destination_encoding_name → string 点击切换源代码
以字符串形式返回目标编码名称。
static VALUE ecerr_destination_encoding_name(VALUE self) { return rb_attr_get(self, id_destination_encoding_name); }
error_bytes → string 点击切换源代码
当出现 Encoding::InvalidByteSequenceError
时,返回被丢弃的字节。
ec = Encoding::Converter.new("EUC-JP", "ISO-8859-1") begin ec.convert("abc\xA1\xFFdef") rescue Encoding::InvalidByteSequenceError p $! #=> #<Encoding::InvalidByteSequenceError: "\xA1" followed by "\xFF" on EUC-JP> puts $!.error_bytes.dump #=> "\xA1" puts $!.readagain_bytes.dump #=> "\xFF" end
static VALUE ecerr_error_bytes(VALUE self) { return rb_attr_get(self, id_error_bytes); }
incomplete_input? → true 或 false 点击切换源代码
如果无效字节序列错误是由于字符串过早结束引起的,则返回 true。
ec = Encoding::Converter.new("EUC-JP", "ISO-8859-1") begin ec.convert("abc\xA1z") rescue Encoding::InvalidByteSequenceError p $! #=> #<Encoding::InvalidByteSequenceError: "\xA1" followed by "z" on EUC-JP> p $!.incomplete_input? #=> false end begin ec.convert("abc\xA1") ec.finish rescue Encoding::InvalidByteSequenceError p $! #=> #<Encoding::InvalidByteSequenceError: incomplete "\xA1" on EUC-JP> p $!.incomplete_input? #=> true end
static VALUE ecerr_incomplete_input(VALUE self) { return rb_attr_get(self, id_incomplete_input); }
readagain_bytes → string 点击切换源代码
当出现 Encoding::InvalidByteSequenceError
时,返回要再次读取的字节。
static VALUE ecerr_readagain_bytes(VALUE self) { return rb_attr_get(self, id_readagain_bytes); }
source_encoding → encoding 点击切换源代码
以编码对象形式返回源编码。
请注意,如果转换有多个步骤,则结果可能不等于编码转换器的源编码。
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, id_source_encoding); }
source_encoding_name → string 点击切换源代码
以字符串形式返回源编码名称。
static VALUE ecerr_source_encoding_name(VALUE self) { return rb_attr_get(self, id_source_encoding_name); }