use multiversx_sc_codec as codec; use codec::{ test_util::{check_dep_encode_decode, check_top_encode_decode}, top_decode_from_nested_or_handle_err, top_encode_from_nested, DecodeError, DecodeErrorHandler, EncodeErrorHandler, NestedDecode, NestedDecodeInput, NestedEncode, NestedEncodeOutput, TopDecode, TopDecodeInput, TopEncode, TopEncodeOutput, }; #[derive(PartialEq, Eq, Clone, Debug)] pub enum E { Unit, Newtype(u32), Tuple(u32, u32), Struct { a: u32 }, } impl NestedEncode for E { fn dep_encode_or_handle_err(&self, dest: &mut O, h: H) -> Result<(), H::HandledErr> where O: NestedEncodeOutput, H: EncodeErrorHandler, { match self { E::Unit => { 0u32.dep_encode_or_handle_err(dest, h)?; }, E::Newtype(arg1) => { 1u32.dep_encode_or_handle_err(dest, h)?; arg1.dep_encode_or_handle_err(dest, h)?; }, E::Tuple(arg1, arg2) => { 2u32.dep_encode_or_handle_err(dest, h)?; arg1.dep_encode_or_handle_err(dest, h)?; arg2.dep_encode_or_handle_err(dest, h)?; }, E::Struct { a } => { 3u32.dep_encode_or_handle_err(dest, h)?; a.dep_encode_or_handle_err(dest, h)?; }, } Ok(()) } } impl TopEncode for E { #[inline] fn top_encode_or_handle_err(&self, output: O, h: H) -> Result<(), H::HandledErr> where O: TopEncodeOutput, H: EncodeErrorHandler, { top_encode_from_nested(self, output, h) } } impl NestedDecode for E { fn dep_decode_or_handle_err(input: &mut I, h: H) -> Result where I: NestedDecodeInput, H: DecodeErrorHandler, { match u32::dep_decode_or_handle_err(input, h)? { 0 => Ok(E::Unit), 1 => Ok(E::Newtype(u32::dep_decode_or_handle_err(input, h)?)), 2 => Ok(E::Tuple( u32::dep_decode_or_handle_err(input, h)?, u32::dep_decode_or_handle_err(input, h)?, )), 3 => Ok(E::Struct { a: u32::dep_decode_or_handle_err(input, h)?, }), _ => Err(h.handle_error(DecodeError::INVALID_VALUE)), } } } impl TopDecode for E { fn top_decode_or_handle_err(input: I, h: H) -> Result where I: TopDecodeInput, H: DecodeErrorHandler, { top_decode_from_nested_or_handle_err(input, h) } } #[test] fn test_top() { let u = E::Unit; let expected: &[u8] = &[/*variant index*/ 0, 0, 0, 0]; check_top_encode_decode(u, expected); let n = E::Newtype(1); let expected: &[u8] = &[/*variant index*/ 0, 0, 0, 1, /*data*/ 0, 0, 0, 1]; check_top_encode_decode(n, expected); let t = E::Tuple(1, 2); let expected: &[u8] = &[ /*variant index*/ 0, 0, 0, 2, /*(*/ 0, 0, 0, 1, /*,*/ 0, 0, 0, 2, /*)*/ ]; check_top_encode_decode(t, expected); let s = E::Struct { a: 1 }; let expected: &[u8] = &[/*variant index*/ 0, 0, 0, 3, /*data*/ 0, 0, 0, 1]; check_top_encode_decode(s, expected); } #[test] fn test_dep() { let u = E::Unit; let expected: &[u8] = &[/*variant index*/ 0, 0, 0, 0]; check_dep_encode_decode(u, expected); let n = E::Newtype(1); let expected: &[u8] = &[/*variant index*/ 0, 0, 0, 1, /*data*/ 0, 0, 0, 1]; check_dep_encode_decode(n, expected); let t = E::Tuple(1, 2); let expected: &[u8] = &[ /*variant index*/ 0, 0, 0, 2, /*(*/ 0, 0, 0, 1, /*,*/ 0, 0, 0, 2, /*)*/ ]; check_dep_encode_decode(t, expected); let s = E::Struct { a: 1 }; let expected: &[u8] = &[/*variant index*/ 0, 0, 0, 3, /*data*/ 0, 0, 0, 1]; check_dep_encode_decode(s, expected); }