Struct game_library::Attribute

source ·
pub struct Attribute {
    pub max: u32,
    pub current: u32,
}
Expand description

Attribute component. This is a simple integer representing the attribute of an entity. Has properties like max_attribute and current_attribute. We support operations with integers, floats, and other Attribute components.

We use positive integers for attribute, and negative integers for damage. There’s no reason to support negative attribute and negative max_attribute, so we don’t. We also won’t allow current_attribute to be greater than max_attribute.

Because we use integers, we can’t represent fractional attribute. It’s a bit of a tradeoff, but it’s a design decision (and I guess it can be changed later at great effort).

All operations that are performed directly between a Attribute component and another value will use the current_attribute value. For example, if you add a Attribute component with current_attribute of 10 to a Attribute component with current_attribute of 20, the result will be a Attribute component with current_attribute of 30. This holds true for all operations (addition, subtraction, multiplication, division, etc.).

What is supported:

  • Affecting (adding/subtracting) attribute with integers, floats, and other Attribute components.
  • Scaling the current attribute with integers, floats, and other Attribute components
  • Scaling the max attribute with integers, floats, and other Attribute components
  • Scaling the current attribute by a percentage of the max attribute (with integers, floats, and other Attribute components)
  • Comparing attribute with integers, floats, and other Attribute components.
  • Getting the percentage of attribute remaining (as a rounded integer between 0 and 100 OR a precise float between 0 and 1).
  • Check is_empty to see if the entity is dead (i.e. current_attribute is 0).
  • Check is_full to see if the entity is at full attribute (i.e. current_attribute is equal to max_attribute).

Fields§

§max: u32

The maximum value for the attribute of the entity

§current: u32

The current value for the attribute of the entity

Implementations§

source§

impl Attribute

source

pub const MIN: u32 = 0u32

Minimum value is 0

source

pub const fn is_empty(&self) -> bool

Returns true if the current attribute is equal to 0

Examples
use game_library::Attribute;

let mut attribute = Attribute::new(10_u32);
assert_eq!(attribute.is_empty(), false);

attribute.set(0_u32);
assert_eq!(attribute.is_empty(), true);
source

pub const fn is_full(&self) -> bool

Returns true if the current attribute is equal to the max attribute.

Note

If max attribute is 0, this will always return true (because current attribute will always be 0 if max attribute is 0)

Examples
use game_library::Attribute;

let mut attribute = Attribute::new(10_u32);
assert_eq!(attribute.is_full(), true);

attribute.set(0_u32);
assert_eq!(attribute.is_full(), false);

attribute.set_max(0_u32);
assert_eq!(attribute.is_full(), true);
source

pub fn remaining(&self) -> f32

Returns the percentage of attribute remaining as a float between 0.00 and 1.00

Note

This will always return 1.00 if max attribute is 0 (because current attribute will always be 0 if max attribute is 0)

Examples
use game_library::Attribute;

let mut attribute = Attribute::new(10_u32);
assert_eq!(attribute.remaining(), 1.0);

attribute.set(5_u32);
assert_eq!(attribute.remaining(), 0.5);

attribute.set(0_u32);
assert_eq!(attribute.remaining(), 0.0);

attribute.set_max(0_u32);
assert_eq!(attribute.remaining(), 1.0);
source

pub fn percentage_remaining(&self) -> u32

Returns the percentage of attribute remaining as an integer between 0% and 100%

Note

This will always return 100% if max attribute is 0 (because current attribute will always be 0 if max attribute is 0)

Examples
use game_library::Attribute;

let mut attribute = Attribute::new(10_u32);
assert_eq!(attribute.percentage_remaining(), 100);

attribute.set(5_u32);
assert_eq!(attribute.percentage_remaining(), 50);

attribute.set(0_u32);
assert_eq!(attribute.percentage_remaining(), 0);

attribute.set_max(0_u32);
assert_eq!(attribute.percentage_remaining(), 100);
source

pub fn new(max_attribute: impl Into<u32>) -> Self

Creates a new Attribute component with the given max_attribute and current_attribute.

