1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
// 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());
// }
// }