Struct libflate::gzip::Encoder
[−]
[src]
pub struct Encoder<W, E = DefaultLz77Encoder> { /* fields omitted */ }
GZIP encoder.
Methods
impl<W> Encoder<W, DefaultLz77Encoder> where
W: Write,
[src]
W: Write,
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]
W: Write,
E: Lz77Encode,
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][..]);
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);
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())
Trait Implementations
impl<W> Write for Encoder<W> where
W: Write,
[src]
W: Write,
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<()>
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
Attempts to write an entire buffer into this write. Read more
fn write_fmt(&mut self, fmt: Arguments) -> Result<(), Error>
1.0.0
Writes a formatted string into this writer, returning any error encountered. Read more
fn by_ref(&mut self) -> &mut Self
1.0.0
Creates a "by reference" adaptor for this instance of Write
. Read more