#[derive(Debug)]
#[cfg_attr(feature = "serde", derive(::serde::Serialize, ::serde::Deserialize))]
pub struct Model12 {
pub nam: Option<String>,
pub cfg_st: CfgSt,
pub chg_st: ChgSt,
pub cap: Cap,
pub cfg: Cfg,
pub ctl: Ctl,
pub addr: String,
pub msk: String,
pub gw: Option<String>,
pub dns1: Option<String>,
pub dns2: Option<String>,
pub ntp1: Option<String>,
pub ntp2: Option<String>,
pub dom_nam: Option<String>,
pub host_nam: Option<String>,
}
#[allow(missing_docs)]
impl Model12 {
pub const NAM: crate::Point<Self, Option<String>> = crate::Point::new(0, 4, true);
pub const CFG_ST: crate::Point<Self, CfgSt> = crate::Point::new(4, 1, false);
pub const CHG_ST: crate::Point<Self, ChgSt> = crate::Point::new(5, 1, false);
pub const CAP: crate::Point<Self, Cap> = crate::Point::new(6, 1, false);
pub const CFG: crate::Point<Self, Cfg> = crate::Point::new(7, 1, true);
pub const CTL: crate::Point<Self, Ctl> = crate::Point::new(8, 1, true);
pub const ADDR: crate::Point<Self, String> = crate::Point::new(9, 8, true);
pub const MSK: crate::Point<Self, String> = crate::Point::new(17, 8, true);
pub const GW: crate::Point<Self, Option<String>> = crate::Point::new(25, 8, true);
pub const DNS1: crate::Point<Self, Option<String>> = crate::Point::new(33, 8, true);
pub const DNS2: crate::Point<Self, Option<String>> = crate::Point::new(41, 8, true);
pub const NTP1: crate::Point<Self, Option<String>> = crate::Point::new(49, 12, true);
pub const NTP2: crate::Point<Self, Option<String>> = crate::Point::new(61, 12, true);
pub const DOM_NAM: crate::Point<Self, Option<String>> = crate::Point::new(73, 12, true);
pub const HOST_NAM: crate::Point<Self, Option<String>> = crate::Point::new(85, 12, true);
}
impl crate::Group for Model12 {
const LEN: u16 = 98;
}
impl Model12 {
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 {
nam: Self::NAM.from_data(data)?,
cfg_st: Self::CFG_ST.from_data(data)?,
chg_st: Self::CHG_ST.from_data(data)?,
cap: Self::CAP.from_data(data)?,
cfg: Self::CFG.from_data(data)?,
ctl: Self::CTL.from_data(data)?,
addr: Self::ADDR.from_data(data)?,
msk: Self::MSK.from_data(data)?,
gw: Self::GW.from_data(data)?,
dns1: Self::DNS1.from_data(data)?,
dns2: Self::DNS2.from_data(data)?,
ntp1: Self::NTP1.from_data(data)?,
ntp2: Self::NTP2.from_data(data)?,
dom_nam: Self::DOM_NAM.from_data(data)?,
host_nam: Self::HOST_NAM.from_data(data)?,
},
))
}
}
#[derive(Copy, Clone, Debug, Eq, PartialEq)]
#[cfg_attr(feature = "serde", derive(::serde::Serialize, ::serde::Deserialize))]
pub enum CfgSt {
#[allow(missing_docs)]
NotConfigured,
#[allow(missing_docs)]
ValidSetting,
#[allow(missing_docs)]
ValidHw,
Invalid(u16),
}
impl crate::EnumValue for CfgSt {
type Repr = u16;
const INVALID: Self::Repr = 65535;
fn from_repr(value: Self::Repr) -> Self {
match value {
0 => Self::NotConfigured,
1 => Self::ValidSetting,
2 => Self::ValidHw,
value => Self::Invalid(value),
}
}
fn to_repr(self) -> Self::Repr {
match self {
Self::NotConfigured => 0,
Self::ValidSetting => 1,
Self::ValidHw => 2,
Self::Invalid(value) => value,
}
}
}
impl crate::FixedSize for CfgSt {
const SIZE: u16 = 1u16;
const INVALID: Self = Self::Invalid(65535);
fn is_invalid(&self) -> bool {
matches!(self, Self::Invalid(_))
}
}
bitflags::bitflags! {
#[doc = " Change Status"] #[doc = " "] #[doc =
" Bitmask value. A configuration change is pending"] #[derive(Copy, Clone, Debug,
Eq, PartialEq)] #[cfg_attr(feature = "serde", derive(::serde::Serialize,
::serde::Deserialize))] pub struct ChgSt : u16 { #[allow(missing_docs)] const Pending
= 1; }
}
impl crate::Value for ChgSt {
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 ChgSt {
const SIZE: u16 = 1u16;
const INVALID: Self = Self::from_bits_retain(65535u16);
fn is_invalid(&self) -> bool {
self.bits() == 65535u16
}
}
bitflags::bitflags! {
#[doc = " Config Capability"] #[doc = " "] #[doc =
" Bitmask value. Identify capable sources of configuration"] #[derive(Copy, Clone,
Debug, Eq, PartialEq)] #[cfg_attr(feature = "serde", derive(::serde::Serialize,
::serde::Deserialize))] pub struct Cap : u16 { #[allow(missing_docs)] const Dhcp = 1;
#[allow(missing_docs)] const Bootp = 2; #[allow(missing_docs)] const Zeroconf = 4;
#[allow(missing_docs)] const Dns = 8; #[allow(missing_docs)] const CfgSettable = 16;
#[allow(missing_docs)] const HwConfig = 32; #[allow(missing_docs)] const NtpClient =
64; #[allow(missing_docs)] const ResetRequired = 128; }
}
impl crate::Value for Cap {
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 Cap {
const SIZE: u16 = 1u16;
const INVALID: Self = Self::from_bits_retain(65535u16);
fn is_invalid(&self) -> bool {
self.bits() == 65535u16
}
}
#[derive(Copy, Clone, Debug, Eq, PartialEq)]
#[cfg_attr(feature = "serde", derive(::serde::Serialize, ::serde::Deserialize))]
pub enum Cfg {
#[allow(missing_docs)]
Static,
#[allow(missing_docs)]
Dhcp,
#[allow(missing_docs)]
Bootp,
#[allow(missing_docs)]
Zeroconf,
Invalid(u16),
}
impl crate::EnumValue for Cfg {
type Repr = u16;
const INVALID: Self::Repr = 65535;
fn from_repr(value: Self::Repr) -> Self {
match value {
0 => Self::Static,
1 => Self::Dhcp,
2 => Self::Bootp,
3 => Self::Zeroconf,
value => Self::Invalid(value),
}
}
fn to_repr(self) -> Self::Repr {
match self {
Self::Static => 0,
Self::Dhcp => 1,
Self::Bootp => 2,
Self::Zeroconf => 3,
Self::Invalid(value) => value,
}
}
}
impl crate::FixedSize for Cfg {
const SIZE: u16 = 1u16;
const INVALID: Self = Self::Invalid(65535);
fn is_invalid(&self) -> bool {
matches!(self, Self::Invalid(_))
}
}
#[derive(Copy, Clone, Debug, Eq, PartialEq)]
#[cfg_attr(feature = "serde", derive(::serde::Serialize, ::serde::Deserialize))]
pub enum Ctl {
#[allow(missing_docs)]
EnableDns,
#[allow(missing_docs)]
EnableNtp,
Invalid(u16),
}
impl crate::EnumValue for Ctl {
type Repr = u16;
const INVALID: Self::Repr = 65535;
fn from_repr(value: Self::Repr) -> Self {
match value {
0 => Self::EnableDns,
1 => Self::EnableNtp,
value => Self::Invalid(value),
}
}
fn to_repr(self) -> Self::Repr {
match self {
Self::EnableDns => 0,
Self::EnableNtp => 1,
Self::Invalid(value) => value,
}
}
}
impl crate::FixedSize for Ctl {
const SIZE: u16 = 1u16;
const INVALID: Self = Self::Invalid(65535);
fn is_invalid(&self) -> bool {
matches!(self, Self::Invalid(_))
}
}
impl crate::Model for Model12 {
const ID: u16 = 12;
fn addr(models: &crate::Models) -> crate::ModelAddr<Self> {
models.m12
}
fn parse(data: &[u16]) -> Result<Self, crate::ParseError<Self>> {
let (_, model) = Self::parse_group(data)?;
Ok(model)
}
}