use super::*;
impl<N: Network> FromBytes for Register<N> {
fn read_le<R: Read>(mut reader: R) -> IoResult<Self> {
let variant = u8::read_le(&mut reader)?;
let locator = read_variable_length_integer(&mut reader)?;
match variant {
0 => Ok(Self::Locator(locator)),
1 => {
let num_accesses = u16::read_le(&mut reader)?;
if num_accesses as usize > N::MAX_DATA_DEPTH {
return Err(error("Failed to deserialize register: Register access exceeds maximum depth"));
}
let accesses = (0..num_accesses).map(|_| Access::read_le(&mut reader)).collect::<IoResult<Vec<_>>>()?;
Ok(Self::Access(locator, accesses))
}
2.. => Err(error(format!("Failed to deserialize register variant {variant}"))),
}
}
}
impl<N: Network> ToBytes for Register<N> {
fn write_le<W: Write>(&self, mut writer: W) -> IoResult<()> {
match self {
Self::Locator(locator) => {
u8::write_le(&0u8, &mut writer)?;
variable_length_integer(locator).write_le(&mut writer)
}
Self::Access(locator, accesses) => {
if accesses.len() > N::MAX_DATA_DEPTH {
return Err(error("Failed to serialize register: too many accesses"));
}
u8::write_le(&1u8, &mut writer)?;
variable_length_integer(locator).write_le(&mut writer)?;
u16::try_from(accesses.len()).map_err(error)?.write_le(&mut writer)?;
accesses.write_le(&mut writer)
}
}
}
}