primitives 0.1.0

Primitves Asm
// use super::Bytes;
// use core::fmt;
// use serde::{de::{self, Visitor}, Serialize};

// impl serde::Serialize for Bytes {
//     #[inline]
//     fn serialize<S: serde::Serializer>(&self, serializer: S) -> Result<S::Ok, S::Error> {
//         if serializer.is_human_readable() {
//             Serialize::serialize(&self, serializer)
//         } else {
//             serializer.serialize_bytes(self.as_ref())
//         }
//     }
// }

// impl<'de> serde::Deserialize<'de> for Bytes {
//     #[inline]
//     fn deserialize<D: serde::Deserializer<'de>>(deserializer: D) -> Result<Self, D::Error> {
//         struct BytesVisitor;

//         impl<'de> Visitor<'de> for BytesVisitor {
//             type Value = Bytes;

//             fn expecting(&self, formatter: &mut fmt::Formatter<'_>) -> fmt::Result {
//                 formatter.write_str("a variable number of bytes represented as a hex string, an array of u8, or raw bytes")
//             }

//             fn visit_bytes<E: de::Error>(self, v: &[u8]) -> Result<Self::Value, E> {
//                 Ok(Bytes::copy_from_slice(v))
//             }

//             fn visit_byte_buf<E: de::Error>(self, v: Vec<u8>) -> Result<Self::Value, E> {
//                 Ok(Bytes::from(v))
//             }

//             fn visit_seq<A: de::SeqAccess<'de>>(self, mut seq: A) -> Result<Self::Value, A::Error> {
//                 let mut bytes = Vec::with_capacity(seq.size_hint().unwrap_or(0));

//                 while let Some(byte) = seq.next_element()? {
//                     bytes.push(byte);
//                 }

//                 Ok(Bytes::from(bytes))
//             }

//             fn visit_str<E: de::Error>(self, v: &str) -> Result<Self::Value, E> {
//                 hex::decode(v)
//                     .map_err(|e| {
//                         de::Error::custom(format!("Invalid hex string: {}", e))
//                     })
//                     .map(Bytes::from)
//             }
//         }

//         if deserializer.is_human_readable() {
//             deserializer.deserialize_any(BytesVisitor)
//         } else {
//             deserializer.deserialize_byte_buf(BytesVisitor)
//         }
//     }
// }

// #[cfg(test)]
// mod tests {
//     use super::*;
//     use serde::Deserialize;

//     #[derive(Debug, Deserialize)]
//     struct TestCase {
//         variable: Bytes,
//     }

//     #[test]
//     fn serde() {
//         let bytes = Bytes::from_static(&[1, 35, 69, 103, 137, 171, 205, 239]);
//         let ser = serde_json::to_string(&bytes).unwrap();
//         assert_eq!(ser, "\"0x0123456789abcdef\"");
//         assert_eq!(serde_json::from_str::<Bytes>(&ser).unwrap(), bytes);

//         let val = serde_json::to_value(&bytes).unwrap();
//         assert_eq!(val, serde_json::json! {"0x0123456789abcdef"});
//         assert_eq!(serde_json::from_value::<Bytes>(val).unwrap(), bytes);
//     }

//     #[test]
//     fn serde_num_array() {
//         let json = serde_json::json! {{"variable": [0,1,2,3,4]}};

//         assert_eq!(
//             serde_json::from_value::<TestCase>(json).unwrap().variable,
//             Bytes::from_static(&[0, 1, 2, 3, 4])
//         );
//     }

//     #[test]
//     fn test_bincode_roundtrip() {
//         let bytes = Bytes::from_static(&[1, 35, 69, 103, 137, 171, 205, 239]);

//         let bin = bincode::serialize(&bytes).unwrap();
//         assert_eq!(bincode::deserialize::<Bytes>(&bin).unwrap(), bytes);
//     }

//     #[test]
//     fn test_empty_bytes() {
//         let empty = Bytes::new();
//         let ser = serde_json::to_string(&empty).unwrap();
//         assert_eq!(ser, "\"0x\"");
//         assert_eq!(serde_json::from_str::<Bytes>(&ser).unwrap(), empty);
//     }

//     #[test]
//     fn test_invalid_hex() {
//         let result = serde_json::from_str::<Bytes>("\"0x123g\"");
//         assert!(result.is_err());
//     }

//     #[test]
//     fn test_odd_length_hex() {
//         let result = serde_json::from_str::<Bytes>("\"0x123\"");
//         assert!(result.is_err());
//     }
// }