Scanner

Struct Scanner 

Source
pub struct Scanner { /* private fields */ }
Expand description

A CRAM scanner.

§Examples

use oxbow::alignment::format::cram::Scanner;
use std::fs::File;
use noodles::fasta::io::indexed_reader::Builder as FastaIndexedReaderBuilder;
use noodles::fasta::repository::adapters::IndexedReader as FastaIndexedReaderAdapter;

let fa_reader = FastaIndexedReaderBuilder::default().build_from_path("reference.fa").unwrap();
let adapter = FastaIndexedReaderAdapter::new(fa_reader);
let repository = noodles::fasta::Repository::new(adapter);

let inner = File::open("sample.cram").unwrap();
let mut fmt_reader = noodles::cram::io::Reader::new(inner);
let header = fmt_reader.read_header().unwrap();

let scanner = Scanner::new(header);
let tag_defs = scanner.tag_defs(&mut fmt_reader, Some(1000)).unwrap();
let batches = scanner.scan(fmt_reader, repository, None, Some(tag_defs), None, Some(1000));

Implementations§

Source§

impl Scanner

Source

pub fn new(header: Header) -> Self

Creates a CRAM scanner from a SAM header.

Source

pub fn header(&self) -> Header

Returns the SAM header.

Source

pub fn chrom_names(&self) -> Vec<String>

Returns the reference sequence names.

Source

pub fn chrom_sizes(&self) -> Vec<(String, u32)>

Returns the reference sequence names and lengths.

Source

pub fn field_names(&self) -> Vec<String>

Returns the fixed field names.

Source

pub fn schema( &self, fields: Option<Vec<String>>, tag_defs: Option<Vec<(String, String)>>, ) -> Result<Schema>

Returns the Arrow schema.

Source§

impl Scanner

Source

pub fn tag_defs<R: Read>( &self, fmt_reader: &mut Reader<R>, scan_rows: Option<usize>, ) -> Result<Vec<(String, String)>>

Discovers tag definitions by scanning over records.

The scan will begin at the current position of the reader and will move the cursor to the end of the last record scanned.

Source

pub fn scan<R: Read>( &self, fmt_reader: Reader<R>, repo: Repository, fields: Option<Vec<String>>, tag_defs: Option<Vec<(String, String)>>, batch_size: Option<usize>, limit: Option<usize>, ) -> Result<impl RecordBatchReader>

Returns an iterator yielding record batches.

The scan will begin at the current position of the reader and will move the cursor to the end of the last record scanned.

Source

pub fn scan_query<R: Read + Seek>( &self, fmt_reader: Reader<R>, repo: Repository, region: Region, index: Index, fields: Option<Vec<String>>, tag_defs: Option<Vec<(String, String)>>, batch_size: Option<usize>, limit: Option<usize>, ) -> Result<impl RecordBatchReader>

Returns an iterator yielding record batches satisfying a genomic range query.

This operation requires a CRAI Index and the FASTA reference repository must be provided separately from the CRAM reader.

The scan will traverse one or more CRAM data containers and slices and filter for records that overlap the given region. The cursor will stop at the end of the last record scanned.

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> Allocation for T
where T: RefUnwindSafe + Send + Sync,