Arguments
  • max_attribute - The maximum attribute of the entity. This will be converted into a u32 and clamped
Returns
  • Self - The new Attribute component
Examples
use game_library::Attribute;

let attribute = Attribute::new(10_u32);
source

pub fn new_with_current( current_attribute: impl Into<u32>, max_attribute: impl Into<u32> ) -> Self

Creates a new Attribute component with the given max_attribute and current_attribute.

Arguments
  • current_attribute - The current attribute of the entity. This will be converted into a u32 and clamped
  • max_attribute - The maximum attribute of the entity. This will be converted into a u32 and clamped
Returns
  • Self - The new Attribute component
Examples
use game_library::Attribute;

let attribute = Attribute::new_with_current(5_u32, 10_u32);

assert_eq!(attribute.current, 5_u32);
assert_eq!(attribute.max, 10_u32);
source

pub fn add_to_max(&mut self, amount: impl Into<i64>)

Adds the given amount to the max attribute, while clamping max attribute within acceptable bounds. Also ensures that current_attribute is not greater than max_attribute (in cases where a negative amount is added here).

Arguments
  • amount - The amount to add to the max attribute. This can be a positive or negative number, which will increase or decrease the max attribute respectively.
Examples
use game_library::Attribute;

let mut attribute = Attribute::new(10_u32);

attribute.add_to_max(5);
assert_eq!(attribute.max, 15_u32);
assert_eq!(attribute.current, 10_u32);

attribute.add_to_max(-5);
assert_eq!(attribute.max, 10_u32);
assert_eq!(attribute.current, 10_u32);

attribute.set(15_u32);
attribute.add_to_max(25);
assert_eq!(attribute.max, 35_u32);
assert_eq!(attribute.current, 10_u32);
source

pub fn scale_max(&mut self, amount: impl Into<f64> + PartialOrd<f64>)

Scales the max attribute by the given amount, while clamping max attribute within acceptable bounds. Also ensures that current_attribute is not greater than max_attribute (in cases where the scale value is less than 1; i.e. the max attribute is decreased).

Arguments
  • amount - The amount to scale the max attribute by. This should be a positive number. See the sister function scale_max_attribute_by_percentage for a function that takes a percentage (integer value).
Note
  • Really large numbers will just cause max attribute to be set to Attribute::MAX.
  • Negative numbers will cause max attribute to be set to 0.
  • This is a sister function to scale_max_attribute_by_percentage which takes a percentage value instead
Examples
use game_library::Attribute;

let mut attribute = Attribute::new(10_u32);

attribute.scale_max(2.0);
assert_eq!(attribute.max, 20_u32);
assert_eq!(attribute.current, 10_u32);

attribute.scale_max(0.5);
assert_eq!(attribute.max, 10_u32);
assert_eq!(attribute.current, 10_u32);
source

pub fn scale_max_by_percentage(&mut self, amount: impl Into<i32>)

Scales the max attribute by the given percentage, while clamping max attribute within acceptable bounds. Also ensures that current_attribute is not greater than max_attribute (in cases where the scale value is less than 100; i.e. the max attribute is decreased).

Arguments
  • amount - The percentage to scale the max attribute by. This should be a positive number. Really large numbers will just cause max attribute to be set to u32::MAX.
Note
  • Really large numbers will just cause max attribute to be set to Attribute::MAX.
  • Negative numbers will cause max attribute to be set to 0.
  • This is a sister function to scale_max_attribute which takes a float value instead of a percentage.
Examples
use game_library::Attribute;

let mut attribute = Attribute::new(10_u32);

attribute.scale_max_by_percentage(200);
assert_eq!(attribute.max, 20_u32);
assert_eq!(attribute.current, 10_u32);

attribute.scale_max_by_percentage(50);
assert_eq!(attribute.max, 10_u32);
assert_eq!(attribute.current, 10_u32);
source

pub fn add_to_current(&mut self, amount: impl Into<i64>)

Adds the given amount to the current attribute, while clamping current attribute within acceptable bounds. (i.e. between 0 and max_attribute). This will not affect max_attribute.

