mod builder;
pub use self::builder::Builder;
use std::io::{self, BufRead};
use noodles_bcf as bcf;
use noodles_bgzf as bgzf;
use noodles_core::Region;
use noodles_vcf::{self as vcf, variant::Record};
pub enum IndexedReader<R> {
Vcf(vcf::io::IndexedReader<R>),
Bcf(bcf::io::IndexedReader<R>),
}
impl<R> IndexedReader<R>
where
R: BufRead,
{
pub fn read_header(&mut self) -> io::Result<vcf::Header> {
match self {
Self::Vcf(reader) => reader.read_header(),
Self::Bcf(reader) => reader.read_header(),
}
}
pub fn records<'r, 'h: 'r>(
&'r mut self,
) -> impl Iterator<Item = io::Result<Box<dyn Record>>> + '_ {
let records: Box<dyn Iterator<Item = io::Result<Box<dyn Record>>>> = match self {
Self::Vcf(reader) => Box::new(
reader
.records()
.map(|result| result.map(|record| Box::new(record) as Box<dyn Record>)),
),
Self::Bcf(reader) => Box::new(
reader
.records()
.map(|result| result.map(|record| Box::new(record) as Box<dyn Record>)),
),
};
records
}
}
impl<R> IndexedReader<R>
where
R: bgzf::io::BufRead + bgzf::io::Seek,
{
pub fn query<'r, 'h: 'r>(
&'r mut self,
header: &'h vcf::Header,
region: &Region,
) -> io::Result<impl Iterator<Item = io::Result<Box<dyn Record>>> + '_> {
let records: Box<dyn Iterator<Item = io::Result<Box<dyn Record>>>> = match self {
Self::Vcf(reader) => Box::new(
reader
.query(header, region)?
.map(|result| result.map(|record| Box::new(record) as Box<dyn Record>)),
),
Self::Bcf(reader) => Box::new(
reader
.query(header, region)?
.map(|result| result.map(|record| Box::new(record) as Box<dyn Record>)),
),
};
Ok(records)
}
}