Expand description
noodles-bgzf handles the reading and writing of the blocked gzip format (BGZF).
While the gzip format is typically a single stream, a BGZF is the concatenation of many gzip
streams. Each stream is called a block, with its uncompressed data size being constrained to
less than 64 KiB. This multistream gzip allows random access using virtual positions
.
noodles-bgzf abstracts away the concept of blocks, implementing std::io::Read
for the
reader and std::io::Write
for the writer.
§Examples
§Read an entire BGZF file
use noodles_bgzf as bgzf;
let mut reader = File::open("data.gz").map(bgzf::io::Reader::new)?;
let mut data = Vec::new();
reader.read_to_end(&mut data)?;
§Write a BGZF file
use noodles_bgzf as bgzf;
let mut writer = File::create("data.gz").map(bgzf::io::Writer::new)?;
writer.write_all(b"noodles-bgzf")?;
Re-exports§
pub use self::virtual_position::VirtualPosition;
pub use self::io::IndexedReader;
pub use self::io::MultithreadedReader;
pub use self::io::MultithreadedWriter;
pub use self::io::Reader;
pub use self::io::Writer;
pub use self::async::io::Reader as AsyncReader;
pub use self::async::Writer as AsyncWriter;
Modules§
- async
- Async BGZF.
- gzi
- gzip index.
- io
- BGZF I/O.
- virtual_
position - BGZF virtual position.