1#![cfg_attr(not(feature = "std"), no_std)]
12
13#[doc(hidden)]
14pub use tetsy_scale_codec as codec;
15
16#[macro_export]
18macro_rules! impl_uint_codec {
19 ($name: ident, $len: expr) => {
20 impl $crate::codec::Encode for $name {
21 fn using_encoded<R, F: FnOnce(&[u8]) -> R>(&self, f: F) -> R {
22 let mut bytes = [0u8; $len * 8];
23 self.to_little_endian(&mut bytes);
24 bytes.using_encoded(f)
25 }
26 }
27
28 impl $crate::codec::EncodeLike for $name {}
29
30 impl $crate::codec::Decode for $name {
31 fn decode<I: $crate::codec::Input>(input: &mut I) -> core::result::Result<Self, $crate::codec::Error> {
32 <[u8; $len * 8] as $crate::codec::Decode>::decode(input).map(|b| $name::from_little_endian(&b))
33 }
34 }
35 };
36}
37
38#[macro_export]
40macro_rules! impl_fixed_hash_codec {
41 ($name: ident, $len: expr) => {
42 impl $crate::codec::Encode for $name {
43 fn using_encoded<R, F: FnOnce(&[u8]) -> R>(&self, f: F) -> R {
44 self.0.using_encoded(f)
45 }
46 }
47
48 impl $crate::codec::EncodeLike for $name {}
49
50 impl $crate::codec::Decode for $name {
51 fn decode<I: $crate::codec::Input>(input: &mut I) -> core::result::Result<Self, $crate::codec::Error> {
52 <[u8; $len] as $crate::codec::Decode>::decode(input).map($name)
53 }
54 }
55 };
56}