use crate::{
    CPUControlFlags, TxDatagram, MSG_RD_CPU_VERSION, MSG_RD_CPU_VERSION_MINOR,
    MSG_RD_FPGA_FUNCTION, MSG_RD_FPGA_VERSION, MSG_RD_FPGA_VERSION_MINOR,
};
#[derive(Default)]
pub struct CPUVersionMajor {}
impl CPUVersionMajor {
    pub fn pack(&mut self, tx: &mut TxDatagram) {
        tx.header_mut().msg_id = MSG_RD_CPU_VERSION;
        tx.header_mut().cpu_flag = CPUControlFlags::from_bits(0x02).unwrap(); tx.num_bodies = 0;
    }
}
#[derive(Default)]
pub struct CPUVersionMinor {}
impl CPUVersionMinor {
    pub fn pack(&mut self, tx: &mut TxDatagram) {
        tx.header_mut().msg_id = MSG_RD_CPU_VERSION_MINOR;
        tx.num_bodies = 0;
    }
}
#[derive(Default)]
pub struct FPGAVersionMajor {}
impl FPGAVersionMajor {
    pub fn pack(&mut self, tx: &mut TxDatagram) {
        tx.header_mut().msg_id = MSG_RD_FPGA_VERSION;
        tx.header_mut().cpu_flag = CPUControlFlags::from_bits(0x04).unwrap(); tx.num_bodies = 0;
    }
}
#[derive(Default)]
pub struct FPGAVersionMinor {}
impl FPGAVersionMinor {
    pub fn pack(&mut self, tx: &mut TxDatagram) {
        tx.header_mut().msg_id = MSG_RD_FPGA_VERSION_MINOR;
        tx.num_bodies = 0;
    }
}
#[derive(Default)]
pub struct FPGAFunctions {}
impl FPGAFunctions {
    pub fn pack(&mut self, tx: &mut TxDatagram) {
        tx.header_mut().msg_id = MSG_RD_FPGA_FUNCTION;
        tx.header_mut().cpu_flag = CPUControlFlags::from_bits(0x05).unwrap(); tx.num_bodies = 0;
    }
}
#[cfg(test)]
mod test {
    use super::*;
    const NUM_TRANS_IN_UNIT: usize = 249;
    #[test]
    fn cpu_version() {
        let mut tx = TxDatagram::new(&[
            NUM_TRANS_IN_UNIT,
            NUM_TRANS_IN_UNIT,
            NUM_TRANS_IN_UNIT,
            NUM_TRANS_IN_UNIT,
            NUM_TRANS_IN_UNIT,
            NUM_TRANS_IN_UNIT,
            NUM_TRANS_IN_UNIT,
            NUM_TRANS_IN_UNIT,
            NUM_TRANS_IN_UNIT,
            NUM_TRANS_IN_UNIT,
        ]);
        CPUVersionMajor {}.pack(&mut tx);
        assert_eq!(tx.header().msg_id, MSG_RD_CPU_VERSION);
        assert_eq!(tx.header().cpu_flag.bits(), 0x02);
        CPUVersionMinor {}.pack(&mut tx);
        assert_eq!(tx.header().msg_id, MSG_RD_CPU_VERSION_MINOR);
    }
    #[test]
    fn fpga_version() {
        let mut tx = TxDatagram::new(&[
            NUM_TRANS_IN_UNIT,
            NUM_TRANS_IN_UNIT,
            NUM_TRANS_IN_UNIT,
            NUM_TRANS_IN_UNIT,
            NUM_TRANS_IN_UNIT,
            NUM_TRANS_IN_UNIT,
            NUM_TRANS_IN_UNIT,
            NUM_TRANS_IN_UNIT,
            NUM_TRANS_IN_UNIT,
            NUM_TRANS_IN_UNIT,
        ]);
        FPGAVersionMajor {}.pack(&mut tx);
        assert_eq!(tx.header().msg_id, MSG_RD_FPGA_VERSION);
        assert_eq!(tx.header().cpu_flag.bits(), 0x04);
        FPGAVersionMinor {}.pack(&mut tx);
        assert_eq!(tx.header().msg_id, MSG_RD_FPGA_VERSION_MINOR);
    }
    #[test]
    fn fpga_functions() {
        let mut tx = TxDatagram::new(&[
            NUM_TRANS_IN_UNIT,
            NUM_TRANS_IN_UNIT,
            NUM_TRANS_IN_UNIT,
            NUM_TRANS_IN_UNIT,
            NUM_TRANS_IN_UNIT,
            NUM_TRANS_IN_UNIT,
            NUM_TRANS_IN_UNIT,
            NUM_TRANS_IN_UNIT,
            NUM_TRANS_IN_UNIT,
            NUM_TRANS_IN_UNIT,
        ]);
        FPGAFunctions {}.pack(&mut tx);
        assert_eq!(tx.header().msg_id, MSG_RD_FPGA_FUNCTION);
        assert_eq!(tx.header().cpu_flag.bits(), 0x05);
    }
}