@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.
@@ -76,7 +76,7 @@
76
76
  }
77
77
  },
78
78
  "bytecode": "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",
79
- "debug_symbols": "rZnRbts6DIbfxde5ECmJIvsqwzBkXToECNIiaw9wUPTdR8qi3Ayw0Sq9ab78iX5RFC067uv06/Dz5feP4/nh8c909+11+nk5nk7H3z9Oj/f75+PjWdXXKdgfSdMd7iaR6S7vJgj6luxV5lco8yvidAdgUBpEapCCQ26QXcmukCuUHLhBiQ7uzD4X2xRJQcAhO8gMGKIDNwBXLPYKaMPJgBpEV6IrKTmoM+rsmKMDNyBXyJXiigVfgcGBGkhwyA42hQYWLdszcANAB2pgwc/gSgwONpwMpEFyJaODBhaDAqkS425KNjwmA40n6qanTA1I54pkkBsU+3IxSA7SgF1hV8QV4RlyQIfSAMCBGmBwyA7NMEdNb2QFKg3YviMKltUZmkJBlRQMcgMr2gQGpUF0xYp2BvsyGuikSfNDOTlwA9v3CgUcNPikOSTb7hlcscBSNsjty9KcS0gOrkB0aHOVGnMFM9QtKLanqRhIA6vMxAbcgFypEVagBuyKbVMF26YkBjIDh+SghllTxzWwYlAa1MAquGIX0QzUoGa1gh0nml62ZGZNLxd0oAYcHLKDjdIcskQHnkFCdHAFXAFX0ObS1ImVTc4GGmrWHErCBlljzsXAJtVsiB1NM9hwMZAGxZXiCpcGgg5NgWBlNxOoJYVK2Qm7ZmESVJJ5agg14pnYKXUtFSe7rBtpGgmN7KJtZLNFI7tsG3WNYyd2Etc01E7mbGcs2LXaqGt1HblSbvOCrWMmO5Eadc3W0YidbB1U+4udTzPVdZRK5FS6Zlswk507jbpmu1AJ7cQhrlScoGt1HVL7GbR5sa6jkp2MjRZNnOw6bMROfR3Y14G2jlJbpe3HTLYfjbrGXeOuSddEIy1WL9HOtRLe3naTd+8fz5fDwZr3u3auTf5pfzmcn6e788vptJv+259e6pf+PO3P9fV5f9FP1fNw/qWvavhwPB2M3nbL6LA+VKvTrq86XJmoW2S48oB1j2jnTHWIlPr4gp+IoYQlBglrMcR1DwLmZkFaMIuDXDmkdQcsboAyuIr3mRRcW8Wmh7bO7pFTWfMoGx5orWq20PuT7sDpyoE3MsEeQxTu4xNcp1LWDQSsD1cHgbJsp23tVU1tpIJC9GxSSEtZxo8HwcmD0KNhPQhc92Ad2TxYe8i6x0Zlxow9m8t+xvDxDdU7Y9/QGGhtQyFvJLOnogRYM/h4XdLqFQq3FybcXJnwBaWJN5cmfEFt4hfUJt5cm3B7ceJGcWZesrlsCNNgcfJqceLmOkIvToiwFgbyVhwcU4+DU1prQrhRGRk8jIzvKjx+JowiZQkDZC2MCJs5Jewm2lxXTTYqNFLxfMQCeaSnSug7K+8c/q3QLQteClRQhizEfmc0i1zGLAp0C8YRCwzkFnofnIYsUvBcYMKxKFJcLN71gc9Y5NAXkpHGLHLoFhnGLFJaLHAwCuoWhW+OYtSiF7j+ThkqcKSE3SKPbSpR3xEqg1HkngvicPNCxiwiF29HkTkNWixtNQxtapQI3YLW05k3mrs+1vNekjguFf7P3dJmFEI9CiljC5Hllk3GChx6E1Acu9iDpMVi7GIH6KWlDyIGF0KLxe0LGbSA5QSHVMYscukWJIMWvQlc3YcPLmTUoj81QJCxVoTLpiLwoEVYLOTWhYxaLD/PEDmu/1INY0fOd323vz9erv5h9WZel+P+5+nQ3j68nO/fffr8/5N/4v/wero83h9+vVwO5rT810v/fEO9y9IHbt/tOai+LbRjsDdgn+kjTm1N398slL8="
79
+ "debug_symbols": "rZnRbts6DIbfxde5ECmJIvsqwzBkXToECNIiaw9wUPTdR8qi3Ayw0Sq9ab78iX5RFC067uv06/Dz5feP4/nh8c909+11+nk5nk7H3z9Oj/f75+PjWdXXKdgfSdMd7iaR6S7vJgj6luxV5lco8yvidAdgUBpEapCCQ26QXcmukCuUHLhBiQ7uzD4X2xRJQcAhO8gMGKIDNwBXLPYKaMPJgBpEV6IrKTmoM+rsmKMDNyBXyJXiigVfgcGBGkhwyA42hQYWLdszcANAB2pgwc/gSgwONpwMpEFyJaODBhaDAqkS425KNjwmA40n6qanTA1I54pkkBsU+3IxSA7SgF1hV8QV4RlyQIfSAMCBGmBwyA7NMEdNb2QFKg3YviMKltUZmkJBlRQMcgMr2gQGpUF0xYp2BvsyGuikSfNDOTlwA9v3CgUcNPikOSTb7hlcscBSNsjty9KcS0gOrkB0aHOVGnMFM9QtKLanqRhIA6vMxAbcgFypEVagBuyKbVMF26YkBjIDh+SghllTxzWwYlAa1MAquGIX0QzUoGa1gh0nml62ZGZNLxd0oAYcHLKDjdIcskQHnkFCdHAFXAFX0ObS1ImVTc4GGmrWHErCBlljzsXAJtVsiB1NM9hwMZAGxZXiCpcGgg5NgWBlNxOoJYVK2Qm7ZmESVJJ5agg14pnYKXUtFSe7rBtpGgmN7KJtZLNFI7tsG3WNYyd2Etc01E7mbGcs2LXaqGt1HblSbvOCrWMmO5Eadc3W0YidbB1U+4udTzPVdZRK5FS6Zlswk507jbpmu1AJ7cQhrlScoGt1HVL7GbR5sa6jkp2MjRZNnOw6bMROfR3Y14G2jlJbpe3HTLYfjbrGXeOuSddEIy1WL9HOtRLe3naTd+8fz5fDwZr3u3auTf5pfzmcn6e788vptJv+259e6pf+PO3P9fV5f9FP1fNw/qWvavhwPB2M3nbL6LA+VKvTrq86XJmoW2S48oB1j2jnTHWIlPr4gp+IoYQlBglrMcR1DwLmZkFaMIuDXDmkdQcsboAyuIr3mRRcW8Wmh7bO7pFTWfMoGx5orWq20PuT7sDpyoE3MsEeQxTu4xNcp1LWDQSsD1cHgbJsp23tVU1tpIJC9GxSSEtZxo8HwcmD0KNhPQhc92Ad2TxYe8i6x0Zlxow9m8t+xvDxDdU7Y9/QGGhtQyFvJLOnogRYM/h4XdLqFQq3FybcXJnwBaWJN5cmfEFt4hfUJt5cm3B7ceJGcWZesrlsCNNgcfJqceLmOkIvToiwFgbyVhwcU4+DU1prQrhRGRk8jIzvKjzBJ8IoUpYwQNbCiLCZU8Juos111WSjQiMVz0cskEd6qoS+s/LO4d8K3bLgpUAFZchC7HdGs8hlzKJAt2AcscBAbqH3wWnIIgXPBSYciyLFxeJdH/iMRQ59IRlpzCKHbpFhzCKlxQIHo6BuUfjmKEYteoHr75ShAkdK2C3y2KYS9R2hMhhF7rkgDjcvZMwicvF2FJnToMXSVsPQpkaJ0C1oPZ15o7nrYz3vJYnjUuH/3C1tRiHUo5AythBZbtlkrMChNwHFsYs9SFosxi52gF5a+iBicCG0WNy+kEELWE5wSGXMIpduQTJo0ZvA1X344EJGLfpTAwQZa0W4bCoCD1qExUJuXcioxfLzDJHj+i/VMHbkfNd3+/vj5eofVm/mdTnuf54O7e3Dy/n+3afP/z/5J/4Pr6fL4/3h18vlYE7Lf730zzfUuyx94PbdnoPq20I7BnsD9pk+4tTW9P3NQvkL"
80
80
  },
81
81
  {
82
82
  "name": "consume",
@@ -152,7 +152,7 @@
152
152
  }
153
153
  },
154
154
  "bytecode": "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",
155
- "debug_symbols": "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"
155
+ "debug_symbols": "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"
156
156
  },
157
157
  {
158
158
  "name": "is_consumable",
@@ -225,7 +225,7 @@
225
225
  }
226
226
  },
227
227
  "bytecode": "JwACBAEoAAABBIBJJwAABEklAAAASScCAwQCJwIEBAAfCgADAAQARi0IRgEtCEcCJQAAAFktAgFIJwICBEgnAgMEATsOAAMAAicAQwQDJwBEAAAnAEUBASYlAAABfB4CAAMJJAIAAwAAAHAlAAABoicCAwACKQIABADvUlNNLQgBBScCBgQEAAgBBgEnAwUEAQAiBQIGLQoGBy0OBAcAIgcCBy0OAwcAIgcCBy0OAQcnAgMEBi0IAAYtCgUHLQhDCAAIAAMAJQAAAbQtAgAALQoHAQoiAUQDJwIFAQAKKgMFBiQCAAYAAADvJQAABSgtCAEDJwIGBAQACAEGAScDAwQBACIDAgYtCgYHLQ4EBwAiBwIHLQ4BBwAiBwIHLQ4CBycCAgQGLQgABi0KAwctCEMIAAgAAgAlAAABtC0CAAAtCgcBCiIBRAIKKgIFAyQCAAMAAAFbJQAABSgeAgACAC8qAAEAAgADHAoDAgEcCgIBABwKAQIBLQoCASYoAAAEBHhJDAAABAMkAAADAAABoSoBAAEF2sX11rRKMm08BAIBJioBAAEF8EPlofqiLDQ8BAIBJiUAAAF8HAoCBAArAgAFAAAAAAAAAAABAAAAAAAAAAAEKgQFBi0IAQQAAAECAS0IAQUnAgcEBQAIAQcBJwMFBAEAIgUCBy0KBwgtDEQIACIIAggtDEQIACIIAggtDEQIACIIAggtDgYILQ4FBAYiAkMFJwIGBAAnAgcEAScCCAQCLQoGAyMAAAI9DCoDBQkkAgAJAAADvSMAAAJPBiICQwUEIgVDCQIqAgkDCioDBgUWCgUJJAIABQAAA1cjAAACdAIqAgMFDioDAgokAgAKAAACiyUAAAU6LQsECgAqCgcMLQsMCwwiBUMMJAIADAAAAqolAAAFTAAiAQINACoNBQ4tCw4MACoLDA0tAgoDJwAEBAUlAAAFXi0IBQsAKgsHDC0ODQwtDgsEDCoHAwokAgAKAAAC7iMAAANXACoLCAotCwoDACoFBwoOKgUKDCQCAAwAAAMOJQAABb0MIgpDBSQCAAUAAAMgJQAABUwAIgECDAAqDAoNLQsNBQAqAwUBLQILAycABAQFJQAABV4tCAUDACoDCAUtDgEFLQ4DBCMAAANXCioCBgESKgEJAiQCAAIAAANuIwAAA6stCwQBLQsBAgAiAgICLQ4CAS0IAQInAgMEBQAIAQMBJwMCBAEAIgECAwAiAgIFPw8AAwAFLQ4CBCMAAAOrLQsEAQAqAQcDLQsDAi0KAgEmLQsECQAqCQcLLQsLCgQiA0MLBiILQw0KKg0DDCQCAAwAAAPmJQAABc8MIgtDDCQCAAwAAAP4JQAABUwAIgECDQAqDQsOLQsODAAqCgwNLQIJAycABAQFJQAABV4tCAUKACoKBwwtDg0MACoKCAwtCwwJACoLBwwOKgsMDSQCAA0AAARGJQAABb0MIgxDDSQCAA0AAARYJQAABUwAIgECDgAqDgwPLQsPDQAqCQ0MLQIKAycABAQFJQAABV4tCAUJACoJCA0tDgwNACIJQwwtCwwKACoLCAwOKgsMDSQCAA0AAASmJQAABb0MIgxDCyQCAAsAAAS4JQAABUwAIgECDQAqDQwOLQsOCwAqCgsMLQIJAycABAQFJQAABV4tCAUKACIKQwstDgwLLQsKCQAiCQIJLQ4JCi0IAQknAgsEBQAIAQsBJwMJBAEAIgoCCwAiCQIMPw8ACwAMLQ4JBAAqAwcJLQoJAyMAAAI9KgEAAQW6uyHXgjMYZDwEAgEmKgEAAQUbvGXQP9zq3DwEAgEmKgEAAQXkCFBFArWMHzwEAgEmLQEDBgoABgIHJAAABwAABXQjAAAFfS0AAwUjAAAFvC0AAQUAAAEEAQAAAwQJLQADCi0ABQsKAAoJDCQAAAwAAAW3LQEKCC0ECAsAAAoCCgAACwILIwAABZMnAQUEASYqAQABBdAH6/TLxmeQPAQCASYqAQABBQUEG5kgr2BMPAQCASY=",
