bgapi 0.0.10

Library for creating and parsing BGAPI packets.
Documentation
use bytes::{Buf, BufMut};
use message::{Message, MessageClass, MessageHeader, MessagePayload, MessageType};
use std::io::Cursor;

#[allow(non_camel_case_types)]
#[derive(Debug, Clone, PartialEq, PartialOrd)]
pub struct flash_set_address {
    pub address: u32,
}

impl flash_set_address {
    pub fn new(address: u32) -> Message {
        let header = MessageHeader {
            message_type: MessageType::command_response,
            payload_length: 0x04,
            message_class: MessageClass::dfu,
            message_id: 0x01,
        };
        let payload = flash_set_address { address };
        let payload = MessagePayload::cmd_dfu_flash_set_address(payload);
        Message { header, payload }
    }
}

impl From<&[u8]> for flash_set_address {
    fn from(data: &[u8]) -> flash_set_address {
        let mut cursor = Cursor::new(data);
        flash_set_address {
            address: cursor.get_u32_le(),
        }
    }
}

impl Into<Vec<u8>> for flash_set_address {
    fn into(self) -> Vec<u8> {
        let mut bytes = Vec::new();
        bytes.put_u32_le(self.address);
        bytes
    }
}

#[allow(non_camel_case_types)]
#[derive(Debug, Clone, PartialEq, PartialOrd)]
pub struct flash_upload {
    pub data: Vec<u8>,
}

impl flash_upload {
    pub fn new(data: Vec<u8>) -> Message {
        let header = MessageHeader {
            message_type: MessageType::command_response,
            payload_length: data.len() as u8,
            message_class: MessageClass::dfu,
            message_id: 0x02,
        };
        let payload = flash_upload { data };
        let payload = MessagePayload::cmd_dfu_flash_upload(payload);
        Message { header, payload }
    }
}

impl From<&[u8]> for flash_upload {
    fn from(data: &[u8]) -> flash_upload {
        flash_upload {
            data: data.to_vec(),
        }
    }
}

impl Into<Vec<u8>> for flash_upload {
    fn into(self) -> Vec<u8> {
        self.data.clone()
    }
}

#[allow(non_camel_case_types)]
#[derive(Debug, Clone, PartialEq, PartialOrd)]
pub struct flash_upload_finish {}

impl flash_upload_finish {
    pub fn new() -> Message {
        let header = MessageHeader {
            message_type: MessageType::command_response,
            payload_length: 0x00,
            message_class: MessageClass::dfu,
            message_id: 0x03,
        };
        let payload = flash_upload_finish {};
        let payload = MessagePayload::cmd_dfu_flash_upload_finish(payload);
        Message { header, payload }
    }
}

impl From<&[u8]> for flash_upload_finish {
    fn from(_: &[u8]) -> flash_upload_finish {
        flash_upload_finish {}
    }
}

impl Into<Vec<u8>> for flash_upload_finish {
    fn into(self) -> Vec<u8> {
        Vec::new()
    }
}

#[allow(non_camel_case_types)]
#[derive(Debug, Clone, PartialEq, PartialOrd)]
pub struct reset {
    pub dfu: u8,
}

impl reset {
    pub fn new(dfu: u8) -> Message {
        let header = MessageHeader {
            message_type: MessageType::command_response,
            payload_length: 0x01,
            message_class: MessageClass::dfu,
            message_id: 0x00,
        };
        let payload = reset { dfu };
        let payload = MessagePayload::cmd_dfu_reset(payload);
        Message { header, payload }
    }
}

impl From<&[u8]> for reset {
    fn from(data: &[u8]) -> reset {
        let mut cursor = Cursor::new(data);
        reset {
            dfu: cursor.get_u8(),
        }
    }
}

impl Into<Vec<u8>> for reset {
    fn into(self) -> Vec<u8> {
        let mut bytes = Vec::new();
        bytes.put_u8(self.dfu);
        bytes
    }
}