primitives/algebra/
biguint.rs1use derive_more::derive::{AsMut, AsRef, Deref, DerefMut, From};
2use serde::{Deserialize, Serialize};
3
4#[derive(Debug, Clone, Deref, DerefMut, PartialEq, Eq, Hash, AsRef, AsMut, From)]
8#[as_ref(forward)]
9#[from(forward)]
10pub struct BoxedUint(crypto_bigint::BoxedUint);
11
12impl Serialize for BoxedUint {
13 fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
14 where
15 S: serde::Serializer,
16 {
17 let bytes = self.0.to_le_bytes();
18 bytes.serialize(serializer)
19 }
20}
21
22impl<'de> Deserialize<'de> for BoxedUint {
23 fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>
24 where
25 D: serde::Deserializer<'de>,
26 {
27 let bytes = Vec::<u8>::deserialize(deserializer)?;
28 let bits_precision = bytes.len() * 8;
29 let boxed_uint = crypto_bigint::BoxedUint::from_le_slice(&bytes, bits_precision as u32)
30 .map_err(serde::de::Error::custom)?;
31 Ok(BoxedUint(boxed_uint))
32 }
33}