[−][src]Struct libflate::gzip::Encoder
GZIP encoder.
Methods
impl<W> Encoder<W, DefaultLz77Encoder> where
W: Write,
[src]
impl<W> Encoder<W, DefaultLz77Encoder> where
W: Write,
pub fn new(inner: W) -> Result<Self>
[src]
pub fn new(inner: W) -> Result<Self>
Makes a new encoder instance.
Encoded GZIP stream is written to inner
.
Examples
use std::io::Write; use libflate::gzip::Encoder; let mut encoder = Encoder::new(Vec::new()).unwrap(); encoder.write_all(b"Hello World!").unwrap(); encoder.finish().into_result().unwrap();
impl<W, E> Encoder<W, E> where
W: Write,
E: Lz77Encode,
[src]
impl<W, E> Encoder<W, E> where
W: Write,
E: Lz77Encode,
pub fn with_options(inner: W, options: EncodeOptions<E>) -> Result<Self>
[src]
pub fn with_options(inner: W, options: EncodeOptions<E>) -> Result<Self>
Makes a new encoder instance with specified options.
Encoded GZIP stream is written to inner
.
Examples
use std::io::Write; use libflate::gzip::{Encoder, EncodeOptions, HeaderBuilder}; let header = HeaderBuilder::new().modification_time(123).finish(); let options = EncodeOptions::new().no_compression().header(header); let mut encoder = Encoder::with_options(Vec::new(), options).unwrap(); encoder.write_all(b"Hello World!").unwrap(); assert_eq!(encoder.finish().into_result().unwrap(), &[31, 139, 8, 0, 123, 0, 0, 0, 0, 3, 1, 12, 0, 243, 255, 72, 101, 108, 108, 111, 32, 87, 111, 114, 108, 100, 33, 163, 28, 41, 28, 12, 0, 0, 0][..]);
pub fn header(&self) -> &Header
[src]
pub fn header(&self) -> &Header
Returns the header of the GZIP stream.
Examples
use libflate::gzip::{Encoder, Os}; let encoder = Encoder::new(Vec::new()).unwrap(); assert_eq!(encoder.header().os(), Os::Unix);
pub fn finish(self) -> Finish<W, Error>
[src]
pub fn finish(self) -> Finish<W, Error>
Writes the GZIP trailer and returns the inner stream.
Examples
use std::io::Write; use libflate::gzip::Encoder; let mut encoder = Encoder::new(Vec::new()).unwrap(); encoder.write_all(b"Hello World!").unwrap(); assert!(encoder.finish().as_result().is_ok())
Note
If you are not concerned the result of this encoding,
it may be convenient to use AutoFinishUnchecked
instead of the explicit invocation of this method.
use std::io; use libflate::finish::AutoFinishUnchecked; use libflate::gzip::Encoder; let plain = b"Hello World!"; let mut buf = Vec::new(); let mut encoder = AutoFinishUnchecked::new(Encoder::new(&mut buf).unwrap()); io::copy(&mut &plain[..], &mut encoder).unwrap();
pub fn as_inner_ref(&self) -> &W
[src]
pub fn as_inner_ref(&self) -> &W
Returns the immutable reference to the inner stream.
pub fn as_inner_mut(&mut self) -> &mut W
[src]
pub fn as_inner_mut(&mut self) -> &mut W
Returns the mutable reference to the inner stream.
pub fn into_inner(self) -> W
[src]
pub fn into_inner(self) -> W
Unwraps the Encoder
, returning the inner stream.
Trait Implementations
impl<W, E> Write for Encoder<W, E> where
W: Write,
E: Lz77Encode,
[src]
impl<W, E> Write for Encoder<W, E> where
W: Write,
E: Lz77Encode,
fn write(&mut self, buf: &[u8]) -> Result<usize>
[src]
fn write(&mut self, buf: &[u8]) -> Result<usize>
Write a buffer into this object, returning how many bytes were written. Read more
fn flush(&mut self) -> Result<()>
[src]
fn flush(&mut self) -> Result<()>
Flush this output stream, ensuring that all intermediately buffered contents reach their destination. Read more
fn write_all(&mut self, buf: &[u8]) -> Result<(), Error>
1.0.0[src]
fn write_all(&mut self, buf: &[u8]) -> Result<(), Error>
Attempts to write an entire buffer into this write. Read more
fn write_fmt(&mut self, fmt: Arguments) -> Result<(), Error>
1.0.0[src]
fn write_fmt(&mut self, fmt: Arguments) -> Result<(), Error>
Writes a formatted string into this writer, returning any error encountered. Read more
fn by_ref(&mut self) -> &mut Self
1.0.0[src]
fn by_ref(&mut self) -> &mut Self
Creates a "by reference" adaptor for this instance of Write
. Read more
impl<W, E> Complete for Encoder<W, E> where
W: Write,
E: Lz77Encode,
[src]
impl<W, E> Complete for Encoder<W, E> where
W: Write,
E: Lz77Encode,
Auto Trait Implementations
impl<W, E> Send for Encoder<W, E> where
E: Send,
W: Send,
impl<W, E> Send for Encoder<W, E> where
E: Send,
W: Send,
impl<W, E> Sync for Encoder<W, E> where
E: Sync,
W: Sync,
impl<W, E> Sync for Encoder<W, E> where
E: Sync,
W: Sync,
Blanket Implementations
impl<T> From for T
[src]
impl<T> From for T
impl<T, U> Into for T where
U: From<T>,
[src]
impl<T, U> Into for T where
U: From<T>,
impl<T, U> TryFrom for T where
T: From<U>,
[src]
impl<T, U> TryFrom for T where
T: From<U>,
type Error = !
try_from
)The type returned in the event of a conversion error.
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
[src]
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
try_from
)Performs the conversion.
impl<T> Borrow for T where
T: ?Sized,
[src]
impl<T> Borrow for T where
T: ?Sized,
impl<T, U> TryInto for T where
U: TryFrom<T>,
[src]
impl<T, U> TryInto for T where
U: TryFrom<T>,
type Error = <U as TryFrom<T>>::Error
try_from
)The type returned in the event of a conversion error.
fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>
[src]
fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>
try_from
)Performs the conversion.
impl<T> BorrowMut for T where
T: ?Sized,
[src]
impl<T> BorrowMut for T where
T: ?Sized,
fn borrow_mut(&mut self) -> &mut T
[src]
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
impl<T> Any for T where
T: 'static + ?Sized,
[src]
impl<T> Any for T where
T: 'static + ?Sized,
fn get_type_id(&self) -> TypeId
[src]
fn get_type_id(&self) -> TypeId
🔬 This is a nightly-only experimental API. (get_type_id
)
this method will likely be replaced by an associated static
Gets the TypeId
of self
. Read more
impl<W> WriteBytesExt for W where
W: Write + ?Sized,
[src]
impl<W> WriteBytesExt for W where
W: Write + ?Sized,
fn write_u8(&mut self, n: u8) -> Result<(), Error>
[src]
fn write_u8(&mut self, n: u8) -> Result<(), Error>
Writes an unsigned 8 bit integer to the underlying writer. Read more
fn write_i8(&mut self, n: i8) -> Result<(), Error>
[src]
fn write_i8(&mut self, n: i8) -> Result<(), Error>
Writes a signed 8 bit integer to the underlying writer. Read more
fn write_u16<T>(&mut self, n: u16) -> Result<(), Error> where
T: ByteOrder,
[src]
fn write_u16<T>(&mut self, n: u16) -> Result<(), Error> where
T: ByteOrder,
Writes an unsigned 16 bit integer to the underlying writer. Read more
fn write_i16<T>(&mut self, n: i16) -> Result<(), Error> where
T: ByteOrder,
[src]
fn write_i16<T>(&mut self, n: i16) -> Result<(), Error> where
T: ByteOrder,
Writes a signed 16 bit integer to the underlying writer. Read more
fn write_u24<T>(&mut self, n: u32) -> Result<(), Error> where
T: ByteOrder,
[src]
fn write_u24<T>(&mut self, n: u32) -> Result<(), Error> where
T: ByteOrder,
Writes an unsigned 24 bit integer to the underlying writer. Read more
fn write_i24<T>(&mut self, n: i32) -> Result<(), Error> where
T: ByteOrder,
[src]
fn write_i24<T>(&mut self, n: i32) -> Result<(), Error> where
T: ByteOrder,
Writes a signed 24 bit integer to the underlying writer. Read more
fn write_u32<T>(&mut self, n: u32) -> Result<(), Error> where
T: ByteOrder,
[src]
fn write_u32<T>(&mut self, n: u32) -> Result<(), Error> where
T: ByteOrder,
Writes an unsigned 32 bit integer to the underlying writer. Read more
fn write_i32<T>(&mut self, n: i32) -> Result<(), Error> where
T: ByteOrder,
[src]
fn write_i32<T>(&mut self, n: i32) -> Result<(), Error> where
T: ByteOrder,
Writes a signed 32 bit integer to the underlying writer. Read more
fn write_u48<T>(&mut self, n: u64) -> Result<(), Error> where
T: ByteOrder,
[src]
fn write_u48<T>(&mut self, n: u64) -> Result<(), Error> where
T: ByteOrder,
Writes an unsigned 48 bit integer to the underlying writer. Read more
fn write_i48<T>(&mut self, n: i64) -> Result<(), Error> where
T: ByteOrder,
[src]
fn write_i48<T>(&mut self, n: i64) -> Result<(), Error> where
T: ByteOrder,
Writes a signed 48 bit integer to the underlying writer. Read more
fn write_u64<T>(&mut self, n: u64) -> Result<(), Error> where
T: ByteOrder,
[src]
fn write_u64<T>(&mut self, n: u64) -> Result<(), Error> where
T: ByteOrder,
Writes an unsigned 64 bit integer to the underlying writer. Read more
fn write_i64<T>(&mut self, n: i64) -> Result<(), Error> where
T: ByteOrder,
[src]
fn write_i64<T>(&mut self, n: i64) -> Result<(), Error> where
T: ByteOrder,
Writes a signed 64 bit integer to the underlying writer. Read more
fn write_uint<T>(&mut self, n: u64, nbytes: usize) -> Result<(), Error> where
T: ByteOrder,
[src]
fn write_uint<T>(&mut self, n: u64, nbytes: usize) -> Result<(), Error> where
T: ByteOrder,
Writes an unsigned n-bytes integer to the underlying writer. Read more
fn write_int<T>(&mut self, n: i64, nbytes: usize) -> Result<(), Error> where
T: ByteOrder,
[src]
fn write_int<T>(&mut self, n: i64, nbytes: usize) -> Result<(), Error> where
T: ByteOrder,
Writes a signed n-bytes integer to the underlying writer. Read more
fn write_f32<T>(&mut self, n: f32) -> Result<(), Error> where
T: ByteOrder,
[src]
fn write_f32<T>(&mut self, n: f32) -> Result<(), Error> where
T: ByteOrder,
Writes a IEEE754 single-precision (4 bytes) floating point number to the underlying writer. Read more
fn write_f64<T>(&mut self, n: f64) -> Result<(), Error> where
T: ByteOrder,
[src]
fn write_f64<T>(&mut self, n: f64) -> Result<(), Error> where
T: ByteOrder,
Writes a IEEE754 double-precision (8 bytes) floating point number to the underlying writer. Read more