pub struct AllBodies<BodyMeta, SpeciesMeta> {
Show 19 fields pub humanoid: BodyData<BodyMeta, AllSpecies<SpeciesMeta>>, pub quadruped_small: BodyData<BodyMeta, AllSpecies<SpeciesMeta>>, pub quadruped_medium: BodyData<BodyMeta, AllSpecies<SpeciesMeta>>, pub bird_medium: BodyData<BodyMeta, AllSpecies<SpeciesMeta>>, pub fish_medium: BodyData<BodyMeta, AllSpecies<SpeciesMeta>>, pub dragon: BodyData<BodyMeta, AllSpecies<SpeciesMeta>>, pub bird_large: BodyData<BodyMeta, AllSpecies<SpeciesMeta>>, pub fish_small: BodyData<BodyMeta, AllSpecies<SpeciesMeta>>, pub biped_large: BodyData<BodyMeta, AllSpecies<SpeciesMeta>>, pub biped_small: BodyData<BodyMeta, AllSpecies<SpeciesMeta>>, pub object: BodyData<BodyMeta, ()>, pub item_drop: BodyData<BodyMeta, ()>, pub golem: BodyData<BodyMeta, AllSpecies<SpeciesMeta>>, pub theropod: BodyData<BodyMeta, AllSpecies<SpeciesMeta>>, pub quadruped_low: BodyData<BodyMeta, AllSpecies<SpeciesMeta>>, pub ship: BodyData<BodyMeta, ()>, pub arthropod: BodyData<BodyMeta, AllSpecies<SpeciesMeta>>, pub crustacean: BodyData<BodyMeta, AllSpecies<SpeciesMeta>>, pub plugin: BodyData<BodyMeta, AllSpecies<SpeciesMeta>>,
}
Expand description

Metadata intended to be stored per-body, together with data intended to be stored for each species for each body.

NOTE: Deliberately don’t (yet?) implement serialize. NOTE: If you are adding new body kind and it should be spawned via /spawn please add it to [ENTITIES](crate::cmd::ENTITIES)

Fields§

§humanoid: BodyData<BodyMeta, AllSpecies<SpeciesMeta>>§quadruped_small: BodyData<BodyMeta, AllSpecies<SpeciesMeta>>§quadruped_medium: BodyData<BodyMeta, AllSpecies<SpeciesMeta>>§bird_medium: BodyData<BodyMeta, AllSpecies<SpeciesMeta>>§fish_medium: BodyData<BodyMeta, AllSpecies<SpeciesMeta>>§dragon: BodyData<BodyMeta, AllSpecies<SpeciesMeta>>§bird_large: BodyData<BodyMeta, AllSpecies<SpeciesMeta>>§fish_small: BodyData<BodyMeta, AllSpecies<SpeciesMeta>>§biped_large: BodyData<BodyMeta, AllSpecies<SpeciesMeta>>§biped_small: BodyData<BodyMeta, AllSpecies<SpeciesMeta>>§object: BodyData<BodyMeta, ()>§item_drop: BodyData<BodyMeta, ()>§golem: BodyData<BodyMeta, AllSpecies<SpeciesMeta>>§theropod: BodyData<BodyMeta, AllSpecies<SpeciesMeta>>§quadruped_low: BodyData<BodyMeta, AllSpecies<SpeciesMeta>>§ship: BodyData<BodyMeta, ()>§arthropod: BodyData<BodyMeta, AllSpecies<SpeciesMeta>>§crustacean: BodyData<BodyMeta, AllSpecies<SpeciesMeta>>§plugin: BodyData<BodyMeta, AllSpecies<SpeciesMeta>>

Implementations§

§

impl<BodyMeta, SpeciesMeta> AllBodies<BodyMeta, SpeciesMeta>

pub fn get_species_meta<'a>(&'a self, body: &Body) -> Option<&'a SpeciesMeta>

Get species meta associated with the body.

Returns None if the body doesn’t have any associated meta, i.e ships, objects, itemdrops.

Trait Implementations§

§

impl<BodyMeta, SpeciesMeta> Asset for AllBodies<BodyMeta, SpeciesMeta>
where BodyMeta: Send + Sync + for<'de> Deserialize<'de> + 'static, SpeciesMeta: Send + Sync + for<'de> Deserialize<'de> + 'static,

§

type Loader = RonLoader

Specifies a way to convert raw bytes into the asset. Read more
§

const EXTENSION: &'static str = "ron"

Use this field if your asset only uses one extension. Read more
§

const EXTENSIONS: &'static [&'static str] = _

This field enables you to specify multiple extension for an asset. Read more
§

fn default_value( id: &SharedString, error: Box<dyn Error + Send + Sync>, ) -> Result<Self, Box<dyn Error + Send + Sync>>

Specifies a eventual default value to use if an asset fails to load. If this method returns Ok, the returned value is used as an asset. In particular, if this method always returns Ok, AssetCache::load is guaranteed not to fail. Read more
§

const HOT_RELOADED: bool = true

If false, disable hot-reloading for assets of this type (true by default). This avoids having to lock the asset to read it (ie it makes [Handle::read] a noop)
§

impl<BodyMeta, SpeciesMeta> Clone for AllBodies<BodyMeta, SpeciesMeta>
where BodyMeta: Clone, SpeciesMeta: Clone,

§

fn clone(&self) -> AllBodies<BodyMeta, SpeciesMeta>

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
§

