From b99c431ac78810034ea57cc778bf57d627998aa9 Mon Sep 17 00:00:00 2001 From: Luca Casonato Date: Thu, 16 Mar 2023 17:59:47 +0100 Subject: feat(serde_v8): support BigInt serialization (#18225) This commit enables serializing `v8::BigInt` to `num_bigint::BigInt` in Rust. Pre-requisite for sub upcoming feature work. --- serde_v8/serializable.rs | 5 +++++ 1 file changed, 5 insertions(+) (limited to 'serde_v8/serializable.rs') diff --git a/serde_v8/serializable.rs b/serde_v8/serializable.rs index 21c7bb752..b02aa0629 100644 --- a/serde_v8/serializable.rs +++ b/serde_v8/serializable.rs @@ -2,6 +2,7 @@ use std::any::TypeId; use std::mem::transmute_copy; +use crate::BigInt; use crate::ByteString; use crate::U16String; use crate::ZeroCopyBuf; @@ -65,6 +66,7 @@ pub enum Primitive { ZeroCopyBuf(ZeroCopyBuf), ByteString(ByteString), U16String(U16String), + BigInt(BigInt), } impl serde::Serialize for Primitive { @@ -89,6 +91,7 @@ impl serde::Serialize for Primitive { Self::ZeroCopyBuf(x) => x.serialize(s), Self::ByteString(x) => x.serialize(s), Self::U16String(x) => x.serialize(s), + Self::BigInt(x) => x.serialize(s), } } } @@ -137,6 +140,8 @@ impl From for SerializablePkg { Self::Primitive(Primitive::ByteString(tc(x))) } else if tid == TypeId::of::() { Self::Primitive(Primitive::U16String(tc(x))) + } else if tid == TypeId::of::() { + Self::Primitive(Primitive::BigInt(tc(x))) } else { Self::Serializable(Box::new(x)) } -- cgit v1.2.3