228
- "debug_symbols": "rZnbbuM4DIbfJde9ECmJEvsqg8Eg06aDAEFaZNoFFkXffUmJlJsFbBRKb+rPTP2bJ4mO8757PPx++/PreH56/ru7//G++305nk7HP79Ozw/71+PzWazvu6B/OO3u492OeXef7nYQSj8C7u5Zj6UfkfoxBjvmfkx2nuw823lOdqz9SNGOpldMv4guoEAFh+zABhwdagcM0aEYgF6eFMgA3YJuiclBleXumKJDNchuyW4ht6jrDQo4kEENDtlBboHqmOa3Q+0QAzqQgTrfwS0YHPTypMAG0S0JHcSxGASyWKJeRXJ51I8oGxSzpCT3illB7hVJQONqoDWJRYEMtCixKmQDDg5mySE4DAsbQHSoBogOxSCCAxkkF0zampLMXKIByz+noEAdKICDWkBAk9kA5aZJskExOrhFY2+Q9Z+jgjifJD+kqeuQHNigFIMqUaSsUAzYLc0xSWZpjiUFUy4QHIbFlAsmh2oQVVBKUHRBpaqQHfQqyUZpHjZwS/NQoXnYwC1aL4Wq9cpBIRuAW0AEMyhwv1fF6FANoltiMdA+7EAG6mqW9FZNZpb01lIN1LEOZKA17aBXZQXuwCE5uAXcAm5Bt+jOlJOCfiQlYF3duShUgyw+Z/GQSW/KCmSgC4SCQjaobqlu0Y2oQ+0AIUQn7Tsj0SRQ0j3IaNjUT8JGud9biJ20542GTfcko+pEkkeKjYqT7kvUN3FyqsOmO1In3ZKM3Nb2/U6681NuVJxw2FocpKQLt923zYJOunSNFhs76Uww0vwVJd1djfRutY0cHDRsrQaNdAcyclubB0aq3AaWbj5Gw6ZxlNCo2H2xxdGJnNKwtTga6UI0SoM8DhxxtDFRtL5tThiRUx22Omw8bOy2NiQKNFIbfHzc7Xx4/3q9HA46uz9Nc5nxL/vL4fy6uz+/nU53u3/2p7f2T39f9ud2fN1f5FOJ/nB+lKMIPh1PB6WPu+XqsH6pZEgnR7tcOJchkeFKA9Y1mJBMgil9UuArBdzwItTkTkjbDoWCs3HwWhybGkk3LdNINaxp5G2NIcF5KNR0pUDrCvLgYQKR67g+wXUyy0Y5QEdlLweUJYjI111R1yUoRE8EhUSLxNd9GAVleWpb9QE2ylFZn5aaRmXidY2N1owZRzKXtorh6/UEZq+nLNu1ekLcSOZIhTxArAl8vS15fYne3pdwc2PCN3Qm3Nya8A29id/Qm3hzb8LtzYkbzZnrks2lIJXmmjMDrTUnbsTB+lTcCyI7/ooTSFvzA7OPIOGyPoPKlkiAMkRCTKsiW+0JtXpCMeCqBG+ss+IK8kVzbRRuBcJccIkj1TUn4mZzJi+rDNN1N7aLkj4VhVeTEbc2z1ESiotAil9vUA6+bQFDXl1nWxJ1WWaMPCXBS39yLnMSBYZExRkJDOQS8pYlTUmk4LnAhHNepLhIUJiSyGEEkpHmJHIYEhnmJFJaJHDSCxoSpd7sxazEaHAkmGpwpIRDIs8VlWhUhMqkF3nkgmq4OZA5iVjL2DtrTZMSy8NBmCpq5AhDgtbTqRlb00jyisk0Uv20//7vmW/TC6bhBZe5QHh58OS5BocxBATnFru8Ylkk5hY7wGgteasxGQgtErcHMikByw4OqcxJ5DIkiCclxhC4+jYxGcisxHjgQ+C5UYRLUUVuUiIsEnxrILMSy5dMxBpXJQrMbTk/5Wz/cLxc/eT1oVqX4/736WCnT2/nh0+fvv774p/4T2Yvl+eHw+Pb5aBKy+9m8ucHysYrb+9+6qtUOZVn8Rr1BPQzeUsqQ+Hnh7ryHw=="
228
+ "debug_symbols": "rZnbbuM4DIbfJde9ECmJEvsqg8Eg06aDAEFaZNoFFkXffUmJlJsFbBRKb+rPTP2bJ4mO8757PPx++/PreH56/ru7//G++305nk7HP79Ozw/71+PzWazvu6B/OO3u492OeXef7nYQSj8C7u5Zj6UfkfoxBjvmfkx2nuw823lOdqz9SNGOpldMv4guoEAFh+zABhwdagcM0aEYgF6eFMgA3YJuiclBleXumKJDNchuyW4ht6jrDQo4kEENDtlBboHqmOa3Q+0QAzqQgTrfwS0YHPTypMAG0S0JHcSxGASyWKJeRXJ51I8oGxSzpCT3illB7hVJQONqoDWJRYEMtCixKmQDDg5mySE4DAsbQHSoBogOxSCCAxkkF0zampLMXKIByz+noEAdKICDWkBAk9kA5aZJskExOrhFY2+Q9Z+jgjifJD+kqeuQHNigFIMqUaSsUAzYLc0xSWZpjiUFUy4QHIbFlAsmh2oQVVBKUHRBpaqQHfQqyUZpHjZwS/NQoXnYwC1aL4Wq9cpBIRuAW0AEMyhwv1fF6FANoltiMdA+7EAG6mqW9FZNZpb01lIN1LEOZKA17aBXZQXuwCE5uAXcAm5Bt+jOlJOCfiQlYF3duShUgyw+Z/GQSW/KCmSgC4SCQjaobqlu0Y2oQ+0AIUQn7Tsj0SRQ0j3IaNjUT8JGud9biJ20542GTfcko+pEkkeKjYqT7kvUN3FyqsOmO1In3ZKM3Nb2/U6681NuVJxw2FocpKQLt923zYJOunSNFhs76Uww0vwVJd1djfRutY0cHDRsrQaNdAcyclubB0aq3AaWbj5Gw6ZxlNCo2H2xxdGJnNKwtTga6UI0SoM8DhxxtDFRtL5tThiRUx22Omw8bOy2NiQKNFIbfHzc7Xx4/3q9HA46uz9Nc5nxL/vL4fy6uz+/nU53u3/2p7f2T39f9ud2fN1f5FOJ/nB+lKMIPh1PB6WPu+XqsH6pZEgnR7tcOJchkeFKA9Y1mJBMgil9UuArBdzwItTkTkjbDoWCs3HwWhybGkk3LdNINaxp5G2NIcF5KNR0pUDrCvLgYQKR67g+wXUyy0Y5QEdlLweUJYjI111R1yUoRE8EhUSLxNd9GAVleWpb9QE2ylFZn5aaRmXidY2N1owZRzKXtorh6/UEZq+nLNu1ekLcSOZIhTxArAl8vS15fYne3pdwc2PCN3Qm3Nya8A29id/Qm3hzb8LtzYkbzZnrks2lIJXmmjMDrTUnbsTB+lTcCyI7/ooTSFvzA7OPIOGyPoPKlkiAMkRCTKsiW+0JtXpCMeCqBG+ss+IK8kVzbRRuBcJccIkj1TUn4mZzJi+rDNN1N7aLkj4VhVeTEbc2z1ESiouAfOP9coNy8G0LGPLqOtuSqMsyY+QpCV76k3OZkygwJCrOSGAgl5C3LGlKIgXPBSac8yLFRYLClEQOI5CMNCeRw5DIMCeR0iKBk17QkCj1Zi9mJUaDI8FUgyMlHBJ5rqhEoyJUJr3IIxdUw82BzEnEWsbeWWualFgeDsJUUSNHGBK0nk7N2JpGkldMppHqp/33f898m14wDS+4zAXCy4MnzzU4jCEgOLfY5RXLIjG32AFGa8lbjclAaJG4PZBJCVh2cEhlTiKXIUE8KTGGwNW3iclAZiXGAx8Cz40iXIoqcpMSYZHgWwOZlVi+ZCLWuCpRYG7L+Sln+4fj5eonrw/Vuhz3v08HO316Oz98+vT13xf/xH8ye7k8Pxwe3y4HVVp+N5M/P1A2Xnl791NfpcqpPIvXqCegn8lbUhkKPz/Ulf8A"
229
229
  },
230
230
  {
231
231
  "name": "is_reject_all",
@@ -275,7 +275,7 @@
275
275
  }
276
276
  },
277
277
  "bytecode": "JwACBAEoAAABBIBGJwAABEYlAAAARScCAgQBJwIDBAAfCgACAAMARC0IRAElAAAARi0CAUUnAgIERScCAwQBOw4AAwACJiUAAAFAHgIAAgknAgMBASQCAAIAAABiJQAAAWYpAgACAO9SU00nAgMAASsCAAQAAAAAAAAAAAMAAAAAAAAAAC0IAQUnAgYEBQAIAQYBJwMFBAEAIgUCBi0KBgctDgIHACIHAgctDgMHACIHAgctDgEHACIHAgctDgQHLQsFAQAiAQIBLQ4BBS0IAQEnAgIEBQAIAQIBJwMBBAEAIgUCAgAiAQIDPw8AAgADJwICBAEAKgECBC0LBAMnAgEAAAoqAwECJwIBAQAKKgIBBCQCAAQAAAEfJQAAAXgeAgABAC8qAAMAAQACHAoCAwEcCgMBABwKAQIBLQoCASYoAAAEBHhGDAAABAMkAAADAAABZSoBAAEF2sX11rRKMm08BAIBJioBAAEFoj+MFkXsKv88BAIBJioBAAEFursh14IzGGQ8BAIBJg==",
