diff --git a/agb/src/lib.rs b/agb/src/lib.rs index 58538e70..4127aa80 100644 --- a/agb/src/lib.rs +++ b/agb/src/lib.rs @@ -6,7 +6,6 @@ #![feature(alloc_error_handler)] #![test_runner(crate::test_runner)] #![reexport_test_harness_main = "test_main"] -#![feature(step_trait)] //! # agb //! `agb` is a library for making games on the Game Boy Advance using the Rust //! programming language. It attempts to be a high level abstraction over the diff --git a/agb/src/number.rs b/agb/src/number.rs index 0524a11e..5983a065 100644 --- a/agb/src/number.rs +++ b/agb/src/number.rs @@ -862,18 +862,52 @@ impl Rect { } } -impl Rect { +impl Rect { pub fn iter(self) -> impl Iterator { - (self.position.x..=(self.position.x + self.size.x)) - .into_iter() - .flat_map(move |x| { - (self.position.y..=(self.position.y + self.size.y)) - .into_iter() - .map(move |y| (x, y)) - }) + let mut x = self.position.x - T::one(); + let mut y = self.position.y; + core::iter::from_fn(move || { + x = x + T::one(); + if x > self.position.x + self.size.x { + x = self.position.x; + y = y + T::one(); + if y > self.position.y + self.size.y { + return None; + } + } + + Some((x, y)) + }) } } +#[cfg(test)] +#[test_case] +fn test_rect_iter(_gba: &mut crate::Gba) { + let rect: Rect = Rect::new((5_i32, 5_i32).into(), (3_i32, 3_i32).into()); + assert_eq!( + rect.iter().collect::>(), + &[ + (5, 5), + (6, 5), + (7, 5), + (8, 5), + (5, 6), + (6, 6), + (7, 6), + (8, 6), + (5, 7), + (6, 7), + (7, 7), + (8, 7), + (5, 8), + (6, 8), + (7, 8), + (8, 8), + ] + ); +} + impl Vector2D { pub fn new(x: T, y: T) -> Self { Vector2D { x, y }