noodles-sam 0.85.0

Sequence Alignment/Map (SAM) format reader and writer
Documentation
use std::{error, fmt};

use bstr::BString;

/// An error when a raw SAM record name fails to parse.
#[derive(Clone, Debug, Eq, PartialEq)]
pub enum ParseError {
    /// The input is empty.
    Empty,
}

impl error::Error for ParseError {}

impl fmt::Display for ParseError {
    fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
        match self {
            Self::Empty => write!(f, "empty input"),
        }
    }
}

pub(super) fn parse_name(src: &[u8], name: &mut Option<BString>) -> Result<(), ParseError> {
    if src.is_empty() {
        return Err(ParseError::Empty);
    }

    if let Some(name) = name {
        name.clear();
        name.extend(src);
    } else {
        *name = Some(BString::from(src));
    }

    Ok(())
}

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

    #[test]
    fn test_parse_name() -> Result<(), ParseError> {
        let mut name = None;

        parse_name(b"r0", &mut name)?;
        assert_eq!(name, Some(BString::from(b"r0")));

        assert_eq!(parse_name(b"", &mut name), Err(ParseError::Empty));

        Ok(())
    }
}