Compare commits
No commits in common. "45dbf1a13c9f67eed05c93d694dc0f62557e2bcd" and "73c4458f230953da4d754266c2092cee451d0cbb" have entirely different histories.
45dbf1a13c
...
73c4458f23
@ -2,7 +2,6 @@
|
|||||||
//! simple static types, which are completely [Context]-independent.
|
//! simple static types, which are completely [Context]-independent.
|
||||||
|
|
||||||
pub mod atomic_object;
|
pub mod atomic_object;
|
||||||
pub mod au64;
|
|
||||||
pub mod boolean;
|
pub mod boolean;
|
||||||
pub mod plain;
|
pub mod plain;
|
||||||
|
|
||||||
|
@ -1,50 +0,0 @@
|
|||||||
use crate::rstd::inlining::*;
|
|
||||||
|
|
||||||
use super::*;
|
|
||||||
|
|
||||||
impl Serializable for u64 {
|
|
||||||
fn serialize(&self, serializer: &mut dyn Serializer) {
|
|
||||||
serializer.write(&self.to_le_bytes());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#[derive(Debug, PartialEq)]
|
|
||||||
pub enum IntParseError {
|
|
||||||
Eof,
|
|
||||||
ExtraData(usize),
|
|
||||||
}
|
|
||||||
|
|
||||||
impl Display for IntParseError {
|
|
||||||
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
|
|
||||||
match self {
|
|
||||||
Self::Eof => f.write_fmt(format_args!("encountered EOF write parsing an integer.")),
|
|
||||||
Self::ExtraData(length) => f.write_fmt(format_args!(
|
|
||||||
"encountered extra data of length {length} while parsing an integer.",
|
|
||||||
)),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl Error for IntParseError {}
|
|
||||||
|
|
||||||
impl From<&[u8]> for IntParseError {
|
|
||||||
fn from(_value: &[u8]) -> Self {
|
|
||||||
Self::Eof
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl Atomic for u64 {
|
|
||||||
type AParseError = IntParseError;
|
|
||||||
|
|
||||||
fn a_deserialize(deserializer: &mut dyn Deserializer) -> Result<Self, Self::AParseError> {
|
|
||||||
Ok(u64::from_le_bytes(deserializer.read_n_const::<8>()?))
|
|
||||||
}
|
|
||||||
|
|
||||||
fn a_unexpected_tail(tail: &[u8]) -> Self::AParseError {
|
|
||||||
IntParseError::ExtraData(tail.len())
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl ConstSizeAtomic for u64 {
|
|
||||||
const SIZE: usize = 8;
|
|
||||||
}
|
|
@ -21,12 +21,15 @@ pub enum BooleanParseError {
|
|||||||
impl Display for BooleanParseError {
|
impl Display for BooleanParseError {
|
||||||
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
|
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
|
||||||
match self {
|
match self {
|
||||||
Self::OutOfBounds(value) => {
|
BooleanParseError::OutOfBounds(value) => {
|
||||||
f.write_fmt(format_args!("boolean value out of bounds: {}.", value))
|
f.write_fmt(format_args!("boolean value out of bounds: {}.", value))
|
||||||
}
|
}
|
||||||
Self::Eof => f.write_fmt(format_args!("encountered EOF write parsing a boolean.")),
|
BooleanParseError::Eof => {
|
||||||
Self::ExtraData(length) => f.write_fmt(format_args!(
|
f.write_fmt(format_args!("encountered EOF write parsing a boolean."))
|
||||||
"encountered extra data of length {length} while parsing a boolean.",
|
}
|
||||||
|
BooleanParseError::ExtraData(length) => f.write_fmt(format_args!(
|
||||||
|
"encountered extra data of length {} while parsing a boolean",
|
||||||
|
length
|
||||||
)),
|
)),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user