Struct noodles_sam::io::writer::Writer
source · pub struct Writer<W>where
W: Write,{ /* private fields */ }
Expand description
A SAM writer.
The SAM format is comprised of two parts: 1) a header and 2) a list of records.
Each header line is prefixed with an @
(at sign). The header is optional and may be empty.
SAM records are line-based and follow directly after the header or the start of the file until EOF.
§Examples
use noodles_sam as sam;
let mut writer = sam::io::Writer::new(Vec::new());
let header = sam::Header::builder().add_comment("noodles-sam").build();
writer.write_header(&header)?;
let record = sam::Record::default();
writer.write_record(&header, &record)?;
let expected = b"@CO\tnoodles-sam
*\t4\t*\t0\t255\t*\t*\t0\t0\t*\t*
";
assert_eq!(&writer.get_ref()[..], &expected[..]);
Implementations§
source§impl<W> Writer<W>where
W: Write,
impl<W> Writer<W>where
W: Write,
sourcepub fn new(inner: W) -> Self
pub fn new(inner: W) -> Self
Creates a SAM writer.
§Examples
use noodles_sam as sam;
let writer = sam::io::Writer::new(Vec::new());
sourcepub fn get_ref(&self) -> &W
pub fn get_ref(&self) -> &W
Returns a reference to the underlying writer.
§Examples
use noodles_sam as sam;
let writer = sam::io::Writer::new(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_sam as sam;
let mut writer = sam::io::Writer::new(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_sam as sam;
let writer = sam::io::Writer::new(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.
The SAM header is optional, though recommended to include. A call to this method can be omitted if it is empty.
§Examples
use noodles_sam as sam;
let mut writer = sam::io::Writer::new(Vec::new());
let header = sam::Header::builder().add_comment("noodles-sam").build();
writer.write_header(&header)?;
assert_eq!(writer.get_ref(), b"@CO\tnoodles-sam\n");
sourcepub fn write_record(&mut self, header: &Header, record: &Record) -> Result<()>
pub fn write_record(&mut self, header: &Header, record: &Record) -> Result<()>
Writes a SAM record.
§Examples
use noodles_sam as sam;
let mut writer = sam::io::Writer::new(Vec::new());
let header = sam::Header::default();
let record = sam::Record::default();
writer.write_record(&header, &record)?;
assert_eq!(writer.get_ref(), b"*\t4\t*\t0\t255\t*\t*\t0\t0\t*\t*\n");
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