Struct noodles::fastq::Reader

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

A FASTQ reader.

Implementations§

source§

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

source

pub fn new(inner: R) -> Reader<R>

Creates a FASTQ reader.

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

pub fn get_ref(&self) -> &R

Returns a reference to the underlying reader.

§Examples
use noodles_fastq as fastq;
let data = [];
let reader = fastq::Reader::new(&data[..]);
assert!(reader.get_ref().is_empty());
source

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

Returns a mutable reference to the underlying reader.

§Examples
use noodles_fastq as fastq;
let data = [];
let mut reader = fastq::Reader::new(&data[..]);
assert!(reader.get_mut().is_empty());
source

pub fn into_inner(self) -> R

Unwraps and returns the underlying reader.

§Examples
use noodles_fastq as fastq;
let data = [];
let reader = fastq::Reader::new(&data[..]);
assert!(reader.into_inner().is_empty());
source

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

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::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::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> Instrument for T

source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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> Same for T

§

type Output = T

Should always be Self
source§

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

§

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

§

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> WithSubscriber for T

source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more