From 5677989af355af6ab1942b4ef1e2627c103c011b Mon Sep 17 00:00:00 2001 From: Yakov Borevich Date: Sun, 10 Mar 2024 13:23:54 +0100 Subject: [PATCH] Implement MutUntyped::from(mut_typed) --- crates/bevy_ecs/src/change_detection.rs | 34 +++++++++++++++++++++++++ 1 file changed, 34 insertions(+) diff --git a/crates/bevy_ecs/src/change_detection.rs b/crates/bevy_ecs/src/change_detection.rs index 6a2fb3a9921af8..4ed7951142e870 100644 --- a/crates/bevy_ecs/src/change_detection.rs +++ b/crates/bevy_ecs/src/change_detection.rs @@ -933,6 +933,15 @@ impl std::fmt::Debug for MutUntyped<'_> { } } +impl<'w, T> From> for MutUntyped<'w> { + fn from(value: Mut<'w, T>) -> Self { + MutUntyped { + value: value.value.into(), + ticks: value.ticks, + } + } +} + #[cfg(test)] mod tests { use bevy_ecs_macros::Resource; @@ -1249,4 +1258,29 @@ mod tests { assert!(new.is_changed()); } + + #[test] + fn mut_untyped_from_mut() { + let mut component_ticks = ComponentTicks { + added: Tick::new(1), + changed: Tick::new(2), + }; + let ticks = TicksMut { + added: &mut component_ticks.added, + changed: &mut component_ticks.changed, + last_run: Tick::new(3), + this_run: Tick::new(4), + }; + let mut c = C {}; + let mut_typed = Mut { + value: &mut c, + ticks, + }; + + let into_mut: MutUntyped = mut_typed.into(); + assert_eq!(1, into_mut.ticks.added.get()); + assert_eq!(2, into_mut.ticks.changed.get()); + assert_eq!(3, into_mut.ticks.last_run.get()); + assert_eq!(4, into_mut.ticks.this_run.get()); + } }