pub type Model140 = Hvrtx;
#[derive(Debug)]
#[cfg_attr(feature = "serde", derive(::serde::Serialize, ::serde::Deserialize))]
pub struct Hvrtx {
pub act_crv: u16,
pub mod_ena: ModEna,
pub win_tms: Option<u16>,
pub rvrt_tms: Option<u16>,
pub rmp_tms: Option<u16>,
pub n_crv: u16,
pub n_pt: u16,
pub tms_sf: i16,
pub v_sf: i16,
#[allow(missing_docs)]
pub crv_type: CrvType,
#[allow(missing_docs)]
pub curve: Vec<Curve>,
}
#[allow(missing_docs)]
impl Hvrtx {
pub const ACT_CRV: crate::Point<Self, u16> = crate::Point::new(0, 1, true);
pub const MOD_ENA: crate::Point<Self, ModEna> = crate::Point::new(1, 1, true);
pub const WIN_TMS: crate::Point<Self, Option<u16>> = crate::Point::new(2, 1, true);
pub const RVRT_TMS: crate::Point<Self, Option<u16>> = crate::Point::new(3, 1, true);
pub const RMP_TMS: crate::Point<Self, Option<u16>> = crate::Point::new(4, 1, true);
pub const N_CRV: crate::Point<Self, u16> = crate::Point::new(5, 1, false);
pub const N_PT: crate::Point<Self, u16> = crate::Point::new(6, 1, false);
pub const TMS_SF: crate::Point<Self, i16> = crate::Point::new(7, 1, false);
pub const V_SF: crate::Point<Self, i16> = crate::Point::new(8, 1, false);
pub const CRV_TYPE: crate::Point<Self, CrvType> = crate::Point::new(9, 1, false);
}
impl crate::Group for Hvrtx {
const LEN: u16 = 10;
}
impl Hvrtx {
fn parse_group(data: &[u16]) -> Result<(&[u16], Self), crate::DecodeError> {
let nested_data = data
.get(usize::from(<Self as crate::Group>::LEN)..)
.unwrap_or(&[]);
let (nested_data, curve) = Curve::parse_multiple(nested_data)?;
Ok((
nested_data,
Self {
act_crv: Self::ACT_CRV.from_data(data)?,
mod_ena: Self::MOD_ENA.from_data(data)?,
win_tms: Self::WIN_TMS.from_data(data)?,
rvrt_tms: Self::RVRT_TMS.from_data(data)?,
rmp_tms: Self::RMP_TMS.from_data(data)?,
n_crv: Self::N_CRV.from_data(data)?,
n_pt: Self::N_PT.from_data(data)?,
tms_sf: Self::TMS_SF.from_data(data)?,
v_sf: Self::V_SF.from_data(data)?,
crv_type: Self::CRV_TYPE.from_data(data)?,
curve,
},
))
}
}
bitflags::bitflags! {
#[doc = " ModEna"] #[doc = " "] #[doc =
" LVRT control mode. Enable active curve. Bitfield value."] #[derive(Copy, Clone,
Debug, Eq, PartialEq)] #[cfg_attr(feature = "serde", derive(::serde::Serialize,
::serde::Deserialize))] pub struct ModEna : u16 { #[allow(missing_docs)] const
Enabled = 1; }
}
impl crate::Value for ModEna {
fn decode(data: &[u16]) -> Result<Self, crate::DecodeError> {
let value = u16::decode(data)?;
Ok(Self::from_bits_retain(value))
}
fn encode(self) -> Box<[u16]> {
self.bits().encode()
}
}
impl crate::FixedSize for ModEna {
const SIZE: u16 = 1u16;
const INVALID: Self = Self::from_bits_retain(65535u16);
fn is_invalid(&self) -> bool {
self.bits() == 65535u16
}
}
#[allow(missing_docs)]
#[derive(Copy, Clone, Debug, Eq, PartialEq)]
#[cfg_attr(feature = "serde", derive(::serde::Serialize, ::serde::Deserialize))]
pub enum CrvType {
#[allow(missing_docs)]
CeaseToEnergize,
Invalid(u16),
}
impl crate::EnumValue for CrvType {
type Repr = u16;
const INVALID: Self::Repr = 65535;
fn from_repr(value: Self::Repr) -> Self {
match value {
1 => Self::CeaseToEnergize,
value => Self::Invalid(value),
}
}
fn to_repr(self) -> Self::Repr {
match self {
Self::CeaseToEnergize => 1,
Self::Invalid(value) => value,
}
}
}
impl crate::FixedSize for CrvType {
const SIZE: u16 = 1u16;
const INVALID: Self = Self::Invalid(65535);
fn is_invalid(&self) -> bool {
matches!(self, Self::Invalid(_))
}
}
#[allow(missing_docs)]
#[derive(Debug)]
#[cfg_attr(feature = "serde", derive(::serde::Serialize, ::serde::Deserialize))]
pub struct Curve {
pub act_pt: u16,
pub tms1: u16,
pub v1: u16,
pub tms2: Option<u16>,
pub v2: Option<u16>,
pub tms3: Option<u16>,
pub v3: Option<u16>,
pub tms4: Option<u16>,
pub v4: Option<u16>,
pub tms5: Option<u16>,
pub v5: Option<u16>,
pub tms6: Option<u16>,
pub v6: Option<u16>,
pub tms7: Option<u16>,
pub v7: Option<u16>,
pub tms8: Option<u16>,
pub v8: Option<u16>,
pub tms9: Option<u16>,
pub v9: Option<u16>,
pub tms10: Option<u16>,
pub v10: Option<u16>,
pub tms11: Option<u16>,
pub v11: Option<u16>,
pub tms12: Option<u16>,
pub v12: Option<u16>,
pub tms13: Option<u16>,
pub v13: Option<u16>,
pub tms14: Option<u16>,
pub v14: Option<u16>,
pub tms15: Option<u16>,
pub v15: Option<u16>,
pub tms16: Option<u16>,
pub v16: Option<u16>,
pub tms17: Option<u16>,
pub v17: Option<u16>,
pub tms18: Option<u16>,
pub v18: Option<u16>,
pub tms19: Option<u16>,
pub v19: Option<u16>,
pub tms20: Option<u16>,
pub v20: Option<u16>,
pub crv_nam: Option<String>,
pub read_only: CurveReadOnly,
}
#[allow(missing_docs)]
impl Curve {
pub const ACT_PT: crate::Point<Self, u16> = crate::Point::new(0, 1, true);
pub const TMS1: crate::Point<Self, u16> = crate::Point::new(1, 1, true);
pub const V1: crate::Point<Self, u16> = crate::Point::new(2, 1, true);
pub const TMS2: crate::Point<Self, Option<u16>> = crate::Point::new(3, 1, true);
pub const V2: crate::Point<Self, Option<u16>> = crate::Point::new(4, 1, true);
pub const TMS3: crate::Point<Self, Option<u16>> = crate::Point::new(5, 1, true);
pub const V3: crate::Point<Self, Option<u16>> = crate::Point::new(6, 1, true);
pub const TMS4: crate::Point<Self, Option<u16>> = crate::Point::new(7, 1, true);
pub const V4: crate::Point<Self, Option<u16>> = crate::Point::new(8, 1, true);
pub const TMS5: crate::Point<Self, Option<u16>> = crate::Point::new(9, 1, true);
pub const V5: crate::Point<Self, Option<u16>> = crate::Point::new(10, 1, true);
pub const TMS6: crate::Point<Self, Option<u16>> = crate::Point::new(11, 1, true);
pub const V6: crate::Point<Self, Option<u16>> = crate::Point::new(12, 1, true);
pub const TMS7: crate::Point<Self, Option<u16>> = crate::Point::new(13, 1, true);
pub const V7: crate::Point<Self, Option<u16>> = crate::Point::new(14, 1, true);
pub const TMS8: crate::Point<Self, Option<u16>> = crate::Point::new(15, 1, true);
pub const V8: crate::Point<Self, Option<u16>> = crate::Point::new(16, 1, true);
pub const TMS9: crate::Point<Self, Option<u16>> = crate::Point::new(17, 1, true);
pub const V9: crate::Point<Self, Option<u16>> = crate::Point::new(18, 1, true);
pub const TMS10: crate::Point<Self, Option<u16>> = crate::Point::new(19, 1, true);
pub const V10: crate::Point<Self, Option<u16>> = crate::Point::new(20, 1, true);
pub const TMS11: crate::Point<Self, Option<u16>> = crate::Point::new(21, 1, true);
pub const V11: crate::Point<Self, Option<u16>> = crate::Point::new(22, 1, true);
pub const TMS12: crate::Point<Self, Option<u16>> = crate::Point::new(23, 1, true);
pub const V12: crate::Point<Self, Option<u16>> = crate::Point::new(24, 1, true);
pub const TMS13: crate::Point<Self, Option<u16>> = crate::Point::new(25, 1, true);
pub const V13: crate::Point<Self, Option<u16>> = crate::Point::new(26, 1, true);
pub const TMS14: crate::Point<Self, Option<u16>> = crate::Point::new(27, 1, true);
pub const V14: crate::Point<Self, Option<u16>> = crate::Point::new(28, 1, true);
pub const TMS15: crate::Point<Self, Option<u16>> = crate::Point::new(29, 1, true);
pub const V15: crate::Point<Self, Option<u16>> = crate::Point::new(30, 1, true);
pub const TMS16: crate::Point<Self, Option<u16>> = crate::Point::new(31, 1, true);
pub const V16: crate::Point<Self, Option<u16>> = crate::Point::new(32, 1, true);
pub const TMS17: crate::Point<Self, Option<u16>> = crate::Point::new(33, 1, true);
pub const V17: crate::Point<Self, Option<u16>> = crate::Point::new(34, 1, true);
pub const TMS18: crate::Point<Self, Option<u16>> = crate::Point::new(35, 1, true);
pub const V18: crate::Point<Self, Option<u16>> = crate::Point::new(36, 1, true);
pub const TMS19: crate::Point<Self, Option<u16>> = crate::Point::new(37, 1, true);
pub const V19: crate::Point<Self, Option<u16>> = crate::Point::new(38, 1, true);
pub const TMS20: crate::Point<Self, Option<u16>> = crate::Point::new(39, 1, true);
pub const V20: crate::Point<Self, Option<u16>> = crate::Point::new(40, 1, true);
pub const CRV_NAM: crate::Point<Self, Option<String>> = crate::Point::new(41, 8, true);
pub const READ_ONLY: crate::Point<Self, CurveReadOnly> = crate::Point::new(49, 1, false);
}
impl crate::Group for Curve {
const LEN: u16 = 50;
}
impl Curve {
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 {
act_pt: Self::ACT_PT.from_data(data)?,
tms1: Self::TMS1.from_data(data)?,
v1: Self::V1.from_data(data)?,
tms2: Self::TMS2.from_data(data)?,
v2: Self::V2.from_data(data)?,
tms3: Self::TMS3.from_data(data)?,
v3: Self::V3.from_data(data)?,
tms4: Self::TMS4.from_data(data)?,
v4: Self::V4.from_data(data)?,
tms5: Self::TMS5.from_data(data)?,
v5: Self::V5.from_data(data)?,
tms6: Self::TMS6.from_data(data)?,
v6: Self::V6.from_data(data)?,
tms7: Self::TMS7.from_data(data)?,
v7: Self::V7.from_data(data)?,
tms8: Self::TMS8.from_data(data)?,
v8: Self::V8.from_data(data)?,
tms9: Self::TMS9.from_data(data)?,
v9: Self::V9.from_data(data)?,
tms10: Self::TMS10.from_data(data)?,
v10: Self::V10.from_data(data)?,
tms11: Self::TMS11.from_data(data)?,
v11: Self::V11.from_data(data)?,
tms12: Self::TMS12.from_data(data)?,
v12: Self::V12.from_data(data)?,
tms13: Self::TMS13.from_data(data)?,
v13: Self::V13.from_data(data)?,
tms14: Self::TMS14.from_data(data)?,
v14: Self::V14.from_data(data)?,
tms15: Self::TMS15.from_data(data)?,
v15: Self::V15.from_data(data)?,
tms16: Self::TMS16.from_data(data)?,
v16: Self::V16.from_data(data)?,
tms17: Self::TMS17.from_data(data)?,
v17: Self::V17.from_data(data)?,
tms18: Self::TMS18.from_data(data)?,
v18: Self::V18.from_data(data)?,
tms19: Self::TMS19.from_data(data)?,
v19: Self::V19.from_data(data)?,
tms20: Self::TMS20.from_data(data)?,
v20: Self::V20.from_data(data)?,
crv_nam: Self::CRV_NAM.from_data(data)?,
read_only: Self::READ_ONLY.from_data(data)?,
},
))
}
fn parse_multiple(data: &[u16]) -> Result<(&[u16], Vec<Self>), crate::DecodeError> {
let group_len = usize::from(<Curve as crate::Group>::LEN);
if group_len == 0 {
return Ok((data, Vec::new()));
}
if data.len() % group_len != 0 {
return Err(crate::DecodeError::OutOfBounds);
}
let group_count = data.len() / group_len;
let (data, groups) =
(0..group_count).try_fold((data, Vec::new()), |(data, mut groups), _| {
let (data, group) = Curve::parse_group(data)?;
groups.push(group);
Ok::<_, crate::DecodeError>((data, groups))
})?;
Ok((data, groups))
}
}
#[derive(Copy, Clone, Debug, Eq, PartialEq)]
#[cfg_attr(feature = "serde", derive(::serde::Serialize, ::serde::Deserialize))]
pub enum CurveReadOnly {
#[allow(missing_docs)]
Readwrite,
#[allow(missing_docs)]
Readonly,
Invalid(u16),
}
impl crate::EnumValue for CurveReadOnly {
type Repr = u16;
const INVALID: Self::Repr = 65535;
fn from_repr(value: Self::Repr) -> Self {
match value {
0 => Self::Readwrite,
1 => Self::Readonly,
value => Self::Invalid(value),
}
}
fn to_repr(self) -> Self::Repr {
match self {
Self::Readwrite => 0,
Self::Readonly => 1,
Self::Invalid(value) => value,
}
}
}
impl crate::FixedSize for CurveReadOnly {
const SIZE: u16 = 1u16;
const INVALID: Self = Self::Invalid(65535);
fn is_invalid(&self) -> bool {
matches!(self, Self::Invalid(_))
}
}
impl crate::Model for Hvrtx {
const ID: u16 = 140;
fn addr(models: &crate::Models) -> crate::ModelAddr<Self> {
models.m140
}
fn parse(data: &[u16]) -> Result<Self, crate::ParseError<Self>> {
let (_, model) = Self::parse_group(data)?;
Ok(model)
}
}