ComplexResource

Enum ComplexResource 

Source
pub enum ComplexResource {
    Diamond(Diamond),
    Water(Water),
    Life(Life),
    Robot(Robot),
    Dolphin(Dolphin),
    AIPartner(AIPartner),
}
Expand description

An enum that provides a unified type for all possible complex resources.

This enum wraps every generated complex resource struct (e.g., Water, Diamond) into a single type. It is useful when you need to store or pass around any complex resource without knowing its specific concrete type at compile time.

Variants§

§

Diamond(Diamond)

§

Water(Water)

§

Life(Life)

§

Robot(Robot)

§

Dolphin(Dolphin)

§

AIPartner(AIPartner)

Implementations§

Source§

impl ComplexResource

Source

pub fn get_type(&self) -> ComplexResourceType

Returns the ComplexResourceType of this resource.

Source

pub fn to_diamond(self) -> Result<Diamond, String>

Attempts to convert the ComplexResource into a $complex.

§Returns
  • Ok($complex) if the resource is $complex.
§Errors

Returns an error if the resource is of a different type.

Source

pub fn to_water(self) -> Result<Water, String>

Attempts to convert the ComplexResource into a $complex.

§Returns
  • Ok($complex) if the resource is $complex.
§Errors

Returns an error if the resource is of a different type.

Source

pub fn to_life(self) -> Result<Life, String>

Attempts to convert the ComplexResource into a $complex.

§Returns
  • Ok($complex) if the resource is $complex.
§Errors

Returns an error if the resource is of a different type.

Source

pub fn to_robot(self) -> Result<Robot, String>

Attempts to convert the ComplexResource into a $complex.

§Returns
  • Ok($complex) if the resource is $complex.
§Errors

Returns an error if the resource is of a different type.

Source

pub fn to_dolphin(self) -> Result<Dolphin, String>

Attempts to convert the ComplexResource into a $complex.

§Returns
  • Ok($complex) if the resource is $complex.
§Errors

Returns an error if the resource is of a different type.

Source

pub fn to_aipartner(self) -> Result<AIPartner, String>

Attempts to convert the ComplexResource into a $complex.

§Returns
  • Ok($complex) if the resource is $complex.
§Errors

Returns an error if the resource is of a different type.

Trait Implementations§

Source§

impl Debug for ComplexResource

Source§

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

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

impl Hash for ComplexResource

Source§

fn hash<__H: Hasher>(&self, state: &mut __H)

Feeds this value into the given Hasher. Read more
1.3.0 · Source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
Source§

impl PartialEq for ComplexResource

Source§

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

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

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

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Eq for ComplexResource

Source§

impl StructuralPartialEq for ComplexResource

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

Source§

fn from(t: T) -> T

Returns the argument unchanged.

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, U> TryFrom<U> for T
where U: Into<T>,

Source§

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>,

Source§

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.