pub struct Query<Views, Filters = None, ResourceViews = Null, EntryViews = Null> { /* private fields */ }Expand description
Defines a query to be run over a world.
This defines either a regular or parallel query (parallel requires the rayon feature to be
enabled). It is essentially a marker type, simply providing the types to the calls to
query() to make the API as simple to use as possible.
§Example
use brood::{
entity,
query::{
filter,
result,
Views,
},
Query,
Registry,
World,
};
// Define components.
struct Foo(u32);
struct Bar(bool);
struct Baz(f64);
type Registry = Registry!(Foo, Bar, Baz);
let mut world = World::<Registry>::new();
world.insert(entity!(Foo(42), Bar(true), Baz(1.5)));
for result!(foo, bar) in world
.query(Query::<Views!(&mut Foo, &Bar), filter::Has<Baz>>::new())
.iter
{
// Do something.
}Implementations§
Source§impl<Views, Filters, ResourceViews, EntryViews> Query<Views, Filters, ResourceViews, EntryViews>
impl<Views, Filters, ResourceViews, EntryViews> Query<Views, Filters, ResourceViews, EntryViews>
Sourcepub fn new() -> Self
pub fn new() -> Self
Creates a new Query.
When creating a query, you must specify the views type V, and can optionally specify the
filter type F. If no filter is specified, the default filter, filter::None, will be
used.
Trait Implementations§
Source§impl<Views, Filters, ResourceViews, EntryViews> Clone for Query<Views, Filters, ResourceViews, EntryViews>
impl<Views, Filters, ResourceViews, EntryViews> Clone for Query<Views, Filters, ResourceViews, EntryViews>
Source§impl<Views, Filters, ResourceViews, EntryViews> Debug for Query<Views, Filters, ResourceViews, EntryViews>
impl<Views, Filters, ResourceViews, EntryViews> Debug for Query<Views, Filters, ResourceViews, EntryViews>
Source§impl<Views, Filters, ResourceViews, EntryViews> Default for Query<Views, Filters, ResourceViews, EntryViews>
impl<Views, Filters, ResourceViews, EntryViews> Default for Query<Views, Filters, ResourceViews, EntryViews>
Source§impl<Views, Filters, ResourceViews, EntryViews> PartialEq for Query<Views, Filters, ResourceViews, EntryViews>
impl<Views, Filters, ResourceViews, EntryViews> PartialEq for Query<Views, Filters, ResourceViews, EntryViews>
impl<Views, Filters, ResourceViews, EntryViews> Copy for Query<Views, Filters, ResourceViews, EntryViews>
impl<Views, Filters, ResourceViews, EntryViews> Eq for Query<Views, Filters, ResourceViews, EntryViews>
Auto Trait Implementations§
impl<Views, Filters, ResourceViews, EntryViews> Freeze for Query<Views, Filters, ResourceViews, EntryViews>
impl<Views, Filters, ResourceViews, EntryViews> RefUnwindSafe for Query<Views, Filters, ResourceViews, EntryViews>where
Views: RefUnwindSafe,
Filters: RefUnwindSafe,
ResourceViews: RefUnwindSafe,
EntryViews: RefUnwindSafe,
impl<Views, Filters, ResourceViews, EntryViews> Send for Query<Views, Filters, ResourceViews, EntryViews>
impl<Views, Filters, ResourceViews, EntryViews> Sync for Query<Views, Filters, ResourceViews, EntryViews>
impl<Views, Filters, ResourceViews, EntryViews> Unpin for Query<Views, Filters, ResourceViews, EntryViews>
impl<Views, Filters, ResourceViews, EntryViews> UnwindSafe for Query<Views, Filters, ResourceViews, EntryViews>
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
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more