278
- "debug_symbols": "nZbRrvIgDMffhetdQCmF+ionxkydJ0uWaXb0S74Y3/2Ah27OBC68kf/K+K2lpXJXx25/+9714+n8ozZfd7Wf+mHov3fD+dBe+/MYrXel0493amMbFeIDxsE9B7Z/Q1AbYxpltM/CQBbWipAplCkUixOLEwsZES4Lr0WgCM4iyCeCuMECZPoToI2IBLRJcBYGRYgFxAJisWLB5AYm4bJwYnHpHUqCsyCxkFi8WAKIiCEDRJF8hsixOgKBknBZmKfl8WiUpGV3nbouZeUlTzF7l3bqxqvajLdhaNS/drg9X/q5tONzvLZTnNWN6sZjHCPw1A9dUo9mWa3LS42xGvLyqAFnhDMrhikzmFJQTwQT+oXAKwJUvNABZyf0QvDwaRxUiqPKQNAzA9GUGK7CiHUkCGA3EwKuCFQmQBAfLId5PZr1ZvpKOsy8mQywBGF5XRWhjAgMspmBiYsILiOsgzmMJaFWv1VVJR0Qj39GxJNMnzGWdAAEW2ZUihM9CwODhZnxlpGaG5Z5SepLVt/dqBWWYZbCsppKhWUqCBdsJpBeWkWgD88H6WKvqFUneilODyUnTKj1CnDSbqL2xX5juAbRxs8QbbHYtCr7QUuBEmgoIiqtE/xc4oyltlcLhOMuLnFgKDpha0cVpTCsq7hRTwq+JIXLm+Fq+ykpoZdjhjbWxjY+tod+Wl1jHgk19e1+6PLj6TYeXmav/y8yI9egy3Q+dMfb1CXSchdKf8hfZBqibbrrxAevGw/bR/r0Lw=="
278
+ "debug_symbols": "nZbLjuowDIbfJesuEse5mFcZIVSgjCpVBXXgSEeo7z4JEzctUrJgQ/46zVc7dkye4twdH9+Hfrxcf8Tu6ymOUz8M/fdhuJ7ae38dg/UpZPxxRux0I3x4wDCY10D6b/Bip1QjlHRJKEhCaxY8hTyFbDFsMWyxioVJwkkWyIKS8PwJz24QA8n+CZCKRQTqKCgJhSzYAmwBtmi2YHQDozBJGLaY+I6NgpKwbLFscWzxwCKEDBBE9BkCR8sABBuFSUK9LPPcCE7L4T51XczKKk8he7d26sa72I2PYWjEv3Z4vF76ubXja7y3U5iVjejGcxgD8NIPXVRzk1fL8lKltIS0PGjABWHUhqHKDLIxqBeCLLpMoA0BKl5Ij4sTMhMcfBqHLcVRZSDIhYGoSgxTYYQ6YgSQWQgeNwRbJoBnHzT5ZT2q7Wa6SjrUspkEkIPQtK0KX0Z4At5MT5aKCCojtIEljJxQLd+qqpIOCMc/IcJJtp8xcjoAvC4zKsWJjpiBXsPCeMtIzQ1NlJO6yuq7G7XCUkRcWFraUmGpCsJ4nQhW5lbh7Yfnw8pir6hVJzouTgclJ5Sv9Qow3G6CdsV+o6gGkcotEKmx2LQq+2FzgVqQUERUWie4pcQJS22vFgiFXcxxoC86oWtHFbkwtKm4UU8KrpJC5c0wtf3klNjVMYt9eN6Hx/bUT5trzBxRU98ehy49Xh7jaTV7/3/jGb4G3abrqTs/pi6S8l0o/iF/WdVYu493nfDgZONgP8dP/wI="
279
279
  },
280
280
  {
281
281
  "name": "public_dispatch",
@@ -351,7 +351,7 @@
351
351
  }
352
352
  },
353
353
  "bytecode": "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",
