From 20c45467612ff2448b87ce731f939145c6e3a3b1 Mon Sep 17 00:00:00 2001 From: HampusM Date: Tue, 23 Sep 2025 18:20:11 +0200 Subject: feat(ecs): make Actions::spawn return future entity's UID --- ecs/src/actions.rs | 17 ++++++++++++----- ecs/src/lib.rs | 4 +--- 2 files changed, 13 insertions(+), 8 deletions(-) diff --git a/ecs/src/actions.rs b/ecs/src/actions.rs index 2dd68bf..ba3ced5 100644 --- a/ecs/src/actions.rs +++ b/ecs/src/actions.rs @@ -16,11 +16,18 @@ pub struct Actions<'world> impl<'world> Actions<'world> { - /// Queues up a entity to spawn at the end of the current tick. - pub fn spawn(&mut self, components: Comps) + /// Queues up a entity to spawn at the end of the current tick, returning the [`Uid`] + /// that the entity will have. + pub fn spawn(&mut self, components: Comps) -> Uid { - self.action_queue - .push(Action::Spawn(components.into_parts_array().into())); + let new_entity_uid = Uid::new_unique(UidKind::Entity); + + self.action_queue.push(Action::Spawn( + new_entity_uid, + components.into_parts_array().into(), + )); + + new_entity_uid } /// Queues up despawning a entity at the end of the current tick. @@ -149,7 +156,7 @@ impl Ref<'_> #[derive(Debug)] pub(crate) enum Action { - Spawn(Vec), + Spawn(Uid, Vec), Despawn(Uid), AddComponents(Uid, Vec), RemoveComponents(Uid, Vec), diff --git a/ecs/src/lib.rs b/ecs/src/lib.rs index 0c2197c..77d40db 100644 --- a/ecs/src/lib.rs +++ b/ecs/src/lib.rs @@ -425,9 +425,7 @@ impl World for action in action_queue_lock.drain(..) { match action { - Action::Spawn(components) => { - let new_entity_uid = Uid::new_unique(UidKind::Entity); - + Action::Spawn(new_entity_uid, components) => { if let Err(err) = self.data.component_storage.create_entity(new_entity_uid) { -- cgit v1.2.3-18-g5258