Arguments
  • amount - The amount to add to the current attribute. This can be a positive or negative number, which will increase or decrease the current attribute respectively.
Examples
use game_library::Attribute;

let mut attribute = Attribute::new_with_current(5_u32, 10_u32);

assert_eq!(attribute.current, 5_u32);

attribute.add_to_current(5);

assert_eq!(attribute.current, 10_u32);
source

pub fn scale_current(&mut self, amount: impl Into<f64> + PartialOrd<f64>)

Scales the current attribute by the given amount, while clamping current attribute within acceptable bounds. (i.e. between 0 and max_attribute). This will not affect max_attribute. This takes a float value; e.g., 0.5 will scale the current attribute by 50% (i.e. half the current attribute), while 2.0 will scale the current attribute by 200% (i.e. double the current attribute).

There’s a similar function add_to_current_attribute_by_scale_max_attribute which applies the same logic but uses the max_attribute as the scale value to arrive at an amount to change the current attribute by.

Arguments
  • amount - The amount to scale the current attribute by. This should be a positive number. See the sister function scale_current_attribute_by_percentage for a function that takes a percentage (integer value).
Examples
use game_library::Attribute;

let mut attribute = Attribute::new_with_current(5_u32, 10_u32);

assert_eq!(attribute.current, 5_u32);

attribute.scale_current(2.0);

assert_eq!(attribute.current, 10_u32);
source

pub fn scale_current_by_percentage(&mut self, amount: impl Into<i32>)

Scales the current attribute by the given percentage, while clamping current attribute within acceptable bounds.

There’s a similar function add_to_current_attribute_by_scale_max_attribute_percentage which applies the same logic but uses the max_attribute as the scale value to arrive at an amount to change the current attribute by.

Arguments
  • amount - The percentage to scale the current attribute by. This should be a positive number. Really large numbers will just cause current attribute to be set to u32::MAX.
Examples
use game_library::Attribute;

let mut attribute = Attribute::new_with_current(5_u32, 10_u32);

assert_eq!(attribute.current, 5_u32);

attribute.scale_current_by_percentage(200);

assert_eq!(attribute.current, 10_u32);
source

pub fn add_to_current_by_scale_max( &mut self, amount: impl Into<f64> + PartialOrd<f64> )

Adds to current attribute by scaling the max_attribute by the given amount, while clamping current attribute within acceptable bounds. (i.e. between 0 and max_attribute). This will not affect max_attribute. This takes a float and expects negatives to be used to decrease the current attribute, and positives to be used to increase the current attribute.

There’s a similar function scale_current_attribute_by_scale_max_attribute_percentage which applies the same logic but expects a percentage value (e.g. 50) instead of a float (e.g. 0.5).

Arguments
  • amount - The amount to scale the max attribute by. If this is positive, the current attribute will increase. If this is negative, the current attribute will decrease.
Examples
use game_library::Attribute;

let mut attribute = Attribute::new_with_current(5_u32, 100_u32);

assert_eq!(attribute.current, 5_u32);
assert_eq!(attribute.max, 100_u32);

attribute.add_to_current_by_scale_max(0.05);

assert_eq!(attribute.current, 10_u32);
assert_eq!(attribute.max, 100_u32);
source

pub fn add_to_current_by_scale_max_percentage(&mut self, amount: impl Into<i32>)

Adds to current attribute by scaling the max_attribute by the given percentage, while clamping current attribute within acceptable bounds. (i.e. between 0 and max_attribute). This will not affect max_attribute. This takes a percentage and expects negatives to be used to decrease the current attribute, and positives to be used to increase the current attribute.

There’s a similar function add_to_current_attribute_by_scale_max_attribute which applies the same logic but expects a float value (e.g. 0.5) instead of a percentage (e.g. 50).

Arguments
  • amount - The percentage to scale the max attribute by. If this is positive, the current attribute will increase. If this is negative, the current attribute will decrease.
Examples
use game_library::Attribute;

let mut attribute = Attribute::new_with_current(5_u32, 100_u32);

assert_eq!(attribute.current, 5_u32);
assert_eq!(attribute.max, 100_u32);

