From a2eb0a235b738864a107eb9d859878c68f7d5bbf Mon Sep 17 00:00:00 2001 From: HampusM Date: Mon, 5 Aug 2024 23:22:49 +0200 Subject: fix(ecs): always sort components & component metadata --- ecs/src/component/storage.rs | 11 +++++++++-- 1 file changed, 9 insertions(+), 2 deletions(-) (limited to 'ecs/src/component/storage.rs') diff --git a/ecs/src/component/storage.rs b/ecs/src/component/storage.rs index e909395..9c149ed 100644 --- a/ecs/src/component/storage.rs +++ b/ecs/src/component/storage.rs @@ -12,6 +12,7 @@ use crate::component::{ use crate::entity::Uid as EntityUid; use crate::lock::Lock; use crate::type_name::TypeName; +use crate::util::Sortable; use crate::EntityComponent; #[derive(Debug, Default)] @@ -26,9 +27,12 @@ impl Storage { pub fn find_entities( &self, - components_metadata: impl IntoIterator, + mut components_metadata: impl IntoIterator + + Sortable, ) -> ArchetypeRefIter<'_> { + components_metadata.sort_by_key_b(|component_metadata| component_metadata.id); + self.archetype_lookup .get(&ArchetypeId::from_components_metadata(components_metadata)) .map_or_else(ArchetypeRefIter::new_empty, |archetypes_indices| { @@ -114,9 +118,12 @@ impl Storage pub fn add_archetype_lookup_entry( &mut self, - components_metadata: impl IntoIterator, + mut components_metadata: impl IntoIterator + + Sortable, ) { + components_metadata.sort_by_key_b(|component_metadata| component_metadata.id); + self.pending_archetype_lookup_entries .push(components_metadata.into_iter().collect()); } -- cgit v1.2.3-18-g5258