pub type Model124 = StorageBasic;
#[derive(Debug)]
#[cfg_attr(feature = "serde", derive(::serde::Serialize, ::serde::Deserialize))]
pub struct StorageBasic {
pub w_cha_max: u16,
pub w_cha_gra: u16,
pub w_dis_cha_gra: u16,
pub stor_ctl_mod: StorCtlMod,
pub va_cha_max: Option<u16>,
pub min_rsv_pct: Option<u16>,
pub cha_state: Option<u16>,
pub stor_aval: Option<u16>,
pub in_bat_v: Option<u16>,
pub cha_st: Option<ChaSt>,
pub out_w_rte: Option<i16>,
pub in_w_rte: Option<i16>,
pub in_out_w_rte_win_tms: Option<u16>,
pub in_out_w_rte_rvrt_tms: Option<u16>,
pub in_out_w_rte_rmp_tms: Option<u16>,
#[allow(missing_docs)]
pub cha_gri_set: Option<ChaGriSet>,
pub w_cha_max_sf: i16,
pub w_cha_dis_cha_gra_sf: i16,
pub va_cha_max_sf: Option<i16>,
pub min_rsv_pct_sf: Option<i16>,
pub cha_state_sf: Option<i16>,
pub stor_aval_sf: Option<i16>,
pub in_bat_v_sf: Option<i16>,
pub in_out_w_rte_sf: Option<i16>,
}
#[allow(missing_docs)]
impl StorageBasic {
pub const W_CHA_MAX: crate::Point<Self, u16> = crate::Point::new(0, 1, true);
pub const W_CHA_GRA: crate::Point<Self, u16> = crate::Point::new(1, 1, true);
pub const W_DIS_CHA_GRA: crate::Point<Self, u16> = crate::Point::new(2, 1, true);
pub const STOR_CTL_MOD: crate::Point<Self, StorCtlMod> = crate::Point::new(3, 1, true);
pub const VA_CHA_MAX: crate::Point<Self, Option<u16>> = crate::Point::new(4, 1, true);
pub const MIN_RSV_PCT: crate::Point<Self, Option<u16>> = crate::Point::new(5, 1, true);
pub const CHA_STATE: crate::Point<Self, Option<u16>> = crate::Point::new(6, 1, false);
pub const STOR_AVAL: crate::Point<Self, Option<u16>> = crate::Point::new(7, 1, false);
pub const IN_BAT_V: crate::Point<Self, Option<u16>> = crate::Point::new(8, 1, false);
pub const CHA_ST: crate::Point<Self, Option<ChaSt>> = crate::Point::new(9, 1, false);
pub const OUT_W_RTE: crate::Point<Self, Option<i16>> = crate::Point::new(10, 1, true);
pub const IN_W_RTE: crate::Point<Self, Option<i16>> = crate::Point::new(11, 1, true);
pub const IN_OUT_W_RTE_WIN_TMS: crate::Point<Self, Option<u16>> =
crate::Point::new(12, 1, true);
pub const IN_OUT_W_RTE_RVRT_TMS: crate::Point<Self, Option<u16>> =
crate::Point::new(13, 1, true);
pub const IN_OUT_W_RTE_RMP_TMS: crate::Point<Self, Option<u16>> =
crate::Point::new(14, 1, true);
pub const CHA_GRI_SET: crate::Point<Self, Option<ChaGriSet>> = crate::Point::new(15, 1, true);
pub const W_CHA_MAX_SF: crate::Point<Self, i16> = crate::Point::new(16, 1, false);
pub const W_CHA_DIS_CHA_GRA_SF: crate::Point<Self, i16> = crate::Point::new(17, 1, false);
pub const VA_CHA_MAX_SF: crate::Point<Self, Option<i16>> = crate::Point::new(18, 1, false);
pub const MIN_RSV_PCT_SF: crate::Point<Self, Option<i16>> = crate::Point::new(19, 1, false);
pub const CHA_STATE_SF: crate::Point<Self, Option<i16>> = crate::Point::new(20, 1, false);
pub const STOR_AVAL_SF: crate::Point<Self, Option<i16>> = crate::Point::new(21, 1, false);
pub const IN_BAT_V_SF: crate::Point<Self, Option<i16>> = crate::Point::new(22, 1, false);
pub const IN_OUT_W_RTE_SF: crate::Point<Self, Option<i16>> = crate::Point::new(23, 1, false);
}
impl crate::Group for StorageBasic {
const LEN: u16 = 24;
}
impl StorageBasic {
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 {
w_cha_max: Self::W_CHA_MAX.from_data(data)?,
w_cha_gra: Self::W_CHA_GRA.from_data(data)?,
w_dis_cha_gra: Self::W_DIS_CHA_GRA.from_data(data)?,
stor_ctl_mod: Self::STOR_CTL_MOD.from_data(data)?,
va_cha_max: Self::VA_CHA_MAX.from_data(data)?,
min_rsv_pct: Self::MIN_RSV_PCT.from_data(data)?,
cha_state: Self::CHA_STATE.from_data(data)?,
stor_aval: Self::STOR_AVAL.from_data(data)?,
in_bat_v: Self::IN_BAT_V.from_data(data)?,
cha_st: Self::CHA_ST.from_data(data)?,
out_w_rte: Self::OUT_W_RTE.from_data(data)?,
in_w_rte: Self::IN_W_RTE.from_data(data)?,
in_out_w_rte_win_tms: Self::IN_OUT_W_RTE_WIN_TMS.from_data(data)?,
in_out_w_rte_rvrt_tms: Self::IN_OUT_W_RTE_RVRT_TMS.from_data(data)?,
in_out_w_rte_rmp_tms: Self::IN_OUT_W_RTE_RMP_TMS.from_data(data)?,
cha_gri_set: Self::CHA_GRI_SET.from_data(data)?,
w_cha_max_sf: Self::W_CHA_MAX_SF.from_data(data)?,
w_cha_dis_cha_gra_sf: Self::W_CHA_DIS_CHA_GRA_SF.from_data(data)?,
va_cha_max_sf: Self::VA_CHA_MAX_SF.from_data(data)?,
min_rsv_pct_sf: Self::MIN_RSV_PCT_SF.from_data(data)?,
cha_state_sf: Self::CHA_STATE_SF.from_data(data)?,
stor_aval_sf: Self::STOR_AVAL_SF.from_data(data)?,
in_bat_v_sf: Self::IN_BAT_V_SF.from_data(data)?,
in_out_w_rte_sf: Self::IN_OUT_W_RTE_SF.from_data(data)?,
},
))
}
}
bitflags::bitflags! {
#[doc = " StorCtl_Mod"] #[doc = " "] #[doc =
" Activate hold/discharge/charge storage control mode. Bitfield value."]
#[derive(Copy, Clone, Debug, Eq, PartialEq)] #[cfg_attr(feature = "serde",
derive(::serde::Serialize, ::serde::Deserialize))] pub struct StorCtlMod : u16 {
#[allow(missing_docs)] const Charge = 1; #[allow(missing_docs)] const DiScharge = 2;
}
}
impl crate::Value for StorCtlMod {
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 StorCtlMod {
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 ChaSt {
#[allow(missing_docs)]
Off,
#[allow(missing_docs)]
Empty,
#[allow(missing_docs)]
Discharging,
#[allow(missing_docs)]
Charging,
#[allow(missing_docs)]
Full,
#[allow(missing_docs)]
Holding,
#[allow(missing_docs)]
Testing,
Invalid(u16),
}
impl crate::EnumValue for ChaSt {
type Repr = u16;
const INVALID: Self::Repr = 65535;
fn from_repr(value: Self::Repr) -> Self {
match value {
1 => Self::Off,
2 => Self::Empty,
3 => Self::Discharging,
4 => Self::Charging,
5 => Self::Full,
6 => Self::Holding,
7 => Self::Testing,
value => Self::Invalid(value),
}
}
fn to_repr(self) -> Self::Repr {
match self {
Self::Off => 1,
Self::Empty => 2,
Self::Discharging => 3,
Self::Charging => 4,
Self::Full => 5,
Self::Holding => 6,
Self::Testing => 7,
Self::Invalid(value) => value,
}
}
}
impl crate::FixedSize for ChaSt {
const SIZE: u16 = 1u16;
const INVALID: Self = Self::Invalid(65535);
fn is_invalid(&self) -> bool {
matches!(self, Self::Invalid(_))
}
}
#[allow(missing_docs)]
#[derive(Copy, Clone, Debug, Eq, PartialEq)]
#[cfg_attr(feature = "serde", derive(::serde::Serialize, ::serde::Deserialize))]
pub enum ChaGriSet {
#[allow(missing_docs)]
Pv,
#[allow(missing_docs)]
Grid,
Invalid(u16),
}
impl crate::EnumValue for ChaGriSet {
type Repr = u16;
const INVALID: Self::Repr = 65535;
fn from_repr(value: Self::Repr) -> Self {
match value {
0 => Self::Pv,
1 => Self::Grid,
value => Self::Invalid(value),
}
}
fn to_repr(self) -> Self::Repr {
match self {
Self::Pv => 0,
Self::Grid => 1,
Self::Invalid(value) => value,
}
}
}
impl crate::FixedSize for ChaGriSet {
const SIZE: u16 = 1u16;
const INVALID: Self = Self::Invalid(65535);
fn is_invalid(&self) -> bool {
matches!(self, Self::Invalid(_))
}
}
impl crate::Model for StorageBasic {
const ID: u16 = 124;
fn addr(models: &crate::Models) -> crate::ModelAddr<Self> {
models.m124
}
fn parse(data: &[u16]) -> Result<Self, crate::ParseError<Self>> {
let (_, model) = Self::parse_group(data)?;
Ok(model)
}
}