mirror of https://git.sr.ht/~stygianentity/bincode
Add impls for Rc<[T]> and Arc<[T]> (#552)
This commit is contained in:
parent
357d7d3c0e
commit
229b597a84
|
|
@ -435,6 +435,26 @@ where
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl<T> Decode for Rc<[T]>
|
||||||
|
where
|
||||||
|
T: Decode,
|
||||||
|
{
|
||||||
|
fn decode<D: Decoder>(decoder: &mut D) -> Result<Self, DecodeError> {
|
||||||
|
let vec = Vec::decode(decoder)?;
|
||||||
|
Ok(vec.into())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<'de, T> BorrowDecode<'de> for Rc<[T]>
|
||||||
|
where
|
||||||
|
T: BorrowDecode<'de> + 'de,
|
||||||
|
{
|
||||||
|
fn borrow_decode<D: BorrowDecoder<'de>>(decoder: &mut D) -> Result<Self, DecodeError> {
|
||||||
|
let vec = Vec::borrow_decode(decoder)?;
|
||||||
|
Ok(vec.into())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#[cfg(target_has_atomic = "ptr")]
|
#[cfg(target_has_atomic = "ptr")]
|
||||||
impl<T> Decode for Arc<T>
|
impl<T> Decode for Arc<T>
|
||||||
where
|
where
|
||||||
|
|
@ -482,3 +502,25 @@ where
|
||||||
T::encode(self, encoder)
|
T::encode(self, encoder)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[cfg(target_has_atomic = "ptr")]
|
||||||
|
impl<T> Decode for Arc<[T]>
|
||||||
|
where
|
||||||
|
T: Decode,
|
||||||
|
{
|
||||||
|
fn decode<D: Decoder>(decoder: &mut D) -> Result<Self, DecodeError> {
|
||||||
|
let vec = Vec::decode(decoder)?;
|
||||||
|
Ok(vec.into())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[cfg(target_has_atomic = "ptr")]
|
||||||
|
impl<'de, T> BorrowDecode<'de> for Arc<[T]>
|
||||||
|
where
|
||||||
|
T: BorrowDecode<'de> + 'de,
|
||||||
|
{
|
||||||
|
fn borrow_decode<D: BorrowDecoder<'de>>(decoder: &mut D) -> Result<Self, DecodeError> {
|
||||||
|
let vec = Vec::borrow_decode(decoder)?;
|
||||||
|
Ok(vec.into())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
||||||
|
|
@ -89,9 +89,12 @@ fn test_alloc_commons() {
|
||||||
{
|
{
|
||||||
// Serde doesn't support Rc or Arc
|
// Serde doesn't support Rc or Arc
|
||||||
the_same(Rc::<u32>::new(5));
|
the_same(Rc::<u32>::new(5));
|
||||||
|
the_same(Rc::<[u32]>::from(vec![1, 2, 3, 4, 5]));
|
||||||
|
|
||||||
#[cfg(target_has_atomic = "ptr")]
|
#[cfg(target_has_atomic = "ptr")]
|
||||||
{
|
{
|
||||||
the_same(Arc::<u32>::new(5));
|
the_same(Arc::<u32>::new(5));
|
||||||
|
the_same(Arc::<[u32]>::from(vec![1, 2, 3, 4, 5]));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue