noodles_cram/
file_definition.rs

1//! CRAM file definition and fields.
2
3mod version;
4
5pub use self::version::Version;
6
7/// A CRAM file definition.
8///
9/// The CRAM file definition holds the format version and file ID. See ยง 6 File definition
10/// (2020-06-22).
11#[derive(Clone, Default, Debug, Eq, PartialEq)]
12pub struct FileDefinition {
13    version: Version,
14    file_id: [u8; 20],
15}
16
17impl FileDefinition {
18    /// Creates a file definition.
19    ///
20    /// # Examples
21    ///
22    /// ```
23    /// use noodles_cram::{file_definition::Version, FileDefinition};
24    /// let file_definition = FileDefinition::new(Version::new(3, 0), [0; 20]);
25    /// ```
26    pub fn new(version: Version, file_id: [u8; 20]) -> Self {
27        Self { version, file_id }
28    }
29
30    /// Returns the file version.
31    ///
32    /// This is also called the (major and minor) format number.
33    ///
34    /// # Examples
35    ///
36    /// ```
37    /// use noodles_cram::{file_definition::Version, FileDefinition};
38    /// let file_definition = FileDefinition::new(Version::new(3, 0), [0; 20]);
39    /// assert_eq!(file_definition.version(), Version::new(3, 0));
40    /// ```
41    pub fn version(&self) -> Version {
42        self.version
43    }
44
45    /// Returns the file ID.
46    ///
47    /// The file ID has a fixed length of 20 bytes. It can be any arbitrary identifier, e.g., the
48    /// file name or a 160-bit checksum.
49    ///
50    /// # Examples
51    ///
52    /// ```
53    /// use noodles_cram::{file_definition::Version, FileDefinition};
54    /// let file_definition = FileDefinition::new(Version::new(3, 0), [0; 20]);
55    /// assert_eq!(file_definition.file_id(), [0; 20]);
56    /// ```
57    pub fn file_id(&self) -> &[u8] {
58        &self.file_id
59    }
60}
61
62#[cfg(test)]
63mod tests {
64    use super::*;
65
66    #[test]
67    fn test_default() {
68        let actual = FileDefinition::default();
69        let expected = FileDefinition::new(Version::new(3, 0), [0; 20]);
70        assert_eq!(actual, expected);
71    }
72}