354
- "debug_symbols": "vZ3Rjl0nr4DfZa5zAQYbnFepqiptp78iRWmVPznSUZV3P9iAvScSZM1aa85N9zfubGPAC2O8mPz79Ofz79/+89vHz3/9/d+n97/8+/T7l4+fPn38z2+f/v7jw9ePf39u0n+fgvwHQnx6H9+1T3p6D+0zxvE5fobxM2D/TGF8jp/z+Dnn8cn9E9P4rP2T2+9n+WT9TCGPz/FzHD/H8TOUp/elfSYYn82eGBrkOKFpjM30hGFC0xHly9iURG5AaUIdUKakTEmdkloGcJxAHXIIE3CC9LN1LIvhHeoAgAk0IMUJU6LDpiBfzwI8AKeEYEIzDKTREifQgDoldUp4SmTEO3AHlDHvUAfENKE1kZo9KMZ3oAEy4x3yBB6QpyTXAShfzwJlAE1JCROaYak2qE2So0BrK8vXOUzACeIP7VukDqNQB0SYUAbAlKTWr4wNUDQ3/yEKE3BAmZIyJXVKamsCm48RpwmtCWymlgATmmZsbRV5YpAFcACECVOSpiSZhAfkNKEOkDHsUAZQa4JAgAaI8R3yhDpA/LnDlDBMkK83m6s89R2mRNy4QzOM2uxUaJLSelrHI19THp/9Ea9ieUkCdYBY3oEGiOUdpqTIgy0NyRQXEuAOLFPcYUrilMQpkXWhthlhWRg6NM21aWZZGTo0zZUFeIA8Ux2mhKaEpkRWhg5lQIUJNEAerg6tCW6DEIMsDYOyUZ0kPjqoTAKTyTPWScaYsxJOyiaTAe4ky2rTrygLWNBvky6O+gslOrq0qhQVyZCzo6yYoU17jNKNKCts+w8bxmS/EKshiDSCYjXUtbqjrtYDdb2W1mJfsVUDilRWuRhlSgZWl1Y2ZP8FNimE7OhStXdgMZShn0iGsjxPtIY1sk30JmQqBqI3gdoECVJ0JMPi0uLS6tLqUlYji2KZmDRQQ1Ukk8bgiIbgUsiObJjUdFashlkaTkGxmBSjIxmSSwkNS3CUhlNUrIYabAdKEykJasAdSBNziI4ujS6NLtWJlejSsBjqxCZWREOd2IEuRZfig5QNdS8xsBoWcCyGOrESv6IG5oES3SZmxzoRQ3J0qawhE1WZ9A0hOro0ZUcxPYs5mJNjNUSXokvJpbLvGKj+O5AMa3BER2kY1V7t5sA6kSSGTiRDndiBLlVXHqjKsiIbJpeq/w4U00lcmSQoRVINsgmIpL+gTtuxuLSoVNYoUk8dKKYXVabP5sAysainFlREQ302B4qRVX9XO1SjIhoml6YHKRvqEjTQpehSncKOOoUDi6F66kCXqqcO1IblcSrqqQOzY51Y1VMHujSqZTKSNWkTsp5VjQEDyRBdii4ll5Ju4mXMqq4lA3Xbrq31jXtH3brr13SGBur2XRY81hkaKPtiDaEsMwQhKapUTGcIjtVQlswWYBSLobjcRJeiS9Gl0reJaFiCY3ZkQ+kmaAhlccSB0s2JNBB0MzIRDaNLNVsZqMokJwuQHF2qyUpHmUKQvKchGmJwdCm5lB6kbFiSYzWs4FgMNZsBtVe7qRi1mwOzYzXUvGagS3ti1lGVSd9iT846ulTzsoGa6lVBzc0kfLX8WGxIPVXOjmyo3UyqQbvZUbs5kAy1mwNN2oZHEAU1/U5FkQ11Rz7Qpdml2aXqiJJttZ0POEprWZvQ5DKTIhtWUYb6u+p9HSUvmmjSFJKjSyV8TSRDPVcYiIaaagzUhrMiG+bkWAwxOpIhuVQdcaAqk77pFmWiS9X7OupDRnrcIas9SJAAPQNoAyeoT9ZAlcpQZ11ABro0uVT7NpANs0uzS/UgZWA11CkcWAyLS/WEoGPVhlkRHdlQZ3NgnaibkYG6akioa3teaaL0Ex4y1PVhoEvRpehSfVokl2vIhvq0FG1Nn5aO+rRIbGko3ZTYAno40JF0JZCMDPSAYCIbRpdGl4JLdcHrqH0bWAy1bwPJUNc+yd0aoiMbUnIshjpDA13aT3E6qjLtGwdHkxadloF6jCPmFH3IBhZDcCm4NLlUp7CjnkgNREc21LVvoBz3SOoJuteYWAxlLZmIhuKIEx+kbMiqTPvGdaLuNQbG6CjnU5KbQpW1JGlQq7I4Jo1ZelwxUaWyylU9shroUnSp9q2j9m2gS4tLZQoHiqdOJEOOjiZlcdqJ2nBRZMOYHIuhHs0NdGlSy+QZ4pwcXYouRZeSS8mlxaXFpdWl1aXsUp7SFEJydGkEx2IILgWXJpcmMszBER3ZsE9hR2+Y3BzyJoo3UbyJGh29CfaG2Ztgazh6j6P3OHqPo/c4QnS0hmMKjujoTeTs6E2gN4zeBHnD5E0Ub7h4E9Ubrt5E9YbZm/A5hgCO1rBWDiZawwDBER2tCUjZ0ZswV27oTaA3jN4EecPkTRRvuGgTrMiGtRgyONJEPXGZ6NIYDCE5VsPk0uTSDI6uDF0ZoiG5lB6kZnryDqXiTVRrOPcze62SqEdB1IIJGeqYyVa4IRrqmEFSzI5sWF1aXcouVS9RRPWSgcVQvWQgGUJwREdrAnVQQWs76g8du+ko2E3v6FJ1cDlVS3pA0ZG6ZUWxGEaXdnM66teqoprDWlbKjtVQnbYjRkfpppyqJdJRH+hSNV2SikTddP1a8daqt1Zdyt4amw2l962jNiETW2S/k+SkrCEb6qBKqtGwGmaXai8GkiG5VH2yozqMJCsN2bC6VENHkgnocb7bIPvqjlVNH+hSdZiBZKgzNFBbk8nqIV9KS0lLERPJUJ+sgegoGrLMRQ/uA6thdWl1KbuUTdojupwCph7GJc9KPYzLGV7qYbyjpJ7tCVUUc+TgLrGGuoGiTNKzpLWMgehSdKnGt44a3wa6VJ+AjhrUJMFLWslQzHp6MFGbKIo8zGkHssmxGoJLNYx31DA+UCYgV8EcHbVh1qJqcHSpxu6B1bC4VAP2QGlCKnVZjwwmmlSPDJJklg1x2hB73xRjdnRp71vHaqh9Qy36SqIwUPuGSZEM0aU6WR0lCZroUp2sjrqflIy1YTFkl/a+oZSZNVCpDaB966iBauCDlA11URhYDb1v4H2D3reiiIY6bwNdSi4llxaX6p5LMuwMukAjff/+7mm+nPDb1y/Pz/JuwsPbCr/8+/TPhy/Pn78+vf/87dOnd0//8+HTN/2l//7z4bN+fv3wpf3fNtfPn/9sn03hXx8/PQt9f+ffDuuvRhn/8fV23B7BVGA8rKPV2NPUgc2Zz+jImhIPO9pDuNKR1jpaep+HirZpcisKHLcii68PK9phwMoKXOtoee1UQW2ZNg0ZX5pBu47g7Af5QLTzkeP9wJS9H7Wu+lE3OlKxSU01L/vBV/tx1AaOSxu2Q0GSZo+haAcfq6GQVHqlJGnaqTpa/A1LFRvn1CW7a6C8cs2tDXoGM2yItLRh45rRJ6TVK/0BabP7QsXONetcbFpo9fmIL6dURmulgaNsDlRF2yD4WLZNxEsdG7+gkKZftBMwH4v0CitsrWh7k7i0Ajau1aou07PaQQevdcTNrCLYePoj0rKw45Mame0ZCbSaVEi7JWuORSvqLb3iqG+mvPJNuO6bcNk34QbfhMu+CTf4ZrrBN9Nl34Trvpk2vonVR9MnpNI538Slb6ZtN4L5ZqucraxIG99sp2QekUM7kHU7Xrpn2jgGxmkGPsSxnF5jRuHiZkRemsE7JUgWUgPFulKSNw7acv05HqnEc5s1Qt+sUQmntp2UH3YHZbnhy7vQHkyHHLie64pPS261ilNdKbb+tQNTWO7CM73tFprBHpbcSvpLM27Ye+bLm8/81rtP5ofUKK4Tis0K1jL2GZUkY1+quLr73NoQCpsNYfmo4fUIj5cjPN4Q4fFyhMcbIjzdEOHpcoTH6xGerkb4w775MJo/+CZdj/B0R4SnyxGe7ojwdEeEL28b4Vs5pTwcLC1z9wJvGp0xVBuNVss5tdHAaKMRW2RdBoKCbxqdMVE0M9ph59KM3epFNiutjP7gpvhy5Sn1+ilZuRzht6OR0R57xPXE1ni9JxXetCdY/UmhsDweEgdaLj6MM7wil+U6Wq/H+Ho5xtcbYny9HOPrDTGeb4jxfDnG1+sxnq/G+MO+ycsHlTfd4GyrVoGVDbwNrfqG5IiKUMoqKnLZKQnR43NIy20C77wzVltzIMBSxW7xLFMD8DIj2HWEufgWIeTlFkGTl7VzWuUo4caO/azkh1lhWBuyOwK1SaGH7PvHjdfeQ60rzUPhzAJMYOGohdhl5tx2ZBsdmeayQ3ntom2beLVWsbeCp3MQrrfCMfDOCrRdPT488eeGc10Di3HjoIXmpJbiK1+G40bom5vTs9alo13tqFTbcJWa1w4eN3ZktsziochbXtORRNYRjOuObNyihjStqCHzuiO7FMk2sFjKqY5AtGCUdm6x8c1MaS6fudCDjh/reeH6BiHu6kdHdwgR4HIRaldCAo9IcpvjpJKHfTDUtFGyCfO5mKfn+rCW/1ii3BqC2RMthJO9eVRS6kklfj4tr9/foKSeVJJqcS8JJ7sjb3+Zkkd3/VFJgredYXkbzAzhdW+2C0mOtiLmnNZvBdxQkk/Xa/LpjqJ8ul6VTzckTTHfkDVpny+uiel63hTz1dL8YSel9f4j3+Ck+bqT5jucNF930nyHk+IdTorXnTTf4KT4ltn9CyfdJD54Nb2PeEd+H/GOBD/i9Qw/4tUUf9uXwzk+Xc/xfzY1B5N8etMkv23BouW1sZxK8pEtIaR1tSpuizxHX+QrlxdkqjcsyLta08GT1qMjmtYJXYnXR3RXaTr6bmS6YURL/n8bUdyMKF0uqcZSbihmxl2t6XA1M+6qTXeUMyk9FGmQT9URCbyA1xaQ5dzUN66JUrUFGQucuzdQir2xhLwuRsb6tkXR9sDYmFLgjR03VEVjvaEsGuub1kUp+jtc7XlZZw18Q2E08ptWRtvz4pPbzlDWfdksiEdfSIuMV/ty3I6Tr6QR2Osybbe0vvETebum6pWtsaYmWt9HYL5aaPiJHb6GhLSuDMKuDHVwtw0Bru62XzGmfHZmEHxEcH2TCsINr+OH6+/jhzteyA/X38gPd1wXibfcF7n+Un644cZIvHxl5BV+uj6aghuuNMH1O01wx6UmuH6rCW651nTLvabrF5vgjptNcPn6yCv8dL0ZArj+ginAHW+YAlx+xfQnhhxMywDueMkU0tu+ZUrJ74DQ5orQXgfQg4510E1ve5GknX/4bjfHU1exW53AtiHtlIvWfXnbmyQtuzV3p5Zuru2o19My2N14OprKwK4sdUMqU/yBoVKXZ4eQYbcSJb8QLX8qea0lbYeVbFjz8qQcct6uZza/bUlZucirekMnxyT7Gh9z3oxsub4X2ZWnDu5FdhefDu9FduWpg3uRvR0H9yK7ux2H9yLb20/H9iLbuT24F9lVqA7tRV7jp5s987aqc6RSBlhvqJQB8g2VMtjdgzqau+9KVIdy921fjlbKgNLlStnPpuZYpQx296GOVcq2sapGj1U1ndtUFaYHHetN1a5IdcemqvqlGap8blPFaAtICesqFeyqVDdsqkp09ygQNnakGzZV2zLV0U1VuXymuh0Q3bTNAVlPLuwKVcf7Ut+0L8lvAZW8PtrVXcZ6G5OS72N2uczuWtTRDeKuTHV0g/ia3vDJMcl+NCt/XHqt5YbDquvXo+CO+1Fw/YIU3HFDCu64IgXX70jBDZekgK8eqr7GT3n97PINfsrX/ZTv8FO+7qd8y9/jueMP8oTrfso3/EmecPVQ9RV+ujljSuHqK38p3PHKXwp3vPKXwvVX/lK4+srfti9HE5kUr7/y97OpOZbIpHj5lb/tnir7H7csmU5t/kuGh30ZLTfdaVemuiGRKbl6EoLrw7K0K1PZefvDi7o5HbaBg223+eF8+sdFbKei+hLGwKdUsD/2jOWcimJJIVc4o6JVz6eKVn3Op1TkMMeinRydsyInV0HhlAp/LRYe3epVKuyCt/wbKudUHLu1tbeCTMXmztZRK86qMAeXf8DllIqD98a2Kih4PnrSCrSx2F08O9qRcyrkD5zPhbPWfFLFoctvOxUHr76lXSHq4NW3rRl2ptawnOvJsbtzu1mNFgUannvag72j3FSce9qjnVFChHCyI+QqrnfkpIroS3jM5ZwKLKaC+KQKiwIv8rWTHTmr4thN5J0K8EmFWE+qCK6Cr3bkrIqDF6rT7u7Nbs35tf304Y+PX178I/vfRdeXjx9+//Q8fvzr2+c/Hv7v1//9Z/6f38c/0v/Pl7//eP7z25dn0eT/Un/7zy+Vyrta6dd3T0l+aqGRA7ef5E/9/9JOW99RLfJjlP9b5Xf51+9i2v8B"
354
+ "debug_symbols": "vZ3Rjl0nr4DfZa5zAQYbnFepqiptp78iRWmVPznSUZV3P9iAvScSZM1aa85N9zfubGPAC2O8mPz79Ofz79/+89vHz3/9/d+n97/8+/T7l4+fPn38z2+f/v7jw9ePf39u0n+fgvwHQnx6H9+1T3p6D+0zxvE5fobxM2D/TGF8jp/z+Dnn8cn9E9P4rP2T2+9n+WT9TCGPz/FzHD/H8TOUp/elfSYYn82eGBrkOKFpjM30hGFC0xHly9iURG5AaUIdUKakTEmdkloGcJxAHXIIE3CC9LN1LIvhHeoAgAk0IMUJU6LDpiBfzwI8AKeEYEIzDKTREifQgDoldUp4SmTEO3AHlDHvUAfENKE1kZo9KMZ3oAEy4x3yBB6QpyTXAShfzwJlAE1JCROaYak2qE2So0BrK8vXOUzACeIP7VukDqNQB0SYUAbAlKTWr4wNUDQ3/yEKE3BAmZIyJXVKamsCm48RpwmtCWymlgATmmZsbRV5YpAFcACECVOSpiSZhAfkNKEOkDHsUAZQa4JAgAaI8R3yhDpA/LnDlDBMkK83m6s89R2mRNy4QzOM2uxUaJLSelrHI19THp/9Ea9ieUkCdYBY3oEGiOUdpqTIgy0NyRQXEuAOLFPcYUrilMQpkXWhthlhWRg6NM21aWZZGTo0zZUFeIA8Ux2mhKaEpkRWhg5lQIUJNEAerg6tCW6DEIMsDYOyUZ0kPjqoTAKTyTPWScaYsxJOyiaTAe4ky2rTrygLWNBvky6O+gslOrq0qhQVyZCzo6yYoU17jNKNKCts+w8bxmS/EKshiDSCYjXUtbqjrtYDdb2W1mJfsVUDilRWuRhlSgZWl1Y2ZP8FNimE7OhStXdgMZShn0iGsjxPtIY1sk30JmQqBqI3gdoECVJ0JMPi0uLS6tLqUlYji2KZmDRQQ1Ukk8bgiIbgUsiObJjUdFashlkaTkGxmBSjIxmSSwkNS3CUhlNUrIYabAdKEykJasAdSBNziI4ujS6NLtWJlejSsBjqxCZWREOd2IEuRZfig5QNdS8xsBoWcCyGOrESv6IG5oES3SZmxzoRQ3J0qawhE1WZ9A0hOro0ZUcxPYs5mJNjNUSXokvJpbLvGKj+O5AMa3BER2kY1V7t5sA6kSSGTiRDndiBLlVXHqjKsiIbJpeq/w4U00lcmSQoRVINsgmIpL+gTtuxuLSoVNYoUk8dKKYXVabP5sAysainFlREQ302B4qRVX9XO1SjIhoml6YHKRvqEjTQpehSncKOOoUDi6F66kCXqqcO1IblcSrqqQOzY51Y1VMHujSqZTKSNWkTsp5VjQEDyRBdii4ll5Ju4mXMqq4lA3Xbrq31jXtH3brr13SGBur2XRY81hkaKPtiDaEsMwQhKapUTGcIjtVQlswWYBSLobjcRJeiS9Gl0reJaFiCY3ZkQ+kmaAhlccSB0s2JNBB0MzIRDaNLNVsZqMokJwuQHF2qyUpHmUKQvKchGmJwdCm5lB6kbFiSYzWs4FgMNZsBtVe7qRi1mwOzYzXUvGagS3ti1lGVSd9iT846ulTzsoGa6lVBzc0kfLX8WGxIPVXOjmyo3UyqQbvZUbs5kAy1mwNN2oZHEAU1/U5FkQ11Rz7Qpdml2aXqiJJttZ0POEprWZvQ5DKTIhtWUYb6u+p9HSUvmmjSFJKjSyV8TSRDPVcYiIaaagzUhrMiG+bkWAwxOpIhuVQdcaAqk77pFmWiS9X7OupDRnrcIas9SJAAPQNoAyeoT9ZAlcpQZ11ABro0uVT7NpANs0uzS/UgZWA11CkcWAyLS/WEoGPVhlkRHdlQZ3NgnaibkYG6akioa3teaaL0Ex4y1PVhoEvRpehSfVokl2vIhvq0FG1Nn5aO+rRIbGko3ZTYAno40JF0JZCMDPSAYCIbRpdGl4JLdcHrqH0bWAy1bwPJUNc+yd0aoiMbUnIshjpDA13aT3E6qjLtGwdHkxadloF6jCPmFH3IBhZDcCm4NLlUp7CjnkgNREc21LVvoBz3SOoJuteYWAxlLZmIhuKIEx+kbMiqTPvGdaLuNQbG6CjnU5KbQpW1JGlQq7I4Jo1ZelwxUaWyylU9shroUnSp9q2j9m2gS4tLZQoHiqdOJEOOjiZlcdqJ2nBRZMOYHIuhHs0NdGlSy+QZ4pwcXYouRZeSS8mlxaXFpdWl1aXsUp7SFEJydGkEx2IILgWXJpcmMszBER3ZsE9hR2+Y3BzyJoo3UbyJGh29CfaG2Ztgazh6j6P3OHqPo/c4QnS0hmMKjujoTeTs6E2gN4zeBHnD5E0Ub7h4E9Ubrt5E9YbZm/A5hgCO1rBWDiZawwDBER2tCUjZ0ZswV27oTaA3jN4EecPkTRRvuGgTrMiGtRgyONJEPXGZ6NIYDCE5VsPk0uTSDI6uDF0ZoiG5lB6kZnryDqXiTVRrOPcze62SqEdB1IIJGeqYyVa4IRrqmEFSzI5sWF1aXcouVS9RRPWSgcVQvWQgGUJwREdrAnVQQWs76g8du+ko2E3v6FJ1cDlVS3pA0ZG6ZUWxGEaXdnM66teqoprDWlbKjtVQnbYjRkfpppyqJdJRH+hSNV2SikTddP1a8daqt1Zdyt4amw2l962jNiETW2S/k+SkrCEb6qBKqtGwGmaXai8GkiG5VH2yozqMJCsN2bC6VENHkgnocb7bIPvqjlVNH+hSdZiBZKgzNFBbk8nqIV9KS0lLERPJUJ+sgegoGrLMRQ/uA6thdWl1KbuUTdojupwCph7GJc9KPYzLGV7qYbyjpJ7tCVUUc+TgLrGGuoGiTNKzpLWMgehSdKnGt44a3wa6VJ+AjhrUJMFLWslQzHp6MFGbKIo8zGkHssmxGoJLNYx31DA+UCYgV8EcHbVh1qJqcHSpxu6B1bC4VAP2QGlCKnVZjwwmmlSPDJJklg1x2hB73xRjdnRp71vHaqh9Qy36SqIwUPuGSZEM0aU6WR0lCZroUp2sjrqflIy1YTFkl/a+oZSZNVCpDaB966iBauCDlA11URhYDb1v4H2D3reiiIY6bwNdSi4llxaX6p5LMuwMukAjff/+7mm+nPDb1y/Pz/JuwsPbCr/8+/TPhy/Pn78+vf/87dOnd0//8+HTN/2l//7z4bN+fv3wpf3fNtfPn/9sn03hXx8/PQt9f+ffDuuvRhn/8fV23B7BVGA8rKPV2NPUgc2Zz+jImhIPO9pDuNKR1jpaep+HirZpcisKHLcii68PK9phwMoKXOtoee1UQW2ZNg0ZywsVtOsIzn5QeVCQj/cDU/Z+1LrqR93oSMUmNdW87Adf7cdRGzgubdgOBUmaPYaiHXyshkJS6ZWSpGmn6mjxNyxVbJxTl+yugfLKNbc26BnMsCHS0oaNa0afkFav9AekvpyQuHPNOhebFlp9PiK/1FDWGjjK5kBVtA2Cj2XbRLzUsfELCmn6RTsB87FIr7DC1oq2N4lLK2DjWq3qMj2rHXTwWkfczCqCjac/Ii0LOz6pkdmekUCrSYW0W7LmWLSi3tIrjvpmyivfhOu+CZd9E27wTbjsm3CDb6YbfDNd9k247ptp45tYfTR9Qiqd801c+mbadiOYb7bK2cqKtPHNdkrmETm0A1m346V7po1jYJxm4EMcyzm+wozCxc2IvDSDd0qQLKQGinWlJG8ctOX6czxSiec2a4S+WaMSTm07KT/sDspyw5d3oT2YDjlwPdcVn5bcahWnulJs/WsHprDchWd62y00gz0suZX0l2bcsPfMlzef+a13n8wPqVFcJxSbFaxl7DMqSca+VHF197m1IRQ2G8LyUcPrER4vR3i8IcLj5QiPN0R4uiHC0+UIj9cjPF2N8Id982E0f/BNuh7h6Y4IT5cjPN0R4emOCF/eNsK3ckp5OFha5u4F3jQ6Y6g2Gq2Wc2qjgdFGI7bIugwEBd80OmOiaGa0w86lGbvVi2xWWhn9wU3byd8LHfX6KVm5HOG3o5HRHnvE9cTWeL0nFd60J1j9SaGwPB4SB1ouPowzvCKX5Tpar8f4ejnG1xtifL0c4+sNMZ5viPF8OcbX6zGer8b4w77JyweVN93gbKtWgZUNvA2t+obkiIpQyioqctkpCdHjc0jLbQLvvDNWW3MgwFLFbvEsUwPwMiPYdYS5+BYh5OUWQZOXtXNa5Sjhxo79rOSHWWFYG7I7ArVJoYfs+8eN195DrSvNQ+HMAkxg4aiF2GXm3HZkGx2Z5rJDee2ibZt4tVaxt4KncxCut8Ix8M4KtF09Pjzx54ZzXQOLceOgheakluIrX4bjRuibm9Oz1qWjXe2oVNtwlZrXDh43dmS2zOKhyFte05FE1hGM645s3KKGNK2oIfO6I7sUyTawWMqpjkC0YJR2brHxzUxpLp+50IOOH+t54foGIe7qR0d3CBHgchFqV0ICj0hym+Okkod9MNS0UbIJ87mYp+f6sJb/WKLcGoLZEy2Ek715VFLqSSV+Pi2v39+gpJ5UkmpxLwknuyNvf5mSR3f9UUmCt51heRvMDOF1b7YLSY62Iuac1m8F3FCST9dr8umOony6XpVPNyRNMd+QNWmfL66J6XreFPPV0vxhJ6X1/iPf4KT5upPmO5w0X3fSfIeT4h1OitedNN/gpPiW2f0LJ90kPng1vY94R34f8Y4EP+L1DD/i1RR/25fDOT5dz/F/NjUHk3x60yS/bcGi5bWxnErykS0hpHW1Km6LPEdf5CuXF2SqNyzIu1rTwZPWoyOa1gldiddHdFdpOvpuZLphREv+fxtR3IwoXS6pxlJuKGbGXa3pcDUz7qpNd5QzKT0UaZBP1REJvIDXFpDl3NQ3rolStQUZC5y7N1CKvbGEvC5Gxvq2RdH2wNiYUuCNHTdURWO9oSwa65vWRSn6O1zteVlnDXxDYTTym1ZG2/Pik9vOUNZ92SyIR19Ii4xX+3LcjpOvpBHY6zJtt7S+8RN5u6bqla2xpiZa30dgvlpo+IkdvoaEtK4Mwq4MdXC3DQGu7rZfMaZ8dmYQfERwfZMKwg2v44fr7+OHO17ID9ffyA93XBeJt9wXuf5Sfrjhxki8fGXkFX66PpqCG640wfU7TXDHpSa4fqsJbrnWdMu9pusXm+COm01w+frIK/x0vRkCuP6CKcAdb5gCXH7F9CeGHEzLAO54yRTS275lSsnvgNDmitBeB9CDjnXQTW97kaSdf/huN8dTV7FbncC2Ie2Ui9Z9edubJC27NXenlm6u7ajX0zLY3Xg6msrArix1QypT/IGhUpdnh5BhtxIlvxAtfyp5rSVth5VsWPPypBxy3q5nNr9tSVm5yKt6QyfHJPsaH2UtXGop1/ciu/LUwb3I7uLT4b3Irjx1cC+yt+PgXmR3t+PwXmR7++nYXmQ7twf3IrsK1aG9yGv8dLNn3lZ1jlTKAOsNlTJAvqFSBrt7UEdz912J6lDuvu3L0UoZULpcKfvZ1ByrlMHuPtSxStk2VtXosaqmc5uqwvSgY72p2hWp7thUVb80Q5XPbaoYbQEpYV2lgl2V6oZNVYnuHgXCxo50w6ZqW6Y6uqkql89UtwOim7Y5IOvJhV2h6nhf6pv2JfktoJLXR7u6y1hvY1Lyfcwul9ldizq6QdyVqY5uEF/TGz45JtmPZuWPS6+13HBYdf16FNxxPwquX5CCO25IwR1XpOD6HSm44ZIU8NVD1df4Ka+fXb7BT/m6n/IdfsrX/ZRv+Xs8d/xBnnDdT/mGP8kTrh6qvsJPN2dMKVx95S+FO175S+GOV/5SuP7KXwpXX/nb9uVoIpPi9Vf+fjY1xxKZFC+/8rfdU2X/45Yl06nNf8nwsC+j5aY77cpUNyQyJVdPQnB9WJZ2ZSo7b394UTenwzZwsO02P5xP/7iI7VRUX8IY+JQK9seesZxTUSwp5ApnVLTq+VTRqs/5lIoc5li0k6NzVuTkKiicUuGvxcKjW71KhV3wln9D5ZyKY7e29laQqdjc2TpqxVkV5uDyD7icUnHw3thWBQXPR09agTYWu4tnRztyToX8gfO5cNaaT6o4dPltp+Lg1be0K0QdvPq2NcPO1BqWcz05dnduN6vRokDDc097sHeUm4pzT3u0M0qIEE52hFzF9Y6cVBF9CY+5nFOBxVQQn1RhUeBFvnayI2dVHLuJvFMBPqkQ60kVwVXw1Y6cVXHwQnXa3b3ZrTm/tp8+/PHxy4t/ZP+76Pry8cPvn57Hj399+/zHw//9+r//zP/z+/hH+v/58vcfz39++/Ismvxf6m//+aVSeVcr/fruKclPLTRy4PaT/Kn/X9pp6zuqRX6M8n+r/C7/+l1M+z8="
355
355
  },
