From cd385ddedc767c953f24109ec3ffe0a07d247ff5 Mon Sep 17 00:00:00 2001 From: HampusM Date: Sat, 4 Jan 2025 15:07:14 +0100 Subject: refactor(ecs): add query component iter lifetime params --- ecs/src/query.rs | 53 ++++++++++++++++++++++++++++++----------------------- 1 file changed, 30 insertions(+), 23 deletions(-) (limited to 'ecs') diff --git a/ecs/src/query.rs b/ecs/src/query.rs index 3905fb8..68964eb 100644 --- a/ecs/src/query.rs +++ b/ecs/src/query.rs @@ -38,9 +38,9 @@ where { /// Iterates over the entities matching this query. #[must_use] - pub fn iter_mut( - &'world self, - ) -> ComponentIterMut<'world, Comps, QueryEntityIter<'world>> + pub fn iter_mut<'query>( + &'query self, + ) -> ComponentIterMut<'query, 'world, Comps, QueryEntityIter<'query>> { #[cfg(feature = "debug")] tracing::debug!("Searching for {}", std::any::type_name::()); @@ -65,7 +65,9 @@ where /// Iterates over the entities matching this query. #[must_use] - pub fn iter(&'world self) -> ComponentIter<'world, Comps, QueryEntityIter<'world>> + pub fn iter<'query>( + &'query self, + ) -> ComponentIter<'query, 'world, Comps, QueryEntityIter<'query>> { #[cfg(feature = "debug")] tracing::debug!("Searching for {}", std::any::type_name::()); @@ -91,10 +93,10 @@ where /// Iterates over the entities matching this query and has the provided extra /// component. #[must_use] - pub fn iter_with_extra_comps( - &'world self, + pub fn iter_with_extra_comps<'query>( + &'query self, extra_components: impl IntoIterator, - ) -> ComponentIter<'world, Comps, QueryEntityIter<'world>> + ) -> ComponentIter<'query, 'world, Comps, QueryEntityIter<'query>> { #[cfg(feature = "debug")] tracing::debug!( @@ -153,13 +155,14 @@ where } } -impl<'world, Comps, OptionsT> IntoIterator for &'world Query<'world, Comps, OptionsT> +impl<'query, 'world, Comps, OptionsT> IntoIterator + for &'query Query<'world, Comps, OptionsT> where - Comps: ComponentSequence, + Comps: ComponentSequence + 'world, OptionsT: Options, { - type IntoIter = ComponentIterMut<'world, Comps, QueryEntityIter<'world>>; - type Item = Comps::MutRefs<'world>; + type IntoIter = ComponentIterMut<'query, 'world, Comps, QueryEntityIter<'query>>; + type Item = Comps::MutRefs<'query>; fn into_iter(self) -> Self::IntoIter { @@ -196,26 +199,28 @@ type ComponentIterMapFn = type ComponentIterFilterFn = for<'a, 'b> fn(&'a (&'b Archetype, &'b ArchetypeEntity)) -> bool; -type QueryEntityIter<'world> = Filter< - Flatten, ComponentIterMapFn>>, +type QueryEntityIter<'query> = Filter< + Flatten, ComponentIterMapFn>>, ComponentIterFilterFn, >; -pub struct ComponentIterMut<'world, Comps, EntityIter> +pub struct ComponentIterMut<'query, 'world, Comps, EntityIter> where - EntityIter: Iterator, + EntityIter: Iterator, { world: &'world World, entities: EntityIter, comps_pd: PhantomData, } -impl<'world, Comps, EntityIter> Iterator for ComponentIterMut<'world, Comps, EntityIter> +impl<'query, 'world, Comps, EntityIter> Iterator + for ComponentIterMut<'query, 'world, Comps, EntityIter> where Comps: ComponentSequence + 'world, - EntityIter: Iterator, + EntityIter: Iterator, + 'world: 'query, { - type Item = Comps::MutRefs<'world>; + type Item = Comps::MutRefs<'query>; fn next(&mut self) -> Option { @@ -245,21 +250,23 @@ fn lock_component_rw( }) } -pub struct ComponentIter<'world, Comps, EntityIter> +pub struct ComponentIter<'query, 'world, Comps, EntityIter> where - EntityIter: Iterator, + EntityIter: Iterator, { world: &'world World, entities: EntityIter, comps_pd: PhantomData, } -impl<'world, Comps, EntityIter> Iterator for ComponentIter<'world, Comps, EntityIter> +impl<'query, 'world, Comps, EntityIter> Iterator + for ComponentIter<'query, 'world, Comps, EntityIter> where Comps: ComponentSequence + 'world, - EntityIter: Iterator, + EntityIter: Iterator, + 'world: 'query, { - type Item = Comps::Refs<'world>; + type Item = Comps::Refs<'query>; fn next(&mut self) -> Option { -- cgit v1.2.3-18-g5258