pub enum JCF {
Continue,
FastForward(usize),
Exit,
}
Expand description
Control flow enum for Join
operations.
Variants§
Continue
Continue iterating permutations of matches.
FastForward(usize)
Skip permutations until the nth join is advanced to the next match. Useful for multiple
joins to avoid unnecessary permutation iteration. Fast forwarding is an O(1)
operation.
§FastForward Illustration:
use bevy::prelude::*;
use aery::prelude::*;
#[derive(Component)]
struct A;
#[derive(Component)]
struct B(usize);
#[derive(Component)]
struct C(usize);
#[derive(Component)]
struct D(usize);
#[derive(Relation)]
struct R0;
#[derive(Relation)]
struct R1;
#[derive(Relation)]
struct R2;
fn setup(world: &mut World) {
let a = world.spawn(A).id();
for n in 0..3 {
world.spawn(B(n)).set::<R0>(a);
world.spawn(C(n)).set::<R1>(a);
world.spawn(D(n)).set::<R2>(a);
}
}
fn fast_forward(
a: Query<(&A, Relations<(R0, R1, R2)>)>,
b: Query<&B>,
c: Query<&C>,
d: Query<&D>
) {
for (_, edges) in a.iter() {
edges
.join::<R0>(&b)
.join::<R1>(&c)
.join::<R2>(&d)
.for_each(|(b, c, d)| {
if c.0 == 1 { return JCF::FastForward(1) }
println!("({}, {}, {})", b.0, c.0, d.0);
JCF::Continue
});
}
}
Output:
ⓘ
(0, 0, 0)
(0, 0, 1)
(0, 0, 2)
// Skipped:
// (0, 1, 0)
// (0, 1, 1)
// (0, 1, 2)
(0, 2, 0)
(0, 2, 1)
(0, 2, 2)
(1, 0, 0)
(1, 0, 1)
(1, 0, 2)
// Skipped:
// (1, 1, 0)
// (1, 1, 1)
// (1, 1, 2)
(1, 2, 0)
(1, 2, 1)
(1, 2, 2)
(2, 0, 0)
(2, 0, 1)
(2, 0, 2)
// Skipped:
// (2, 1, 0)
// (2, 1, 1)
// (2, 1, 2)
(2, 2, 0)
(2, 2, 1)
(2, 2, 2)
Exit
Terminate the loop.
Trait Implementations§
Auto Trait Implementations§
impl RefUnwindSafe for JCF
impl Send for JCF
impl Sync for JCF
impl Unpin for JCF
impl UnwindSafe for JCF
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Convert
Box<dyn Trait>
(where Trait: Downcast
) to Box<dyn Any>
. Box<dyn Any>
can
then be further downcast
into Box<ConcreteType>
where ConcreteType
implements Trait
.§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Convert
Rc<Trait>
(where Trait: Downcast
) to Rc<Any>
. Rc<Any>
can then be
further downcast
into Rc<ConcreteType>
where ConcreteType
implements Trait
.§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
Convert
&Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &Any
’s vtable from &Trait
’s.§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
Convert
&mut Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &mut Any
’s vtable from &mut Trait
’s.