impl<BodyMeta, SpeciesMeta> Debug for AllBodies<BodyMeta, SpeciesMeta>
where BodyMeta: Debug, SpeciesMeta: Debug,

§

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

Formats the value using the given formatter. Read more
§

impl<'de, BodyMeta, SpeciesMeta> Deserialize<'de> for AllBodies<BodyMeta, SpeciesMeta>
where BodyMeta: Deserialize<'de>, SpeciesMeta: Deserialize<'de>,

§

fn deserialize<__D>( __deserializer: __D, ) -> Result<AllBodies<BodyMeta, SpeciesMeta>, <__D as Deserializer<'de>>::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
§

impl<'a, BodyMeta, SpeciesMeta> Index<&'a Body> for AllBodies<BodyMeta, SpeciesMeta>

Can only retrieve body metadata by direct index.

§

type Output = BodyMeta

The returned type after indexing.
§

fn index( &self, index: &Body, ) -> &<AllBodies<BodyMeta, SpeciesMeta> as Index<&'a Body>>::Output

Performs the indexing (container[index]) operation. Read more
§

impl<BodyMeta, SpeciesMeta> Index<NpcKind> for AllBodies<BodyMeta, SpeciesMeta>

Can only retrieve body metadata by direct index.

§

type Output = BodyMeta

The returned type after indexing.
§

fn index( &self, index: NpcKind, ) -> &<AllBodies<BodyMeta, SpeciesMeta> as Index<NpcKind>>::Output

Performs the indexing (container[index]) operation. Read more

Auto Trait Implementations§

§

impl<BodyMeta, SpeciesMeta> Freeze for AllBodies<BodyMeta, SpeciesMeta>
where BodyMeta: Freeze, SpeciesMeta: Freeze,

§

impl<BodyMeta, SpeciesMeta> RefUnwindSafe for AllBodies<BodyMeta, SpeciesMeta>
where BodyMeta: RefUnwindSafe, SpeciesMeta: RefUnwindSafe,

§

impl<BodyMeta, SpeciesMeta> Send for AllBodies<BodyMeta, SpeciesMeta>
where BodyMeta: Send, SpeciesMeta: Send,

§

impl<BodyMeta, SpeciesMeta> Sync for AllBodies<BodyMeta, SpeciesMeta>
where BodyMeta: Sync, SpeciesMeta: Sync,

§

impl<BodyMeta, SpeciesMeta> Unpin for AllBodies<BodyMeta, SpeciesMeta>
where BodyMeta: Unpin, SpeciesMeta: Unpin,

§

impl<BodyMeta, SpeciesMeta> UnwindSafe for AllBodies<BodyMeta, SpeciesMeta>
where BodyMeta: UnwindSafe, SpeciesMeta: UnwindSafe,

Blanket Implementations§

source§

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

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

impl<T> AssetExt for T
where T: Compound,

§

fn load(specifier: &str) -> Result<&'static Handle<T>, Error>

Function used to load assets from the filesystem or the cache. Example usage: Read more
§

fn load_owned(specifier: &str) -> Result<T, Error>

§

fn get_or_insert(specifier: &str, default: T) -> &'static Handle<T>

§

fn load_cloned(specifier: &str) -> Result<Self, Error>
where Self: Clone,

Function used to load assets from the filesystem or the cache and return a clone.
§

fn load_or_insert_with( specifier: &str, default: impl FnOnce(Error) -> Self, ) -> &'static Handle<Self>

§

fn load_expect(specifier: &str) -> &'static Handle<Self>

Function used to load essential assets from the filesystem or the cache. It will panic if the asset is not found. Example usage: Read more
§

fn load_expect_cloned(specifier: &str) -> Self
where Self: Clone,

Function used to load essential assets from the filesystem or the cache and return a clone. It will panic if the asset is not found.
source§

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

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

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

source§

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

Mutably borrows from an owned value. Read more
source§

impl<T> CloneToUninit for T
where T: Clone,

source§

default unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
§

impl<T> Compound for T
where T: Asset,

§

fn load( cache: AnyCache<'_>, id: &SharedString, ) -> Result<T, Box<dyn Error + Send + Sync>>

Loads an asset from the cache. Read more
§

const HOT_RELOADED: bool = Self::HOT_RELOADED

If false, disable hot-reloading for assets of this type (true by default). This avoids having to lock the asset to read it (ie it makes [Handle::read] a noop)
§

impl<T> DirLoadable for T
where T: Asset,

§

fn select_ids( cache: AnyCache<'_>, id: &SharedString, ) -> Result<Vec<SharedString>, Error>

Returns the ids of the assets contained in the directory given by id. Read more
§

fn sub_directories( cache: AnyCache<'_>, id: &SharedString, f: impl FnMut(&str), ) -> Result<(), Error>

Executes the given closure for each id of a child directory of the given directory. The default implementation reads the cache’s source.
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided [Span], returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
source§

impl<T, U> Into<U> for T
where 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.

source§

impl<T> IntoEither for T

source§

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 more
source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

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
§

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> Same for T

§

type Output = T

Should always be Self
§

impl<Context> SubContext<Context> for Context

§

fn sub_context(self) -> Context

source§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T, U> TryFrom<U> for T
where 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 T
where 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.
§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V

§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a [WithDispatch] wrapper. Read more
source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,

§

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

§

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

§

impl<T> Storable for T
where T: Send + Sync + 'static,