@aztec/protocol-contracts 4.0.3 → 4.0.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/artifacts/AuthRegistry.json +15 -15
- package/artifacts/ContractClassRegistry.json +8 -8
- package/artifacts/ContractInstanceRegistry.json +8 -8
- package/artifacts/FeeJuice.json +12 -12
- package/artifacts/MultiCallEntrypoint.json +12 -12
- package/artifacts/PublicChecks.json +16 -16
- package/package.json +4 -4
|
@@ -352,7 +352,7 @@
|
|
|
352
352
|
}
|
|
353
353
|
},
|
|
354
354
|
"bytecode": "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",
|
|
355
|
-
"debug_symbols": "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"
|
|
355
|
+
"debug_symbols": "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"
|
|
356
356
|
},
|
|
357
357
|
{
|
|
358
358
|
"name": "public_dispatch",
|
|
@@ -409,7 +409,7 @@
|
|
|
409
409
|
}
|
|
410
410
|
},
|
|
411
411
|
"bytecode": "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",
|
|
412
|
-
"debug_symbols": "tVnbbhs5DP0XP+dBEkld+itFUbipWxgwnMBNFlgE+fclJZIeGxghmG1ewiNOdHgRRWnGb7ufhx+vv78fz7+e/uy+fH3b/bgcT6fj7++np8f9y/HpzNq3XZA/EfPuS3zYRaIhM6uTSBqy6LjYuA1ZUaWOm45b7TIFUFmGjGlIZB4U2YYkVKnjrOOs48LzC8uaVLK/lWWLKscYAo9jEJAVRPY8RgGkIImGBIimMQCJLgmQ8IABggEJJDMg0RQBohFbGQwUBSUaIANNQU9UB6ZpNr3pdAw6C+PINkZUObKLiadAEFAVQDKQFWA0YBoqfU0xjzXGOnKLtQ4pjnQ5xhRApY5j7jmnFFVSzzVJ1rrUMfIYkgAywH4DZ5FkeQdoI/ckCyy5J1lhyT0VHCknWeMB2HHg3FOTKMW0pArYVg7JQFYgORsADVQFPW0dmAZsOth0tFk4cp0JVI5KzlkznWW1OyjRACmowYBppC4Th1mkMAcwTTRNNE0yTTINmKYXpgBJ8gCmIdOQa5qCXqEdVAUlGSgKqpmoZrQZYTPCpoQ1oAElrBEMKGFNyYASVouiWhTVoqhohGgmyAjJTGQjzGaiGGExE9UIq5moRtjMRFPCFsCAEraYDChhs7VoSQkbBANoQE00NEI0E2SEZCayEWYzUYywmIlihNVMVCNsZkK2AHJpxSB7QJHrpMkNJF1OETpqhsB1UA1RdJQNZddl1xVnLs5SnKWCI9c117n30b2PwZhjNGtRFhblIIpSn5g7Eh13gZikDLF21AxJtWETJDVFwpKkcih2VAxJakmOKBAPFBVD0XXRdcl1yXXgOukgA0nnVeQ6ch25Ts5WRe6LdMGBCjiqhqpbq+5Bc+ZmzBiCI3JkzP00UWTM/URRZMzosaHHhh4bojOTWyNnJreWnTm7teLMxa1VZ65urTlzc2vNmCmgI2FGQdKGFLlOKmIgaUCKyJC0IEVXXTPUK2egYqi4rriuOnN1luos0noUmS4HdGSeZvc+d/+oX7zkaX5/f9jZde37y+VwkNva4v7Gt7rn/eVwftl9Ob+eTg+7f/an1/5Pf5735y5f9hd+yvvhcP7Jkgl/HU8HQe8P19lhfSpGuTb12ch7wAl413+
|
|
412
|
+
"debug_symbols": "tVnbbhs5DP0XP+dBEkld+itFUbipWxgwnMBNFlgE+fclJZIeGxghmG1ewiNOdHgRRWnGb7ufhx+vv78fz7+e/uy+fH3b/bgcT6fj7++np8f9y/HpzNq3XZA/EfPuS3zYRaIhM6uTSBqy6LjYuA1ZUaWOm45b7TIFUFmGjGlIZB4U2YYkVKnjrOOs48LzC8uaVLK/lWWLKscYAo9jEJAVRPY8RgGkIImGBIimMQCJLgmQ8IABggEJJDMg0RQBohFbGQwUBSUaIANNQU9UB6ZpNr3pdAw6C+PINkZUObKLiadAEFAVQDKQFWA0YBoqfU0xjzXGOnKLtQ4pjnQ5xhRApY5j7jmnFFVSzzVJ1rrUMfIYkgAywH4DZ5FkeQdoI/ckCyy5J1lhyT0VHCknWeMB2HHg3FOTKMW0pArYVg7JQFYgORsADVQFPW0dmAZsOth0tFk4cp0JVI5KzlkznWW1OyjRACmowYBppC4Th1mkMAcwTTRNNE0yTTINmKYXpgBJ8gCmIdOQa5qCXqEdVAUlGSgKqpmoZrQZYTPCpoQ1oAElrBEMKGFNyYASVouiWhTVoqhohGgmyAjJTGQjzGaiGGExE9UIq5moRtjMRFPCFsCAEraYDChhs7VoSQkbBANoQE00NEI0E2SEZCayEWYzUYywmIlihNVMVCNsZkK2AHJpxSB7QJHrpMkNJF1OETpqhsB1UA1RdJQNZddl1xVnLs5SnKWCI9c117n30b2PwZhjNGtRFhblIIpSn5g7Eh13gZikDLF21AxJtWETJDVFwpKkcih2VAxJakmOKBAPFBVD0XXRdcl1yXXgOukgA0nnVeQ6ch25Ts5WRe6LdMGBCjiqhqpbq+5Bc+ZmzBiCI3JkzP00UWTM/URRZMzosaHHhh4bojOTWyNnJreWnTm7teLMxa1VZ65urTlzc2vNmCmgI2FGQdKGFLlOKmIgaUCKyJC0IEVXXTPUK2egYqi4rriuOnN1luos0noUmS4HdGSeZvc+d/+oX7zkaX5/f9jZde37y+VwkNva4v7Gt7rn/eVwftl9Ob+eTg+7f/an1/5Pf5735y5f9hd+yvvhcP7Jkgl/HU8HQe8P19lhfSpGuTb12ch7wAl413+UgiuYlIJh2ULBWx2UInGtrFLAhIKvPkbBt5grRYEPe5HBcpFKCKte0ISiJVuM1CA6BabbFcmzQCyb3NiuBHGjD23VhwkFJzArBd14cUfRPjGMGx9KXvVhVpncTqwyM64vaEyTOCB4ILCsq7tI4qQ2Y4tyenUSxhmc5a44I04cKdVXFVfLexpKrtnru9b1UCbVCejryifhNR3ljqL8jWzUz8wGQCkeScDVbKRZx2gFvHHxVQ/XQklxko/gnStKZf7/YPL60k44+E1AKWq6di6Kt4HMKjQj+apkLOvZmGz77F6UuC0XizgWB9pdHDMCfr1QgpbaGsGs7ZSG1wNx/TRLk/YJAZNxhLyeiEkmEb0mEBfb/b6BQvzELn7jRFs/SWbrwbd+K6uYCqytCMxKkwC99xEsG9dtPmFWmsnqIlPYVJo3kVTcUpz8MmQdh9876obyREx+5UOaXLYm5VmswMvifvHhixb4/lg2Xs7Nh0NItjlwsb/uCXDWJKhYEviTyqL731HA7Cj0qzPDtiiIWwqc7fIAvssTrlJMipKPDO8U8rpNa6FMK8LXo4Qt60HBr2oAmwiKXVmp5S0Ey725iYAv/FYPaRtBSb4n2haCCn5u5XUPCD5rVxaoviO2rUE2glzvtvU3Hu4fj5ebnyfehepy3P84HXT46/X8uHj68u+zPbGfN54vT4+Hn6+XgzBdf+Pgd+yv/O3lAUr4Jp+ieJj4gz7f2GUY5Sl/IeLv/N/exZn/AA=="
|
|
413
413
|
},
|
|
414
414
|
{
|
|
415
415
|
"name": "sync_state",
|
|
@@ -580,7 +580,7 @@
|
|
|
580
580
|
}
|
|
581
581
|
},
|
|
582
582
|
"bytecode": "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",
|
|
583
|
-
"debug_symbols": "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"
|
|
583
|
+
"debug_symbols": "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"
|
|
584
584
|
}
|
|
585
585
|
],
|
|
586
586
|
"outputs": {
|
|
@@ -912,34 +912,34 @@
|
|
|
912
912
|
"path": "/home/aztec-dev/aztec-packages/noir-projects/noir-protocol-circuits/crates/types/src/poseidon2.nr",
|
|
913
913
|
"source": "use crate::constants::TWO_POW_64;\nuse crate::traits::{Deserialize, Serialize};\nuse std::meta::derive;\n// NB: This is a clone of noir/noir-repo/noir_stdlib/src/hash/poseidon2.nr\n// It exists as we sometimes need to perform custom absorption, but the stdlib version\n// has a private absorb() method (it's also designed to just be a hasher)\n// Can be removed when standalone noir poseidon lib exists: See noir#6679\n\ncomptime global RATE: u32 = 3;\n\n#[derive(Deserialize, Eq, Serialize)]\npub struct Poseidon2Sponge {\n pub cache: [Field; 3],\n pub state: [Field; 4],\n pub cache_size: u32,\n pub squeeze_mode: bool, // 0 => absorb, 1 => squeeze\n}\n\nimpl Poseidon2Sponge {\n #[no_predicates]\n pub fn hash<let N: u32>(input: [Field; N], message_size: u32) -> Field {\n Poseidon2Sponge::hash_internal(input, message_size, message_size != N)\n }\n\n pub(crate) fn new(iv: Field) -> Poseidon2Sponge {\n let mut result =\n Poseidon2Sponge { cache: [0; 3], state: [0; 4], cache_size: 0, squeeze_mode: false };\n result.state[RATE] = iv;\n result\n }\n\n fn perform_duplex(&mut self) {\n // add the cache into sponge state\n for i in 0..RATE {\n // We effectively zero-pad the cache by only adding to the state\n // cache that is less than the specified `cache_size`\n if i < self.cache_size {\n self.state[i] += self.cache[i];\n }\n }\n self.state = std::hash::poseidon2_permutation(self.state, 4);\n }\n\n pub fn absorb(&mut self, input: Field) {\n assert(!self.squeeze_mode);\n if self.cache_size == RATE {\n // If we're absorbing, and the cache is full, apply the sponge permutation to compress the cache\n self.perform_duplex();\n self.cache[0] = input;\n self.cache_size = 1;\n } else {\n // If we're absorbing, and the cache is not full, add the input into the cache\n self.cache[self.cache_size] = input;\n self.cache_size += 1;\n }\n }\n\n pub fn squeeze(&mut self) -> Field {\n assert(!self.squeeze_mode);\n // If we're in absorb mode, apply sponge permutation to compress the cache.\n self.perform_duplex();\n self.squeeze_mode = true;\n\n // Pop one item off the top of the permutation and return it.\n self.state[0]\n }\n\n fn hash_internal<let N: u32>(\n input: [Field; N],\n in_len: u32,\n is_variable_length: bool,\n ) -> Field {\n let iv: Field = (in_len as Field) * TWO_POW_64;\n let mut sponge = Poseidon2Sponge::new(iv);\n for i in 0..input.len() {\n if i < in_len {\n sponge.absorb(input[i]);\n }\n }\n\n sponge.squeeze()\n }\n}\n"
|
|
914
914
|
},
|
|
915
|
-
"
|
|
916
|
-
"path": "/home/aztec-dev/aztec-packages/noir-projects/noir-protocol-circuits/crates/types/src/traits.nr",
|
|
917
|
-
"source": "use crate::
|
|
915
|
+
"403": {
|
|
916
|
+
"path": "/home/aztec-dev/aztec-packages/noir-projects/noir-protocol-circuits/crates/types/src/traits/to_field.nr",
|
|
917
|
+
"source": "use crate::utils::field::field_from_bytes;\n\npub trait ToField {\n fn to_field(self) -> Field;\n}\n\nimpl ToField for Field {\n #[inline_always]\n fn to_field(self) -> Field {\n self\n }\n}\n\nimpl ToField for bool {\n #[inline_always]\n fn to_field(self) -> Field {\n self as Field\n }\n}\nimpl ToField for u1 {\n #[inline_always]\n fn to_field(self) -> Field {\n self as Field\n }\n}\nimpl ToField for u8 {\n #[inline_always]\n fn to_field(self) -> Field {\n self as Field\n }\n}\nimpl ToField for u16 {\n fn to_field(self) -> Field {\n self as Field\n }\n}\nimpl ToField for u32 {\n #[inline_always]\n fn to_field(self) -> Field {\n self as Field\n }\n}\nimpl ToField for u64 {\n #[inline_always]\n fn to_field(self) -> Field {\n self as Field\n }\n}\nimpl ToField for u128 {\n #[inline_always]\n fn to_field(self) -> Field {\n self as Field\n }\n}\nimpl<let N: u32> ToField for str<N> {\n #[inline_always]\n fn to_field(self) -> Field {\n assert(N < 32, \"String doesn't fit in a field, consider using Serialize instead\");\n field_from_bytes(self.as_bytes(), true)\n }\n}\n"
|
|
918
918
|
},
|
|
919
|
-
"
|
|
919
|
+
"411": {
|
|
920
920
|
"path": "/home/aztec-dev/aztec-packages/noir-projects/noir-protocol-circuits/crates/types/src/utils/field.nr",
|
|
921
921
|
"source": "pub fn field_from_bytes<let N: u32>(bytes: [u8; N], big_endian: bool) -> Field {\n assert(bytes.len() < 32, \"field_from_bytes: N must be less than 32\");\n let mut as_field = 0;\n let mut offset = 1;\n for i in 0..N {\n let mut index = i;\n if big_endian {\n index = N - i - 1;\n }\n as_field += (bytes[index] as Field) * offset;\n offset *= 256;\n }\n\n as_field\n}\n\n// Convert a 32 byte array to a field element by truncating the final byte\npub fn field_from_bytes_32_trunc(bytes32: [u8; 32]) -> Field {\n // Convert it to a field element\n let mut v = 1;\n let mut high = 0 as Field;\n let mut low = 0 as Field;\n\n for i in 0..15 {\n // covers bytes 16..30 (31 is truncated and ignored)\n low = low + (bytes32[15 + 15 - i] as Field) * v;\n v = v * 256;\n // covers bytes 0..14\n high = high + (bytes32[14 - i] as Field) * v;\n }\n // covers byte 15\n low = low + (bytes32[15] as Field) * v;\n\n low + high * v\n}\n\n// TODO to radix returns u8, so we cannot use bigger radixes. It'd be ideal to use a radix of the maximum range-constrained integer noir supports\npub fn full_field_less_than(lhs: Field, rhs: Field) -> bool {\n lhs.lt(rhs)\n}\n\npub fn full_field_greater_than(lhs: Field, rhs: Field) -> bool {\n rhs.lt(lhs)\n}\n\npub fn min(f1: Field, f2: Field) -> Field {\n if f1.lt(f2) {\n f1\n } else {\n f2\n }\n}\n\n// TODO: write doc-comments and tests for these magic constants.\n\nglobal KNOWN_NON_RESIDUE: Field = 5; // This is a non-residue in Noir's native Field.\nglobal C1: u32 = 28;\nglobal C3: Field = 40770029410420498293352137776570907027550720424234931066070132305055;\nglobal C5: Field = 19103219067921713944291392827692070036145651957329286315305642004821462161904;\n\n// @dev: only use this for _huge_ exponents y, when writing a constrained function.\n// If you're only exponentiating by a small value, first consider writing-out the multiplications by hand.\n// Only after you've measured the gates of that approach, consider using the native Field::pow_32 function.\n// Only if your exponent is larger than 32 bits, resort to using this function.\npub fn pow(x: Field, y: Field) -> Field {\n let mut r = 1 as Field;\n let b: [u1; 254] = y.to_le_bits();\n\n for i in 0..254 {\n r *= r;\n r *= (b[254 - 1 - i] as Field) * x + (1 - b[254 - 1 - i] as Field);\n }\n\n r\n}\n\n/// Returns Option::some(sqrt) if there is a square root, and Option::none() if there isn't.\npub fn sqrt(x: Field) -> Option<Field> {\n // Safety: if the hint returns the square root of x, then we simply square it\n // check the result equals x. If x is not square, we return a value that\n // enables us to prove that fact (see the `else` clause below).\n let (is_sq, maybe_sqrt) = unsafe { __sqrt(x) };\n\n if is_sq {\n let sqrt = maybe_sqrt;\n validate_sqrt_hint(x, sqrt);\n Option::some(sqrt)\n } else {\n let not_sqrt_hint = maybe_sqrt;\n validate_not_sqrt_hint(x, not_sqrt_hint);\n Option::none()\n }\n}\n\n// Boolean indicating whether Field element is a square, i.e. whether there exists a y in Field s.t. x = y*y.\nunconstrained fn is_square(x: Field) -> bool {\n let v = pow(x, -1 / 2);\n v * (v - 1) == 0\n}\n\n// Tonelli-Shanks algorithm for computing the square root of a Field element.\n// Requires C1 = max{c: 2^c divides (p-1)}, where p is the order of Field\n// as well as C3 = (C2 - 1)/2, where C2 = (p-1)/(2^c1),\n// and C5 = ZETA^C2, where ZETA is a non-square element of Field.\n// These are pre-computed above as globals.\nunconstrained fn tonelli_shanks_sqrt(x: Field) -> Field {\n let mut z = pow(x, C3);\n let mut t = z * z * x;\n z *= x;\n let mut b = t;\n let mut c = C5;\n\n for i in 0..(C1 - 1) {\n for _j in 1..(C1 - i - 1) {\n b *= b;\n }\n\n z *= if b == 1 { 1 } else { c };\n\n c *= c;\n\n t *= if b == 1 { 1 } else { c };\n\n b = t;\n }\n\n z\n}\n\n// NB: this doesn't return an option, because in the case of there _not_ being a square root, we still want to return a field element that allows us to then assert in the _constrained_ sqrt function that there is no sqrt.\nunconstrained fn __sqrt(x: Field) -> (bool, Field) {\n let is_sq = is_square(x);\n if is_sq {\n let sqrt = tonelli_shanks_sqrt(x);\n (true, sqrt)\n } else {\n // Demonstrate that x is not a square (a.k.a. a \"quadratic non-residue\").\n // Facts:\n // The Legendre symbol (\"LS\") of x, is x^((p-1)/2) (mod p).\n // - If x is a square, LS(x) = 1\n // - If x is not a square, LS(x) = -1\n // - If x = 0, LS(x) = 0.\n //\n // Hence:\n // sq * sq = sq // 1 * 1 = 1\n // non-sq * non-sq = sq // -1 * -1 = 1\n // sq * non-sq = non-sq // -1 * 1 = -1\n //\n // See: https://en.wikipedia.org/wiki/Legendre_symbol\n let demo_x_not_square = x * KNOWN_NON_RESIDUE;\n let not_sqrt = tonelli_shanks_sqrt(demo_x_not_square);\n (false, not_sqrt)\n }\n}\n\nfn validate_sqrt_hint(x: Field, hint: Field) {\n assert(hint * hint == x, f\"The claimed_sqrt {hint} is not the sqrt of x {x}\");\n}\n\nfn validate_not_sqrt_hint(x: Field, hint: Field) {\n // We need this assertion, because x = 0 would pass the other assertions in this\n // function, and we don't want people to be able to prove that 0 is not square!\n assert(x != 0, \"0 has a square root; you cannot claim it is not square\");\n // Demonstrate that x is not a square (a.k.a. a \"quadratic non-residue\").\n //\n // Facts:\n // The Legendre symbol (\"LS\") of x, is x^((p-1)/2) (mod p).\n // - If x is a square, LS(x) = 1\n // - If x is not a square, LS(x) = -1\n // - If x = 0, LS(x) = 0.\n //\n // Hence:\n // 1. sq * sq = sq // 1 * 1 = 1\n // 2. non-sq * non-sq = sq // -1 * -1 = 1\n // 3. sq * non-sq = non-sq // -1 * 1 = -1\n //\n // See: https://en.wikipedia.org/wiki/Legendre_symbol\n //\n // We want to demonstrate that this below multiplication falls under bullet-point (2):\n let demo_x_not_square = x * KNOWN_NON_RESIDUE;\n // I.e. we want to demonstrate that `demo_x_not_square` has Legendre symbol 1\n // (i.e. that it is a square), so we prove that it is square below.\n // Why do we want to prove that it has LS 1?\n // Well, since it was computed with a known-non-residue, its squareness implies we're\n // in case 2 (something multiplied by a known-non-residue yielding a result which\n // has a LS of 1), which implies that x must be a non-square. The unconstrained\n // function gave us the sqrt of demo_x_not_square, so all we need to do is\n // assert its squareness:\n assert(\n hint * hint == demo_x_not_square,\n f\"The hint {hint} does not demonstrate that {x} is not a square\",\n );\n}\n\n#[test]\nunconstrained fn bytes_field_test() {\n // Tests correctness of field_from_bytes_32_trunc against existing methods\n // Bytes representing 0x543e0a6642ffeb8039296861765a53407bba62bd1c97ca43374de950bbe0a7\n let inputs = [\n 84, 62, 10, 102, 66, 255, 235, 128, 57, 41, 104, 97, 118, 90, 83, 64, 123, 186, 98, 189, 28,\n 151, 202, 67, 55, 77, 233, 80, 187, 224, 167,\n ];\n let field = field_from_bytes(inputs, true);\n let return_bytes: [u8; 31] = field.to_be_bytes();\n assert_eq(inputs, return_bytes);\n // 32 bytes - we remove the final byte, and check it matches the field\n let inputs2 = [\n 84, 62, 10, 102, 66, 255, 235, 128, 57, 41, 104, 97, 118, 90, 83, 64, 123, 186, 98, 189, 28,\n 151, 202, 67, 55, 77, 233, 80, 187, 224, 167, 158,\n ];\n let field2 = field_from_bytes_32_trunc(inputs2);\n let return_bytes2: [u8; 31] = field2.to_be_bytes();\n\n assert_eq(return_bytes2, return_bytes);\n assert_eq(field2, field);\n}\n\n#[test]\nunconstrained fn max_field_test() {\n // Tests the hardcoded value in constants.nr vs underlying modulus\n // NB: We can't use 0-1 in constants.nr as it will be transpiled incorrectly to ts and sol constants files\n let max_value = crate::constants::MAX_FIELD_VALUE;\n assert_eq(max_value, 0 - 1);\n // modulus == 0 is tested elsewhere, so below is more of a sanity check\n let max_bytes: [u8; 32] = max_value.to_be_bytes();\n let mod_bytes = std::field::modulus_be_bytes();\n for i in 0..31 {\n assert_eq(max_bytes[i], mod_bytes[i]);\n }\n assert_eq(max_bytes[31], mod_bytes[31] - 1);\n}\n\n#[test]\nunconstrained fn sqrt_valid_test() {\n let x = 16; // examples: 16, 9, 25, 81\n let result = sqrt(x);\n assert(result.is_some());\n assert_eq(result.unwrap() * result.unwrap(), x);\n}\n\n#[test]\nunconstrained fn sqrt_invalid_test() {\n let x = KNOWN_NON_RESIDUE; // has no square root in the field\n let result = sqrt(x);\n assert(result.is_none());\n}\n\n#[test]\nunconstrained fn sqrt_zero_test() {\n let result = sqrt(0);\n assert(result.is_some());\n assert_eq(result.unwrap(), 0);\n}\n\n#[test]\nunconstrained fn sqrt_one_test() {\n let result = sqrt(1);\n assert(result.is_some());\n assert_eq(result.unwrap() * result.unwrap(), 1);\n}\n\n#[test]\nunconstrained fn field_from_bytes_empty_test() {\n let empty: [u8; 0] = [];\n let result = field_from_bytes(empty, true);\n assert_eq(result, 0);\n\n let result_le = field_from_bytes(empty, false);\n assert_eq(result_le, 0);\n}\n\n#[test]\nunconstrained fn field_from_bytes_little_endian_test() {\n // Test little-endian conversion: [0x01, 0x02] should be 0x0201 = 513\n let bytes = [0x01, 0x02];\n let result_le = field_from_bytes(bytes, false);\n assert_eq(result_le, 0x0201);\n\n // Compare with big-endian: [0x01, 0x02] should be 0x0102 = 258\n let result_be = field_from_bytes(bytes, true);\n assert_eq(result_be, 0x0102);\n}\n\n#[test]\nunconstrained fn pow_test() {\n assert_eq(pow(2, 0), 1);\n assert_eq(pow(2, 1), 2);\n assert_eq(pow(2, 10), 1024);\n assert_eq(pow(3, 5), 243);\n assert_eq(pow(0, 5), 0);\n assert_eq(pow(1, 100), 1);\n}\n\n#[test]\nunconstrained fn min_test() {\n assert_eq(min(5, 10), 5);\n assert_eq(min(10, 5), 5);\n assert_eq(min(7, 7), 7);\n assert_eq(min(0, 1), 0);\n}\n\n#[test]\nunconstrained fn full_field_comparison_test() {\n assert(full_field_less_than(5, 10));\n assert(!full_field_less_than(10, 5));\n assert(!full_field_less_than(5, 5));\n\n assert(full_field_greater_than(10, 5));\n assert(!full_field_greater_than(5, 10));\n assert(!full_field_greater_than(5, 5));\n}\n\n#[test]\nunconstrained fn sqrt_has_two_roots_test() {\n // Every square has two roots: r and -r (i.e., p - r)\n // sqrt(16) can return 4 or -4\n let x = 16;\n let result = sqrt(x).unwrap();\n assert(result * result == x);\n // The other root is -result\n let other_root = 0 - result;\n assert(other_root * other_root == x);\n // Verify they are different (unless x = 0)\n assert(result != other_root);\n\n // Same for 9: roots are 3 and -3\n let y = 9;\n let result_y = sqrt(y).unwrap();\n assert(result_y * result_y == y);\n let other_root_y = 0 - result_y;\n assert(other_root_y * other_root_y == y);\n assert(result_y != other_root_y);\n}\n\n#[test]\nunconstrained fn sqrt_negative_one_test() {\n let x = 0 - 1;\n let result = sqrt(x);\n assert(result.unwrap() == 0x30644e72e131a029048b6e193fd841045cea24f6fd736bec231204708f703636);\n}\n\n#[test]\nunconstrained fn validate_sqrt_hint_valid_test() {\n // 4 is a valid sqrt of 16\n validate_sqrt_hint(16, 4);\n // -4 is also a valid sqrt of 16\n validate_sqrt_hint(16, 0 - 4);\n // 0 is a valid sqrt of 0\n validate_sqrt_hint(0, 0);\n // 1 is a valid sqrt of 1\n validate_sqrt_hint(1, 1);\n // -1 is also a valid sqrt of 1\n validate_sqrt_hint(1, 0 - 1);\n}\n\n#[test(should_fail_with = \"is not the sqrt of x\")]\nunconstrained fn validate_sqrt_hint_invalid_test() {\n // 5 is not a valid sqrt of 16\n validate_sqrt_hint(16, 5);\n}\n\n#[test]\nunconstrained fn validate_not_sqrt_hint_valid_test() {\n // 5 (KNOWN_NON_RESIDUE) is not a square.\n let x = KNOWN_NON_RESIDUE;\n let hint = tonelli_shanks_sqrt(x * KNOWN_NON_RESIDUE);\n validate_not_sqrt_hint(x, hint);\n}\n\n#[test(should_fail_with = \"0 has a square root\")]\nunconstrained fn validate_not_sqrt_hint_zero_test() {\n // 0 has a square root, so we cannot claim it is not square\n validate_not_sqrt_hint(0, 0);\n}\n\n#[test(should_fail_with = \"does not demonstrate that\")]\nunconstrained fn validate_not_sqrt_hint_wrong_hint_test() {\n // Provide a wrong hint for a non-square\n let x = KNOWN_NON_RESIDUE;\n validate_not_sqrt_hint(x, 123);\n}\n"
|
|
922
922
|
},
|
|
923
|
-
"
|
|
923
|
+
"417": {
|
|
924
924
|
"path": "/home/aztec-dev/aztec-packages/noir-projects/noir-protocol-circuits/crates/serde/src/reader.nr",
|
|
925
925
|
"source": "pub struct Reader<let N: u32> {\n data: [Field; N],\n offset: u32,\n}\n\nimpl<let N: u32> Reader<N> {\n pub fn new(data: [Field; N]) -> Self {\n Self { data, offset: 0 }\n }\n\n pub fn read(&mut self) -> Field {\n let result = self.data[self.offset];\n self.offset += 1;\n result\n }\n\n pub fn read_u32(&mut self) -> u32 {\n self.read() as u32\n }\n\n pub fn read_u64(&mut self) -> u64 {\n self.read() as u64\n }\n\n pub fn read_bool(&mut self) -> bool {\n self.read() != 0\n }\n\n pub fn read_array<let K: u32>(&mut self) -> [Field; K] {\n let mut result = [0; K];\n for i in 0..K {\n result[i] = self.data[self.offset + i];\n }\n self.offset += K;\n result\n }\n\n pub fn read_struct<T, let K: u32>(&mut self, deserialise: fn([Field; K]) -> T) -> T {\n let result = deserialise(self.read_array());\n result\n }\n\n pub fn read_struct_array<T, let K: u32, let C: u32>(\n &mut self,\n deserialise: fn([Field; K]) -> T,\n mut result: [T; C],\n ) -> [T; C] {\n for i in 0..C {\n result[i] = self.read_struct(deserialise);\n }\n result\n }\n\n pub fn peek_offset(&mut self, offset: u32) -> Field {\n self.data[self.offset + offset]\n }\n\n pub fn advance_offset(&mut self, offset: u32) {\n self.offset += offset;\n }\n\n pub fn finish(self) {\n assert_eq(self.offset, self.data.len(), \"Reader did not read all data\");\n }\n}\n"
|
|
926
926
|
},
|
|
927
|
-
"
|
|
927
|
+
"418": {
|
|
928
928
|
"path": "/home/aztec-dev/aztec-packages/noir-projects/noir-protocol-circuits/crates/serde/src/serialization.nr",
|
|
929
929
|
"source": "use crate::{reader::Reader, writer::Writer};\n\n// docs:start:serialize\n/// Trait for serializing Noir types into arrays of Fields.\n///\n/// An implementation of the Serialize trait has to follow Noir's intrinsic serialization (each member of a struct\n/// converted directly into one or more Fields without any packing or compression). This trait (and Deserialize) are\n/// typically used to communicate between Noir and TypeScript (via oracles and function arguments).\n///\n/// # On Following Noir's Intrinsic Serialization\n/// When calling a Noir function from TypeScript (TS), first the function arguments are serialized into an array\n/// of fields. This array is then included in the initial witness. Noir's intrinsic serialization is then used\n/// to deserialize the arguments from the witness. When the same Noir function is called from Noir this Serialize trait\n/// is used instead of the serialization in TS. For this reason we need to have a match between TS serialization,\n/// Noir's intrinsic serialization and the implementation of this trait. If there is a mismatch, the function calls\n/// fail with an arguments hash mismatch error message.\n///\n/// # Associated Constants\n/// * `N` - The length of the output Field array, known at compile time\n///\n/// # Example\n/// ```\n/// impl<let N: u32> Serialize for str<N> {\n/// let N: u32 = N;\n///\n/// fn serialize(self) -> [Field; Self::N] {\n/// let mut writer: Writer<Self::N> = Writer::new();\n/// self.stream_serialize(&mut writer);\n/// writer.finish()\n/// }\n///\n/// fn stream_serialize<let K: u32>(self, writer: &mut Writer<K>) {\n/// let bytes = self.as_bytes();\n/// for i in 0..bytes.len() {\n/// writer.write(bytes[i] as Field);\n/// }\n/// }\n/// }\n/// ```\n#[derive_via(derive_serialize)]\npub trait Serialize {\n let N: u32;\n\n fn serialize(self) -> [Field; Self::N];\n\n fn stream_serialize<let K: u32>(self, writer: &mut Writer<K>);\n}\n\n/// Generates a `Serialize` trait implementation for a struct type.\n///\n/// # Parameters\n/// - `s`: The struct type definition to generate the implementation for\n///\n/// # Returns\n/// A quoted code block containing the trait implementation\n///\n/// # Example\n/// For a struct defined as:\n/// ```\n/// struct Log<N> {\n/// fields: [Field; N],\n/// length: u32\n/// }\n/// ```\n///\n/// This function generates code equivalent to:\n/// ```\n/// impl<let N: u32> Serialize for Log<N> {\n/// let N: u32 = <[Field; N] as Serialize>::N + <u32 as Serialize>::N;\n///\n/// fn serialize(self) -> [Field; Self::N] {\n/// let mut writer: Writer<Self::N> = Writer::new();\n/// self.stream_serialize(&mut writer);\n/// writer.finish()\n/// }\n///\n/// #[inline_always]\n/// fn stream_serialize<let K: u32>(self, writer: &mut Writer<K>) {\n/// Serialize::stream_serialize(self.fields, writer);\n/// Serialize::stream_serialize(self.length, writer);\n/// }\n/// }\n/// ```\npub comptime fn derive_serialize(s: TypeDefinition) -> Quoted {\n let typ = s.as_type();\n let nested_struct = typ.as_data_type().unwrap();\n\n // We care only about the name and type so we drop the last item of the tuple\n let params = nested_struct.0.fields(nested_struct.1).map(|(name, typ, _)| (name, typ));\n\n // Generates the generic parameter declarations (to be placed after the `impl` keyword) and the `where` clause\n // for the `Serialize` trait.\n let generics_declarations = get_generics_declarations(s);\n let where_serialize_clause = get_where_trait_clause(s, quote {Serialize});\n\n let params_len_quote = get_params_len_quote(params);\n\n let function_body = params\n .map(|(name, _typ): (Quoted, Type)| {\n quote {\n $crate::serialization::Serialize::stream_serialize(self.$name, writer);\n }\n })\n .join(quote {});\n\n quote {\n impl$generics_declarations $crate::serialization::Serialize for $typ\n $where_serialize_clause\n {\n let N: u32 = $params_len_quote;\n\n\n fn serialize(self) -> [Field; Self::N] {\n let mut writer: $crate::writer::Writer<Self::N> = $crate::writer::Writer::new();\n $crate::serialization::Serialize::stream_serialize(self, &mut writer);\n writer.finish()\n }\n\n\n #[inline_always]\n fn stream_serialize<let K: u32>(self, writer: &mut $crate::writer::Writer<K>) {\n $function_body\n }\n }\n }\n}\n\n// docs:start:deserialize\n/// Trait for deserializing Noir types from arrays of Fields.\n///\n/// An implementation of the Deserialize trait has to follow Noir's intrinsic serialization (each member of a struct\n/// converted directly into one or more Fields without any packing or compression). This trait is typically used when\n/// deserializing return values from function calls in Noir. Since the same function could be called from TypeScript\n/// (TS), in which case the TS deserialization would get used, we need to have a match between the 2.\n///\n/// # Associated Constants\n/// * `N` - The length of the input Field array, known at compile time\n///\n/// # Example\n/// ```\n/// impl<let M: u32> Deserialize for str<M> {\n/// let N: u32 = M;\n///\n/// fn deserialize(fields: [Field; Self::N]) -> Self {\n/// let mut reader = Reader::new(fields);\n/// let result = Self::stream_deserialize(&mut reader);\n/// reader.finish();\n/// result\n/// }\n///\n/// fn stream_deserialize<let K: u32>(reader: &mut Reader<K>) -> Self {\n/// let mut bytes = [0 as u8; M];\n/// for i in 0..M {\n/// bytes[i] = reader.read() as u8;\n/// }\n/// str::<M>::from(bytes)\n/// }\n/// }\n/// ```\n#[derive_via(derive_deserialize)]\npub trait Deserialize {\n let N: u32;\n\n fn deserialize(fields: [Field; Self::N]) -> Self;\n\n fn stream_deserialize<let K: u32>(reader: &mut Reader<K>) -> Self;\n}\n\n/// Generates a `Deserialize` trait implementation for a given struct `s`.\n///\n/// # Arguments\n/// * `s` - The struct type definition to generate the implementation for\n///\n/// # Returns\n/// A `Quoted` block containing the generated trait implementation\n///\n/// # Requirements\n/// Each struct member type must implement the `Deserialize` trait (it gets used in the generated code).\n///\n/// # Example\n/// For a struct like:\n/// ```\n/// struct MyStruct {\n/// x: AztecAddress,\n/// y: Field,\n/// }\n/// ```\n///\n/// This generates:\n/// ```\n/// impl Deserialize for MyStruct {\n/// let N: u32 = <AztecAddress as Deserialize>::N + <Field as Deserialize>::N;\n///\n/// fn deserialize(fields: [Field; Self::N]) -> Self {\n/// let mut reader = Reader::new(fields);\n/// let result = Self::stream_deserialize(&mut reader);\n/// reader.finish();\n/// result\n/// }\n///\n/// #[inline_always]\n/// fn stream_deserialize<let K: u32>(reader: &mut Reader<K>) -> Self {\n/// let x = <AztecAddress as Deserialize>::stream_deserialize(reader);\n/// let y = <Field as Deserialize>::stream_deserialize(reader);\n/// Self { x, y }\n/// }\n/// }\n/// ```\npub comptime fn derive_deserialize(s: TypeDefinition) -> Quoted {\n let typ = s.as_type();\n let nested_struct = typ.as_data_type().unwrap();\n let params = nested_struct.0.fields(nested_struct.1);\n\n // Generates the generic parameter declarations (to be placed after the `impl` keyword) and the `where` clause\n // for the `Deserialize` trait.\n let generics_declarations = get_generics_declarations(s);\n let where_deserialize_clause = get_where_trait_clause(s, quote {Deserialize});\n\n // The following will give us:\n // <type_of_struct_member_1 as Deserialize>::N + <type_of_struct_member_2 as Deserialize>::N + ...\n // (or 0 if the struct has no members)\n let right_hand_side_of_definition_of_n = if params.len() > 0 {\n params\n .map(|(_, param_type, _): (Quoted, Type, Quoted)| {\n quote {\n <$param_type as $crate::serialization::Deserialize>::N\n }\n })\n .join(quote {+})\n } else {\n quote {0}\n };\n\n // For structs containing a single member, we can enhance performance by directly deserializing the input array,\n // bypassing the need for loop-based array construction. While this optimization yields significant benefits in\n // Brillig where the loops are expected to not be optimized, it is not relevant in ACIR where the loops are\n // expected to be optimized away.\n let function_body = if params.len() > 1 {\n // This generates deserialization code for each struct member and concatenates them together.\n let deserialization_of_struct_members = params\n .map(|(param_name, param_type, _): (Quoted, Type, Quoted)| {\n quote {\n let $param_name = <$param_type as Deserialize>::stream_deserialize(reader);\n }\n })\n .join(quote {});\n\n // We join the struct member names with a comma to be used in the `Self { ... }` syntax\n // This will give us e.g. `a, b, c` for a struct with three fields named `a`, `b`, and `c`.\n let struct_members = params\n .map(|(param_name, _, _): (Quoted, Type, Quoted)| quote { $param_name })\n .join(quote {,});\n\n quote {\n $deserialization_of_struct_members\n\n Self { $struct_members }\n }\n } else if params.len() == 1 {\n let param_name = params[0].0;\n quote {\n Self { $param_name: $crate::serialization::Deserialize::stream_deserialize(reader) }\n }\n } else {\n quote {\n Self {}\n }\n };\n\n quote {\n impl$generics_declarations $crate::serialization::Deserialize for $typ\n $where_deserialize_clause\n {\n let N: u32 = $right_hand_side_of_definition_of_n;\n\n fn deserialize(fields: [Field; Self::N]) -> Self {\n let mut reader = $crate::reader::Reader::new(fields);\n let result = Self::stream_deserialize(&mut reader);\n reader.finish();\n result\n }\n\n #[inline_always]\n fn stream_deserialize<let K: u32>(reader: &mut $crate::reader::Reader<K>) -> Self {\n $function_body\n }\n }\n }\n}\n\n/// Generates a quoted expression that computes the total serialized length of function parameters.\n///\n/// # Parameters\n/// * `params` - An array of tuples where each tuple contains a quoted parameter name and its Type. The type needs\n/// to implement the Serialize trait.\n///\n/// # Returns\n/// A quoted expression that evaluates to:\n/// * `0` if there are no parameters\n/// * `(<type1 as Serialize>::N + <type2 as Serialize>::N + ...)` for one or more parameters\ncomptime fn get_params_len_quote(params: [(Quoted, Type)]) -> Quoted {\n if params.len() == 0 {\n quote { 0 }\n } else {\n let params_quote_without_parentheses = params\n .map(|(_, param_type): (Quoted, Type)| {\n quote {\n <$param_type as $crate::serialization::Serialize>::N\n }\n })\n .join(quote {+});\n quote { ($params_quote_without_parentheses) }\n }\n}\n\ncomptime fn get_generics_declarations(s: TypeDefinition) -> Quoted {\n let generics = s.generics();\n\n if generics.len() > 0 {\n let generics_declarations_items = generics\n .map(|(name, maybe_integer_typ)| {\n // The second item in the generics tuple is an Option of an integer type that is Some only if\n // the generic is numeric.\n if maybe_integer_typ.is_some() {\n // The generic is numeric, so we return a quote defined as e.g. \"let N: u32\"\n let integer_type = maybe_integer_typ.unwrap();\n quote {let $name: $integer_type}\n } else {\n // The generic is not numeric, so we return a quote containing the name of the generic (e.g. \"T\")\n quote {$name}\n }\n })\n .join(quote {,});\n quote {<$generics_declarations_items>}\n } else {\n // The struct doesn't have any generics defined, so we just return an empty quote.\n quote {}\n }\n}\n\ncomptime fn get_where_trait_clause(s: TypeDefinition, trait_name: Quoted) -> Quoted {\n let generics = s.generics();\n\n // The second item in the generics tuple is an Option of an integer type that is Some only if the generic is\n // numeric.\n let non_numeric_generics =\n generics.filter(|(_, maybe_integer_typ)| maybe_integer_typ.is_none());\n\n if non_numeric_generics.len() > 0 {\n let non_numeric_generics_declarations =\n non_numeric_generics.map(|(name, _)| quote {$name: $trait_name}).join(quote {,});\n quote {where $non_numeric_generics_declarations}\n } else {\n // There are no non-numeric generics, so we return an empty quote.\n quote {}\n }\n}\n"
|
|
930
930
|
},
|
|
931
|
-
"
|
|
931
|
+
"42": {
|
|
932
|
+
"path": "std/option.nr",
|
|
933
|
+
"source": "use crate::cmp::{Eq, Ord, Ordering};\nuse crate::default::Default;\nuse crate::hash::{Hash, Hasher};\n\npub struct Option<T> {\n _is_some: bool,\n _value: T,\n}\n\nimpl<T> Option<T> {\n /// Constructs a None value\n pub fn none() -> Self {\n Self { _is_some: false, _value: crate::mem::zeroed() }\n }\n\n /// Constructs a Some wrapper around the given value\n pub fn some(_value: T) -> Self {\n Self { _is_some: true, _value }\n }\n\n /// True if this Option is None\n pub fn is_none(self) -> bool {\n !self._is_some\n }\n\n /// True if this Option is Some\n pub fn is_some(self) -> bool {\n self._is_some\n }\n\n /// Asserts `self.is_some()` and returns the wrapped value.\n pub fn unwrap(self) -> T {\n assert(self._is_some);\n self._value\n }\n\n /// Returns the inner value without asserting `self.is_some()`\n /// Note that if `self` is `None`, there is no guarantee what value will be returned,\n /// only that it will be of type `T`.\n pub fn unwrap_unchecked(self) -> T {\n self._value\n }\n\n /// Returns the wrapped value if `self.is_some()`. Otherwise, returns the given default value.\n pub fn unwrap_or(self, default: T) -> T {\n if self._is_some {\n self._value\n } else {\n default\n }\n }\n\n /// Returns the wrapped value if `self.is_some()`. Otherwise, calls the given function to return\n /// a default value.\n pub fn unwrap_or_else<Env>(self, default: fn[Env]() -> T) -> T {\n if self._is_some {\n self._value\n } else {\n default()\n }\n }\n\n /// Asserts `self.is_some()` with a provided custom message and returns the contained `Some` value\n pub fn expect<let N: u32, MessageTypes>(self, message: fmtstr<N, MessageTypes>) -> T {\n assert(self.is_some(), message);\n self._value\n }\n\n /// If self is `Some(x)`, this returns `Some(f(x))`. Otherwise, this returns `None`.\n pub fn map<U, Env>(self, f: fn[Env](T) -> U) -> Option<U> {\n if self._is_some {\n Option::some(f(self._value))\n } else {\n Option::none()\n }\n }\n\n /// If self is `Some(x)`, this returns `f(x)`. Otherwise, this returns the given default value.\n pub fn map_or<U, Env>(self, default: U, f: fn[Env](T) -> U) -> U {\n if self._is_some {\n f(self._value)\n } else {\n default\n }\n }\n\n /// If self is `Some(x)`, this returns `f(x)`. Otherwise, this returns `default()`.\n pub fn map_or_else<U, Env1, Env2>(self, default: fn[Env1]() -> U, f: fn[Env2](T) -> U) -> U {\n if self._is_some {\n f(self._value)\n } else {\n default()\n }\n }\n\n /// Returns None if self is None. Otherwise, this returns `other`.\n pub fn and(self, other: Self) -> Self {\n if self.is_none() {\n Option::none()\n } else {\n other\n }\n }\n\n /// If self is None, this returns None. Otherwise, this calls the given function\n /// with the Some value contained within self, and returns the result of that call.\n ///\n /// In some languages this function is called `flat_map` or `bind`.\n pub fn and_then<U, Env>(self, f: fn[Env](T) -> Option<U>) -> Option<U> {\n if self._is_some {\n f(self._value)\n } else {\n Option::none()\n }\n }\n\n /// If self is Some, return self. Otherwise, return `other`.\n pub fn or(self, other: Self) -> Self {\n if self._is_some {\n self\n } else {\n other\n }\n }\n\n /// If self is Some, return self. Otherwise, return `default()`.\n pub fn or_else<Env>(self, default: fn[Env]() -> Self) -> Self {\n if self._is_some {\n self\n } else {\n default()\n }\n }\n\n // If only one of the two Options is Some, return that option.\n // Otherwise, if both options are Some or both are None, None is returned.\n pub fn xor(self, other: Self) -> Self {\n if self._is_some {\n if other._is_some {\n Option::none()\n } else {\n self\n }\n } else if other._is_some {\n other\n } else {\n Option::none()\n }\n }\n\n /// Returns `Some(x)` if self is `Some(x)` and `predicate(x)` is true.\n /// Otherwise, this returns `None`\n pub fn filter<Env>(self, predicate: fn[Env](T) -> bool) -> Self {\n if self._is_some {\n if predicate(self._value) {\n self\n } else {\n Option::none()\n }\n } else {\n Option::none()\n }\n }\n\n /// Flattens an Option<Option<T>> into a Option<T>.\n /// This returns None if the outer Option is None. Otherwise, this returns the inner Option.\n pub fn flatten(option: Option<Option<T>>) -> Option<T> {\n if option._is_some {\n option._value\n } else {\n Option::none()\n }\n }\n}\n\nimpl<T> Default for Option<T> {\n fn default() -> Self {\n Option::none()\n }\n}\n\nimpl<T> Eq for Option<T>\nwhere\n T: Eq,\n{\n fn eq(self, other: Self) -> bool {\n if self._is_some == other._is_some {\n if self._is_some {\n self._value == other._value\n } else {\n true\n }\n } else {\n false\n }\n }\n}\n\nimpl<T> Hash for Option<T>\nwhere\n T: Hash,\n{\n fn hash<H>(self, state: &mut H)\n where\n H: Hasher,\n {\n self._is_some.hash(state);\n if self._is_some {\n self._value.hash(state);\n }\n }\n}\n\n// For this impl we're declaring Option::none < Option::some\nimpl<T> Ord for Option<T>\nwhere\n T: Ord,\n{\n fn cmp(self, other: Self) -> Ordering {\n if self._is_some {\n if other._is_some {\n self._value.cmp(other._value)\n } else {\n Ordering::greater()\n }\n } else if other._is_some {\n Ordering::less()\n } else {\n Ordering::equal()\n }\n }\n}\n"
|
|
934
|
+
},
|
|
935
|
+
"420": {
|
|
932
936
|
"path": "/home/aztec-dev/aztec-packages/noir-projects/noir-protocol-circuits/crates/serde/src/type_impls.nr",
|
|
933
|
-
"source": "use crate::{reader::Reader, serialization::{Deserialize, Serialize}, writer::Writer};\nuse std::embedded_curve_ops::EmbeddedCurvePoint;\nuse std::embedded_curve_ops::EmbeddedCurveScalar;\n\nglobal U1_SERIALIZED_LEN: u32 = 1;\nglobal BOOL_SERIALIZED_LEN: u32 = 1;\nglobal U8_SERIALIZED_LEN: u32 = 1;\nglobal U16_SERIALIZED_LEN: u32 = 1;\nglobal U32_SERIALIZED_LEN: u32 = 1;\nglobal U64_SERIALIZED_LEN: u32 = 1;\nglobal U128_SERIALIZED_LEN: u32 = 1;\nglobal FIELD_SERIALIZED_LEN: u32 = 1;\nglobal I8_SERIALIZED_LEN: u32 = 1;\nglobal I16_SERIALIZED_LEN: u32 = 1;\nglobal I32_SERIALIZED_LEN: u32 = 1;\nglobal I64_SERIALIZED_LEN: u32 = 1;\n\nimpl Serialize for bool {\n let N: u32 = BOOL_SERIALIZED_LEN;\n\n fn serialize(self) -> [Field; Self::N] {\n let mut writer: Writer<Self::N> = Writer::new();\n self.stream_serialize(&mut writer);\n writer.finish()\n }\n\n #[inline_always]\n fn stream_serialize<let K: u32>(self, writer: &mut Writer<K>) {\n writer.write(self as Field);\n }\n}\n\nimpl Deserialize for bool {\n let N: u32 = BOOL_SERIALIZED_LEN;\n\n fn deserialize(fields: [Field; Self::N]) -> Self {\n let mut reader = Reader::new(fields);\n let result = Self::stream_deserialize(&mut reader);\n reader.finish();\n result\n }\n\n #[inline_always]\n fn stream_deserialize<let K: u32>(reader: &mut Reader<K>) -> bool {\n reader.read() != 0\n }\n}\n\nimpl Serialize for u1 {\n let N: u32 = U1_SERIALIZED_LEN;\n\n fn serialize(self) -> [Field; Self::N] {\n let mut writer: Writer<Self::N> = Writer::new();\n self.stream_serialize(&mut writer);\n writer.finish()\n }\n\n #[inline_always]\n fn stream_serialize<let K: u32>(self, writer: &mut Writer<K>) {\n writer.write(self as Field);\n }\n}\n\nimpl Deserialize for u1 {\n let N: u32 = U1_SERIALIZED_LEN;\n\n fn deserialize(fields: [Field; Self::N]) -> Self {\n let mut reader = Reader::new(fields);\n let result = Self::stream_deserialize(&mut reader);\n reader.finish();\n result\n }\n\n #[inline_always]\n fn stream_deserialize<let K: u32>(reader: &mut Reader<K>) -> Self {\n reader.read() as u1\n }\n}\n\nimpl Serialize for u8 {\n let N: u32 = U8_SERIALIZED_LEN;\n\n fn serialize(self) -> [Field; Self::N] {\n let mut writer: Writer<Self::N> = Writer::new();\n self.stream_serialize(&mut writer);\n writer.finish()\n }\n\n #[inline_always]\n fn stream_serialize<let K: u32>(self, writer: &mut Writer<K>) {\n writer.write(self as Field);\n }\n}\n\nimpl Deserialize for u8 {\n let N: u32 = U8_SERIALIZED_LEN;\n\n fn deserialize(fields: [Field; Self::N]) -> Self {\n let mut reader = Reader::new(fields);\n let result = Self::stream_deserialize(&mut reader);\n reader.finish();\n result\n }\n\n #[inline_always]\n fn stream_deserialize<let K: u32>(reader: &mut Reader<K>) -> Self {\n reader.read() as u8\n }\n}\n\nimpl Serialize for u16 {\n let N: u32 = U16_SERIALIZED_LEN;\n\n fn serialize(self) -> [Field; Self::N] {\n let mut writer: Writer<Self::N> = Writer::new();\n self.stream_serialize(&mut writer);\n writer.finish()\n }\n\n #[inline_always]\n fn stream_serialize<let K: u32>(self, writer: &mut Writer<K>) {\n writer.write(self as Field);\n }\n}\n\nimpl Deserialize for u16 {\n let N: u32 = U16_SERIALIZED_LEN;\n\n fn deserialize(fields: [Field; Self::N]) -> Self {\n let mut reader = Reader::new(fields);\n let result = Self::stream_deserialize(&mut reader);\n reader.finish();\n result\n }\n\n #[inline_always]\n fn stream_deserialize<let K: u32>(reader: &mut Reader<K>) -> Self {\n reader.read() as u16\n }\n}\n\nimpl Serialize for u32 {\n let N: u32 = U32_SERIALIZED_LEN;\n\n fn serialize(self) -> [Field; Self::N] {\n let mut writer: Writer<Self::N> = Writer::new();\n self.stream_serialize(&mut writer);\n writer.finish()\n }\n\n #[inline_always]\n fn stream_serialize<let K: u32>(self, writer: &mut Writer<K>) {\n writer.write(self as Field);\n }\n}\n\nimpl Deserialize for u32 {\n let N: u32 = U32_SERIALIZED_LEN;\n\n fn deserialize(fields: [Field; Self::N]) -> Self {\n let mut reader = Reader::new(fields);\n let result = Self::stream_deserialize(&mut reader);\n reader.finish();\n result\n }\n\n #[inline_always]\n fn stream_deserialize<let K: u32>(reader: &mut Reader<K>) -> Self {\n reader.read() as u32\n }\n}\n\nimpl Serialize for u64 {\n let N: u32 = U64_SERIALIZED_LEN;\n\n fn serialize(self) -> [Field; Self::N] {\n let mut writer: Writer<Self::N> = Writer::new();\n self.stream_serialize(&mut writer);\n writer.finish()\n }\n\n #[inline_always]\n fn stream_serialize<let K: u32>(self, writer: &mut Writer<K>) {\n writer.write(self as Field);\n }\n}\n\nimpl Deserialize for u64 {\n let N: u32 = U64_SERIALIZED_LEN;\n\n fn deserialize(fields: [Field; Self::N]) -> Self {\n let mut reader = Reader::new(fields);\n let result = Self::stream_deserialize(&mut reader);\n reader.finish();\n result\n }\n\n #[inline_always]\n fn stream_deserialize<let K: u32>(reader: &mut Reader<K>) -> Self {\n reader.read() as u64\n }\n}\n\nimpl Serialize for u128 {\n let N: u32 = U128_SERIALIZED_LEN;\n\n fn serialize(self) -> [Field; Self::N] {\n let mut writer: Writer<Self::N> = Writer::new();\n self.stream_serialize(&mut writer);\n writer.finish()\n }\n\n #[inline_always]\n fn stream_serialize<let K: u32>(self, writer: &mut Writer<K>) {\n writer.write(self as Field);\n }\n}\n\nimpl Deserialize for u128 {\n let N: u32 = U128_SERIALIZED_LEN;\n\n fn deserialize(fields: [Field; Self::N]) -> Self {\n let mut reader = Reader::new(fields);\n let result = Self::stream_deserialize(&mut reader);\n reader.finish();\n result\n }\n\n #[inline_always]\n fn stream_deserialize<let K: u32>(reader: &mut Reader<K>) -> Self {\n reader.read() as u128\n }\n}\n\nimpl Serialize for Field {\n let N: u32 = FIELD_SERIALIZED_LEN;\n\n fn serialize(self) -> [Field; Self::N] {\n let mut writer: Writer<Self::N> = Writer::new();\n self.stream_serialize(&mut writer);\n writer.finish()\n }\n\n #[inline_always]\n fn stream_serialize<let K: u32>(self, writer: &mut Writer<K>) {\n writer.write(self);\n }\n}\n\nimpl Deserialize for Field {\n let N: u32 = FIELD_SERIALIZED_LEN;\n\n fn deserialize(fields: [Field; Self::N]) -> Self {\n let mut reader = Reader::new(fields);\n let result = Self::stream_deserialize(&mut reader);\n reader.finish();\n result\n }\n\n #[inline_always]\n fn stream_deserialize<let K: u32>(reader: &mut Reader<K>) -> Self {\n reader.read()\n }\n}\n\nimpl Serialize for i8 {\n let N: u32 = I8_SERIALIZED_LEN;\n\n fn serialize(self) -> [Field; Self::N] {\n let mut writer: Writer<Self::N> = Writer::new();\n self.stream_serialize(&mut writer);\n writer.finish()\n }\n\n #[inline_always]\n fn stream_serialize<let K: u32>(self, writer: &mut Writer<K>) {\n writer.write(self as u8 as Field);\n }\n}\n\nimpl Deserialize for i8 {\n let N: u32 = I8_SERIALIZED_LEN;\n\n fn deserialize(fields: [Field; Self::N]) -> Self {\n let mut reader = Reader::new(fields);\n let result = Self::stream_deserialize(&mut reader);\n reader.finish();\n result\n }\n\n #[inline_always]\n fn stream_deserialize<let K: u32>(reader: &mut Reader<K>) -> Self {\n reader.read() as u8 as i8\n }\n}\n\nimpl Serialize for i16 {\n let N: u32 = I16_SERIALIZED_LEN;\n\n fn serialize(self) -> [Field; Self::N] {\n let mut writer: Writer<Self::N> = Writer::new();\n self.stream_serialize(&mut writer);\n writer.finish()\n }\n\n #[inline_always]\n fn stream_serialize<let K: u32>(self, writer: &mut Writer<K>) {\n writer.write(self as u16 as Field);\n }\n}\n\nimpl Deserialize for i16 {\n let N: u32 = I16_SERIALIZED_LEN;\n\n fn deserialize(fields: [Field; Self::N]) -> Self {\n let mut reader = Reader::new(fields);\n let result = Self::stream_deserialize(&mut reader);\n reader.finish();\n result\n }\n\n #[inline_always]\n fn stream_deserialize<let K: u32>(reader: &mut Reader<K>) -> Self {\n reader.read() as u16 as i16\n }\n}\n\nimpl Serialize for i32 {\n let N: u32 = I32_SERIALIZED_LEN;\n\n fn serialize(self) -> [Field; Self::N] {\n let mut writer: Writer<Self::N> = Writer::new();\n self.stream_serialize(&mut writer);\n writer.finish()\n }\n\n #[inline_always]\n fn stream_serialize<let K: u32>(self, writer: &mut Writer<K>) {\n writer.write(self as u32 as Field);\n }\n}\n\nimpl Deserialize for i32 {\n let N: u32 = I32_SERIALIZED_LEN;\n\n fn deserialize(fields: [Field; Self::N]) -> Self {\n let mut reader = Reader::new(fields);\n let result = Self::stream_deserialize(&mut reader);\n reader.finish();\n result\n }\n\n #[inline_always]\n fn stream_deserialize<let K: u32>(reader: &mut Reader<K>) -> Self {\n reader.read() as u32 as i32\n }\n}\n\nimpl Serialize for i64 {\n let N: u32 = I64_SERIALIZED_LEN;\n\n fn serialize(self) -> [Field; Self::N] {\n let mut writer: Writer<Self::N> = Writer::new();\n self.stream_serialize(&mut writer);\n writer.finish()\n }\n\n #[inline_always]\n fn stream_serialize<let K: u32>(self, writer: &mut Writer<K>) {\n writer.write(self as u64 as Field);\n }\n}\n\nimpl Deserialize for i64 {\n let N: u32 = I64_SERIALIZED_LEN;\n\n fn deserialize(fields: [Field; Self::N]) -> Self {\n let mut reader = Reader::new(fields);\n let result = Self::stream_deserialize(&mut reader);\n reader.finish();\n result\n }\n\n #[inline_always]\n fn stream_deserialize<let K: u32>(reader: &mut Reader<K>) -> Self {\n reader.read() as u64 as i64\n }\n}\n\nimpl<T, let M: u32> Serialize for [T; M]\nwhere\n T: Serialize,\n{\n let N: u32 = <T as Serialize>::N * M;\n\n fn serialize(self) -> [Field; Self::N] {\n let mut writer: Writer<Self::N> = Writer::new();\n self.stream_serialize(&mut writer);\n writer.finish()\n }\n\n #[inline_always]\n fn stream_serialize<let K: u32>(self, writer: &mut Writer<K>) {\n for i in 0..M {\n self[i].stream_serialize(writer);\n }\n }\n}\n\nimpl<T, let M: u32> Deserialize for [T; M]\nwhere\n T: Deserialize,\n{\n let N: u32 = <T as Deserialize>::N * M;\n\n fn deserialize(fields: [Field; Self::N]) -> Self {\n let mut reader = Reader::new(fields);\n let result = Self::stream_deserialize(&mut reader);\n reader.finish();\n result\n }\n\n #[inline_always]\n fn stream_deserialize<let K: u32>(reader: &mut Reader<K>) -> Self {\n let mut result: [T; M] = std::mem::zeroed();\n for i in 0..M {\n result[i] = T::stream_deserialize(reader);\n }\n result\n }\n}\n\nimpl<T> Serialize for Option<T>\nwhere\n T: Serialize,\n{\n let N: u32 = <T as Serialize>::N + 1;\n\n fn serialize(self) -> [Field; Self::N] {\n let mut writer: Writer<Self::N> = Writer::new();\n self.stream_serialize(&mut writer);\n writer.finish()\n }\n\n #[inline_always]\n fn stream_serialize<let K: u32>(self, writer: &mut Writer<K>) {\n writer.write_bool(self.is_some());\n if self.is_some() {\n self.unwrap_unchecked().stream_serialize(writer);\n } else {\n writer.advance_offset(<T as Serialize>::N);\n }\n }\n}\n\nimpl<T> Deserialize for Option<T>\nwhere\n T: Deserialize,\n{\n let N: u32 = <T as Deserialize>::N + 1;\n\n fn deserialize(fields: [Field; Self::N]) -> Self {\n let mut reader = Reader::new(fields);\n let result = Self::stream_deserialize(&mut reader);\n reader.finish();\n result\n }\n\n #[inline_always]\n fn stream_deserialize<let K: u32>(reader: &mut Reader<K>) -> Self {\n if reader.read_bool() {\n Option::some(<T as Deserialize>::stream_deserialize(reader))\n } else {\n reader.advance_offset(<T as Deserialize>::N);\n Option::none()\n }\n }\n}\n\nglobal SCALAR_SIZE: u32 = 2;\n\nimpl Serialize for EmbeddedCurveScalar {\n\n let N: u32 = SCALAR_SIZE;\n\n fn serialize(self) -> [Field; SCALAR_SIZE] {\n [self.lo, self.hi]\n }\n\n #[inline_always]\n fn stream_serialize<let K: u32>(self, writer: &mut Writer<K>) {\n writer.write(self.lo);\n writer.write(self.hi);\n }\n}\n\nimpl Deserialize for EmbeddedCurveScalar {\n let N: u32 = SCALAR_SIZE;\n\n fn deserialize(fields: [Field; Self::N]) -> Self {\n Self { lo: fields[0], hi: fields[1] }\n }\n\n #[inline_always]\n fn stream_deserialize<let K: u32>(reader: &mut Reader<K>) -> Self {\n Self { lo: reader.read(), hi: reader.read() }\n }\n}\n\nglobal POINT_SIZE: u32 = 3;\n\nimpl Serialize for EmbeddedCurvePoint {\n let N: u32 = POINT_SIZE;\n\n fn serialize(self) -> [Field; Self::N] {\n [self.x, self.y, self.is_infinite as Field]\n }\n\n fn stream_serialize<let K: u32>(self, writer: &mut Writer<K>) {\n writer.write(self.x);\n writer.write(self.y);\n writer.write(self.is_infinite as Field);\n }\n}\n\nimpl Deserialize for EmbeddedCurvePoint {\n let N: u32 = POINT_SIZE;\n\n fn deserialize(fields: [Field; Self::N]) -> Self {\n Self { x: fields[0], y: fields[1], is_infinite: fields[2] != 0 }\n }\n\n #[inline_always]\n fn stream_deserialize<let K: u32>(reader: &mut Reader<K>) -> Self {\n Self { x: reader.read(), y: reader.read(), is_infinite: reader.read_bool() }\n }\n}\n\nimpl<let M: u32> Deserialize for str<M> {\n let N: u32 = M;\n\n fn deserialize(fields: [Field; Self::N]) -> Self {\n let mut reader = Reader::new(fields);\n let result = Self::stream_deserialize(&mut reader);\n reader.finish();\n result\n }\n\n #[inline_always]\n fn stream_deserialize<let K: u32>(reader: &mut Reader<K>) -> Self {\n let u8_arr = <[u8; Self::N] as Deserialize>::stream_deserialize(reader);\n str::<Self::N>::from(u8_arr)\n }\n}\n\nimpl<let M: u32> Serialize for str<M> {\n let N: u32 = M;\n\n fn serialize(self) -> [Field; Self::N] {\n let mut writer: Writer<Self::N> = Writer::new();\n self.stream_serialize(&mut writer);\n writer.finish()\n }\n\n #[inline_always]\n fn stream_serialize<let K: u32>(self, writer: &mut Writer<K>) {\n self.as_bytes().stream_serialize(writer);\n }\n}\n\n// Note: Not deriving this because it's not supported to call derive_serialize on a \"remote\" struct (and it will never\n// be supported).\nimpl<T, let M: u32> Deserialize for BoundedVec<T, M>\nwhere\n T: Deserialize,\n{\n let N: u32 = <T as Deserialize>::N * M + 1;\n\n fn deserialize(fields: [Field; Self::N]) -> Self {\n let mut reader = Reader::new(fields);\n let result = Self::stream_deserialize(&mut reader);\n reader.finish();\n result\n }\n\n #[inline_always]\n fn stream_deserialize<let K: u32>(reader: &mut Reader<K>) -> Self {\n let mut new_bounded_vec: BoundedVec<T, M> = BoundedVec::new();\n let payload_len = Self::N - 1;\n\n // Length is stored in the last field as we need to match intrinsic Noir serialization and the `len` struct\n // field is after `storage` struct field (see `bounded_vec.nr` in noir-stdlib)\n let len = reader.peek_offset(payload_len) as u32;\n\n for i in 0..M {\n if i < len {\n new_bounded_vec.push(<T as Deserialize>::stream_deserialize(reader));\n }\n }\n\n // +1 for the length of the BoundedVec\n reader.advance_offset((M - len) * <T as Deserialize>::N + 1);\n\n new_bounded_vec\n }\n}\n\n// This may cause issues if used as program input, because noir disallows empty arrays for program input.\n// I think this is okay because I don't foresee a unit type being used as input. But leaving this comment as a hint\n// if someone does run into this in the future.\nimpl Deserialize for () {\n let N: u32 = 0;\n\n fn deserialize(fields: [Field; Self::N]) -> Self {\n let mut reader = Reader::new(fields);\n let result = Self::stream_deserialize(&mut reader);\n reader.finish();\n result\n }\n\n #[inline_always]\n fn stream_deserialize<let K: u32>(_reader: &mut Reader<K>) -> Self {\n ()\n }\n}\n\n// Note: Not deriving this because it's not supported to call derive_serialize on a \"remote\" struct (and it will never\n// be supported).\nimpl<T, let M: u32> Serialize for BoundedVec<T, M>\nwhere\n T: Serialize,\n{\n let N: u32 = <T as Serialize>::N * M + 1; // +1 for the length of the BoundedVec\n\n fn serialize(self) -> [Field; Self::N] {\n let mut writer: Writer<Self::N> = Writer::new();\n self.stream_serialize(&mut writer);\n writer.finish()\n }\n\n #[inline_always]\n fn stream_serialize<let K: u32>(self, writer: &mut Writer<K>) {\n self.storage().stream_serialize(writer);\n // Length is stored in the last field as we need to match intrinsic Noir serialization and the `len` struct\n // field is after `storage` struct field (see `bounded_vec.nr` in noir-stdlib)\n writer.write_u32(self.len() as u32);\n }\n}\n\n// Create a slice of the given length with each element made from `f(i)` where `i` is the current index\ncomptime fn make_slice<Env, T>(length: u32, f: fn[Env](u32) -> T) -> [T] {\n let mut slice = @[];\n for i in 0..length {\n slice = slice.push_back(f(i));\n }\n slice\n}\n\n// Implements Serialize and Deserialize for an arbitrary tuple type\ncomptime fn impl_serialize_for_tuple(_m: Module, length: u32) -> Quoted {\n // `T0`, `T1`, `T2`\n let type_names = make_slice(length, |i| f\"T{i}\".quoted_contents());\n\n // `result0`, `result1`, `result2`\n let result_names = make_slice(length, |i| f\"result{i}\".quoted_contents());\n\n // `T0, T1, T2`\n let field_generics = type_names.join(quote [,]);\n\n // `<T0 as Serialize>::N + <T1 as Serialize>::N + <T2 as Serialize>::N`\n let full_size_serialize = type_names\n .map(|type_name| quote {\n <$type_name as Serialize>::N\n })\n .join(quote [+]);\n\n // `<T0 as Deserialize>::N + <T1 as Deserialize>::N + <T2 as Deserialize>::N`\n let full_size_deserialize = type_names\n .map(|type_name| quote {\n <$type_name as Deserialize>::N\n })\n .join(quote [+]);\n\n // `T0: Serialize, T1: Serialize, T2: Serialize,`\n let serialize_constraints = type_names\n .map(|field_name| quote {\n $field_name: Serialize,\n })\n .join(quote []);\n\n // `T0: Deserialize, T1: Deserialize, T2: Deserialize,`\n let deserialize_constraints = type_names\n .map(|field_name| quote {\n $field_name: Deserialize,\n })\n .join(quote []);\n\n // Statements to serialize each field\n let serialized_fields = type_names\n .mapi(|i, _type_name| quote {\n $crate::serialization::Serialize::stream_serialize(self.$i, writer);\n })\n .join(quote []);\n\n // Statements to deserialize each field\n let deserialized_fields = type_names\n .mapi(|i, type_name| {\n let result_name = result_names[i];\n quote {\n let $result_name = <$type_name as $crate::serialization::Deserialize>::stream_deserialize(reader);\n }\n })\n .join(quote []);\n let deserialize_results = result_names.join(quote [,]);\n\n quote {\n impl<$field_generics> Serialize for ($field_generics) where $serialize_constraints {\n let N: u32 = $full_size_serialize;\n\n fn serialize(self) -> [Field; Self::N] {\n let mut writer: $crate::writer::Writer<Self::N> = $crate::writer::Writer::new();\n self.stream_serialize(&mut writer);\n writer.finish()\n }\n\n #[inline_always]\n fn stream_serialize<let K: u32>(self, writer: &mut $crate::writer::Writer<K>) {\n\n $serialized_fields\n }\n }\n\n impl<$field_generics> Deserialize for ($field_generics) where $deserialize_constraints {\n let N: u32 = $full_size_deserialize;\n\n fn deserialize(fields: [Field; Self::N]) -> Self {\n let mut reader = $crate::reader::Reader::new(fields);\n let result = Self::stream_deserialize(&mut reader);\n reader.finish();\n result\n }\n \n #[inline_always]\n fn stream_deserialize<let K: u32>(reader: &mut $crate::reader::Reader<K>) -> Self {\n $deserialized_fields\n ($deserialize_results)\n }\n }\n }\n}\n\n// Keeping these manual impls. They are more efficient since they do not\n// require copying sub-arrays from any serialized arrays.\nimpl<T1> Serialize for (T1,)\nwhere\n T1: Serialize,\n{\n let N: u32 = <T1 as Serialize>::N;\n\n fn serialize(self) -> [Field; Self::N] {\n let mut writer: crate::writer::Writer<Self::N> = crate::writer::Writer::new();\n self.stream_serialize(&mut writer);\n writer.finish()\n }\n\n #[inline_always]\n fn stream_serialize<let K: u32>(self, writer: &mut Writer<K>) {\n self.0.stream_serialize(writer);\n }\n}\n\nimpl<T1> Deserialize for (T1,)\nwhere\n T1: Deserialize,\n{\n let N: u32 = <T1 as Deserialize>::N;\n\n fn deserialize(fields: [Field; Self::N]) -> Self {\n let mut reader = crate::reader::Reader::new(fields);\n let result = Self::stream_deserialize(&mut reader);\n reader.finish();\n result\n }\n\n #[inline_always]\n fn stream_deserialize<let K: u32>(reader: &mut Reader<K>) -> Self {\n (<T1 as Deserialize>::stream_deserialize(reader),)\n }\n}\n\n#[impl_serialize_for_tuple(2)]\n#[impl_serialize_for_tuple(3)]\n#[impl_serialize_for_tuple(4)]\n#[impl_serialize_for_tuple(5)]\n#[impl_serialize_for_tuple(6)]\nmod impls {\n use crate::serialization::{Deserialize, Serialize};\n}\n"
|
|
937
|
+
"source": "use crate::{reader::Reader, serialization::{Deserialize, Serialize}, writer::Writer};\nuse std::embedded_curve_ops::EmbeddedCurvePoint;\nuse std::embedded_curve_ops::EmbeddedCurveScalar;\n\nglobal U1_SERIALIZED_LEN: u32 = 1;\nglobal BOOL_SERIALIZED_LEN: u32 = 1;\nglobal U8_SERIALIZED_LEN: u32 = 1;\nglobal U16_SERIALIZED_LEN: u32 = 1;\nglobal U32_SERIALIZED_LEN: u32 = 1;\nglobal U64_SERIALIZED_LEN: u32 = 1;\nglobal U128_SERIALIZED_LEN: u32 = 1;\nglobal FIELD_SERIALIZED_LEN: u32 = 1;\nglobal I8_SERIALIZED_LEN: u32 = 1;\nglobal I16_SERIALIZED_LEN: u32 = 1;\nglobal I32_SERIALIZED_LEN: u32 = 1;\nglobal I64_SERIALIZED_LEN: u32 = 1;\n\nimpl Serialize for bool {\n let N: u32 = BOOL_SERIALIZED_LEN;\n\n fn serialize(self) -> [Field; Self::N] {\n let mut writer: Writer<Self::N> = Writer::new();\n self.stream_serialize(&mut writer);\n writer.finish()\n }\n\n #[inline_always]\n fn stream_serialize<let K: u32>(self, writer: &mut Writer<K>) {\n writer.write(self as Field);\n }\n}\n\nimpl Deserialize for bool {\n let N: u32 = BOOL_SERIALIZED_LEN;\n\n fn deserialize(fields: [Field; Self::N]) -> Self {\n let mut reader = Reader::new(fields);\n let result = Self::stream_deserialize(&mut reader);\n reader.finish();\n result\n }\n\n #[inline_always]\n fn stream_deserialize<let K: u32>(reader: &mut Reader<K>) -> bool {\n reader.read() != 0\n }\n}\n\nimpl Serialize for u1 {\n let N: u32 = U1_SERIALIZED_LEN;\n\n fn serialize(self) -> [Field; Self::N] {\n let mut writer: Writer<Self::N> = Writer::new();\n self.stream_serialize(&mut writer);\n writer.finish()\n }\n\n #[inline_always]\n fn stream_serialize<let K: u32>(self, writer: &mut Writer<K>) {\n writer.write(self as Field);\n }\n}\n\nimpl Deserialize for u1 {\n let N: u32 = U1_SERIALIZED_LEN;\n\n fn deserialize(fields: [Field; Self::N]) -> Self {\n let mut reader = Reader::new(fields);\n let result = Self::stream_deserialize(&mut reader);\n reader.finish();\n result\n }\n\n #[inline_always]\n fn stream_deserialize<let K: u32>(reader: &mut Reader<K>) -> Self {\n reader.read() as u1\n }\n}\n\nimpl Serialize for u8 {\n let N: u32 = U8_SERIALIZED_LEN;\n\n fn serialize(self) -> [Field; Self::N] {\n let mut writer: Writer<Self::N> = Writer::new();\n self.stream_serialize(&mut writer);\n writer.finish()\n }\n\n #[inline_always]\n fn stream_serialize<let K: u32>(self, writer: &mut Writer<K>) {\n writer.write(self as Field);\n }\n}\n\nimpl Deserialize for u8 {\n let N: u32 = U8_SERIALIZED_LEN;\n\n fn deserialize(fields: [Field; Self::N]) -> Self {\n let mut reader = Reader::new(fields);\n let result = Self::stream_deserialize(&mut reader);\n reader.finish();\n result\n }\n\n #[inline_always]\n fn stream_deserialize<let K: u32>(reader: &mut Reader<K>) -> Self {\n reader.read() as u8\n }\n}\n\nimpl Serialize for u16 {\n let N: u32 = U16_SERIALIZED_LEN;\n\n fn serialize(self) -> [Field; Self::N] {\n let mut writer: Writer<Self::N> = Writer::new();\n self.stream_serialize(&mut writer);\n writer.finish()\n }\n\n #[inline_always]\n fn stream_serialize<let K: u32>(self, writer: &mut Writer<K>) {\n writer.write(self as Field);\n }\n}\n\nimpl Deserialize for u16 {\n let N: u32 = U16_SERIALIZED_LEN;\n\n fn deserialize(fields: [Field; Self::N]) -> Self {\n let mut reader = Reader::new(fields);\n let result = Self::stream_deserialize(&mut reader);\n reader.finish();\n result\n }\n\n #[inline_always]\n fn stream_deserialize<let K: u32>(reader: &mut Reader<K>) -> Self {\n reader.read() as u16\n }\n}\n\nimpl Serialize for u32 {\n let N: u32 = U32_SERIALIZED_LEN;\n\n fn serialize(self) -> [Field; Self::N] {\n let mut writer: Writer<Self::N> = Writer::new();\n self.stream_serialize(&mut writer);\n writer.finish()\n }\n\n #[inline_always]\n fn stream_serialize<let K: u32>(self, writer: &mut Writer<K>) {\n writer.write(self as Field);\n }\n}\n\nimpl Deserialize for u32 {\n let N: u32 = U32_SERIALIZED_LEN;\n\n fn deserialize(fields: [Field; Self::N]) -> Self {\n let mut reader = Reader::new(fields);\n let result = Self::stream_deserialize(&mut reader);\n reader.finish();\n result\n }\n\n #[inline_always]\n fn stream_deserialize<let K: u32>(reader: &mut Reader<K>) -> Self {\n reader.read() as u32\n }\n}\n\nimpl Serialize for u64 {\n let N: u32 = U64_SERIALIZED_LEN;\n\n fn serialize(self) -> [Field; Self::N] {\n let mut writer: Writer<Self::N> = Writer::new();\n self.stream_serialize(&mut writer);\n writer.finish()\n }\n\n #[inline_always]\n fn stream_serialize<let K: u32>(self, writer: &mut Writer<K>) {\n writer.write(self as Field);\n }\n}\n\nimpl Deserialize for u64 {\n let N: u32 = U64_SERIALIZED_LEN;\n\n fn deserialize(fields: [Field; Self::N]) -> Self {\n let mut reader = Reader::new(fields);\n let result = Self::stream_deserialize(&mut reader);\n reader.finish();\n result\n }\n\n #[inline_always]\n fn stream_deserialize<let K: u32>(reader: &mut Reader<K>) -> Self {\n reader.read() as u64\n }\n}\n\nimpl Serialize for u128 {\n let N: u32 = U128_SERIALIZED_LEN;\n\n fn serialize(self) -> [Field; Self::N] {\n let mut writer: Writer<Self::N> = Writer::new();\n self.stream_serialize(&mut writer);\n writer.finish()\n }\n\n #[inline_always]\n fn stream_serialize<let K: u32>(self, writer: &mut Writer<K>) {\n writer.write(self as Field);\n }\n}\n\nimpl Deserialize for u128 {\n let N: u32 = U128_SERIALIZED_LEN;\n\n fn deserialize(fields: [Field; Self::N]) -> Self {\n let mut reader = Reader::new(fields);\n let result = Self::stream_deserialize(&mut reader);\n reader.finish();\n result\n }\n\n #[inline_always]\n fn stream_deserialize<let K: u32>(reader: &mut Reader<K>) -> Self {\n reader.read() as u128\n }\n}\n\nimpl Serialize for Field {\n let N: u32 = FIELD_SERIALIZED_LEN;\n\n fn serialize(self) -> [Field; Self::N] {\n let mut writer: Writer<Self::N> = Writer::new();\n self.stream_serialize(&mut writer);\n writer.finish()\n }\n\n #[inline_always]\n fn stream_serialize<let K: u32>(self, writer: &mut Writer<K>) {\n writer.write(self);\n }\n}\n\nimpl Deserialize for Field {\n let N: u32 = FIELD_SERIALIZED_LEN;\n\n fn deserialize(fields: [Field; Self::N]) -> Self {\n let mut reader = Reader::new(fields);\n let result = Self::stream_deserialize(&mut reader);\n reader.finish();\n result\n }\n\n #[inline_always]\n fn stream_deserialize<let K: u32>(reader: &mut Reader<K>) -> Self {\n reader.read()\n }\n}\n\nimpl Serialize for i8 {\n let N: u32 = I8_SERIALIZED_LEN;\n\n fn serialize(self) -> [Field; Self::N] {\n let mut writer: Writer<Self::N> = Writer::new();\n self.stream_serialize(&mut writer);\n writer.finish()\n }\n\n #[inline_always]\n fn stream_serialize<let K: u32>(self, writer: &mut Writer<K>) {\n writer.write(self as u8 as Field);\n }\n}\n\nimpl Deserialize for i8 {\n let N: u32 = I8_SERIALIZED_LEN;\n\n fn deserialize(fields: [Field; Self::N]) -> Self {\n let mut reader = Reader::new(fields);\n let result = Self::stream_deserialize(&mut reader);\n reader.finish();\n result\n }\n\n #[inline_always]\n fn stream_deserialize<let K: u32>(reader: &mut Reader<K>) -> Self {\n reader.read() as u8 as i8\n }\n}\n\nimpl Serialize for i16 {\n let N: u32 = I16_SERIALIZED_LEN;\n\n fn serialize(self) -> [Field; Self::N] {\n let mut writer: Writer<Self::N> = Writer::new();\n self.stream_serialize(&mut writer);\n writer.finish()\n }\n\n #[inline_always]\n fn stream_serialize<let K: u32>(self, writer: &mut Writer<K>) {\n writer.write(self as u16 as Field);\n }\n}\n\nimpl Deserialize for i16 {\n let N: u32 = I16_SERIALIZED_LEN;\n\n fn deserialize(fields: [Field; Self::N]) -> Self {\n let mut reader = Reader::new(fields);\n let result = Self::stream_deserialize(&mut reader);\n reader.finish();\n result\n }\n\n #[inline_always]\n fn stream_deserialize<let K: u32>(reader: &mut Reader<K>) -> Self {\n reader.read() as u16 as i16\n }\n}\n\nimpl Serialize for i32 {\n let N: u32 = I32_SERIALIZED_LEN;\n\n fn serialize(self) -> [Field; Self::N] {\n let mut writer: Writer<Self::N> = Writer::new();\n self.stream_serialize(&mut writer);\n writer.finish()\n }\n\n #[inline_always]\n fn stream_serialize<let K: u32>(self, writer: &mut Writer<K>) {\n writer.write(self as u32 as Field);\n }\n}\n\nimpl Deserialize for i32 {\n let N: u32 = I32_SERIALIZED_LEN;\n\n fn deserialize(fields: [Field; Self::N]) -> Self {\n let mut reader = Reader::new(fields);\n let result = Self::stream_deserialize(&mut reader);\n reader.finish();\n result\n }\n\n #[inline_always]\n fn stream_deserialize<let K: u32>(reader: &mut Reader<K>) -> Self {\n reader.read() as u32 as i32\n }\n}\n\nimpl Serialize for i64 {\n let N: u32 = I64_SERIALIZED_LEN;\n\n fn serialize(self) -> [Field; Self::N] {\n let mut writer: Writer<Self::N> = Writer::new();\n self.stream_serialize(&mut writer);\n writer.finish()\n }\n\n #[inline_always]\n fn stream_serialize<let K: u32>(self, writer: &mut Writer<K>) {\n writer.write(self as u64 as Field);\n }\n}\n\nimpl Deserialize for i64 {\n let N: u32 = I64_SERIALIZED_LEN;\n\n fn deserialize(fields: [Field; Self::N]) -> Self {\n let mut reader = Reader::new(fields);\n let result = Self::stream_deserialize(&mut reader);\n reader.finish();\n result\n }\n\n #[inline_always]\n fn stream_deserialize<let K: u32>(reader: &mut Reader<K>) -> Self {\n reader.read() as u64 as i64\n }\n}\n\nimpl<T, let M: u32> Serialize for [T; M]\nwhere\n T: Serialize,\n{\n let N: u32 = <T as Serialize>::N * M;\n\n fn serialize(self) -> [Field; Self::N] {\n let mut writer: Writer<Self::N> = Writer::new();\n self.stream_serialize(&mut writer);\n writer.finish()\n }\n\n #[inline_always]\n fn stream_serialize<let K: u32>(self, writer: &mut Writer<K>) {\n for i in 0..M {\n self[i].stream_serialize(writer);\n }\n }\n}\n\nimpl<T, let M: u32> Deserialize for [T; M]\nwhere\n T: Deserialize,\n{\n let N: u32 = <T as Deserialize>::N * M;\n\n fn deserialize(fields: [Field; Self::N]) -> Self {\n let mut reader = Reader::new(fields);\n let result = Self::stream_deserialize(&mut reader);\n reader.finish();\n result\n }\n\n #[inline_always]\n fn stream_deserialize<let K: u32>(reader: &mut Reader<K>) -> Self {\n let mut result: [T; M] = std::mem::zeroed();\n for i in 0..M {\n result[i] = T::stream_deserialize(reader);\n }\n result\n }\n}\n\nimpl<T> Serialize for Option<T>\nwhere\n T: Serialize,\n{\n let N: u32 = <T as Serialize>::N + 1;\n\n fn serialize(self) -> [Field; Self::N] {\n let mut writer: Writer<Self::N> = Writer::new();\n self.stream_serialize(&mut writer);\n writer.finish()\n }\n\n #[inline_always]\n fn stream_serialize<let K: u32>(self, writer: &mut Writer<K>) {\n writer.write_bool(self.is_some());\n if self.is_some() {\n self.unwrap_unchecked().stream_serialize(writer);\n } else {\n writer.advance_offset(<T as Serialize>::N);\n }\n }\n}\n\nimpl<T> Deserialize for Option<T>\nwhere\n T: Deserialize,\n{\n let N: u32 = <T as Deserialize>::N + 1;\n\n fn deserialize(fields: [Field; Self::N]) -> Self {\n let mut reader = Reader::new(fields);\n let result = Self::stream_deserialize(&mut reader);\n reader.finish();\n result\n }\n\n #[inline_always]\n fn stream_deserialize<let K: u32>(reader: &mut Reader<K>) -> Self {\n if reader.read_bool() {\n Option::some(<T as Deserialize>::stream_deserialize(reader))\n } else {\n reader.advance_offset(<T as Deserialize>::N);\n Option::none()\n }\n }\n}\n\nglobal SCALAR_SIZE: u32 = 2;\n\nimpl Serialize for EmbeddedCurveScalar {\n\n let N: u32 = SCALAR_SIZE;\n\n fn serialize(self) -> [Field; SCALAR_SIZE] {\n [self.lo, self.hi]\n }\n\n #[inline_always]\n fn stream_serialize<let K: u32>(self, writer: &mut Writer<K>) {\n writer.write(self.lo);\n writer.write(self.hi);\n }\n}\n\nimpl Deserialize for EmbeddedCurveScalar {\n let N: u32 = SCALAR_SIZE;\n\n fn deserialize(fields: [Field; Self::N]) -> Self {\n Self { lo: fields[0], hi: fields[1] }\n }\n\n #[inline_always]\n fn stream_deserialize<let K: u32>(reader: &mut Reader<K>) -> Self {\n Self { lo: reader.read(), hi: reader.read() }\n }\n}\n\nglobal POINT_SIZE: u32 = 3;\n\nimpl Serialize for EmbeddedCurvePoint {\n let N: u32 = POINT_SIZE;\n\n fn serialize(self) -> [Field; Self::N] {\n [self.x, self.y, self.is_infinite as Field]\n }\n\n fn stream_serialize<let K: u32>(self, writer: &mut Writer<K>) {\n writer.write(self.x);\n writer.write(self.y);\n writer.write(self.is_infinite as Field);\n }\n}\n\nimpl Deserialize for EmbeddedCurvePoint {\n let N: u32 = POINT_SIZE;\n\n fn deserialize(fields: [Field; Self::N]) -> Self {\n Self { x: fields[0], y: fields[1], is_infinite: fields[2] != 0 }\n }\n\n #[inline_always]\n fn stream_deserialize<let K: u32>(reader: &mut Reader<K>) -> Self {\n Self { x: reader.read(), y: reader.read(), is_infinite: reader.read_bool() }\n }\n}\n\nimpl<let M: u32> Deserialize for str<M> {\n let N: u32 = M;\n\n fn deserialize(fields: [Field; Self::N]) -> Self {\n let mut reader = Reader::new(fields);\n let result = Self::stream_deserialize(&mut reader);\n reader.finish();\n result\n }\n\n #[inline_always]\n fn stream_deserialize<let K: u32>(reader: &mut Reader<K>) -> Self {\n let u8_arr = <[u8; Self::N] as Deserialize>::stream_deserialize(reader);\n str::<Self::N>::from(u8_arr)\n }\n}\n\nimpl<let M: u32> Serialize for str<M> {\n let N: u32 = M;\n\n fn serialize(self) -> [Field; Self::N] {\n let mut writer: Writer<Self::N> = Writer::new();\n self.stream_serialize(&mut writer);\n writer.finish()\n }\n\n #[inline_always]\n fn stream_serialize<let K: u32>(self, writer: &mut Writer<K>) {\n self.as_bytes().stream_serialize(writer);\n }\n}\n\n// Note: Not deriving this because it's not supported to call derive_serialize on a \"remote\" struct (and it will never\n// be supported).\nimpl<T, let M: u32> Deserialize for BoundedVec<T, M>\nwhere\n T: Deserialize,\n{\n let N: u32 = <T as Deserialize>::N * M + 1;\n\n fn deserialize(fields: [Field; Self::N]) -> Self {\n let mut reader = Reader::new(fields);\n let result = Self::stream_deserialize(&mut reader);\n reader.finish();\n result\n }\n\n #[inline_always]\n fn stream_deserialize<let K: u32>(reader: &mut Reader<K>) -> Self {\n let mut new_bounded_vec: BoundedVec<T, M> = BoundedVec::new();\n let payload_len = Self::N - 1;\n\n // Length is stored in the last field as we need to match intrinsic Noir serialization and the `len` struct\n // field is after `storage` struct field (see `bounded_vec.nr` in noir-stdlib)\n let len = reader.peek_offset(payload_len) as u32;\n\n for i in 0..M {\n if i < len {\n new_bounded_vec.push(<T as Deserialize>::stream_deserialize(reader));\n }\n }\n\n // +1 for the length of the BoundedVec\n reader.advance_offset((M - len) * <T as Deserialize>::N + 1);\n\n new_bounded_vec\n }\n}\n\n// This may cause issues if used as program input, because noir disallows empty arrays for program input.\n// I think this is okay because I don't foresee a unit type being used as input. But leaving this comment as a hint\n// if someone does run into this in the future.\nimpl Deserialize for () {\n let N: u32 = 0;\n\n fn deserialize(fields: [Field; Self::N]) -> Self {\n let mut reader = Reader::new(fields);\n let result = Self::stream_deserialize(&mut reader);\n reader.finish();\n result\n }\n\n #[inline_always]\n fn stream_deserialize<let K: u32>(_reader: &mut Reader<K>) -> Self {\n ()\n }\n}\n\n// Note: Not deriving this because it's not supported to call derive_serialize on a \"remote\" struct (and it will never\n// be supported).\nimpl<T, let M: u32> Serialize for BoundedVec<T, M>\nwhere\n T: Serialize,\n{\n let N: u32 = <T as Serialize>::N * M + 1; // +1 for the length of the BoundedVec\n\n fn serialize(self) -> [Field; Self::N] {\n let mut writer: Writer<Self::N> = Writer::new();\n self.stream_serialize(&mut writer);\n writer.finish()\n }\n\n #[inline_always]\n fn stream_serialize<let K: u32>(self, writer: &mut Writer<K>) {\n self.storage().stream_serialize(writer);\n // Length is stored in the last field as we need to match intrinsic Noir serialization and the `len` struct\n // field is after `storage` struct field (see `bounded_vec.nr` in noir-stdlib)\n writer.write_u32(self.len() as u32);\n }\n}\n\n// Create a slice of the given length with each element made from `f(i)` where `i` is the current index\ncomptime fn make_slice<Env, T>(length: u32, f: fn[Env](u32) -> T) -> [T] {\n let mut slice = @[];\n for i in 0..length {\n slice = slice.push_back(f(i));\n }\n slice\n}\n\n// Implements Serialize and Deserialize for an arbitrary tuple type\ncomptime fn impl_serialize_for_tuple(_m: Module, length: u32) -> Quoted {\n // `T0`, `T1`, `T2`\n let type_names = make_slice(length, |i| f\"T{i}\".quoted_contents());\n\n // `result0`, `result1`, `result2`\n let result_names = make_slice(length, |i| f\"result{i}\".quoted_contents());\n\n // `T0, T1, T2`\n let field_generics = type_names.join(quote [,]);\n\n // `<T0 as Serialize>::N + <T1 as Serialize>::N + <T2 as Serialize>::N`\n let full_size_serialize = type_names\n .map(|type_name| quote {\n <$type_name as Serialize>::N\n })\n .join(quote [+]);\n\n // `<T0 as Deserialize>::N + <T1 as Deserialize>::N + <T2 as Deserialize>::N`\n let full_size_deserialize = type_names\n .map(|type_name| quote {\n <$type_name as Deserialize>::N\n })\n .join(quote [+]);\n\n // `T0: Serialize, T1: Serialize, T2: Serialize,`\n let serialize_constraints = type_names\n .map(|field_name| quote {\n $field_name: Serialize,\n })\n .join(quote []);\n\n // `T0: Deserialize, T1: Deserialize, T2: Deserialize,`\n let deserialize_constraints = type_names\n .map(|field_name| quote {\n $field_name: Deserialize,\n })\n .join(quote []);\n\n // Statements to serialize each field\n let serialized_fields = type_names\n .mapi(|i, _type_name| quote {\n $crate::serialization::Serialize::stream_serialize(self.$i, writer);\n })\n .join(quote []);\n\n // Statements to deserialize each field\n let deserialized_fields = type_names\n .mapi(|i, type_name| {\n let result_name = result_names[i];\n quote {\n let $result_name = <$type_name as $crate::serialization::Deserialize>::stream_deserialize(reader);\n }\n })\n .join(quote []);\n let deserialize_results = result_names.join(quote [,]);\n\n quote {\n impl<$field_generics> Serialize for ($field_generics) where $serialize_constraints {\n let N: u32 = $full_size_serialize;\n\n fn serialize(self) -> [Field; Self::N] {\n let mut writer: $crate::writer::Writer<Self::N> = $crate::writer::Writer::new();\n self.stream_serialize(&mut writer);\n writer.finish()\n }\n\n #[inline_always]\n fn stream_serialize<let K: u32>(self, writer: &mut $crate::writer::Writer<K>) {\n\n $serialized_fields\n }\n }\n\n impl<$field_generics> Deserialize for ($field_generics) where $deserialize_constraints {\n let N: u32 = $full_size_deserialize;\n\n fn deserialize(fields: [Field; Self::N]) -> Self {\n let mut reader = $crate::reader::Reader::new(fields);\n let result = Self::stream_deserialize(&mut reader);\n reader.finish();\n result\n }\n \n #[inline_always]\n fn stream_deserialize<let K: u32>(reader: &mut $crate::reader::Reader<K>) -> Self {\n $deserialized_fields\n ($deserialize_results)\n }\n }\n }\n}\n\n// Keeping these manual impls. They are more efficient since they do not\n// require copying sub-arrays from any serialized arrays.\nimpl<T1> Serialize for (T1,)\nwhere\n T1: Serialize,\n{\n let N: u32 = <T1 as Serialize>::N;\n\n fn serialize(self) -> [Field; Self::N] {\n let mut writer: crate::writer::Writer<Self::N> = crate::writer::Writer::new();\n self.stream_serialize(&mut writer);\n writer.finish()\n }\n\n #[inline_always]\n fn stream_serialize<let K: u32>(self, writer: &mut Writer<K>) {\n self.0.stream_serialize(writer);\n }\n}\n\nimpl<T1> Deserialize for (T1,)\nwhere\n T1: Deserialize,\n{\n let N: u32 = <T1 as Deserialize>::N;\n\n fn deserialize(fields: [Field; Self::N]) -> Self {\n let mut reader = crate::reader::Reader::new(fields);\n let result = Self::stream_deserialize(&mut reader);\n reader.finish();\n result\n }\n\n #[inline_always]\n fn stream_deserialize<let K: u32>(reader: &mut Reader<K>) -> Self {\n (<T1 as Deserialize>::stream_deserialize(reader),)\n }\n}\n\n#[impl_serialize_for_tuple(2)]\n#[impl_serialize_for_tuple(3)]\n#[impl_serialize_for_tuple(4)]\n#[impl_serialize_for_tuple(5)]\n#[impl_serialize_for_tuple(6)]\nmod impls {\n use crate::serialization::{Deserialize, Serialize};\n}\n\n#[test]\nunconstrained fn bounded_vec_serialization() {\n // Test empty BoundedVec\n let empty_vec: BoundedVec<Field, 3> = BoundedVec::from_array([]);\n let serialized = empty_vec.serialize();\n let deserialized = BoundedVec::<Field, 3>::deserialize(serialized);\n assert_eq(empty_vec, deserialized);\n assert_eq(deserialized.len(), 0);\n\n // Test partially filled BoundedVec\n let partial_vec: BoundedVec<[u32; 2], 3> = BoundedVec::from_array([[1, 2]]);\n let serialized = partial_vec.serialize();\n let deserialized = BoundedVec::<[u32; 2], 3>::deserialize(serialized);\n assert_eq(partial_vec, deserialized);\n assert_eq(deserialized.len(), 1);\n assert_eq(deserialized.get(0), [1, 2]);\n\n // Test full BoundedVec\n let full_vec: BoundedVec<[u32; 2], 3> = BoundedVec::from_array([[1, 2], [3, 4], [5, 6]]);\n let serialized = full_vec.serialize();\n let deserialized = BoundedVec::<[u32; 2], 3>::deserialize(serialized);\n assert_eq(full_vec, deserialized);\n assert_eq(deserialized.len(), 3);\n assert_eq(deserialized.get(0), [1, 2]);\n assert_eq(deserialized.get(1), [3, 4]);\n assert_eq(deserialized.get(2), [5, 6]);\n}\n"
|
|
934
938
|
},
|
|
935
|
-
"
|
|
939
|
+
"421": {
|
|
936
940
|
"path": "/home/aztec-dev/aztec-packages/noir-projects/noir-protocol-circuits/crates/serde/src/writer.nr",
|
|
937
941
|
"source": "pub struct Writer<let N: u32> {\n data: [Field; N],\n offset: u32,\n}\n\nimpl<let N: u32> Writer<N> {\n pub fn new() -> Self {\n Self { data: [0; N], offset: 0 }\n }\n\n pub fn write(&mut self, value: Field) {\n self.data[self.offset] = value;\n self.offset += 1;\n }\n\n pub fn write_u32(&mut self, value: u32) {\n self.write(value as Field);\n }\n\n pub fn write_u64(&mut self, value: u64) {\n self.write(value as Field);\n }\n\n pub fn write_bool(&mut self, value: bool) {\n self.write(value as Field);\n }\n\n pub fn write_array<let K: u32>(&mut self, value: [Field; K]) {\n for i in 0..K {\n self.data[i + self.offset] = value[i];\n }\n self.offset += K;\n }\n\n pub fn write_struct<T, let K: u32>(&mut self, value: T, serialize: fn(T) -> [Field; K]) {\n self.write_array(serialize(value));\n }\n\n pub fn write_struct_array<T, let K: u32, let C: u32>(\n &mut self,\n value: [T; C],\n serialize: fn(T) -> [Field; K],\n ) {\n for i in 0..C {\n self.write_struct(value[i], serialize);\n }\n }\n\n pub fn advance_offset(&mut self, offset: u32) {\n self.offset += offset;\n }\n\n pub fn finish(self) -> [Field; N] {\n assert_eq(self.offset, self.data.len(), \"Writer did not write all data\");\n self.data\n }\n}\n"
|
|
938
942
|
},
|
|
939
|
-
"42": {
|
|
940
|
-
"path": "std/option.nr",
|
|
941
|
-
"source": "use crate::cmp::{Eq, Ord, Ordering};\nuse crate::default::Default;\nuse crate::hash::{Hash, Hasher};\n\npub struct Option<T> {\n _is_some: bool,\n _value: T,\n}\n\nimpl<T> Option<T> {\n /// Constructs a None value\n pub fn none() -> Self {\n Self { _is_some: false, _value: crate::mem::zeroed() }\n }\n\n /// Constructs a Some wrapper around the given value\n pub fn some(_value: T) -> Self {\n Self { _is_some: true, _value }\n }\n\n /// True if this Option is None\n pub fn is_none(self) -> bool {\n !self._is_some\n }\n\n /// True if this Option is Some\n pub fn is_some(self) -> bool {\n self._is_some\n }\n\n /// Asserts `self.is_some()` and returns the wrapped value.\n pub fn unwrap(self) -> T {\n assert(self._is_some);\n self._value\n }\n\n /// Returns the inner value without asserting `self.is_some()`\n /// Note that if `self` is `None`, there is no guarantee what value will be returned,\n /// only that it will be of type `T`.\n pub fn unwrap_unchecked(self) -> T {\n self._value\n }\n\n /// Returns the wrapped value if `self.is_some()`. Otherwise, returns the given default value.\n pub fn unwrap_or(self, default: T) -> T {\n if self._is_some {\n self._value\n } else {\n default\n }\n }\n\n /// Returns the wrapped value if `self.is_some()`. Otherwise, calls the given function to return\n /// a default value.\n pub fn unwrap_or_else<Env>(self, default: fn[Env]() -> T) -> T {\n if self._is_some {\n self._value\n } else {\n default()\n }\n }\n\n /// Asserts `self.is_some()` with a provided custom message and returns the contained `Some` value\n pub fn expect<let N: u32, MessageTypes>(self, message: fmtstr<N, MessageTypes>) -> T {\n assert(self.is_some(), message);\n self._value\n }\n\n /// If self is `Some(x)`, this returns `Some(f(x))`. Otherwise, this returns `None`.\n pub fn map<U, Env>(self, f: fn[Env](T) -> U) -> Option<U> {\n if self._is_some {\n Option::some(f(self._value))\n } else {\n Option::none()\n }\n }\n\n /// If self is `Some(x)`, this returns `f(x)`. Otherwise, this returns the given default value.\n pub fn map_or<U, Env>(self, default: U, f: fn[Env](T) -> U) -> U {\n if self._is_some {\n f(self._value)\n } else {\n default\n }\n }\n\n /// If self is `Some(x)`, this returns `f(x)`. Otherwise, this returns `default()`.\n pub fn map_or_else<U, Env1, Env2>(self, default: fn[Env1]() -> U, f: fn[Env2](T) -> U) -> U {\n if self._is_some {\n f(self._value)\n } else {\n default()\n }\n }\n\n /// Returns None if self is None. Otherwise, this returns `other`.\n pub fn and(self, other: Self) -> Self {\n if self.is_none() {\n Option::none()\n } else {\n other\n }\n }\n\n /// If self is None, this returns None. Otherwise, this calls the given function\n /// with the Some value contained within self, and returns the result of that call.\n ///\n /// In some languages this function is called `flat_map` or `bind`.\n pub fn and_then<U, Env>(self, f: fn[Env](T) -> Option<U>) -> Option<U> {\n if self._is_some {\n f(self._value)\n } else {\n Option::none()\n }\n }\n\n /// If self is Some, return self. Otherwise, return `other`.\n pub fn or(self, other: Self) -> Self {\n if self._is_some {\n self\n } else {\n other\n }\n }\n\n /// If self is Some, return self. Otherwise, return `default()`.\n pub fn or_else<Env>(self, default: fn[Env]() -> Self) -> Self {\n if self._is_some {\n self\n } else {\n default()\n }\n }\n\n // If only one of the two Options is Some, return that option.\n // Otherwise, if both options are Some or both are None, None is returned.\n pub fn xor(self, other: Self) -> Self {\n if self._is_some {\n if other._is_some {\n Option::none()\n } else {\n self\n }\n } else if other._is_some {\n other\n } else {\n Option::none()\n }\n }\n\n /// Returns `Some(x)` if self is `Some(x)` and `predicate(x)` is true.\n /// Otherwise, this returns `None`\n pub fn filter<Env>(self, predicate: fn[Env](T) -> bool) -> Self {\n if self._is_some {\n if predicate(self._value) {\n self\n } else {\n Option::none()\n }\n } else {\n Option::none()\n }\n }\n\n /// Flattens an Option<Option<T>> into a Option<T>.\n /// This returns None if the outer Option is None. Otherwise, this returns the inner Option.\n pub fn flatten(option: Option<Option<T>>) -> Option<T> {\n if option._is_some {\n option._value\n } else {\n Option::none()\n }\n }\n}\n\nimpl<T> Default for Option<T> {\n fn default() -> Self {\n Option::none()\n }\n}\n\nimpl<T> Eq for Option<T>\nwhere\n T: Eq,\n{\n fn eq(self, other: Self) -> bool {\n if self._is_some == other._is_some {\n if self._is_some {\n self._value == other._value\n } else {\n true\n }\n } else {\n false\n }\n }\n}\n\nimpl<T> Hash for Option<T>\nwhere\n T: Hash,\n{\n fn hash<H>(self, state: &mut H)\n where\n H: Hasher,\n {\n self._is_some.hash(state);\n if self._is_some {\n self._value.hash(state);\n }\n }\n}\n\n// For this impl we're declaring Option::none < Option::some\nimpl<T> Ord for Option<T>\nwhere\n T: Ord,\n{\n fn cmp(self, other: Self) -> Ordering {\n if self._is_some {\n if other._is_some {\n self._value.cmp(other._value)\n } else {\n Ordering::greater()\n }\n } else if other._is_some {\n Ordering::less()\n } else {\n Ordering::equal()\n }\n }\n}\n"
|
|
942
|
-
},
|
|
943
943
|
"43": {
|
|
944
944
|
"path": "std/panic.nr",
|
|
945
945
|
"source": "pub fn panic<T, U>(message: T) -> U\nwhere\n T: StringLike,\n{\n assert(false, message);\n crate::mem::zeroed()\n}\n\ntrait StringLike {}\n\nimpl<let N: u32> StringLike for str<N> {}\nimpl<let N: u32, T> StringLike for fmtstr<N, T> {}\n"
|