attribute.add_to_current_by_scale_max_percentage(20);

assert_eq!(attribute.current, 25_u32);
assert_eq!(attribute.max, 100_u32);
source

pub fn set(&mut self, value: impl Into<u32>)

Set the current value directly.

Arguments
  • value - The value to set the current attribute to. This will be clamped between 0 and max_attribute.
Examples
use game_library::Attribute;

let mut attribute = Attribute::new(10_u32);

assert_eq!(attribute.current, 10_u32);
assert_eq!(attribute.max, 10_u32);

attribute.set(5_u32);
assert_eq!(attribute.current, 5_u32);
assert_eq!(attribute.max, 10_u32);
source

pub fn set_max(&mut self, value: impl Into<u32>)

Set the max value directly.

Arguments
  • value - The value to set the max attribute to. This will be clamped between 0 and u32::MAX.
Examples
use game_library::Attribute;

let mut attribute = Attribute::new(10_u32);

assert_eq!(attribute.current, 10_u32);
assert_eq!(attribute.max, 10_u32);

attribute.set_max(5_u32);

assert_eq!(attribute.current, 5_u32);
assert_eq!(attribute.max, 5_u32);

attribute.set_max(10_u32);

assert_eq!(attribute.current, 5_u32);
assert_eq!(attribute.max, 10_u32);

Trait Implementations§

source§

impl AddAssign<f32> for Attribute

source§

fn add_assign(&mut self, rhs: f32)

Performs the += operation. Read more
source§

impl AddAssign<f64> for Attribute

source§

fn add_assign(&mut self, rhs: f64)

Performs the += operation. Read more
source§

impl AddAssign<i32> for Attribute

source§

fn add_assign(&mut self, rhs: i32)

Performs the += operation. Read more
source§

impl AddAssign<u32> for Attribute

source§

fn add_assign(&mut self, rhs: u32)

Performs the += operation. Read more
source§

impl AddAssign for Attribute

source§

fn add_assign(&mut self, rhs: Self)

Performs the += operation. Read more
source§

impl Clone for Attribute

source§

fn clone(&self) -> Attribute

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 Component for Attribute
where Self: Send + Sync + 'static,

§

type Storage = TableStorage

A marker type indicating the storage type used for this component. This must be either [TableStorage] or [SparseStorage].
source§

impl Debug for Attribute

source§

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

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

impl Default for Attribute

source§

fn default() -> Attribute

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

impl<'de> Deserialize<'de> for Attribute

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 Display for Attribute

source§

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

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

impl DivAssign<f32> for Attribute

source§

fn div_assign(&mut self, rhs: f32)

Performs the /= operation. Read more
source§

impl DivAssign<f64> for Attribute

source§

fn div_assign(&mut self, rhs: f64)

Performs the /= operation. Read more
source§

impl DivAssign<i32> for Attribute

source§

fn div_assign(&mut self, rhs: i32)

Performs the /= operation. Read more
source§

impl DivAssign<u32> for Attribute

source§

fn div_assign(&mut self, rhs: u32)

Performs the /= operation. Read more
source§

impl DivAssign for Attribute

source§

fn div_assign(&mut self, rhs: Self)

Performs the /= operation. Read more
source§

impl From<Attribute> for f32

source§

fn from(value: Attribute) -> Self

Converts to this type from the input type.
source§

impl From<Attribute> for f64

source§

fn from(value: Attribute) -> Self

Converts to this type from the input type.
source§

impl From<Attribute> for i16

source§

fn from(value: Attribute) -> Self

Converts to this type from the input type.
source§

impl From<Attribute> for i32

source§

fn from(value: Attribute) -> Self

Converts to this type from the input type.
source§

impl From<Attribute> for i64

source§

fn from(value: Attribute) -> Self

Converts to this type from the input type.
source§

impl From<Attribute> for i8

source§

fn from(value: Attribute) -> Self

Converts to this type from the input type.
source§

impl From<Attribute> for u16

source§

fn from(value: Attribute) -> Self

Converts to this type from the input type.
source§

impl From<Attribute> for u32

