Crate bgzip

source ·
Expand description

bgzip-rs

Build Crates.io Crates.io Crates.io doc-rs

Rust implementation of BGZF format

Feature flags

  • rayon: Enable rayon based multi-threaded writer. This is default feature.
  • log: Enable log crate to log warnings. This is default feature.
  • rust_backend: use use miniz_oxide crate for flate2 backend. This is default feature.
  • zlib: use zlib for flate2 backend. Please read flate2 description for the detail.
  • zlib-ng: use zlib-ng for flate2 backend. Please read flate2 description for the detail.
  • zlib-ng-compat: Please read flate2 description for the detail.
  • cloudflare_zlib: Please read flate2 description for the detail.
  • libdeflater: use libdeflater instead of flate2 crate.

Write Examples

use bgzip::{BGZFWriter, BGZFError, Compression};
use std::io::{self, Write};
fn main() -> Result<(), BGZFError> {
    let mut write_buffer = Vec::new();
    let mut writer = BGZFWriter::new(&mut write_buffer, Compression::default());
    writer.write_all(b"##fileformat=VCFv4.2\n")?;
    writer.write_all(b"#CHROM\tPOS\tID\tREF\tALT\tQUAL\tFILTER\tINFO\n")?;
    writer.close()?;
    Ok(())
}

Multi-thread support is available via write::BGZFMultiThreadWriter. rayon flag is required to use this feature.

Read Examples

use bgzip::{BGZFReader, BGZFError};
use std::io::{self, BufRead};
use std::fs;
fn main() -> Result<(), BGZFError> {
    let mut reader =
        BGZFReader::new(fs::File::open("testfiles/common_all_20180418_half.vcf.gz")?)?;
    let mut line = String::new();
    reader.read_line(&mut line)?;
    assert_eq!("##fileformat=VCFv4.0\n", line);
    reader.bgzf_seek(4210818610)?;
    line.clear();
    reader.read_line(&mut line)?;
    assert_eq!("1\t72700625\trs12116859\tT\tA,C\t.\t.\tRS=12116859;RSPOS=72700625;dbSNPBuildID=120;SSR=0;SAO=0;VP=0x05010008000517053e000100;GENEINFO=LOC105378798:105378798;WGT=1;VC=SNV;SLO;INT;ASP;VLD;G5A;G5;HD;GNO;KGPhase1;KGPhase3;CAF=0.508,.,0.492;COMMON=1;TOPMED=0.37743692660550458,0.00608435270132517,0.61647872069317023\n", line);

    Ok(())
}

Re-exports

pub use deflate::Compression;
pub use read::BGZFReader;
pub use write::BGZFWriter;

Modules

Binding to DEFLATE library.
BGZ header parser
.gzi index support
BGZF reader
Tabix file parser. (This module is alpha state.)
BGZF writer

Enums

A BGZF error.

Constants

End-of-file maker.