From 44b59725af90bba5647e5bfe0a5acb17695ced9a Mon Sep 17 00:00:00 2001 From: Hennadii Chernyshchyk Date: Fri, 7 Oct 2022 20:57:57 +0300 Subject: [PATCH] Use default serde impls for Entity --- crates/bevy_ecs/src/entity/mod.rs | 5 ++-- crates/bevy_ecs/src/entity/serde.rs | 44 ----------------------------- 2 files changed, 2 insertions(+), 47 deletions(-) delete mode 100644 crates/bevy_ecs/src/entity/serde.rs diff --git a/crates/bevy_ecs/src/entity/mod.rs b/crates/bevy_ecs/src/entity/mod.rs index 1c56e1b40e15b..6165d69e9c1eb 100644 --- a/crates/bevy_ecs/src/entity/mod.rs +++ b/crates/bevy_ecs/src/entity/mod.rs @@ -31,12 +31,11 @@ //! [`EntityMut::insert`]: crate::world::EntityMut::insert //! [`EntityMut::remove`]: crate::world::EntityMut::remove mod map_entities; -mod serde; -pub use self::serde::*; pub use map_entities::*; use crate::{archetype::ArchetypeId, storage::SparseSetIndex}; +use serde::{Deserialize, Serialize}; use std::{convert::TryFrom, fmt, mem, sync::atomic::Ordering}; #[cfg(target_has_atomic = "64")] @@ -104,7 +103,7 @@ type IdCursor = isize; /// [`EntityMut::id`]: crate::world::EntityMut::id /// [`EntityCommands`]: crate::system::EntityCommands /// [`Query::get`]: crate::system::Query::get -#[derive(Clone, Copy, Hash, Eq, Ord, PartialEq, PartialOrd)] +#[derive(Clone, Copy, Deserialize, Eq, Hash, Ord, PartialEq, PartialOrd, Serialize)] pub struct Entity { pub(crate) generation: u32, pub(crate) id: u32, diff --git a/crates/bevy_ecs/src/entity/serde.rs b/crates/bevy_ecs/src/entity/serde.rs deleted file mode 100644 index e9dbf03d1b2d5..0000000000000 --- a/crates/bevy_ecs/src/entity/serde.rs +++ /dev/null @@ -1,44 +0,0 @@ -use crate::entity::Entity; -use serde::{de::Visitor, Deserialize, Serialize, Serializer}; - -impl Serialize for Entity { - fn serialize(&self, serializer: S) -> Result - where - S: Serializer, - { - serializer.serialize_u32(self.id()) - } -} - -impl<'de> Deserialize<'de> for Entity { - fn deserialize(deserializer: D) -> Result - where - D: serde::Deserializer<'de>, - { - deserializer.deserialize_u32(EntityVisitor) - } -} - -struct EntityVisitor; - -impl<'de> Visitor<'de> for EntityVisitor { - type Value = Entity; - - fn expecting(&self, formatter: &mut std::fmt::Formatter) -> std::fmt::Result { - formatter.write_str("Entity") - } - - fn visit_u32(self, v: u32) -> Result - where - E: serde::de::Error, - { - Ok(Entity::from_raw(v)) - } - - fn visit_u64(self, v: u64) -> Result - where - E: serde::de::Error, - { - Ok(Entity::from_raw(v as u32)) - } -}