Method: Encoding::InvalidByteSequenceError#source_encoding
- Defined in:
- transcode.c
#source_encoding ⇒ Encoding
Returns the source encoding as an encoding object.
Note that the result may not be equal to the source encoding of the encoding converter if the conversion has multiple steps.
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
4320 4321 4322 4323 4324 |
# File 'transcode.c', line 4320
static VALUE
ecerr_source_encoding(VALUE self)
{
return rb_attr_get(self, id_source_encoding);
}
|