Skip to content

Commit

Permalink
feat: HeaderRecord::push_tag: Value may be owned (#388)
Browse files Browse the repository at this point in the history
The type of the value may be a ref or owned. Previously it must be a ref.
  • Loading branch information
sjackman authored May 12, 2023
1 parent fb74387 commit b64537d
Showing 1 changed file with 20 additions and 1 deletion.
21 changes: 20 additions & 1 deletion src/bam/header.rs
Original file line number Diff line number Diff line change
Expand Up @@ -139,7 +139,7 @@ impl<'a> HeaderRecord<'a> {
/// * `tag` - the tag identifier
/// * `value` - the value. Can be any type convertible into a string. Preferably numbers or
/// strings.
pub fn push_tag<V: ToString>(&mut self, tag: &'a [u8], value: &V) -> &mut Self {
pub fn push_tag<V: ToString>(&mut self, tag: &'a [u8], value: V) -> &mut Self {
self.tags.push((tag, value.to_string().into_bytes()));
self
}
Expand All @@ -156,3 +156,22 @@ impl<'a> HeaderRecord<'a> {
out
}
}

#[cfg(test)]
mod tests {
use super::HeaderRecord;

#[test]
fn test_push_tag() {
let mut record = HeaderRecord::new(b"HD");
record.push_tag(b"X1", 0);
record.push_tag(b"X2", &0);

let x = "x".to_string();
record.push_tag(b"X3", x.as_str());
record.push_tag(b"X4", &x);
record.push_tag(b"X5", x);

assert_eq!(record.to_bytes(), b"@HD\tX1:0\tX2:0\tX3:x\tX4:x\tX5:x");
}
}

0 comments on commit b64537d

Please sign in to comment.