noodles_csi/binning_index/index/reference_sequence/bin/chunk.rs
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73
use std::ops::Range;
use noodles_bgzf as bgzf;
/// An index reference sequence bin chunk.
///
/// A chunk is a range of virtual positions representing [start, end).
#[derive(Clone, Copy, Debug, Eq, PartialEq)]
pub struct Chunk {
start: bgzf::VirtualPosition,
end: bgzf::VirtualPosition,
}
impl Chunk {
/// Creates a new chunk.
///
/// # Examples
///
/// ```
/// use noodles_bgzf as bgzf;
/// use noodles_csi::binning_index::index::reference_sequence::bin::Chunk;
/// let chunk = Chunk::new(bgzf::VirtualPosition::from(8), bgzf::VirtualPosition::from(13));
/// ```
pub fn new(start: bgzf::VirtualPosition, end: bgzf::VirtualPosition) -> Self {
Self { start, end }
}
/// Returns the chunk start (inclusive) as a virtual position.
///
/// # Examples
///
/// ```
/// use noodles_bgzf as bgzf;
/// use noodles_csi::binning_index::index::reference_sequence::bin::Chunk;
/// let chunk = Chunk::new(bgzf::VirtualPosition::from(8), bgzf::VirtualPosition::from(13));
/// assert_eq!(chunk.start(), bgzf::VirtualPosition::from(8));
/// ```
pub fn start(&self) -> bgzf::VirtualPosition {
self.start
}
/// Returns the chunk end (exclusive) as a virtual position.
///
/// # Examples
///
/// ```
/// use noodles_bgzf as bgzf;
/// use noodles_csi::binning_index::index::reference_sequence::bin::Chunk;
/// let chunk = Chunk::new(bgzf::VirtualPosition::from(8), bgzf::VirtualPosition::from(13));
/// assert_eq!(chunk.end(), bgzf::VirtualPosition::from(13));
/// ```
pub fn end(&self) -> bgzf::VirtualPosition {
self.end
}
}
impl From<Range<bgzf::VirtualPosition>> for Chunk {
fn from(range: Range<bgzf::VirtualPosition>) -> Self {
Self::new(range.start, range.end)
}
}
#[cfg(test)]
mod tests {
use super::*;
#[test]
fn test_from_range_bgzf_virtual_position_for_chunk() {
let start = bgzf::VirtualPosition::from(8);
let end = bgzf::VirtualPosition::from(13);
assert_eq!(Chunk::from(start..end), Chunk::new(start, end));
}
}