pub struct Writer<W> { /* private fields */ }
Expand description
A BAM writer.
§Examples
use noodles_bam as bam;
use noodles_sam as sam;
let mut writer = bam::io::Writer::new(io::sink());
let header = sam::Header::default();
writer.write_header(&header)?;
let record = bam::Record::default();
writer.write_record(&header, &record)?;
Implementations§
Source§impl<W> Writer<W>where
W: Write,
impl<W> Writer<W>where
W: Write,
Sourcepub fn get_ref(&self) -> &W
pub fn get_ref(&self) -> &W
Returns a reference to the underlying writer.
§Examples
use noodles_bam as bam;
let writer = bam::io::Writer::from(Vec::new());
assert!(writer.get_ref().is_empty());
Sourcepub fn get_mut(&mut self) -> &mut W
pub fn get_mut(&mut self) -> &mut W
Returns a mutable reference to the underlying writer.
§Examples
use noodles_bam as bam;
let mut writer = bam::io::Writer::from(Vec::new());
assert!(writer.get_mut().is_empty());
Sourcepub fn into_inner(self) -> W
pub fn into_inner(self) -> W
Returns the underlying writer.
§Examples
use noodles_bam as bam;
let writer = bam::io::Writer::from(Vec::new());
assert!(writer.into_inner().is_empty());
Sourcepub fn write_header(&mut self, header: &Header) -> Result<()>
pub fn write_header(&mut self, header: &Header) -> Result<()>
Writes a SAM header.
This writes the BAM magic number, the raw SAM header, and a copy of the reference sequence dictionary as binary reference sequences.
§Examples
use noodles_bam as bam;
use noodles_sam as sam;
let mut writer = bam::io::Writer::new(io::sink());
let header = sam::Header::builder().add_comment("noodles-bam").build();
writer.write_header(&header)?;
Sourcepub fn write_record(&mut self, header: &Header, record: &Record) -> Result<()>
pub fn write_record(&mut self, header: &Header, record: &Record) -> Result<()>
Writes a BAM record.
§Examples
use noodles_bam as bam;
use noodles_sam as sam;
let header = sam::Header::default();
let mut writer = bam::io::Writer::new(io::sink());
writer.write_header(&header)?;
let record = bam::Record::default();
writer.write_record(&header, &record)?;
Source§impl<W> Writer<Writer<W>>where
W: Write,
impl<W> Writer<Writer<W>>where
W: Write,
Sourcepub fn new(writer: W) -> Self
pub fn new(writer: W) -> Self
Creates a BAM writer with a default compression level.
The given stream is wrapped in a BGZF encoder.
§Examples
use noodles_bam as bam;
let writer = bam::io::Writer::new(io::sink());
Sourcepub fn try_finish(&mut self) -> Result<()>
pub fn try_finish(&mut self) -> Result<()>
Attempts to finish the output stream.
This is typically only manually called if the underlying stream is needed before the writer is dropped.
§Examples
use noodles_bam as bam;
let mut writer = bam::io::Writer::new(io::sink());
writer.try_finish()?;
Trait Implementations§
Auto Trait Implementations§
impl<W> Freeze for Writer<W>where
W: Freeze,
impl<W> RefUnwindSafe for Writer<W>where
W: RefUnwindSafe,
impl<W> Send for Writer<W>where
W: Send,
impl<W> Sync for Writer<W>where
W: Sync,
impl<W> Unpin for Writer<W>where
W: Unpin,
impl<W> UnwindSafe for Writer<W>where
W: UnwindSafe,
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more