rkyv/impls/hashbrown/
hash_set.rs

1use 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}