Struct utf8::LossyDecoder [−][src]
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
Auto Trait Implementations
impl<F> RefUnwindSafe for LossyDecoder<F> where
F: RefUnwindSafe,
F: RefUnwindSafe,
impl<F> Send for LossyDecoder<F> where
F: Send,
F: Send,
impl<F> Sync for LossyDecoder<F> where
F: Sync,
F: Sync,
impl<F> Unpin for LossyDecoder<F> where
F: Unpin,
F: Unpin,
impl<F> UnwindSafe for LossyDecoder<F> where
F: UnwindSafe,
F: UnwindSafe,
Blanket Implementations
impl<T> Any for T where
T: 'static + ?Sized,
[src]
T: 'static + ?Sized,
impl<T> Borrow<T> for T where
T: ?Sized,
[src]
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]
T: ?Sized,
pub fn borrow_mut(&mut self) -> &mut T
[src]
impl<T> From<T> for T
[src]
impl<T, U> Into<U> for T where
U: From<T>,
[src]
U: From<T>,
impl<T, U> TryFrom<U> for T where
U: Into<T>,
[src]
U: Into<T>,
type Error = Infallible
The type returned in the event of a conversion error.
pub fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
[src]
impl<T, U> TryInto<U> for T where
U: TryFrom<T>,
[src]
U: TryFrom<T>,