356
356
  {
357
357
  "name": "set_authorized",
@@ -405,7 +405,7 @@
405
405
  }
406
406
  },
407
407
  "bytecode": "JwACBAEoAAABBIBHJwAABEclAAAASicCAwQCJwIEBAAfCgADAAQARRwARkYBLQhFAS0IRgIlAAAAVScCAQRHJwICBAA7DgACAAEnAEMEAycARAAAJiUAAAFWHgIAAwEnAgQAAikCAAUA71JTTS0IAQYnAgcEBAAIAQcBJwMGBAEAIgYCBy0KBwgtDgUIACIIAggtDgQIACIIAggtDgMIJwIEBActCAAHLQoGCC0IQwkACAAEACUAAAF8LQIAAC0KCAMKIgNEBCcCBgEACioEBgckAgAHAAAA3iUAAAT1LQgBBCcCBwQEAAgBBwEnAwQEAQAiBAIHLQoHCC0OBQgAIggCCC0OAwgAIggCCC0OAQgnAgMEBy0IAActCgQILQhDCQAIAAMAJQAAAXwtAgAALQoIAQoiAUQDCioDBgQkAgAEAAABSiUAAAT1HAoCAwAwCgADAAEmKAAABAR4RwwAAAQDJAAAAwAAAXsqAQABBdrF9da0SjJtPAQCASYlAAABVhwKAgQAKwIABQAAAAAAAAAAAQAAAAAAAAAABCoEBQYtCAEEAAABAgEtCAEFJwIHBAUACAEHAScDBQQBACIFAgctCgcILQxECAAiCAIILQxECAAiCAIILQxECAAiCAIILQ4GCC0OBQQGIgJDBScCBgQAJwIHAQEnAggEAScCCQQCLQoGAyMAAAIKDCoDBQokAgAKAAADiiMAAAIcBiICQwUEIgVDCgIqAgoDCioDBgUWCgUKJAIABQAAAyQjAAACQQIqAgMFDioDAgskAgALAAACWCUAAAUHLQsECwAqCwgNLQsNDAwiBUMNJAIADQAAAnclAAAFGQAiAQIOACoOBQ8tCw8NACoMDQ4tAgsDJwAEBAUlAAAFKy0IBQwAKgwIDS0ODg0tDgwEDCoIAwskAgALAAACuyMAAAMkACoMCQstCwsDACoFCAsOKgULDSQCAA0AAALbJQAABYoMIgtDBSQCAAUAAALtJQAABRkAIgECBwAqBwsNLQsNBQAqAwUBLQIMAycABAQFJQAABSstCAUDACoDCQUtDgEFLQ4DBCMAAAMkCioCBgESKgEKAiQCAAIAAAM7IwAAA3gtCwQBLQsBAgAiAgICLQ4CAS0IAQInAgMEBQAIAQMBJwMCBAEAIgECAwAiAgIFPw8AAwAFLQ4CBCMAAAN4LQsEAQAqAQgDLQsDAi0KAgEmLQsECgAqCggMLQsMCwQiA0MMBiIMQw4KKg4DDSQCAA0AAAOzJQAABZwMIgxDDSQCAA0AAAPFJQAABRkAIgECDgAqDgwPLQsPDQAqCw0OLQIKAycABAQFJQAABSstCAULACoLCA0tDg4NACoLCQ0tCw0KACoMCA0OKgwNDiQCAA4AAAQTJQAABYoMIg1DDiQCAA4AAAQlJQAABRkAIgECDwAqDw0QLQsQDgAqCg4NLQILAycABAQFJQAABSstCAUKACoKCQ4tDg0OACIKQw0tCw0LACoMCQ0OKgwNDiQCAA4AAARzJQAABYoMIg1DDCQCAAwAAASFJQAABRkAIgECDgAqDg0PLQsPDAAqCwwNLQIKAycABAQFJQAABSstCAULACILQwwtDg0MLQsLCgAiCgIKLQ4KCy0IAQonAgwEBQAIAQwBJwMKBAEAIgsCDAAiCgINPw8ADAANLQ4KBAAqAwgKLQoKAyMAAAIKKgEAAQW6uyHXgjMYZDwEAgEmKgEAAQUbvGXQP9zq3DwEAgEmKgEAAQXkCFBFArWMHzwEAgEmLQEDBgoABgIHJAAABwAABUEjAAAFSi0AAwUjAAAFiS0AAQUAAAEEAQAAAwQJLQADCi0ABQsKAAoJDCQAAAwAAAWELQEKCC0ECAsAAAoCCgAACwILIwAABWAnAQUEASYqAQABBdAH6/TLxmeQPAQCASYqAQABBQUEG5kgr2BMPAQCASY=",
