pub struct AllBodies<BodyMeta, SpeciesMeta> {
Show 18 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>>,
}
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>>

Implementations§

source§

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

source

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§

source§

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

§

type Loader = RonLoader

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

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). If so, you may want to implement [NotHotReloaded] for this type to enable additional functions.
source§

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

source§

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

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

source§

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

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

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

source§

fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>
where __D: Deserializer<'de>,

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

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

fn index(&self, index: &Body) -> &Self::Output

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

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

fn index(&self, index: NpcKind) -> &Self::Output

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

Auto Trait Implementations§

§

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

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

source§

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

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

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

source§

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

source§

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

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

source§

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

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
§

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). If so, you may want to implement [NotHotReloaded] for this type to enable additional functions.
§

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.

§

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<T> Storable for T
where T: Compound,

§

fn get_type<P>() -> Type
where P: PrivateMarker,

source§

impl<Context> SubContext<Context> for Context

source§

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,