mod builder;
pub use self::builder::Builder;
use std::io::{self, Read, Seek};
use noodles_core::Region;
use noodles_fasta as fasta;
use noodles_sam as sam;
use super::{
crai,
reader::{Query, Records},
DataContainer, FileDefinition, Reader,
};
pub struct IndexedReader<R> {
inner: Reader<R>,
index: crai::Index,
}
impl<R> IndexedReader<R>
where
R: Read,
{
pub fn new(inner: R, index: crai::Index) -> Self {
Self {
inner: Reader::new(inner),
index,
}
}
pub fn get_ref(&self) -> &R {
self.inner.get_ref()
}
pub fn get_mut(&mut self) -> &mut R {
self.inner.get_mut()
}
pub fn into_inner(self) -> R {
self.inner.into_inner()
}
pub fn read_file_definition(&mut self) -> io::Result<FileDefinition> {
self.inner.read_file_definition()
}
pub fn read_file_header(&mut self) -> io::Result<sam::Header> {
self.inner.read_file_header()
}
pub fn read_data_container(&mut self) -> io::Result<Option<DataContainer>> {
self.inner.read_data_container()
}
pub fn records<'a>(
&'a mut self,
reference_sequence_repository: &'a fasta::Repository,
header: &'a sam::Header,
) -> Records<'a, R> {
self.inner.records(reference_sequence_repository, header)
}
pub fn index(&self) -> &crai::Index {
&self.index
}
}
impl<R> IndexedReader<R>
where
R: Read + Seek,
{
pub fn query<'a>(
&'a mut self,
reference_sequence_repository: &'a fasta::Repository,
header: &'a sam::Header,
region: &Region,
) -> io::Result<Query<'_, R>> {
self.inner
.query(reference_sequence_repository, header, &self.index, region)
}
}