rytm-rs 0.1.3

More than safe rust abstractions over rytm-sys, an unofficial SDK for Analog Rytm MKII running firmware 1.70
Documentation
use super::ObjectQuery;
use crate::{
    error::{ParameterError, RytmError},
    sysex::{AnySysexType, SysexType},
};
use rytm_rs_macro::parameter_range;

#[derive(Debug, Clone, Copy, Default, PartialEq, Eq, PartialOrd, Ord, Hash)]
/// A query to retrieve a [`Pattern`](crate::object::Pattern) object from rytm.
pub struct PatternQuery {
    /// Pattern index
    object_number: usize,
    sysex_type: SysexType,
    device_id: u8,
}

impl PatternQuery {
    /// Creates a new pattern query.
    ///
    /// Accepts a pattern index in the range of `0..=127`.
    #[parameter_range(range = "pattern_index:0..=127")]
    pub fn new(pattern_index: usize) -> Result<Self, RytmError> {
        Ok(Self {
            object_number: pattern_index,
            sysex_type: SysexType::Pattern,
            device_id: 0,
        })
    }

    /// Creates a new pattern query.
    ///
    /// Accepts a pattern index in the range of `0..=127`.
    ///
    /// Accepts a device id in the range of `0..=255`.
    #[parameter_range(range = "pattern_index:0..=127")]
    pub fn new_with_device_id(pattern_index: usize, device_id: u8) -> Result<Self, RytmError> {
        Ok(Self {
            object_number: pattern_index,
            sysex_type: SysexType::Pattern,
            device_id,
        })
    }

    /// Creates a new pattern query for the pattern in the work buffer.
    pub const fn new_targeting_work_buffer() -> Self {
        Self {
            object_number: 0b1000_0000,
            sysex_type: SysexType::Pattern,
            device_id: 0,
        }
    }

    /// Creates a new pattern query for the pattern in the work buffer.
    ///
    /// Accepts a device id in the range of `0..=255`.
    pub const fn new_targeting_work_buffer_with_device_id(device_id: u8) -> Self {
        Self {
            object_number: 0b1000_0000,
            sysex_type: SysexType::Pattern,
            device_id,
        }
    }
}

impl ObjectQuery for PatternQuery {
    fn sysex_type(&self) -> AnySysexType {
        self.sysex_type.into()
    }

    fn device_id(&self) -> u8 {
        self.device_id
    }

    fn obj_nr(&self) -> u16 {
        self.object_number as u16
    }
}