noodles_fastq::io::reader

Struct Reader

source
pub struct Reader<R> { /* private fields */ }
Expand description

A FASTQ reader.

Implementations§

source§

impl<R> Reader<R>

source

pub fn get_ref(&self) -> &R

Returns a reference to the underlying reader.

§Examples
use noodles_fastq as fastq;
let reader = fastq::io::Reader::new(io::empty());
let _inner = reader.get_ref();
source

pub fn get_mut(&mut self) -> &mut R

Returns a mutable reference to the underlying reader.

§Examples
use noodles_fastq as fastq;
let mut reader = fastq::io::Reader::new(io::empty());
let _inner = reader.get_mut();
source

pub fn into_inner(self) -> R

Unwraps and returns the underlying reader.

§Examples
use noodles_fastq as fastq;
let reader = fastq::io::Reader::new(io::empty());
let _inner = reader.into_inner();
source§

impl<R> Reader<R>
where R: BufRead,

source

pub fn new(inner: R) -> Self

Creates a FASTQ reader.

§Examples
use noodles_fastq as fastq;
let data = b"@r0\nATCG\n+\nNDLS\n";
let reader = fastq::io::Reader::new(&data[..]);
source

pub fn read_record(&mut self, record: &mut Record) -> Result<usize>

Reads a FASTQ record.

This reads from the underlying stream until four lines are read: the read name, the sequence, the plus line, and the quality scores. Each line omits the trailing newline.

The stream is expected to be at the start of a record.

If successful, the number of bytes read is returned. If the number of bytes read is 0, the stream reached EOF.

§Examples
use noodles_fastq as fastq;

let data = b"@r0\nATCG\n+\nNDLS\n";
let mut reader = fastq::io::Reader::new(&data[..]);

let mut record = fastq::Record::default();
reader.read_record(&mut record)?;

assert_eq!(record.name(), &b"r0"[..]);
assert_eq!(record.sequence(), b"ATCG");
assert_eq!(record.quality_scores(), b"NDLS");
Ok::<(), io::Error>(())
source

pub fn records(&mut self) -> Records<'_, R>

Returns an iterator over records starting from the current stream position.

The stream is expected to be at the start of a record.

§Examples
use noodles_fastq::{self as fastq, record::Definition};

let data = b"@r0\nATCG\n+\nNDLS\n";
let mut reader = fastq::io::Reader::new(&data[..]);

let mut records = reader.records();

assert_eq!(
    records.next().transpose()?,
    Some(fastq::Record::new(Definition::new("r0", ""), "ATCG", "NDLS")
));

assert!(records.next().is_none());

Auto Trait Implementations§

§

impl<R> Freeze for Reader<R>
where R: Freeze,

§

impl<R> RefUnwindSafe for Reader<R>
where R: RefUnwindSafe,

§

impl<R> Send for Reader<R>
where R: Send,

§

impl<R> Sync for Reader<R>
where R: Sync,

§

impl<R> Unpin for Reader<R>
where R: Unpin,

§

impl<R> UnwindSafe for Reader<R>
where R: UnwindSafe,

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, 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.