Struct specs::world::EntitiesRes

source ·
pub struct EntitiesRes { /* private fields */ }
Expand description

The entities of this ECS. This is a resource, stored in the World. If you just want to access it in your system, you can also use the Entities type def.

Please note that you should never get this mutably in a system, because it would block all the other systems.

You need to call World::maintain after creating / deleting entities with this struct.

Implementations§

source§

impl EntitiesRes

source

pub fn create(&self) -> Entity

Creates a new entity atomically. This will be persistent as soon as you call World::maintain.

If you want a lazy entity builder, take a look at LazyUpdate::create_entity.

In case you have access to the World, you can also use World::create_entity which creates the entity and the components immediately.

source

pub fn create_iter(&self) -> CreateIterAtomic<'_>

Returns an iterator which creates new entities atomically. They will be persistent as soon as you call World::maintain.

source

pub fn build_entity(&self) -> EntityResBuilder<'_>

Similar to the create method above this creates an entity atomically, and then returns a builder which can be used to insert components into various storages if available.

source

pub fn delete(&self, e: Entity) -> Result<(), WrongGeneration>

Deletes an entity atomically. The associated components will be deleted as soon as you call World::maintain.

source

pub fn entity(&self, id: Index) -> Entity

Returns an entity with a given id. There’s no guarantee for validity, meaning the entity could be not alive.

source

pub fn is_alive(&self, e: Entity) -> bool

Returns true if the specified entity is alive.

Trait Implementations§

source§

impl Debug for EntitiesRes

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Default for EntitiesRes

source§

fn default() -> EntitiesRes

Returns the “default value” for a type. Read more
source§

impl<'a> Join for &'a EntitiesRes

§

type Mask = BitSetOr<&'a BitSet, &'a AtomicBitSet>

Type of joined bit mask.
§

type Type = Entity

Type of joined components.
§

type Value = &'a EntitiesRes

Type of joined storages.
source§

unsafe fn open(self) -> (Self::Mask, Self::Value)

Open this join by returning the mask and the storages. Read more
source§

unsafe fn get(v: &mut &'a EntitiesRes, id: Index) -> Entity

Get a joined component value by a given index. Read more
source§

fn join(self) -> JoinIter<Self> where Self: Sized,

Create a joined iterator over the contents.
source§

fn is_unconstrained() -> bool

If this Join typically returns all indices in the mask, then iterating over only it or combined with other joins that are also dangerous will cause the JoinIter to go through all indices which is usually not what is wanted and will kill performance.
source§

impl<'a> LendJoin for &'a EntitiesRes

§

type Mask = BitSetOr<&'a BitSet, &'a AtomicBitSet>

Type of joined bit mask.
§

type Value = &'a EntitiesRes

Type of joined storages.
source§

unsafe fn open(self) -> (Self::Mask, Self::Value)

Open this join by returning the mask and the storages. Read more
source§

unsafe fn get<'next>(v: &'next mut &'a EntitiesRes, id: Index) -> Entity

Get a joined component value by a given index. Read more
source§

fn lend_join(self) -> JoinLendIter<Self>where Self: Sized,

Create a joined lending iterator over the contents.
source§

fn maybe(self) -> MaybeJoin<Self>where Self: Sized,

Returns a structure that implements Join/LendJoin/MaybeJoin if the contained T does and that yields all indices, returning None for all missing elements and Some(T) for found elements. Read more
source§

fn is_unconstrained() -> bool

If this LendJoin typically returns all indices in the mask, then iterating over only it or combined with other joins that are also dangerous will cause the JoinLendIter to go through all indices which is usually not what is wanted and will kill performance.
source§

impl<'a> ParJoin for &'a EntitiesRes

§

type Mask = BitSetOr<&'a BitSet, &'a AtomicBitSet>

Type of joined bit mask.
§

type Type = Entity

Type of joined components.
§

type Value = &'a EntitiesRes

Type of joined storages.
source§

unsafe fn open(self) -> (Self::Mask, Self::Value)

Open this join by returning the mask and the storages. Read more
source§

unsafe fn get(v: &&'a EntitiesRes, id: Index) -> Entity

Get a joined component value by a given index. Read more
source§

fn par_join(self) -> JoinParIter<Self>where Self: Sized,

Create a joined parallel iterator over the contents.
source§

fn is_unconstrained() -> bool

If this LendJoin typically returns all indices in the mask, then iterating over only it or combined with other joins that are also dangerous will cause the JoinLendIter to go through all indices which is usually not what is wanted and will kill performance.
source§

impl<'a> RepeatableLendGet for &'a EntitiesRes

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for Twhere T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for Twhere U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

§

impl<T> Pointable for T

§

const ALIGN: usize = _

The alignment of pointer.
§

type Init = T

The type for initializers.
§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
source§

impl<T> TryDefault for Twhere T: Default,

source§

fn try_default() -> Result<T, String>

Tries to create the default.
source§

fn unwrap_default() -> Self

Calls try_default and panics on an error case.
source§

impl<T, U> TryFrom<U> for Twhere U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for Twhere U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
source§

impl<T> Event for Twhere T: Send + Sync + 'static,

source§

impl<T> Resource for Twhere T: Any + Send + Sync,