source§

fn from(value: Attribute) -> Self

Converts to this type from the input type.
source§

impl From<Attribute> for u64

source§

fn from(value: Attribute) -> Self

Converts to this type from the input type.
source§

impl From<Attribute> for u8

source§

fn from(value: Attribute) -> Self

Converts to this type from the input type.
source§

impl From<f32> for Attribute

source§

fn from(value: f32) -> Self

Converts to this type from the input type.
source§

impl From<f64> for Attribute

source§

fn from(value: f64) -> Self

Converts to this type from the input type.
source§

impl From<i16> for Attribute

source§

fn from(value: i16) -> Self

Converts to this type from the input type.
source§

impl From<i32> for Attribute

source§

fn from(value: i32) -> Self

Converts to this type from the input type.
source§

impl From<i64> for Attribute

source§

fn from(value: i64) -> Self

Converts to this type from the input type.
source§

impl From<i8> for Attribute

source§

fn from(value: i8) -> Self

Converts to this type from the input type.
source§

impl From<u16> for Attribute

source§

fn from(value: u16) -> Self

Converts to this type from the input type.
source§

impl From<u32> for Attribute

source§

fn from(value: u32) -> Self

Converts to this type from the input type.
source§

impl From<u64> for Attribute

source§

fn from(value: u64) -> Self

Converts to this type from the input type.
source§

impl From<u8> for Attribute

source§

fn from(value: u8) -> Self

Converts to this type from the input type.
source§

impl FromReflect for Attribute
where u32: FromReflect + TypePath,

source§

fn from_reflect(reflect: &dyn Reflect) -> Option<Self>

Constructs a concrete instance of Self from a reflected value.
§

fn take_from_reflect( reflect: Box<dyn Reflect> ) -> Result<Self, Box<dyn Reflect>>

Attempts to downcast the given value to Self using, constructing the value using from_reflect if that fails. Read more
source§

impl FromType<Attribute> for InspectorOptions

source§

fn from_type() -> Self

source§

impl GetTypeRegistration for Attribute
where u32: FromReflect + TypePath,

source§

fn get_type_registration() -> TypeRegistration

source§

impl MulAssign<f32> for Attribute

source§

fn mul_assign(&mut self, rhs: f32)

Performs the *= operation. Read more
source§

impl MulAssign<f64> for Attribute

source§

fn mul_assign(&mut self, rhs: f64)

Performs the *= operation. Read more
source§

impl MulAssign<i32> for Attribute

source§

fn mul_assign(&mut self, rhs: i32)

Performs the *= operation. Read more
source§

impl MulAssign<u32> for Attribute

source§

fn mul_assign(&mut self, rhs: u32)

Performs the *= operation. Read more
source§

impl MulAssign for Attribute

source§

fn mul_assign(&mut self, rhs: Self)

Performs the *= operation. Read more
source§

impl Ord for Attribute

source§

fn cmp(&self, other: &Self) -> Ordering

This method returns an Ordering between self and other. Read more
1.21.0 · source§

fn max(self, other: Self) -> Self
where Self: Sized,

Compares and returns the maximum of two values. Read more
1.21.0 · source§

fn min(self, other: Self) -> Self
where Self: Sized,

Compares and returns the minimum of two values. Read more
1.50.0 · source§

fn clamp(self, min: Self, max: Self) -> Self
where Self: Sized + PartialOrd,

Restrict a value to a certain interval. Read more
source§

impl PartialEq<u32> for Attribute

source§

fn eq(&self, other: &u32) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl PartialEq for Attribute

source§

fn eq(&self, other: &Self) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl PartialOrd for Attribute

source§

fn partial_cmp(&self, other: &Self) -> Option<Ordering>

This method returns an ordering between self and other values if one exists. Read more
1.0.0 · source§

fn lt(&self, other: &Rhs) -> bool

This method tests less than (for self and other) and is used by the < operator. Read more
1.0.0 · source§

fn le(&self, other: &Rhs) -> bool

This method tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 · source§

fn gt(&self, other: &Rhs) -> bool

This method tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 · source§

