1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
use crate::native::boundednum::*;
use crate::fawkes_crypto::{
ff_uint::{Uint, PrimeField, Num, NumRepr},
borsh::{BorshDeserialize, BorshSerialize},
serde::{Serialize, Deserialize, Serializer, Deserializer, de},
};
use std::io::{Write, self};
impl<Fr:PrimeField, const L: usize> BorshSerialize for BoundedNum<Fr, L> {
fn serialize<W: Write>(&self, writer: &mut W) -> io::Result<()> {
let n_limbs = (L - 1) / 8 + 1;
let w = writer.write(&self.0.try_to_vec().unwrap()[0..n_limbs])?;
if w!=n_limbs {
Err(io::Error::new(io::ErrorKind::Other, "Writer is broken"))
} else {
Ok(())
}
}
}
impl<Fr:PrimeField, const L: usize> BorshDeserialize for BoundedNum<Fr, L> {
fn deserialize(buf: &mut &[u8]) -> io::Result<Self> {
let n_limbs = (L - 1) / 8 + 1;
let n_limbs_total = Fr::Inner::NUM_WORDS*Fr::Inner::WORD_BITS/8;
let mut b = vec![0;n_limbs_total];
b[0..n_limbs].copy_from_slice(&buf[0..n_limbs]);
*buf = &buf[n_limbs..];
let n = Num::<Fr>::try_from_slice(&b)?;
Ok(Self(n))
}
}
impl<Fr:PrimeField, const L: usize> Serialize for BoundedNum<Fr, L> {
fn serialize<S: Serializer>(&self, serializer: S) -> Result<S::Ok, S::Error> {
Serialize::serialize(&self.0, serializer)
}
}
impl<'de, Fr:PrimeField, const L: usize> Deserialize<'de> for BoundedNum<Fr, L> {
fn deserialize<D: Deserializer<'de>>(deserializer: D) -> Result<Self, D::Error> {
let n: NumRepr<Fr::Inner> = Deserialize::deserialize(deserializer)?;
if n >= (NumRepr::ONE << L as u32) {
Err(de::Error::custom("Overflow"))
} else {
Ok(Self::new(Num::from_uint_unchecked(n)))
}
}
}