use core::convert::TryFrom;
use core::fmt::Display;
use core::result;
use imbl::Vector;
use serde::ser::{Impossible, Serialize};
use serde_json::{Error, Number, Result};
use std::sync::Arc;
use crate::to_value;
use crate::InOMap as Map;
use crate::InternedString;
use crate::Value;
impl Serialize for Value {
#[inline]
fn serialize<S>(&self, serializer: S) -> result::Result<S::Ok, S::Error>
where
S: ::serde::Serializer,
{
match self {
Value::Null => serializer.serialize_unit(),
Value::Bool(b) => serializer.serialize_bool(*b),
Value::Number(n) => n.serialize(serializer),
Value::String(s) => serializer.serialize_str(s),
Value::Array(v) => v.serialize(serializer),
Value::Object(m) => {
use serde::ser::SerializeMap;
let mut map = serializer.serialize_map(Some(m.len()))?;
for (k, v) in m {
map.serialize_entry(k, v)?;
}
map.end()
}
}
}
}
pub struct Serializer;
impl serde::Serializer for Serializer {
type Ok = Value;
type Error = Error;
type SerializeSeq = SerializeVec;
type SerializeTuple = SerializeVec;
type SerializeTupleStruct = SerializeVec;
type SerializeTupleVariant = SerializeTupleVariant;
type SerializeMap = SerializeMap;
type SerializeStruct = SerializeMap;
type SerializeStructVariant = SerializeStructVariant;
#[inline]
fn serialize_bool(self, value: bool) -> Result<Value> {
Ok(Value::Bool(value))
}
#[inline]
fn serialize_i8(self, value: i8) -> Result<Value> {
self.serialize_i64(value as i64)
}
#[inline]
fn serialize_i16(self, value: i16) -> Result<Value> {
self.serialize_i64(value as i64)
}
#[inline]
fn serialize_i32(self, value: i32) -> Result<Value> {
self.serialize_i64(value as i64)
}
fn serialize_i64(self, value: i64) -> Result<Value> {
Ok(Value::Number(value.into()))
}
fn serialize_i128(self, value: i128) -> Result<Value> {
if let Ok(value) = u64::try_from(value) {
Ok(Value::Number(value.into()))
} else if let Ok(value) = i64::try_from(value) {
Ok(Value::Number(value.into()))
} else {
Err(<Error as serde::ser::Error>::custom("number out of range"))
}
}
#[inline]
fn serialize_u8(self, value: u8) -> Result<Value> {
self.serialize_u64(value as u64)
}
#[inline]
fn serialize_u16(self, value: u16) -> Result<Value> {
self.serialize_u64(value as u64)
}
#[inline]
fn serialize_u32(self, value: u32) -> Result<Value> {
self.serialize_u64(value as u64)
}
#[inline]
fn serialize_u64(self, value: u64) -> Result<Value> {
Ok(Value::Number(value.into()))
}
fn serialize_u128(self, value: u128) -> Result<Value> {
if let Ok(value) = u64::try_from(value) {
Ok(Value::Number(value.into()))
} else {
Err(<Error as serde::ser::Error>::custom("number out of range"))
}
}
#[inline]
fn serialize_f32(self, value: f32) -> Result<Value> {
self.serialize_f64(value as f64)
}
#[inline]
fn serialize_f64(self, value: f64) -> Result<Value> {
Ok(Number::from_f64(value).map_or(Value::Null, Value::Number))
}
#[inline]
fn serialize_char(self, value: char) -> Result<Value> {
let mut s = String::new();
s.push(value);
Ok(Value::String(Arc::new(s)))
}
#[inline]
fn serialize_str(self, value: &str) -> Result<Value> {
Ok(Value::String(Arc::new(value.to_owned())))
}
fn serialize_bytes(self, value: &[u8]) -> Result<Value> {
let vec = value.iter().map(|&b| Value::Number(b.into())).collect();
Ok(Value::Array(vec))
}
#[inline]
fn serialize_unit(self) -> Result<Value> {
Ok(Value::Null)
}
#[inline]
fn serialize_unit_struct(self, _name: &'static str) -> Result<Value> {
self.serialize_unit()
}
#[inline]
fn serialize_unit_variant(
self,
_name: &'static str,
_variant_index: u32,
variant: &'static str,
) -> Result<Value> {
self.serialize_str(variant)
}
#[inline]
fn serialize_newtype_struct<T>(self, _name: &'static str, value: &T) -> Result<Value>
where
T: ?Sized + Serialize,
{
value.serialize(self)
}
fn serialize_newtype_variant<T>(
self,
_name: &'static str,
_variant_index: u32,
variant: &'static str,
value: &T,
) -> Result<Value>
where
T: ?Sized + Serialize,
{
let mut values = Map::new();
values.insert(
InternedString::intern(variant),
to_value(&value).map_err(|e| e.source)?,
);
Ok(Value::Object(values))
}
#[inline]
fn serialize_none(self) -> Result<Value> {
self.serialize_unit()
}
#[inline]
fn serialize_some<T>(self, value: &T) -> Result<Value>
where
T: ?Sized + Serialize,
{
value.serialize(self)
}
fn serialize_seq(self, _len: Option<usize>) -> Result<Self::SerializeSeq> {
Ok(SerializeVec { vec: Vector::new() })
}
fn serialize_tuple(self, len: usize) -> Result<Self::SerializeTuple> {
self.serialize_seq(Some(len))
}
fn serialize_tuple_struct(
self,
_name: &'static str,
len: usize,
) -> Result<Self::SerializeTupleStruct> {
self.serialize_seq(Some(len))
}
fn serialize_tuple_variant(
self,
_name: &'static str,
_variant_index: u32,
variant: &'static str,
_len: usize,
) -> Result<Self::SerializeTupleVariant> {
Ok(SerializeTupleVariant {
name: InternedString::intern(variant),
vec: Vector::new(),
})
}
fn serialize_map(self, _len: Option<usize>) -> Result<Self::SerializeMap> {
Ok(SerializeMap::Map {
map: Map::new(),
next_key: None,
})
}
fn serialize_struct(self, name: &'static str, len: usize) -> Result<Self::SerializeStruct> {
match name {
_ => self.serialize_map(Some(len)),
}
}
fn serialize_struct_variant(
self,
_name: &'static str,
_variant_index: u32,
variant: &'static str,
_len: usize,
) -> Result<Self::SerializeStructVariant> {
Ok(SerializeStructVariant {
name: InternedString::intern(variant),
map: Map::new(),
})
}
fn collect_str<T>(self, value: &T) -> Result<Value>
where
T: ?Sized + Display,
{
Ok(Value::String(Arc::new(value.to_string())))
}
}
pub struct SerializeVec {
vec: Vector<Value>,
}
pub struct SerializeTupleVariant {
name: InternedString,
vec: Vector<Value>,
}
pub enum SerializeMap {
Map {
map: Map<InternedString, Value>,
next_key: Option<InternedString>,
},
}
pub struct SerializeStructVariant {
name: InternedString,
map: Map<InternedString, Value>,
}
impl serde::ser::SerializeSeq for SerializeVec {
type Ok = Value;
type Error = Error;
fn serialize_element<T>(&mut self, value: &T) -> Result<()>
where
T: ?Sized + Serialize,
{
self.vec.push_back(to_value(&value).map_err(|e| e.source)?);
Ok(())
}
fn end(self) -> Result<Value> {
Ok(Value::Array(self.vec))
}
}
impl serde::ser::SerializeTuple for SerializeVec {
type Ok = Value;
type Error = Error;
fn serialize_element<T>(&mut self, value: &T) -> Result<()>
where
T: ?Sized + Serialize,
{
serde::ser::SerializeSeq::serialize_element(self, value)
}
fn end(self) -> Result<Value> {
serde::ser::SerializeSeq::end(self)
}
}
impl serde::ser::SerializeTupleStruct for SerializeVec {
type Ok = Value;
type Error = Error;
fn serialize_field<T>(&mut self, value: &T) -> Result<()>
where
T: ?Sized + Serialize,
{
serde::ser::SerializeSeq::serialize_element(self, value)
}
fn end(self) -> Result<Value> {
serde::ser::SerializeSeq::end(self)
}
}
impl serde::ser::SerializeTupleVariant for SerializeTupleVariant {
type Ok = Value;
type Error = Error;
fn serialize_field<T>(&mut self, value: &T) -> Result<()>
where
T: ?Sized + Serialize,
{
self.vec.push_back(to_value(&value).map_err(|e| e.source)?);
Ok(())
}
fn end(self) -> Result<Value> {
let mut object = Map::new();
object.insert(self.name, Value::Array(self.vec));
Ok(Value::Object(object))
}
}
impl serde::ser::SerializeMap for SerializeMap {
type Ok = Value;
type Error = Error;
fn serialize_key<T>(&mut self, key: &T) -> Result<()>
where
T: ?Sized + Serialize,
{
match self {
SerializeMap::Map { next_key, .. } => {
*next_key = Some(key.serialize(MapKeySerializer)?);
Ok(())
}
}
}
fn serialize_value<T>(&mut self, value: &T) -> Result<()>
where
T: ?Sized + Serialize,
{
match self {
SerializeMap::Map { map, next_key } => {
let key = next_key.take();
let key = key.expect("serialize_value called before serialize_key");
map.insert(key, to_value(&value).map_err(|e| e.source)?);
Ok(())
}
}
}
fn end(self) -> Result<Value> {
match self {
SerializeMap::Map { map, .. } => Ok(Value::Object(map)),
}
}
}
struct MapKeySerializer;
fn key_must_be_a_string() -> Error {
<Error as serde::ser::Error>::custom("key must be a string")
}
impl serde::Serializer for MapKeySerializer {
type Ok = InternedString;
type Error = Error;
type SerializeSeq = Impossible<InternedString, Error>;
type SerializeTuple = Impossible<InternedString, Error>;
type SerializeTupleStruct = Impossible<InternedString, Error>;
type SerializeTupleVariant = Impossible<InternedString, Error>;
type SerializeMap = Impossible<InternedString, Error>;
type SerializeStruct = Impossible<InternedString, Error>;
type SerializeStructVariant = Impossible<InternedString, Error>;
#[inline]
fn serialize_unit_variant(
self,
_name: &'static str,
_variant_index: u32,
variant: &'static str,
) -> Result<InternedString> {
Ok(InternedString::intern(variant))
}
#[inline]
fn serialize_newtype_struct<T>(self, _name: &'static str, value: &T) -> Result<InternedString>
where
T: ?Sized + Serialize,
{
value.serialize(self)
}
fn serialize_bool(self, _value: bool) -> Result<InternedString> {
Err(key_must_be_a_string())
}
fn serialize_i8(self, value: i8) -> Result<InternedString> {
Ok(InternedString::from_display(&value))
}
fn serialize_i16(self, value: i16) -> Result<InternedString> {
Ok(InternedString::from_display(&value))
}
fn serialize_i32(self, value: i32) -> Result<InternedString> {
Ok(InternedString::from_display(&value))
}
fn serialize_i64(self, value: i64) -> Result<InternedString> {
Ok(InternedString::from_display(&value))
}
fn serialize_u8(self, value: u8) -> Result<InternedString> {
Ok(InternedString::from_display(&value))
}
fn serialize_u16(self, value: u16) -> Result<InternedString> {
Ok(InternedString::from_display(&value))
}
fn serialize_u32(self, value: u32) -> Result<InternedString> {
Ok(InternedString::from_display(&value))
}
fn serialize_u64(self, value: u64) -> Result<InternedString> {
Ok(InternedString::from_display(&value))
}
fn serialize_f32(self, _value: f32) -> Result<InternedString> {
Err(key_must_be_a_string())
}
fn serialize_f64(self, _value: f64) -> Result<InternedString> {
Err(key_must_be_a_string())
}
#[inline]
fn serialize_char(self, value: char) -> Result<InternedString> {
Ok(InternedString::from_display(&value))
}
#[inline]
fn serialize_str(self, value: &str) -> Result<InternedString> {
Ok(InternedString::intern(value))
}
fn serialize_bytes(self, _value: &[u8]) -> Result<InternedString> {
Err(key_must_be_a_string())
}
fn serialize_unit(self) -> Result<InternedString> {
Err(key_must_be_a_string())
}
fn serialize_unit_struct(self, _name: &'static str) -> Result<InternedString> {
Err(key_must_be_a_string())
}
fn serialize_newtype_variant<T>(
self,
_name: &'static str,
_variant_index: u32,
_variant: &'static str,
_value: &T,
) -> Result<InternedString>
where
T: ?Sized + Serialize,
{
Err(key_must_be_a_string())
}
fn serialize_none(self) -> Result<InternedString> {
Err(key_must_be_a_string())
}
fn serialize_some<T>(self, _value: &T) -> Result<InternedString>
where
T: ?Sized + Serialize,
{
Err(key_must_be_a_string())
}
fn serialize_seq(self, _len: Option<usize>) -> Result<Self::SerializeSeq> {
Err(key_must_be_a_string())
}
fn serialize_tuple(self, _len: usize) -> Result<Self::SerializeTuple> {
Err(key_must_be_a_string())
}
fn serialize_tuple_struct(
self,
_name: &'static str,
_len: usize,
) -> Result<Self::SerializeTupleStruct> {
Err(key_must_be_a_string())
}
fn serialize_tuple_variant(
self,
_name: &'static str,
_variant_index: u32,
_variant: &'static str,
_len: usize,
) -> Result<Self::SerializeTupleVariant> {
Err(key_must_be_a_string())
}
fn serialize_map(self, _len: Option<usize>) -> Result<Self::SerializeMap> {
Err(key_must_be_a_string())
}
fn serialize_struct(self, _name: &'static str, _len: usize) -> Result<Self::SerializeStruct> {
Err(key_must_be_a_string())
}
fn serialize_struct_variant(
self,
_name: &'static str,
_variant_index: u32,
_variant: &'static str,
_len: usize,
) -> Result<Self::SerializeStructVariant> {
Err(key_must_be_a_string())
}
fn collect_str<T>(self, value: &T) -> Result<InternedString>
where
T: ?Sized + Display,
{
Ok(InternedString::from_display(value))
}
}
impl serde::ser::SerializeStruct for SerializeMap {
type Ok = Value;
type Error = Error;
fn serialize_field<T>(&mut self, key: &'static str, value: &T) -> Result<()>
where
T: ?Sized + Serialize,
{
match self {
SerializeMap::Map { .. } => serde::ser::SerializeMap::serialize_entry(self, key, value),
}
}
fn end(self) -> Result<Value> {
match self {
SerializeMap::Map { .. } => serde::ser::SerializeMap::end(self),
}
}
}
impl serde::ser::SerializeStructVariant for SerializeStructVariant {
type Ok = Value;
type Error = Error;
fn serialize_field<T>(&mut self, key: &'static str, value: &T) -> Result<()>
where
T: ?Sized + Serialize,
{
self.map.insert(
InternedString::intern(key),
to_value(&value).map_err(|e| e.source)?,
);
Ok(())
}
fn end(self) -> Result<Value> {
let mut object = Map::new();
object.insert(self.name, Value::Object(self.map));
Ok(Value::Object(object))
}
}