fn ge(&self, other: &Rhs) -> bool

This method tests greater than or equal to (for self and other) and is used by the >= operator. Read more
source§

impl Percentage for Attribute

source§

fn percentage(&self) -> f32

Returns the percentage of the value to draw.
source§

impl Reflect for Attribute
where u32: FromReflect + TypePath,

source§

fn get_represented_type_info(&self) -> Option<&'static TypeInfo>

Returns the [TypeInfo] of the type represented by this value. Read more
source§

fn into_any(self: Box<Self>) -> Box<dyn Any>

Returns the value as a Box<dyn Any>.
source§

fn as_any(&self) -> &dyn Any

Returns the value as a &dyn Any.
source§

fn as_any_mut(&mut self) -> &mut dyn Any

Returns the value as a &mut dyn Any.
source§

fn into_reflect(self: Box<Self>) -> Box<dyn Reflect>

Casts this type to a boxed reflected value.
source§

fn as_reflect(&self) -> &dyn Reflect

Casts this type to a reflected value.
source§

fn as_reflect_mut(&mut self) -> &mut dyn Reflect

Casts this type to a mutable reflected value.
source§

fn clone_value(&self) -> Box<dyn Reflect>

Clones the value as a Reflect trait object. Read more
source§

fn set(&mut self, value: Box<dyn Reflect>) -> Result<(), Box<dyn Reflect>>

Performs a type-checked assignment of a reflected value to this value. Read more
source§

fn apply(&mut self, value: &dyn Reflect)

Applies a reflected value to this value. Read more
source§

fn reflect_ref(&self) -> ReflectRef<'_>

Returns an enumeration of “kinds” of type. Read more
source§

fn reflect_mut(&mut self) -> ReflectMut<'_>

Returns a mutable enumeration of “kinds” of type. Read more
source§

fn reflect_owned(self: Box<Self>) -> ReflectOwned

Returns an owned enumeration of “kinds” of type. Read more
source§

fn reflect_partial_eq(&self, value: &dyn Reflect) -> Option<bool>

Returns a “partial equality” comparison result. Read more
§

fn type_name(&self) -> &str

👎Deprecated since 0.12.0: view the method documentation to find alternatives to this method.
Returns the type path of the underlying type. Read more
§

fn reflect_hash(&self) -> Option<u64>

Returns a hash of the value (which includes the type). Read more
§

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

Debug formatter for the value. Read more
§

fn serializable(&self) -> Option<Serializable<'_>>

Returns a serializable version of the value. Read more
§

fn is_dynamic(&self) -> bool

Indicates whether or not this type is a dynamic type. Read more
source§

impl Serialize for Attribute

source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
source§

impl Struct for Attribute
where u32: FromReflect + TypePath,

source§

fn field(&self, name: &str) -> Option<&dyn Reflect>

Returns a reference to the value of the field named name as a &dyn Reflect.
source§

fn field_mut(&mut self, name: &str) -> Option<&mut dyn Reflect>

Returns a mutable reference to the value of the field named name as a &mut dyn Reflect.
source§

fn field_at(&self, index: usize) -> Option<&dyn Reflect>

Returns a reference to the value of the field with index index as a &dyn Reflect.
source§

fn field_at_mut(&mut self, index: usize) -> Option<&mut dyn Reflect>

Returns a mutable reference to the value of the field with index index as a &mut dyn Reflect.
source§

fn name_at(&self, index: usize) -> Option<&str>

Returns the name of the field with index index.
source§

fn field_len(&self) -> usize

Returns the number of fields in the struct.
source§

fn iter_fields(&self) -> FieldIter<'_>

Returns an iterator over the values of the reflectable fields for this struct.
source§

fn clone_dynamic(&self) -> DynamicStruct

Clones the struct into a [DynamicStruct].
source§

impl SubAssign<f32> for Attribute

source§

fn sub_assign(&mut self, rhs: f32)

Performs the -= operation. Read more
source§

impl SubAssign<f64> for Attribute

source§

fn sub_assign(&mut self, rhs: f64)

Performs the -= operation. Read more
source§

