midi2 0.11.1

Ergonomic, versatile, strong types wrapping MIDI 2.0 message data.
Documentation
use crate::{
    detail::{common_properties, schema},
    system_common::{self, UMP_MESSAGE_TYPE},
};

pub const STATUS: u8 = 0xF1;

/// MIDI 2.0 Channel Voice Time Code Message
///
/// See the [module docs](crate::system_common) for more info.
#[midi2_proc::generate_message(
    Via(system_common::SystemCommon),
    FixedSize,
    MinSizeUmp(1),
    MinSizeBytes(3)
)]
struct TimeCode {
    #[property(common_properties::UmpMessageTypeProperty<UMP_MESSAGE_TYPE>)]
    ump_type: (),
    #[property(system_common::SystemCommonStatus<{STATUS}>)]
    status: (),
    #[property(common_properties::GroupProperty)]
    group: crate::ux::u4,
    #[property(common_properties::HybridSchemaProperty<
        crate::ux::u7,
        schema::Bytes<0x0, 0x7F, 0x0>,
        schema::Ump<0x0000_7F00, 0x0, 0x0, 0x0>,
    >)]
    time_code: crate::ux::u7,
}

#[cfg(test)]
mod tests {
    use super::*;
    use crate::{traits::Grouped, ux::*};
    use pretty_assertions::assert_eq;

    #[test]
    fn setter() {
        let mut message = TimeCode::<[u32; 4]>::new();
        message.set_group(u4::new(0x5));
        message.set_time_code(u7::new(0x5F));
        assert_eq!(message, TimeCode([0x15F1_5F00, 0x0, 0x0, 0x0]),);
    }

    #[test]
    fn setters_bytes() {
        let mut message = TimeCode::<[u8; 3]>::new();
        message.set_time_code(u7::new(0x5F));
        assert_eq!(message, TimeCode([0xF1, 0x5F, 0x0,]),);
    }

    #[test]
    fn group() {
        assert_eq!(
            TimeCode::try_from(&[0x15F1_5F00_u32][..]).unwrap().group(),
            u4::new(0x5),
        );
    }

    #[test]
    fn time_code() {
        assert_eq!(
            TimeCode::try_from(&[0x15F1_5F00_u32][..])
                .unwrap()
                .time_code(),
            u7::new(0x5F),
        );
    }
}