408
- "debug_symbols": "rZnRbhs5DEX/xc9+ECmRkvorRVGkqVsYMJzATRZYFPn35dWImrjAGFm5L54z19YVSXFGY/v37vvh2+vPr8fzj6dfu0+ff+++XY6n0/Hn19PT48PL8els6u9dwEu1V97vquw+5f2OQujHuhwp9mNZjtzPuZ/Hfh7zckzUj7ocpftJ9xfzpWCgyaF0yOygHQo5uIJoF8BwBtQFOCQHVyh3YDhngHaI5OBKciW5gtAXSA61g0aH0gHBcwDkDgh+AXGoHRD8Al2JITpguMUciR1cYekQsWQKgFINMEXEcNQn0n6XiBwsnWijEgcHfDgCaoeYHFxJriRXJDrkDsoO2iGTg09RgoMbFqtYTPudYFEaJHxGANJBXEHXRMtUNHRAeaMVXAo7uIIWBih6OBYAJq2A2gHtvEDpgJZogJZIAaAdkisILFkxtQWGD4s7izurK+rO2edqMQPQEsmWQLHuyaqREeECNipZNTIiXMAVRNigRdjAFSzTAjC0imUEtoAr6NWkgNLnQq8ukDsUV3ChNajkIAuUFmoGwNnKWzh3aIE1kA5Y0wVslARA6YBGWsAVdUVdya5kzGWlK2gbsSUo1UIVBuQFarCYxSKsZJNKAoiDDRcrQuXk4Ep0JbFD7iCuoOsWgKHVsObgMBQYWlkqOrxN2kIF1OjQFbu78qDshEtVSiN1wsUqtZE4xaHF4pTioKGJOqk5a2ikTnloSEEJhKt0mbclsVB1qkNreYAI96tOlofiRky4Y3XCbBHENGhoqHyn6pSGhuJ3gjMqRLjTdBpay0Maqc+LPDqJUx0a8uhUOzHy6OR58MiDWx5tt8N6dBKnOLQ4tDS0NDRBpNoImr697Xe+D399uRwO2Ibfbcy2XT8/XA7nl92n8+vptN/983B6bR/69fxwbseXh4u9a6t4OH+3oxn+OJ4OoLf9OjpsD40Ru1YbHW0/GQZCVw50wwGX5WKgaYzP/OEIbDscEZBuRRC3HVDj7kBcZTiUdOWQth24eAljLWN8onplINsGlbAtNIdKeS2j7cNXFrptoQHbYrOw/WqtQ/x4DCV5DMy0GUPZtrCbKneLUrVuWtQbyyk8SplXg/Dx1bSr0lczBt1aTbrRkjoKkQNtGXy0JWPavCju70m6uynpL3Ql3d2W9Bf6kv5CY9LdnUn3tybfaE0pazXXBSk61Zqy2Zp8M4swWpMibQXBN1rTngqirymeFd7Fcd2dfKMvhDwM4Xf9Hf9PGLnmNQyqm2HkWyaiPEzs+8CmyY3+jJq9HjGTTGyD9nzilzvVdw5/9ucti7K2pz3fTllUPMt2C8lzFpmGReEZCw7qFvY4lqYsUvBacOK5KFJcLTRMWUgYiQjrnIWEYSE0Z5HSasGTUeiwyOXuKGYtRoOz0lSDsyYeFjK3qKpjRTRPRiGjFlrC3YnMWUT7eu03rVLSpMW6qYapRY010rDQ7XKmG1t7sl8nukcqce3wP56VbkZRdURR81widX1gq3MNTmMTMJy72O1r+moxd7ETjday78OTiehqcX8ikxa03sEp5TkLycNC66TF2ASunsInE5m1KGVY1LmtiNdFZSqTFmG1qPcmMmuxfjljLnHTQnXulvPFzh4ej5erf1ne4HU5Pnw7Hfrpj9fz47t3X/599nf8X5rny9Pj4fvr5QCn9a8ae/lsfz3sufAX/Bxnp/bMlRUnhPesZ22v/PKGUP4D"
408
+ "debug_symbols": "rZnRbhs5DEX/xc9+ECmRkvorRVGkqVsYMJzATRZYFPn35dWImrjAGFm5L54z19YVSXFGY/v37vvh2+vPr8fzj6dfu0+ff+++XY6n0/Hn19PT48PL8els6u9dwEu1V97vquw+5f2OQujHuhwp9mNZjtzPuZ/Hfh7zckzUj7ocpftJ9xfzpWCgyaF0yOygHQo5uIJoF8BwBtQFOCQHVyh3YDhngHaI5OBKciW5gtAXSA61g0aH0gHBcwDkDgh+AXGoHRD8Al2JITpguMUciR1cYekQsWQKgFINMEXEcNQn0n6XiBwsnWijEgcHfDgCaoeYHFxJriRXJDrkDsoO2iGTg09RgoMbFqtYTPudYFEaJHxGANJBXEHXRMtUNHRAeaMVXAo7uIIWBih6OBYAJq2A2gHtvEDpgJZogJZIAaAdkisILFkxtQWGD4s7izurK+rO2edqMQPQEsmWQLHuyaqREeECNipZNTIiXMAVRNigRdjAFSzTAjC0imUEtoAr6NWkgNLnQq8ukDsUV3ChNajkIAuUFmoGwNnKWzh3aIE1kA5Y0wVslARA6YBGWsAVdUVdya5kzGWlK2gbsSUo1UIVBuQFarCYxSKsZJNKAoiDDRcrQuXk4Ep0JbFD7iCuoOsWgKHVsObgMBQYWlkqOrxN2kIF1OjQFbu78qDshEtVSiN1wsUqtZE4xaHF4pTioKGJOqk5a2ikTnloSEEJhKt0mbclsVB1qkNreYAI96tOlofiRky4Y3XCbBHENGhoqHyn6pSGhuJ3gjMqRLjTdBpay0Maqc+LPDqJUx0a8uhUOzHy6OR58MiDWx5tt8N6dBKnOLQ4tDS0NDRBpNoImr697Xe+D399uRwO2Ibfbcy2XT8/XA7nl92n8+vptN/983B6bR/69fxwbseXh4u9a6t4OH+3oxn+OJ4OoLf9OjpsD40Ru1YbHW0/GQZCVw50wwGX5WKgaYzP/OEIbDscEZBuRRC3HVDj7kBcZTiUdOWQth24eAljLWN8onplINsGlbAtNIdKeS2j7cNXFrptoQHbYrOw/WqtQ/x4DCV5DMy0GUPZtrCbKneLUrVuWtQbyyk8SplXg/Dx1bSr0lczBt1aTbrRkjoKkQNtGXy0JWPavCju70m6uynpL3Ql3d2W9Bf6kv5CY9LdnUn3tybfaE0pazXXBSk61Zqy2Zp8M4swWpMibQXBN1rTngqirymeFd7Fcd2dfKMvhDwM4Xf9neh/hJFrXsOguhlGvmUiysPEvg9smtzoz6jZ6xEzycQ2aM8nfrlTfefwZ3/esihre9rz7ZRFxbNst5A8Z5FpWBSeseCgbmGPY2nKIgWvBSeeiyLF1ULDlIWEkYiwzllIGBZCcxYprRY8GYUOi1zujmLWYjQ4K001OGviYSFzi6o6VkTzZBQyaqEl3J3InEW0r9d+0yolTVqsm2qYWtRYIw0L3S5nurG1J/t1onukEtcO/+NZ6WYUVUcUNc8lUtcHtjrX4DQ2AcO5i92+pq8Wcxc70Wgt+z48mYiuFvcnMmlB6x2cUp6zkDwstE5ajE3g6il8MpFZi1KGRZ3binhdVKYyaRFWi3pvIrMW65cz5hI3LVTnbjlf7Ozh8Xi5+pflDV6X48O306Gf/ng9P7579+XfZ3/H/6V5vjw9Hr6/Xg5wWv+qsZfP9tfDngt/wc9xdmrPXFlxQnjPetb2yi9vCOU/"
409
409
  },
410
410
  {
411
411
  "name": "set_authorized_private",
@@ -2227,7 +2227,7 @@
2227
2227
  }
2228
2228
  },
2229
2229
  "bytecode": "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",