impl SubAssign<i32> for Attribute

source§

fn sub_assign(&mut self, rhs: i32)

Performs the -= operation. Read more
source§

impl SubAssign<u32> for Attribute

source§

fn sub_assign(&mut self, rhs: u32)

Performs the -= operation. Read more
source§

impl SubAssign for Attribute

source§

fn sub_assign(&mut self, rhs: Self)

Performs the -= operation. Read more
source§

impl TypePath for Attribute
where u32: FromReflect + TypePath,

source§

fn type_path() -> &'static str

Returns the fully qualified path of the underlying type. Read more
source§

fn short_type_path() -> &'static str

Returns a short, pretty-print enabled path to the type. Read more
source§

fn type_ident() -> Option<&'static str>

Returns the name of the type, or None if it is anonymous. Read more
source§

fn crate_name() -> Option<&'static str>

Returns the name of the crate the type is in, or None if it is anonymous. Read more
source§

fn module_path() -> Option<&'static str>

Returns the path to the module the type is in, or None if it is anonymous. Read more
source§

impl Typed for Attribute
where u32: FromReflect + TypePath,

source§

fn type_info() -> &'static TypeInfo

Returns the compile-time info for the underlying type.
source§

impl Copy for Attribute

source§

impl Eq for Attribute

source§

impl Resource for Attribute
where Self: Send + Sync + 'static,

Auto Trait Implementations§

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, U> AsBindGroupShaderType<U> for T
where U: ShaderType, &'a T: for<'a> Into<U>,

§

fn as_bind_group_shader_type(&self, _images: &RenderAssets<Image>) -> U

Return the T [ShaderType] for self. When used in [AsBindGroup] derives, it is safe to assume that all images in self exist.
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<C> Bundle for C
where C: Component,

§

fn component_ids( components: &mut Components, storages: &mut Storages, ids: &mut impl FnMut(ComponentId) )

§

unsafe fn from_components<T, F>(ctx: &mut T, func: &mut F) -> C
where F: for<'a> FnMut(&'a mut T) -> OwningPtr<'a>,

§

impl<Q, K> Comparable<K> for Q
where Q: Ord + ?Sized, K: Borrow<Q> + ?Sized,

§

fn compare(&self, key: &K) -> Ordering

Compare self to key and return their ordering.
§

impl<T> Downcast<T> for T

§

fn downcast(&self) -> &T

§

impl<T> Downcast for T
where T: 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>

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)

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)

Convert &mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &mut Any’s vtable from &mut Trait’s.
§

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

§

fn into_any_arc(self: Arc<T>) -> Arc<dyn Any + Send + Sync>

Convert Arc<Trait> (where Trait: Downcast) to Arc<Any>. Arc<Any> can then be further downcast into Arc<ConcreteType> where ConcreteType implements Trait.
§

impl<T> DynEq for T
where T: Any + Eq,

§

fn as_any(&self) -> &(dyn Any + 'static)

Casts the type to dyn Any.
§

fn dyn_eq(&self, other: &(dyn DynEq + 'static)) -> bool

This method tests for self and other values to be equal. Read more
§

impl<C> DynamicBundle for C
where C: Component,

§

fn get_components(self, func: &mut impl FnMut(StorageType, OwningPtr<'_>))

§

impl<T> DynamicTypePath for T
where T: TypePath,

§

fn reflect_type_path(&self) -> &str

See [TypePath::type_path].
§

fn reflect_short_type_path(&self) -> &str

See [TypePath::short_type_path].
§

fn reflect_type_ident(&self) -> Option<&str>

See [TypePath::type_ident].
§

fn reflect_crate_name(&self) -> Option<&str>

See [TypePath::crate_name].
§

fn reflect_module_path(&self) -> Option<&str>

See [TypePath::module_path].
§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

source§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<S> FromSample<S> for S

§

fn from_sample_(s: S) -> S

§

impl<T> FromWorld for T
where T: Default,

§

fn from_world(_world: &mut World) -> T

Creates Self using data from the given [World].
§

impl<S> GetField for S
where S: Struct,

§

fn get_field<T>(&self, name: &str) -> Option<&T>
where T: Reflect,

Returns a reference to the value of the field named name, downcast to T.
§

fn get_field_mut<T>(&mut self, name: &str) -> Option<&mut T>
where T: Reflect,

Returns a mutable reference to the value of the field named name, downcast to T.
§

impl<T> GetPath for T
where T: Reflect + ?Sized,

§

fn reflect_path<'p>( &self, path: impl ReflectPath<'p> ) -> Result<&(dyn Reflect + 'static), ReflectPathError<'p>>

Returns a reference to the value specified by path. Read more
§

fn reflect_path_mut<'p>( &mut self, path: impl ReflectPath<'p> ) -> Result<&mut (dyn Reflect + 'static), ReflectPathError<'p>>

Returns a mutable reference to the value specified by path. Read more
§

fn path<'p, T>( &self, path: impl ReflectPath<'p> ) -> Result<&T, ReflectPathError<'p>>
where T: Reflect,

Returns a statically typed reference to the value specified by path. Read more
§

fn path_mut<'p, T>( &mut self, path: impl ReflectPath<'p> ) -> Result<&mut T, ReflectPathError<'p>>
where T: Reflect,

Returns a statically typed mutable reference to the value specified by path. Read more
§

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<R, P> ReadPrimitive<R> for P
where R: Read + ReadEndian<P>, P: Default,

source§

fn read_from_little_endian(read: &mut R) -> Result<Self, Error>

Read this value from the supplied reader. Same as ReadEndian::read_from_little_endian().
source§

fn read_from_big_endian(read: &mut R) -> Result<Self, Error>

Read this value from the supplied reader. Same as ReadEndian::read_from_big_endian().
source§

fn read_from_native_endian(read: &mut R) -> Result<Self, Error>

Read this value from the supplied reader. Same as ReadEndian::read_from_native_endian().
source§

impl<T> Same for T

§

type Output = T

Should always be Self
source§

impl<T> Serialize for T
where T: Serialize + ?Sized,

source§

fn erased_serialize(&self, serializer: &mut dyn Serializer) -> Result<Ok, Error>

source§

impl<T> Serialize for T
where T: Serialize + ?Sized,

source§

fn erased_serialize(&self, serializer: &mut dyn Serializer) -> Result<(), Error>

source§

fn do_erased_serialize( &self, serializer: &mut dyn Serializer ) -> Result<(), ErrorImpl>

§

impl<SS, SP> SupersetOf<SS> for SP
where SS: SubsetOf<SP>,

§

fn to_subset(&self) -> Option<SS>

The inverse inclusion map: attempts to construct self from the equivalent element of its superset. Read more
§

fn is_in_subset(&self) -> bool

Checks if self is actually part of its subset T (and can be converted to it).
§

fn to_subset_unchecked(&self) -> SS

Use with care! Same as self.to_subset but without any property checks. Always succeeds.
§

fn from_subset(element: &SS) -> SP

The inclusion map: converts self to the equivalent element of its superset.
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
§

impl<T, U> ToSample<U> for T
where U: FromSample<T>,

§

fn to_sample_(self) -> U

§

impl<T> ToSmolStr for T
where T: Display + ?Sized,

§

fn to_smolstr(&self) -> SmolStr

source§

impl<T> ToString for T
where T: Display + ?Sized,

source§

default fn to_string(&self) -> String

Converts the given value to a String. 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<T> TypeData for T
where T: 'static + Send + Sync + Clone,

§

fn clone_type_data(&self) -> Box<dyn TypeData>

§

impl<T> Upcast<T> for T

§

fn upcast(&self) -> Option<&T>

§

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<S, T> Duplex<S> for T
where T: FromSample<S> + ToSample<S>,

source§

impl<T> Scalar for T
where T: 'static + Clone + PartialEq + Debug,

§

impl<T> SerializableAny for T
where T: 'static + Any + Clone + for<'a> Send + Sync,

§

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

§

impl<T> WasmNotSend for T
where T: Send,

§

impl<T> WasmNotSync for T
where T: Sync,