rkyv/impls/hashbrown/
hash_set.rs1use crate::{
2 collections::hash_set::{ArchivedHashSet, HashSetResolver},
3 ser::{ScratchSpace, Serializer},
4 Archive, Deserialize, Fallible, Serialize,
5};
6use core::{
7 borrow::Borrow,
8 hash::{BuildHasher, Hash},
9};
10use hashbrown::HashSet;
11
12impl<K: Archive + Hash + Eq, S> Archive for HashSet<K, S>
13where
14 K::Archived: Hash + Eq,
15{
16 type Archived = ArchivedHashSet<K::Archived>;
17 type Resolver = HashSetResolver;
18
19 #[inline]
20 unsafe fn resolve(&self, pos: usize, resolver: Self::Resolver, out: *mut Self::Archived) {
21 ArchivedHashSet::<K::Archived>::resolve_from_len(self.len(), pos, resolver, out);
22 }
23}
24
25impl<K, S, RS> Serialize<S> for HashSet<K, RS>
26where
27 K::Archived: Hash + Eq,
28 K: Serialize<S> + Hash + Eq,
29 S: ScratchSpace + Serializer + ?Sized,
30{
31 #[inline]
32 fn serialize(&self, serializer: &mut S) -> Result<Self::Resolver, S::Error> {
33 unsafe { ArchivedHashSet::serialize_from_iter(self.iter(), serializer) }
34 }
35}
36
37impl<K, D, S> Deserialize<HashSet<K, S>, D> for ArchivedHashSet<K::Archived>
38where
39 K: Archive + Hash + Eq,
40 K::Archived: Deserialize<K, D> + Hash + Eq,
41 D: Fallible + ?Sized,
42 S: Default + BuildHasher,
43{
44 #[inline]
45 fn deserialize(&self, deserializer: &mut D) -> Result<HashSet<K, S>, D::Error> {
46 let mut result = HashSet::with_hasher(S::default());
47 for k in self.iter() {
48 result.insert(k.deserialize(deserializer)?);
49 }
50 Ok(result)
51 }
52}
53
54impl<K: Hash + Eq + Borrow<AK>, AK: Hash + Eq, S: BuildHasher> PartialEq<HashSet<K, S>>
55 for ArchivedHashSet<AK>
56{
57 #[inline]
58 fn eq(&self, other: &HashSet<K, S>) -> bool {
59 if self.len() != other.len() {
60 false
61 } else {
62 self.iter().all(|key| other.get(key).is_some())
63 }
64 }
65}
66
67impl<K: Hash + Eq + Borrow<AK>, AK: Hash + Eq, S: BuildHasher> PartialEq<ArchivedHashSet<AK>>
68 for HashSet<K, S>
69{
70 #[inline]
71 fn eq(&self, other: &ArchivedHashSet<AK>) -> bool {
72 other.eq(self)
73 }
74}
75
76#[cfg(test)]
77mod tests {
78 use crate::{
79 archived_root,
80 ser::{serializers::AllocSerializer, Serializer},
81 Deserialize, Infallible,
82 };
83 #[cfg(all(feature = "alloc", not(feature = "std")))]
84 use alloc::string::String;
85 use hashbrown::HashSet;
86
87 #[test]
88 fn index_set() {
89 let mut value = HashSet::new();
90 value.insert(String::from("foo"));
91 value.insert(String::from("bar"));
92 value.insert(String::from("baz"));
93 value.insert(String::from("bat"));
94
95 let mut serializer = AllocSerializer::<4096>::default();
96 serializer.serialize_value(&value).unwrap();
97 let result = serializer.into_serializer().into_inner();
98 let archived = unsafe { archived_root::<HashSet<String>>(result.as_ref()) };
99
100 assert_eq!(value.len(), archived.len());
101 for k in value.iter() {
102 let ak = archived.get(k.as_str()).unwrap();
103 assert_eq!(k, ak);
104 }
105
106 let deserialized: HashSet<String> = archived.deserialize(&mut Infallible).unwrap();
107 assert_eq!(value, deserialized);
108 }
109
110 #[cfg(feature = "validation")]
111 #[test]
112 fn validate_index_set() {
113 use crate::check_archived_root;
114
115 let mut value = HashSet::new();
116 value.insert(String::from("foo"));
117 value.insert(String::from("bar"));
118 value.insert(String::from("baz"));
119 value.insert(String::from("bat"));
120
121 let mut serializer = AllocSerializer::<4096>::default();
122 serializer.serialize_value(&value).unwrap();
123 let result = serializer.into_serializer().into_inner();
124 check_archived_root::<HashSet<String>>(result.as_ref())
125 .expect("failed to validate archived index set");
126 }
127}