Skip to main content

Name

Struct Name 

Source
pub struct Name { /* private fields */ }
Expand description

Component providing a human-readable name for an entity.

Names are useful for:

  • Debugging and logging
  • Editor integration and scene hierarchies
  • Scripting references (find entity by name)
  • UI display

§Performance

Names use Rust’s String type internally. For performance-critical code, consider using entity IDs directly rather than string lookups.

§Example

use goud_engine::ecs::components::Name;

let name = Name::new("Player");
assert_eq!(name.as_str(), "Player");

let mut name = Name::new("Enemy");
name.set("Boss");
assert_eq!(name.as_str(), "Boss");

Implementations§

Source§

impl Name

Source

pub fn new(name: impl Into<String>) -> Name

Creates a new Name component with the given string.

§Arguments
  • name - The name string (anything that can be converted to String)
§Example
use goud_engine::ecs::components::Name;

let name = Name::new("Player");
let name2 = Name::new(String::from("Enemy"));
Source

pub fn as_str(&self) -> &str

Returns the name as a string slice.

§Example
use goud_engine::ecs::components::Name;

let name = Name::new("Player");
assert_eq!(name.as_str(), "Player");
Source

pub fn set(&mut self, name: impl Into<String>)

Sets a new name.

§Arguments
  • name - The new name string
§Example
use goud_engine::ecs::components::Name;

let mut name = Name::new("Player");
name.set("Player_renamed");
assert_eq!(name.as_str(), "Player_renamed");
Source

pub fn len(&self) -> usize

Returns the length of the name in bytes.

§Example
use goud_engine::ecs::components::Name;

let name = Name::new("Test");
assert_eq!(name.len(), 4);
Source

pub fn is_empty(&self) -> bool

Returns true if the name is empty.

§Example
use goud_engine::ecs::components::Name;

let name = Name::new("");
assert!(name.is_empty());

let name2 = Name::new("Player");
assert!(!name2.is_empty());
Source

pub fn into_string(self) -> String

Consumes the Name and returns the inner String.

§Example
use goud_engine::ecs::components::Name;

let name = Name::new("Player");
let string: String = name.into_string();
assert_eq!(string, "Player");
Source

pub fn contains(&self, pattern: &str) -> bool

Returns true if the name contains the given pattern.

§Example
use goud_engine::ecs::components::Name;

let name = Name::new("Player_01");
assert!(name.contains("Player"));
assert!(name.contains("01"));
assert!(!name.contains("Enemy"));
Source

pub fn starts_with(&self, prefix: &str) -> bool

Returns true if the name starts with the given prefix.

§Example
use goud_engine::ecs::components::Name;

let name = Name::new("Player_01");
assert!(name.starts_with("Player"));
assert!(!name.starts_with("Enemy"));
Source

pub fn ends_with(&self, suffix: &str) -> bool

Returns true if the name ends with the given suffix.

§Example
use goud_engine::ecs::components::Name;

let name = Name::new("Player_01");
assert!(name.ends_with("01"));
assert!(!name.ends_with("Player"));

Trait Implementations§

Source§

impl AsRef<str> for Name

Source§

fn as_ref(&self) -> &str

Converts this type into a shared reference of the (usually inferred) input type.
Source§

impl Borrow<str> for Name

Source§

fn borrow(&self) -> &str

Immutably borrows from an owned value. Read more
Source§

impl Clone for Name

Source§

fn clone(&self) -> Name

Returns a duplicate 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 Debug for Name

Source§

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

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

impl Default for Name

Source§

fn default() -> Name

Returns a Name with an empty string.

Source§

impl Display for Name

Source§

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

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

impl From<&str> for Name

Source§

fn from(s: &str) -> Name

Converts to this type from the input type.
Source§

impl From<String> for Name

Source§

fn from(s: String) -> Name

Converts to this type from the input type.
Source§

impl Hash for Name

Source§

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

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<&str> for Name

Source§

fn eq(&self, other: &&str) -> 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 PartialEq<String> for Name

Source§

fn eq(&self, other: &String) -> 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 PartialEq<str> for Name

Source§

fn eq(&self, other: &str) -> 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 PartialEq for Name

Source§

fn eq(&self, other: &Name) -> 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 Component for Name

Source§

impl Eq for Name

Source§

impl StructuralPartialEq for Name

Auto Trait Implementations§

§

impl Freeze for Name

§

impl RefUnwindSafe for Name

§

impl Send for Name

§

impl Sync for Name

§

impl Unpin for Name

§

impl UnsafeUnpin for Name

§

impl UnwindSafe for Name

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> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

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

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<S> FromSample<S> for S

Source§

fn from_sample_(s: S) -> S

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

impl<F, T> IntoSample<T> for F
where T: FromSample<F>,

Source§

fn into_sample(self) -> T

Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

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

Initializes a with the given initializer. Read more
Source§

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

Dereferences the given pointer. Read more
Source§

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

Mutably dereferences the given pointer. Read more
Source§

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> ToOwned for T
where T: Clone,

Source§

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> ToSample<U> for T
where U: FromSample<T>,

Source§

fn to_sample_(self) -> U

Source§

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

Source§

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

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

impl<S, T> Duplex<S> for T
where T: FromSample<S> + ToSample<S>,

Source§

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

Source§

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

Source§

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