wolfrpg_map_parser/command/input_key_command/input_toggle/
device.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
#[cfg(feature = "serde")]
use serde::{Serialize, Deserialize};
use crate::byte_utils::as_u32_le;
use crate::command::input_key_command::input_toggle::device_inputs::DeviceInputs;

#[cfg_attr(feature = "serde", derive(Serialize, Deserialize))]
#[derive(PartialEq)]
pub struct Device {
    inputs: DeviceInputs,
    enable: bool,
    key_code: Option<u32>
}

impl Device {
    pub(crate) fn parse(bytes: &[u8]) -> (usize, Self) {
        let mut offset: usize = 0;

        let inputs: u8 = bytes[offset];
        let inputs: DeviceInputs = DeviceInputs::new(inputs);
        offset += 1;

        let enable: bool = bytes[offset] == 0;
        offset += 1;

        offset += 1; // Padding

        offset += 1; // input_type

        let key_code: Option<u32> = match inputs {
            DeviceInputs::KeyboardKey => {
                let key_code: u32 = as_u32_le(&bytes[offset..offset + 4]);
                offset += 4;

                Some(key_code)
            }

            _ => None,
        };

        (offset, Self {
            inputs,
            enable,
            key_code
        })
    }

    pub fn inputs(&self) -> &DeviceInputs {
        &self.inputs
    }

    pub fn inputs_mut(&mut self) -> &mut DeviceInputs {
        &mut self.inputs
    }

    pub fn enable(&self) -> bool {
        self.enable
    }

    pub fn enable_mut(&mut self) -> &mut bool {
        &mut self.enable
    }

    pub fn key_code(&self) -> Option<u32> {
        self.key_code
    }

    pub fn key_code_mut(&mut self) -> &mut Option<u32> {
        &mut self.key_code
    }
}