pub type Model703 = DerEnterService;
#[derive(Debug)]
#[cfg_attr(feature = "serde", derive(::serde::Serialize, ::serde::Deserialize))]
pub struct DerEnterService {
pub es: Option<Es>,
pub esv_hi: Option<u16>,
pub esv_lo: Option<u16>,
pub es_hz_hi: Option<u32>,
pub es_hz_lo: Option<u32>,
pub es_dly_tms: Option<u32>,
pub es_rnd_tms: Option<u32>,
pub es_rmp_tms: Option<u32>,
pub es_dly_rem_tms: Option<u32>,
pub v_sf: Option<i16>,
pub hz_sf: Option<i16>,
}
#[allow(missing_docs)]
impl DerEnterService {
pub const ES: crate::Point<Self, Option<Es>> = crate::Point::new(0, 1, true);
pub const ESV_HI: crate::Point<Self, Option<u16>> = crate::Point::new(1, 1, true);
pub const ESV_LO: crate::Point<Self, Option<u16>> = crate::Point::new(2, 1, true);
pub const ES_HZ_HI: crate::Point<Self, Option<u32>> = crate::Point::new(3, 2, true);
pub const ES_HZ_LO: crate::Point<Self, Option<u32>> = crate::Point::new(5, 2, true);
pub const ES_DLY_TMS: crate::Point<Self, Option<u32>> = crate::Point::new(7, 2, true);
pub const ES_RND_TMS: crate::Point<Self, Option<u32>> = crate::Point::new(9, 2, true);
pub const ES_RMP_TMS: crate::Point<Self, Option<u32>> = crate::Point::new(11, 2, true);
pub const ES_DLY_REM_TMS: crate::Point<Self, Option<u32>> = crate::Point::new(13, 2, false);
pub const V_SF: crate::Point<Self, Option<i16>> = crate::Point::new(15, 1, false);
pub const HZ_SF: crate::Point<Self, Option<i16>> = crate::Point::new(16, 1, false);
}
impl crate::Group for DerEnterService {
const LEN: u16 = 17;
}
impl DerEnterService {
fn parse_group(data: &[u16]) -> Result<(&[u16], Self), crate::DecodeError> {
let nested_data = data
.get(usize::from(<Self as crate::Group>::LEN)..)
.unwrap_or(&[]);
Ok((
nested_data,
Self {
es: Self::ES.from_data(data)?,
esv_hi: Self::ESV_HI.from_data(data)?,
esv_lo: Self::ESV_LO.from_data(data)?,
es_hz_hi: Self::ES_HZ_HI.from_data(data)?,
es_hz_lo: Self::ES_HZ_LO.from_data(data)?,
es_dly_tms: Self::ES_DLY_TMS.from_data(data)?,
es_rnd_tms: Self::ES_RND_TMS.from_data(data)?,
es_rmp_tms: Self::ES_RMP_TMS.from_data(data)?,
es_dly_rem_tms: Self::ES_DLY_REM_TMS.from_data(data)?,
v_sf: Self::V_SF.from_data(data)?,
hz_sf: Self::HZ_SF.from_data(data)?,
},
))
}
}
#[derive(Copy, Clone, Debug, Eq, PartialEq)]
#[cfg_attr(feature = "serde", derive(::serde::Serialize, ::serde::Deserialize))]
pub enum Es {
#[allow(missing_docs)]
Disabled,
#[allow(missing_docs)]
Enabled,
Invalid(u16),
}
impl crate::EnumValue for Es {
type Repr = u16;
const INVALID: Self::Repr = 65535;
fn from_repr(value: Self::Repr) -> Self {
match value {
0 => Self::Disabled,
1 => Self::Enabled,
value => Self::Invalid(value),
}
}
fn to_repr(self) -> Self::Repr {
match self {
Self::Disabled => 0,
Self::Enabled => 1,
Self::Invalid(value) => value,
}
}
}
impl crate::FixedSize for Es {
const SIZE: u16 = 1u16;
const INVALID: Self = Self::Invalid(65535);
fn is_invalid(&self) -> bool {
matches!(self, Self::Invalid(_))
}
}
impl crate::Model for DerEnterService {
const ID: u16 = 703;
fn addr(models: &crate::Models) -> crate::ModelAddr<Self> {
models.m703
}
fn parse(data: &[u16]) -> Result<Self, crate::ParseError<Self>> {
let (_, model) = Self::parse_group(data)?;
Ok(model)
}
}