serde impl #16
+10
-5
@@ -663,19 +663,24 @@ where
|
|||||||
}
|
}
|
||||||
|
|
||||||
#[cfg(feature = "serde")]
|
#[cfg(feature = "serde")]
|
||||||
impl<'de, G: Game> serde::Deserialize<'de> for SessionState<G>
|
impl<'de, G: Game> serde::de::DeserializeSeed<'de> for Session<G>
|
||||||
where
|
where
|
||||||
G: serde::Deserialize<'de>,
|
G: serde::Deserialize<'de>,
|
||||||
G::Instruction: serde::Deserialize<'de>,
|
G::Instruction: serde::Deserialize<'de>,
|
||||||
{
|
{
|
||||||
fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>
|
type Value = SessionState<G>;
|
||||||
|
fn deserialize<D>(deserializer: D) -> Result<Self::Value, D::Error>
|
||||||
where
|
where
|
||||||
D: serde::Deserializer<'de>,
|
D: serde::Deserializer<'de>,
|
||||||
{
|
{
|
||||||
struct SessionStateVisitor<G> {
|
struct SessionStateVisitor<G> {
|
||||||
state: G,
|
state: G,
|
||||||
}
|
}
|
||||||
impl<'de, G: Game> serde::de::Visitor<'de> for SessionStateVisitor<G> {
|
impl<'de, G: Game> serde::de::Visitor<'de> for SessionStateVisitor<G>
|
||||||
|
where
|
||||||
|
G: serde::Deserialize<'de>,
|
||||||
|
G::Instruction: serde::Deserialize<'de>,
|
||||||
|
{
|
||||||
type Value = SessionState<G>;
|
type Value = SessionState<G>;
|
||||||
fn expecting(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
|
fn expecting(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
|
||||||
write!(f, "State History")
|
write!(f, "State History")
|
||||||
@@ -689,7 +694,7 @@ where
|
|||||||
Some(capacity) => Vec::with_capacity(capacity),
|
Some(capacity) => Vec::with_capacity(capacity),
|
||||||
None => Vec::new(),
|
None => Vec::new(),
|
||||||
};
|
};
|
||||||
while let Some(instruction) = seq.next_element()? {
|
while let Some(instruction) = seq.next_element::<G::Instruction>()? {
|
||||||
history.push(StateSnapshot {
|
history.push(StateSnapshot {
|
||||||
state: state.clone(),
|
state: state.clone(),
|
||||||
instruction: instruction.clone(),
|
instruction: instruction.clone(),
|
||||||
@@ -715,7 +720,7 @@ where
|
|||||||
{
|
{
|
||||||
if let Some(state) = self.history.first() {
|
if let Some(state) = self.history.first() {
|
||||||
state.serialize(serializer)?;
|
state.serialize(serializer)?;
|
||||||
}else{
|
} else {
|
||||||
self.state.serialize(serializer)?;
|
self.state.serialize(serializer)?;
|
||||||
}
|
}
|
||||||
use serde::ser::SerializeSeq;
|
use serde::ser::SerializeSeq;
|
||||||
|
|||||||
Reference in New Issue
Block a user