2230
- "debug_symbols": "tVpbbhs7DN2Lv/0hiqQkZitFUbipWxgwnMBNClwU3fulPCPNOK1YxXJ/cuSZ8AxF8aHXz82X/efXb58Op69P3zcPH35uPp8Px+Ph26fj0+Pu5fB00qc/Ny7/Ado8gP+13UD+hXHz4LcbTAr6zOdnHjcPpG2agCcIE8QJ0gSyeYgq7SaACZQkKeAENIGygFMMM8aM+kW8fFElAZTPz4gz0ow8Y5YGlaLSE9Qf/IeOhMs/qHrwS38VK3x6Oe/3+c3KLGqs5915f3rZPJxej8ft5sfu+Hr5p+/Pu9MFX3Znfata709fFJXw6+G4z61f20XatUUp8iwcfKzikXvlOfoiDyv52Cs/oHqg8unk0vJp7JVPKc7y4nxLntvyGIrpMFKVJ5IrgtAm8FQIfIhNgj4NEjYJDBOIl2ICci0TyGgPrDEUnAkiwg3uAw6KE4BbqeCx2w2iiFQ/wsWMDFcMgIYn1V4I8i06JPCp6AAUmjoYvkDkYKYggpU/IvdrkWpEeXBNLaLhEBBKR7xfJZTgrymS4ZOQqFjT+8UpUK4zA4g1IL72RII0ObxhDeRCgbJ0BN21MTwYDA7LkGhTbuMAKNZAYN/mQCvHSwlTSrhwgPSrEUJxcQwRbuvKmiPxbRyymPRqYN9yxH9rDhFX1ZDUVMMKNs9Ug018K9jQ8lCkULTAtKJI/RTMy5hgaFFY/dDEU/rBrt0Pwz8FS86QsCK4ThlIxoiyqyPKHJuGsEpprWQEvEp9t3RiFR9vO2G4ZazREeMyEOT7NRCqpdC3VTDSJoUylBoji1P7dwxlLULg1ma81oHMLOEWj2y7Q577jVYQwvEKQjRaQYjHK4jJ0VlBaDxlmmp0VpBuDqOCmBydFYTh35qjs4JYwaYhVlYwAB5bocKGi0J0ZfILMcWbKIKveSesDPqWwlgIAUKoPUFolzIen3ryHaaefIepZxieeoY7zNfCHeZaYXzqGe4w1/qLg0ldJ6JfLTXfOFgIpj3qAiu01qq2Fp5g0aLt5sHwUdB1XiWhtaO/iyTWqaO2IzYDrjPw03rReh1wEUyLYDUILwk9uHdQpFR74mKTAoczRyQrc9SRFc2pzaiPRkkIjkouDo5Xjv4OLfryV4zj+Sum0fwVZTx/mRyd+SuNV3pbjb78ZTt5jB1ObkZrCjVtpJRuqfTe1am5d0wtimTm0FR3qcA1Fwgpjjt5SuNOnmTUycWNz+5Njs7ZvfhhJzfV6IxXm6NugmJYbUf/VuhNF61LWO9Sc/UohouqP9RN8YjUqoxiuCjXkrTeU0nQr0OCUp4lYbM6i+GewKnmHWABuWVvJ8W6t5NWqevthrADq6oh1qq2miX0740Lc43VRG0lrAqPS4WnlT3fbku7OxRXcDyeePQwYzTzgIvjqccm6cw94GQ4+diKdGaffhJjc8Em6ZxzAOA/NskddqhVrh6QEjcDD0bXTNYBpeOajDUm2jpYix2GZZ+EITZTOsA98ulfdPGxbrgwYXMJCNbxg9RzX/WjdMOpvfjl7Dt7xNqsH/XX7vFwvr6gAfl+g0Y75MsMGdOMMqF3itrxfF/igj4nhem+BM73JdBP9yUuGHKYTbc2LphmVL68k54vblwQchBMVzdovrtB8+WNnAbz7Y0LhnwhYLq9ccE0o/LlvSVy+bBZEWZUvlzcCGdUvnyVgTifxyiGfLShGPO5hmLKplKUCdnNCLlEK+b7IU6JGEuD8vDkBpdGKI1YGik39DMscyO40rhcPFHNQ2bOB5UBSyMz++w6P3bnw+7zcZ+HKA/i6+mxjJj+fPnvubwpl26ez0+P+y+v530e3dXNG/37QePYQx796fqNPvG8Rf64nV7rMQ9xfu2rhK55KeRHWCVki/KbBP3+Dba/EaqExoHXb2S//B8=",
2230
+ "debug_symbols": "tVrbbts8DH4XX+dCFEkd+irDMKRtNgQI0iJrB/wo+u4/ZVuyk06cGqU3/RS7/ExRPOj0Njzu7l9//dgffz79Hu6+vQ33p/3hsP/14/D0sH3ZPx3l6dtg0h+g4Q7s+2aA9Av9cGc3AwYBeWbTM4vDHUmbJuAJ3AR+gjBBHO68SJsJYAIhCQI4AU0gLGAE3Yw+oXwRxy+KJIDw2RlxRpqRZ0zSIFKUe4Lyg//SETf+g6gH7/IrW+HHy2m3S29WZhFjPW9Pu+PLcHd8PRw2w5/t4XX8p9/P2+OIL9uTvBWtd8dHQSH8uT/sUut9s0ibuih5noWd9UXcc6s8e5vlYSXvW+U7VHeUPx1MWD6NrfIh+Fk+GluT57o8umw69FTkiemMwNUJLGUC63yVoE2DgFUCxQTRxmwCMjUTxN4eaGMYcSbwCFe4DxjITgBmpYLFZjfwMcbiR7iYkeGMAVDxpNKLiHyNDgFsyDoAuaoOii/Y4PJQxLgMBZl2HUKJJwumqoNXdACXu2HtKp04e04RFI+EQNmW1i4ugfG8IxC14bClJ9HFKodVrIGcKTAuHUFzbgwLCoNByBQG43UcANkaCGzrHKhl+JiDlAIuHBDb1XAuOzg6D9d1Zc0R+DqOuJj0bGAvOfzXmiNGU9SIoaqGFmyWqQRbtLVgQ81DkXLEI4YVRWinYF7GBF2NQuuHJJjcDzb1fij+GTHnjOhWBOcpA0kZUTZlRJl91RBaIS11jIBXqe+aTqzi47ITilv6Eh3eLwNBtl2DSKUQ2roKStokl4dSYmRxavuJoTRQdFib8VwHUrOEWTyy7g5p5tdbQQj7KwhRbwUh7q8gKkdjBaH+lKmq0VhBmjmUCqJyNFYQhq81R2MF0YJNQiyvXwAs1kKFFRcFb/LUF3zwV1E4W/KOWxn0kkJZBgGCKz1BqJcy7p968g2mnnyDqafrnnq6G8zX3A3mWq5/6uluMNf6h4PFskpEu1poXjiYc6o9cldWC7SLlaquhSVYtKi7uVN8FMhAIaG1o3+KxJepo7Q9VgOuMfDDesl6HnAeVItgMQgvCd2ZT1CEUHpifJUCuzOHJy1zlJGNklOrUe+VkuAM5VzsDK8c/RNatOUv7/vzlw+9+cvH/vylcjTmr9Bf6XU12vKX7uTeNzi5Gq3BlbQRQrim0ltTpubWMNUogppDA5R1lqkuEILvd/IQ+p08xF4nj6Z/dq9yNM7uo+12clWNxnjVOcoWKLrVZvSHQq+6aFnCWhOqq8eouKj4Q9kS90i1yhgVF+VSktZ7KgHadQiQy3MMWK3OUXFP4FDyDnCEeM3eTvBlbyesUtflhrABraohlqq2miW074xH5hKrgepKaBUelwpPK3tebkubGxRXMNyfeOQoozfzgPH9qUcnacw9YGJ38tEVacw+7STK5oJO0jjnAMAvNskNdqhFrhyPElcDD3rXTNrxpOGSjCUm6jpoix2GZZ+EwVdTOsAt8uk/dLG+bLgwYXUJCNrxQyynvuJH4Yoz+2iXk+/kEWuzfpdf24f96fx6BqTbDRLtkK4yJAwzxgmtSQeQm/G2xIg2JYXptgTOtyXQTrclRnQpzKY7GyOGGYUv7aSnaxsjQgqC6eIGzTc3aL66kdJgursxokvXAaa7GyOGGYUv7S2RSUfNgjCj8KXiRjij8KWLDMTpPEbQpaMNQZ/ONQRDMpVgnJDNjJBKtGC6HWKEiDE3KA1PanBuuNzwuRFSQz7DcW44kxvjtRPR3CXmdFDpMDcSs02u82d72m/vD7s0RGkQX48PecTk58t/z/lNvnLzfHp62D2+nnZpdFf3buTvN4ljC2n0p8s38sTyBvn7ZnotxzzE6bUtErLmJZceYZGIG4wfJOjjN1j/hisSEgdWvpH88n8=",
2231
2231
  "verification_key": "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"
2232
2232
  },
2233
2233
  {
@@ -2259,7 +2259,7 @@
2259
2259
  }
2260
2260
  },
2261
2261
  "bytecode": "JwACBAEoAAABBIBFJwAABEUlAAAARicCAgQBJwIDBAAfCgACAAMARBwAREQBLQhEASUAAABHJwIBBEUnAgIEADsOAAIAASYlAAABGh4CAAIBKQIAAwDvUlNNJwIEAAErAgAFAAAAAAAAAAADAAAAAAAAAAAtCAEGJwIHBAUACAEHAScDBgQBACIGAgctCgcILQ4DCAAiCAIILQ4ECAAiCAIILQ4CCAAiCAIILQ4FCC0LBgIAIgICAi0OAgYtCAECJwIDBAUACAEDAScDAgQBACIGAgMAIgICBD8PAAMABCcCAwQBACoCAwUtCwUEJwICAAAKKgQCAycCAgEACioDAgUkAgAFAAABDiUAAAFAHAoBAgAwCgACAAQmKAAABAR4RQwAAAQDJAAAAwAAAT8qAQABBdrF9da0SjJtPAQCASYqAQABBbq7IdeCMxhkPAQCASY=",
2262
- "debug_symbols": "nZXbiuMwDIbfxde5sOSj+irDUNI2HQIhLZl2YSl991UaOYeCzc7c5JeV+IssyfZDnZrD/Wvf9ufLt9p9PNRhaLuu/dp3l2N9ay89ex9Kj4/g1Q4rFUHtqFKkJ3EvAfCTohYVv5GxkbGVsbWicVJnRMOkHkWFG0BUOIEmjcKJzAFggzAZYTJQYzKSB5IHkgf594CjEcUwyWPGbywbFpORPC55XPJ4J0bgdUIcDfYgPJ+VShnd34amGRO6SjEn/loPTX9Tu/7edZX6U3f310ff17p/6a0e+K2uVNOfWBl4brtmtJ7VMlvnp1rQILMtgJ0BDjYEyBOMJQEYv8wP+N8R6EBzBFrnIjB5AqB1QgAkNxOi3RBsnoAxpdBQnOdboA3A5QHEPScEQq5sQhjaVsLnEZEnCiKSpywiFErhcF5GWAB6m8lYyANvGSEgkP8VYikG7xuTRUCpJQIlho0GZ8ZbPQpRGKKloquSvkdR6iqg1Jd8YPlcV0EB4aIRgl81dvS/2hqrrnrfnK60Cj3vDTCQCwIKjQk6mtTcbNvVIbGtBxRa00EKw+Fqh5mfhBEoLGEAZcOgEsR5nCEeYg6ChbIYH1I+TAC3OfM+eVQf22FzVT5H1tDWh66R4fneH1dvb3+v6U26aq/D5dic7kMzkpb7Fvj54Wzl6HO8YHngdeXx8zn++h8="
2262
+ "debug_symbols": "nZXbiuMwDIbfxde5sOSj+irDUNI2HQIhLZl2YSl991UaOYeCzc7c5JeV+IssyfZDnZrD/Wvf9ufLt9p9PNRhaLuu/dp3l2N9ay89ex9Kj4/g1Q4rFUHtqFKkJ3EvAfCTohYVv5GxkbGVsbWicVJnRMOkHkWFG0BUOIEmjcKJzAFggzAZYTJQYzKSB5IHkgf594CjEcUwyWPGbywbFpORPC55XPJ4J0bgdUIcDfYgPJ+VShnd34amGRO6SjEn/loPTX9Tu/7edZX6U3f310ff17p/6a0e+K2uVNOfWBl4brtmtJ7VMlvnp1rQILMtgJ0BDjYEyBOMJQEYv8wP+N8R6EBzBFrnIjB5AqB1QgAkNxOi3RBsnoAxpdBQnOdboA3A5QHEPScEQq5sQhjaVsLnEZEnCiKSpywiFErhcF5GWAB6m8lYyANvGSEgkP8VYikG7xuTRUCpJQIlho0GZ8ZbPQpRGKKloquSvkdR6iqg1Jd8YPlcV0EB4aIRgl81dvS/2hqrrnrfnK60Cj3vDTCQCwIKjQk6mtTcbNvVIbGtBxRa00EKw+Fqh1n4QRiBwhIGUDYMKkGcxxniIeYgWCiL8SHlwwRwmzPvk0f1sR02V+VzZA1tfegaGZ7v/XH19vb3mt6kq/Y6XI7N6T40I2m5b4GfH85Wjj7HC5YHXlceP5/jr/8B"
2263
2263
  },
2264
2264
  {
2265
2265
  "name": "utility_is_consumable",
@@ -2327,7 +2327,7 @@
2327
2327
  }
2328
2328
  },
2329
2329
  "bytecode": "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",
