mirror of https://git.sr.ht/~stygianentity/bincode
Added support for BinaryHeap, BTreeMap, BTreeSet and VecDeque
This commit is contained in:
parent
4e1a72796c
commit
a322e0f1b3
|
|
@ -5,7 +5,7 @@ use crate::{
|
||||||
error::{DecodeError, EncodeError},
|
error::{DecodeError, EncodeError},
|
||||||
Config,
|
Config,
|
||||||
};
|
};
|
||||||
use alloc::{borrow::Cow, boxed::Box, rc::Rc, sync::Arc, vec::Vec};
|
use alloc::{borrow::Cow, boxed::Box, collections::*, rc::Rc, sync::Arc, vec::Vec};
|
||||||
|
|
||||||
#[derive(Default)]
|
#[derive(Default)]
|
||||||
struct VecWriter {
|
struct VecWriter {
|
||||||
|
|
@ -35,6 +35,122 @@ pub fn encode_to_vec_with_config<E: enc::Encodeable, C: Config>(
|
||||||
Ok(encoder.into_writer().inner)
|
Ok(encoder.into_writer().inner)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl<T> Decodable for BinaryHeap<T>
|
||||||
|
where
|
||||||
|
T: Decodable + Ord,
|
||||||
|
{
|
||||||
|
fn decode<D: Decode>(mut decoder: D) -> Result<Self, DecodeError> {
|
||||||
|
let len = usize::decode(&mut decoder)?;
|
||||||
|
let mut map = BinaryHeap::with_capacity(len);
|
||||||
|
for _ in 0..len {
|
||||||
|
let key = T::decode(&mut decoder)?;
|
||||||
|
map.push(key);
|
||||||
|
}
|
||||||
|
Ok(map)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<T> Encodeable for BinaryHeap<T>
|
||||||
|
where
|
||||||
|
T: Encodeable + Ord,
|
||||||
|
{
|
||||||
|
fn encode<E: Encode>(&self, mut encoder: E) -> Result<(), EncodeError> {
|
||||||
|
self.len().encode(&mut encoder)?;
|
||||||
|
for val in self.iter() {
|
||||||
|
val.encode(&mut encoder)?;
|
||||||
|
}
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<K, V> Decodable for BTreeMap<K, V>
|
||||||
|
where
|
||||||
|
K: Decodable + Ord,
|
||||||
|
V: Decodable,
|
||||||
|
{
|
||||||
|
fn decode<D: Decode>(mut decoder: D) -> Result<Self, DecodeError> {
|
||||||
|
let len = usize::decode(&mut decoder)?;
|
||||||
|
let mut map = BTreeMap::new();
|
||||||
|
for _ in 0..len {
|
||||||
|
let key = K::decode(&mut decoder)?;
|
||||||
|
let value = V::decode(&mut decoder)?;
|
||||||
|
map.insert(key, value);
|
||||||
|
}
|
||||||
|
Ok(map)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<K, V> Encodeable for BTreeMap<K, V>
|
||||||
|
where
|
||||||
|
K: Encodeable + Ord,
|
||||||
|
V: Encodeable,
|
||||||
|
{
|
||||||
|
fn encode<E: Encode>(&self, mut encoder: E) -> Result<(), EncodeError> {
|
||||||
|
self.len().encode(&mut encoder)?;
|
||||||
|
for (key, val) in self.iter() {
|
||||||
|
key.encode(&mut encoder)?;
|
||||||
|
val.encode(&mut encoder)?;
|
||||||
|
}
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<T> Decodable for BTreeSet<T>
|
||||||
|
where
|
||||||
|
T: Decodable + Ord,
|
||||||
|
{
|
||||||
|
fn decode<D: Decode>(mut decoder: D) -> Result<Self, DecodeError> {
|
||||||
|
let len = usize::decode(&mut decoder)?;
|
||||||
|
let mut map = BTreeSet::new();
|
||||||
|
for _ in 0..len {
|
||||||
|
let key = T::decode(&mut decoder)?;
|
||||||
|
map.insert(key);
|
||||||
|
}
|
||||||
|
Ok(map)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<T> Encodeable for BTreeSet<T>
|
||||||
|
where
|
||||||
|
T: Encodeable + Ord,
|
||||||
|
{
|
||||||
|
fn encode<E: Encode>(&self, mut encoder: E) -> Result<(), EncodeError> {
|
||||||
|
self.len().encode(&mut encoder)?;
|
||||||
|
for item in self.iter() {
|
||||||
|
item.encode(&mut encoder)?;
|
||||||
|
}
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<T> Decodable for VecDeque<T>
|
||||||
|
where
|
||||||
|
T: Decodable,
|
||||||
|
{
|
||||||
|
fn decode<D: Decode>(mut decoder: D) -> Result<Self, DecodeError> {
|
||||||
|
let len = usize::decode(&mut decoder)?;
|
||||||
|
let mut map = VecDeque::with_capacity(len);
|
||||||
|
for _ in 0..len {
|
||||||
|
let key = T::decode(&mut decoder)?;
|
||||||
|
map.push_back(key);
|
||||||
|
}
|
||||||
|
Ok(map)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<T> Encodeable for VecDeque<T>
|
||||||
|
where
|
||||||
|
T: Encodeable,
|
||||||
|
{
|
||||||
|
fn encode<E: Encode>(&self, mut encoder: E) -> Result<(), EncodeError> {
|
||||||
|
self.len().encode(&mut encoder)?;
|
||||||
|
for item in self.iter() {
|
||||||
|
item.encode(&mut encoder)?;
|
||||||
|
}
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
impl<T> Decodable for Vec<T>
|
impl<T> Decodable for Vec<T>
|
||||||
where
|
where
|
||||||
T: Decodable,
|
T: Decodable,
|
||||||
|
|
|
||||||
|
|
@ -5,6 +5,7 @@ extern crate alloc;
|
||||||
mod utils;
|
mod utils;
|
||||||
|
|
||||||
use alloc::borrow::Cow;
|
use alloc::borrow::Cow;
|
||||||
|
use alloc::collections::*;
|
||||||
use alloc::rc::Rc;
|
use alloc::rc::Rc;
|
||||||
use alloc::sync::Arc;
|
use alloc::sync::Arc;
|
||||||
use utils::the_same;
|
use utils::the_same;
|
||||||
|
|
@ -53,4 +54,20 @@ fn test_alloc_commons() {
|
||||||
the_same(Cow::<u32>::Borrowed(&5));
|
the_same(Cow::<u32>::Borrowed(&5));
|
||||||
the_same(Rc::<u32>::new(5));
|
the_same(Rc::<u32>::new(5));
|
||||||
the_same(Arc::<u32>::new(5));
|
the_same(Arc::<u32>::new(5));
|
||||||
|
the_same({
|
||||||
|
let mut map = BTreeMap::<u32, i32>::new();
|
||||||
|
map.insert(5, -5);
|
||||||
|
map
|
||||||
|
});
|
||||||
|
the_same({
|
||||||
|
let mut set = BTreeSet::<u32>::new();
|
||||||
|
set.insert(5);
|
||||||
|
set
|
||||||
|
});
|
||||||
|
the_same({
|
||||||
|
let mut set = VecDeque::<u32>::new();
|
||||||
|
set.push_back(15);
|
||||||
|
set.push_front(5);
|
||||||
|
set
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue