Struct utf8::LossyDecoder[][src]

pub struct LossyDecoder<F: FnMut(&str)> { /* fields omitted */ }

A push-based, lossy decoder for UTF-8. Errors are replaced with the U+FFFD replacement character.

Users “push” bytes into the decoder, which in turn “pushes” &str slices into a callback.

For example, String::from_utf8_lossy (but returning String instead of Cow) can be rewritten as:

fn string_from_utf8_lossy(input: &[u8]) -> String {
    let mut string = String::new();
    utf8::LossyDecoder::new(|s| string.push_str(s)).feed(input);
    string
}

Note: Dropping the decoder signals the end of the input: If the last input chunk ended with an incomplete byte sequence for a code point, this is an error and a replacement character is emitted. Use std::mem::forget to inhibit this behavior.

Implementations

impl<F: FnMut(&str)> LossyDecoder<F>[src]

pub fn new(push_str: F) -> Self[src]

Create a new decoder from a callback.

pub fn feed(&mut self, input: &[u8])[src]

Feed one chunk of input into the decoder.

The input is decoded lossily and the callback called once or more with &str string slices.

If the UTF-8 byte sequence for one code point was split into this bytes chunk and previous bytes chunks, it will be correctly pieced back together.

Trait Implementations

impl<F: FnMut(&str)> Drop for LossyDecoder<F>[src]

Auto Trait Implementations

impl<F> RefUnwindSafe for LossyDecoder<F> where
    F: RefUnwindSafe

impl<F> Send for LossyDecoder<F> where
    F: Send

impl<F> Sync for LossyDecoder<F> where
    F: Sync

impl<F> Unpin for LossyDecoder<F> where
    F: Unpin

impl<F> UnwindSafe for LossyDecoder<F> where
    F: UnwindSafe

Blanket Implementations

impl<T> Any for T where
    T: 'static + ?Sized
[src]

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

impl<T> From<T> for T[src]

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.