From b9fa43ec983e60c05dca6fa97b9e79fa3e44ec3b Mon Sep 17 00:00:00 2001 From: devil-ira Date: Thu, 2 Feb 2023 14:31:15 +0100 Subject: [PATCH 1/4] Add `ManualEventReader::clear()` --- crates/bevy_ecs/src/event.rs | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/crates/bevy_ecs/src/event.rs b/crates/bevy_ecs/src/event.rs index 2b641bf48216b..dae374ecf630b 100644 --- a/crates/bevy_ecs/src/event.rs +++ b/crates/bevy_ecs/src/event.rs @@ -241,7 +241,7 @@ impl<'w, 's, E: Event> EventReader<'w, 's, E> { /// /// For more information see [`EventReader::is_empty()`]. pub fn clear(&mut self) { - self.iter().last(); + self.reader.clear(&self.events) } } @@ -366,6 +366,11 @@ impl ManualEventReader { pub fn is_empty(&self, events: &Events) -> bool { self.len(events) == 0 } + + /// See [`EventReader::clear()`] + pub fn clear(&mut self, events: &Events) { + self.last_event_count = events.event_count; + } } pub struct ManualEventIterator<'a, E: Event> { From 3110d45e25eb13d072aaac89ac92aef34de33fe8 Mon Sep 17 00:00:00 2001 From: devil-ira Date: Thu, 2 Feb 2023 14:32:24 +0100 Subject: [PATCH 2/4] Re-use `ManualEventReader::is_empty()` --- crates/bevy_ecs/src/event.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/crates/bevy_ecs/src/event.rs b/crates/bevy_ecs/src/event.rs index dae374ecf630b..61c5c288ca270 100644 --- a/crates/bevy_ecs/src/event.rs +++ b/crates/bevy_ecs/src/event.rs @@ -229,7 +229,7 @@ impl<'w, 's, E: Event> EventReader<'w, 's, E> { /// # bevy_ecs::system::assert_is_system(play_collision_sound); /// ``` pub fn is_empty(&self) -> bool { - self.len() == 0 + self.reader.is_empty(&self.events) } /// Consumes the iterator. From 5fa251a127584c2334906f3661c3459c2d09b579 Mon Sep 17 00:00:00 2001 From: devil-ira Date: Thu, 2 Feb 2023 14:32:46 +0100 Subject: [PATCH 3/4] Reword docs --- crates/bevy_ecs/src/event.rs | 20 ++++++++------------ 1 file changed, 8 insertions(+), 12 deletions(-) diff --git a/crates/bevy_ecs/src/event.rs b/crates/bevy_ecs/src/event.rs index 61c5c288ca270..5be1f40f1e835 100644 --- a/crates/bevy_ecs/src/event.rs +++ b/crates/bevy_ecs/src/event.rs @@ -207,17 +207,15 @@ impl<'w, 's, E: Event> EventReader<'w, 's, E> { self.reader.len(&self.events) } - /// Determines if no events are available to be read without consuming any. - /// If you need to consume the iterator you can use [`EventReader::clear`]. + /// Returns `true` if there are no events available to read. /// /// # Example /// - /// The following example shows a common pattern of this function in conjunction with `clear` - /// to avoid leaking events to the next schedule iteration while also checking if it was emitted. + /// The following example shows a useful pattern where some behaviour is triggered if new events are available. + /// [`EventReader::clear()`] is used so the same events don't re-trigger the behaviour the next time the system runs. /// /// ``` /// # use bevy_ecs::prelude::*; - /// # /// struct CollisionEvent; /// /// fn play_collision_sound(mut events: EventReader) { @@ -232,14 +230,12 @@ impl<'w, 's, E: Event> EventReader<'w, 's, E> { self.reader.is_empty(&self.events) } - /// Consumes the iterator. + /// Consumes all available events. /// - /// This means all currently available events will be removed before the next frame. - /// This is useful when multiple events are sent in a single frame and you want - /// to react to one or more events without needing to know how many were sent. - /// In those situations you generally want to consume those events to make sure they don't appear in the next frame. + /// This means these events will not appear in calls to [`EventReader::iter()`] or + /// [`EventReader::iter_with_id()`] and [`EventReader::is_empty()`] will return `true`. /// - /// For more information see [`EventReader::is_empty()`]. + /// For usage, see [`EventReader::is_empty()`]. pub fn clear(&mut self) { self.reader.clear(&self.events) } @@ -362,7 +358,7 @@ impl ManualEventReader { .saturating_sub(self.last_event_count) } - /// See [`EventReader::is_empty`] + /// See [`EventReader::is_empty()`] pub fn is_empty(&self, events: &Events) -> bool { self.len(events) == 0 } From 71bce40e85e096b6fdd7077b97b31c3e0e397939 Mon Sep 17 00:00:00 2001 From: devil-ira Date: Thu, 2 Feb 2023 14:59:14 +0100 Subject: [PATCH 4/4] clippy --- crates/bevy_ecs/src/event.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/crates/bevy_ecs/src/event.rs b/crates/bevy_ecs/src/event.rs index 5be1f40f1e835..3c0b278e00238 100644 --- a/crates/bevy_ecs/src/event.rs +++ b/crates/bevy_ecs/src/event.rs @@ -237,7 +237,7 @@ impl<'w, 's, E: Event> EventReader<'w, 's, E> { /// /// For usage, see [`EventReader::is_empty()`]. pub fn clear(&mut self) { - self.reader.clear(&self.events) + self.reader.clear(&self.events); } }