2330
- "debug_symbols": "rZvdbts4EIXfxde9EH+GQ+ZVFkWRtukiQJAW2WSBRZF3Xx6SZ2QHEOHKuul8aayPFMkRhzLy+/T94evb318en3/8/Od099fv09eXx6enx7+/PP38dv/6+PO5/u/v04J/fDjdhU8nH093qQY53TlXYxpRR8wjlh7DMqIb0Y8YRowjDl8YvjB8Ab5YY+kxLiO6Ef2IYcQ4oowIX+1v1BHziKVHWUasPl/bEz9iGDGOKCOmEXXEPGLpMS0jDl+Cr/YjhRHjiDJiGlFHzCOWHhW+2j91I/oRw4jVFxCrL2iN1RdKjTpi9cXaDy095mVEN6IfMYwYR5QR04g64vDl4SvDV4avDF8ZvjJ8ZfjK8JXhK8NXhs8tC8ERPCEQIkEIiaCETKDZ0exodjQ7mh3NjmZHs6PZ0exo9jR7mj3NnmZPs6fZ04zciRGQCTBLBaRPB0fwhECIBCEkghIygeZIc6Q50hxpjjRHmiPNkeZIc6RZaBaahWahWWgWmoVmoVloFpoTzYnmRHOiOdGcaE40J5oTzYlmpVlpVpqVZqVZaVaalWalWWnONGeaW0olAD5Tc9YhiQQrAVnUobYuHhAIkSCERFBCJpQOHtnUwRE8IRAiQQjD7JEygoc+EkQiAB8WgBDwYewISJAO6IYCyvgMEqSDI3hCINCMBJEMSASYCyATqjktFZAg7TNIkA6eEAiRQDMSJGGXQoJ0yASY2z63EBzBEwIhEoQAM4YOCZIwYkiQDjC3rXMhOIInBEIkVLOiY0iQDtWsaAsJ0qEMQF4o2kJeKAYTedGhChVC5EWHRFAChJg45EUD5EUHmDF0SrPSjLzoIIREUALMmDjkRQPkRcYMIi86eEIgRIIQEqGac6s3MqEMQDZlTAGyqbWFbOoQCJEghESAGYOJbOoAM2oQZFMHR/CEQIgEIaDPAlBCJsCcUB0tva2AvamDJwRCJAghEZSQCTBn1FsLwRE8IRAiQQgwK0AHINFyAVRPWQCeEAiRIIREUELuD70QxtMvtJ2ogSN4QiBEggxAXpRWOKIJD1BCbaJgEJAXDbBxFMwFEqSDJwRCJAghEZSQCWWA0qw0K81KMxKkYLqRDg2w+AvmHYu/gyfgKtwgFn8HXIVJwVLvUAZgqXeAB7ODpV5rKFAwikZilIxQGS8YSSz4QWVQxJKvFRjIjSvi4o2CUTQSo2SkRq2NgAK++Vop742aT0DRSIySkRplo0Lyrc8o8r0z8katDQVFtttOM52SkRplo0Jq55pOzZxBzVxAyUiNslEhtdMMjjmxnWc6eaNgFI3EKBm1sxJGt51qHGarnWscxlmcUbO0w1GzYKwkGTULRkiyUSGlxcgZeaNgFI1aGxjnlIzUqLWBUUuFPdDFyBl5o2AUjVobGElNRmjDYzSw6QwqJGTeIGfkjYIR2sABLmLvGZSMWhsY55zZbi6kshg5I28UjFobmJmWl51aG5ijlpedslEZJC0vOzkjb9TuQ0DRSIxaG+3wq6NdaXnZqZDcYuSMvFEwikZi1NrIIDXKRoXUcrWTM/JGrQ0FtTb0/f3Tia8mvry+PDzgzcTZu4r6BuPX/cvD8+vp7vnt6enT6d/7p7f2oX9+3T+3+Hr/Un9b5/jh+XuNVfjj8ekB9P5pvXrZvrR2DQu8XV5ZVoW4C4fbdmRsS81Qgtj1tWS9EPhJJxakee/DknRTMb8PbKDjPorzW/cRtx3RcyTqU8iuT5fXy/b1AXt5uz7oOg6arr6HWoFxKiuf9eHDPehsHHAs4zCsvcjxwpC3DT6zD3UPtevrjnQhKNuC4iJnotSzqCnqBn+5oiZDkZbANZWWmFbH9Z1Audo7UQ9q253ws3XtuSxzSWXbESZrQryN5jqftea+ekIdSiGuibQ1oW6yLpMNhS5uS3D9ukxx8xlx+8J0N69Md8DS9DcvTXfA2vQHrE1/89p0ty9OP1mcktfRXCck731o5rC1OP3sPkKM5jgbzQ/d8JPFWV+/2VCoX7a2Dz9ZF/WtIzeQ+gYxbCnCZDRUmGSqZ7fhLwWTvbxOKG+jvmZb+1CP8JcOP9tHLUNiOHvi1Dr+0jFbm5roqKdIv+2IBzgmy7Oe9jLvZSnn9+Kvd2ThvNZie9nluPpeJku0rineiySZ3MtkTFN0fIKmOs+bjjhZpD4wYeu7wjND+INVmtZVGuPmKo3+9r0gTlaplIW3IuUs6cMfGFIyw1nVeL0hLU7tCeryLsM1O9p8LK/b0WK+fUeL5dYdTWbbSRE7DhXZ61A7ipTsdznq1xbOVrjGfQ6RNdHO8v3PHLYzVoff249kDs2392OvI0Uuj/rFwbLTIdaPlJfb+7HTUV+krkt92Tce9a2qM8d5xn1wpNler0Vsbzvblz4U5fNulLWuL9u3Mqt78sIVdr7Bfqh70myPVnsMn2X9x8JpVnlltR5sCpLOZrQkG4azvaS+f710zIpQt9ax9Qvm1REvpyOV2XOYs1EW2TTo7ISUnZ03ddMwL6bzWkyfvVP6UAnrZGGmdVc8L5c+DOY0TZ1t7hV3Pj6XElfHzsens7dj3vmdjxxnCVIdB9zLXocLVri5qDsdVk7X7+vLXodtrxfF39572e3I2Rwl7XP4dW69y3sdy+ooN9/Lbsf6lsj7s7P8R0fWm7ekeUUcl7Ui3leVx2IG2arKp0WkzYgrTjZHYqbI6yuJ4ssuxZXl8AHV8AHF8EwRF0vW+v3pPsWa7zEtuxSyuPXom/YprivqD6jpDyjpD6jop4r1ZVVyuxb4tWeCqSLZjCTd2YvrThUHHCrmZ4r1HVOOOxVXHUsOOJW42fdHV+4B81PJWo4X3Xcn1x1sDqhBDyhBD6hADyhAD6g/Dyg/D6g+Dyg+D6g9Dyg9D6g8Dyg8D6g7Dyg7nd9Zd36uP91/e3y5+FOUd7heHu+/Pj2MH3+8PX87++3rf7/4G/4py6+Xn98evr+9PMC0/j1L/ecvqa8nJJbP+DOB+mOoL1uDBPzo8Nu6YYvkz+/ozP8="
2330
+ "debug_symbols": "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"
2331
2331
  }
2332
2332
  ],
2333
2333
  "outputs": {
@@ -2672,23 +2672,23 @@
2672
2672
  "path": "std/panic.nr",
2673
2673
  "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"
2674
2674
  },
2675
- "436": {
2675
+ "441": {
2676
2676
  "path": "/home/aztec-dev/aztec-packages/noir-projects/noir-protocol-circuits/crates/types/src/type_packing.nr",
2677
2677
  "source": "use crate::traits::Packable;\n\nglobal BOOL_PACKED_LEN: u32 = 1;\nglobal U8_PACKED_LEN: u32 = 1;\nglobal U16_PACKED_LEN: u32 = 1;\nglobal U32_PACKED_LEN: u32 = 1;\nglobal U64_PACKED_LEN: u32 = 1;\nglobal U128_PACKED_LEN: u32 = 1;\nglobal FIELD_PACKED_LEN: u32 = 1;\nglobal I8_PACKED_LEN: u32 = 1;\nglobal I16_PACKED_LEN: u32 = 1;\nglobal I32_PACKED_LEN: u32 = 1;\nglobal I64_PACKED_LEN: u32 = 1;\n\nimpl Packable for bool {\n let N: u32 = BOOL_PACKED_LEN;\n\n #[inline_always]\n fn pack(self) -> [Field; Self::N] {\n [self as Field]\n }\n\n #[inline_always]\n fn unpack(fields: [Field; Self::N]) -> bool {\n (fields[0] as u1) != 0\n }\n}\n\nimpl Packable for u8 {\n let N: u32 = U8_PACKED_LEN;\n\n #[inline_always]\n fn pack(self) -> [Field; Self::N] {\n [self as Field]\n }\n\n #[inline_always]\n fn unpack(fields: [Field; Self::N]) -> Self {\n fields[0] as u8\n }\n}\n\nimpl Packable for u16 {\n let N: u32 = U16_PACKED_LEN;\n\n #[inline_always]\n fn pack(self) -> [Field; Self::N] {\n [self as Field]\n }\n\n #[inline_always]\n fn unpack(fields: [Field; Self::N]) -> Self {\n fields[0] as u16\n }\n}\n\nimpl Packable for u32 {\n let N: u32 = U32_PACKED_LEN;\n\n #[inline_always]\n fn pack(self) -> [Field; Self::N] {\n [self as Field]\n }\n\n #[inline_always]\n fn unpack(fields: [Field; Self::N]) -> Self {\n fields[0] as u32\n }\n}\n\nimpl Packable for u64 {\n let N: u32 = U64_PACKED_LEN;\n\n #[inline_always]\n fn pack(self) -> [Field; Self::N] {\n [self as Field]\n }\n\n #[inline_always]\n fn unpack(fields: [Field; Self::N]) -> Self {\n fields[0] as u64\n }\n}\n\nimpl Packable for u128 {\n let N: u32 = U128_PACKED_LEN;\n\n #[inline_always]\n fn pack(self) -> [Field; Self::N] {\n [self as Field]\n }\n\n #[inline_always]\n fn unpack(fields: [Field; Self::N]) -> Self {\n fields[0] as u128\n }\n}\n\nimpl Packable for Field {\n let N: u32 = FIELD_PACKED_LEN;\n\n #[inline_always]\n fn pack(self) -> [Field; Self::N] {\n [self]\n }\n\n #[inline_always]\n fn unpack(fields: [Field; Self::N]) -> Self {\n fields[0]\n }\n}\n\nimpl Packable for i8 {\n let N: u32 = I8_PACKED_LEN;\n\n #[inline_always]\n fn pack(self) -> [Field; Self::N] {\n [self as u8 as Field]\n }\n\n #[inline_always]\n fn unpack(fields: [Field; Self::N]) -> Self {\n fields[0] as u8 as i8\n }\n}\n\nimpl Packable for i16 {\n let N: u32 = I16_PACKED_LEN;\n\n #[inline_always]\n fn pack(self) -> [Field; Self::N] {\n [self as u16 as Field]\n }\n\n #[inline_always]\n fn unpack(fields: [Field; Self::N]) -> Self {\n fields[0] as u16 as i16\n }\n}\n\nimpl Packable for i32 {\n let N: u32 = I32_PACKED_LEN;\n\n #[inline_always]\n fn pack(self) -> [Field; Self::N] {\n [self as u32 as Field]\n }\n\n #[inline_always]\n fn unpack(fields: [Field; Self::N]) -> Self {\n fields[0] as u32 as i32\n }\n}\n\nimpl Packable for i64 {\n let N: u32 = I64_PACKED_LEN;\n\n #[inline_always]\n fn pack(self) -> [Field; Self::N] {\n [self as u64 as Field]\n }\n\n #[inline_always]\n fn unpack(fields: [Field; Self::N]) -> Self {\n fields[0] as u64 as i64\n }\n}\n\nimpl<T, let M: u32> Packable for [T; M]\nwhere\n T: Packable,\n{\n let N: u32 = M * <T as Packable>::N;\n\n #[inline_always]\n fn pack(self) -> [Field; Self::N] {\n let mut result: [Field; Self::N] = std::mem::zeroed();\n for i in 0..M {\n let serialized = self[i].pack();\n for j in 0..<T as Packable>::N {\n result[i * <T as Packable>::N + j] = serialized[j];\n }\n }\n result\n }\n\n #[inline_always]\n fn unpack(fields: [Field; Self::N]) -> Self {\n let mut reader = crate::utils::reader::Reader::new(fields);\n let mut result: [T; M] = std::mem::zeroed();\n reader.read_struct_array::<T, <T as Packable>::N, M>(Packable::unpack, result)\n }\n}\n\n#[test]\nfn test_u16_packing() {\n let a: u16 = 10;\n assert_eq(a, u16::unpack(a.pack()));\n}\n\n#[test]\nfn test_i8_packing() {\n let a: i8 = -10;\n assert_eq(a, i8::unpack(a.pack()));\n}\n\n#[test]\nfn test_i16_packing() {\n let a: i16 = -10;\n assert_eq(a, i16::unpack(a.pack()));\n}\n\n#[test]\nfn test_i32_packing() {\n let a: i32 = -10;\n assert_eq(a, i32::unpack(a.pack()));\n}\n\n#[test]\nfn test_i64_packing() {\n let a: i64 = -10;\n assert_eq(a, i64::unpack(a.pack()));\n}\n"
2678
2678
  },
2679
- "449": {
2679
+ "454": {
2680
2680
  "path": "/home/aztec-dev/aztec-packages/noir-projects/noir-protocol-circuits/crates/serde/src/reader.nr",
2681
2681
  "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"
2682
2682
  },
2683
- "450": {
2683
+ "455": {
2684
2684
  "path": "/home/aztec-dev/aztec-packages/noir-projects/noir-protocol-circuits/crates/serde/src/serialization.nr",
2685
2685
  "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"
2686
2686
  },
2687
- "452": {
2687
+ "457": {
2688
2688
  "path": "/home/aztec-dev/aztec-packages/noir-projects/noir-protocol-circuits/crates/serde/src/type_impls.nr",
2689
- "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"
2689
+ "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"
2690
2690
  },
2691
- "453": {
2691
+ "458": {
2692
2692
  "path": "/home/aztec-dev/aztec-packages/noir-projects/noir-protocol-circuits/crates/serde/src/writer.nr",
2693
2693
  "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"
2694
2694
  },