godot::builtin

Struct NodePath

pub struct NodePath { /* private fields */ }
Expand description

A pre-parsed scene tree path.

§Null bytes

Note that Godot ignores any bytes after a null-byte. This means that for instance "hello, world!" and "hello, world!\0 ignored by Godot" will be treated as the same string if converted to a NodePath.

§All string types

Intended use caseString type
General purposeGString
Interned namesStringName
Scene-node pathsNodePath

§Godot docs

NodePath (stable)

Implementations§

§

impl NodePath

pub fn get_name(&self, index: usize) -> StringName

Returns the node name at position index.

If you want to get a property name instead, check out get_subname().

§Example
let path = NodePath::from("../RigidBody2D/Sprite2D");
godot_print!("{}", path.get_name(0)); // ".."
godot_print!("{}", path.get_name(1)); // "RigidBody2D"
godot_print!("{}", path.get_name(2)); // "Sprite"
§Panics

In Debug mode, if index is out of bounds. In Release, a Godot error is generated and the result is unspecified (but safe).

pub fn get_subname(&self, index: usize) -> StringName

Returns the node subname (property) at position index.

If you want to get a node name instead, check out get_name().

§Example
let path = NodePath::from("Sprite2D:texture:resource_name");
godot_print!("{}", path.get_subname(0)); // "texture"
godot_print!("{}", path.get_subname(1)); // "resource_name"
§Panics

In Debug mode, if index is out of bounds. In Release, a Godot error is generated and the result is unspecified (but safe).

pub fn get_name_count(&self) -> usize

Returns the number of node names in the path. Property subnames are not included.

pub fn get_subname_count(&self) -> usize

Returns the number of property names (“subnames”) in the path. Each subname in the node path is listed after a colon character (:).

pub fn get_total_count(&self) -> usize

Returns the total number of names + subnames.

This method does not exist in Godot and is provided in Rust for convenience.

pub fn hash(&self) -> u32

Returns a 32-bit integer hash value representing the string.

pub fn subpath(&self, begin: i32, exclusive_end: i32) -> NodePath

Available on since_api="4.3" only.

Returns the range begin..exclusive_end as a new NodePath.

The absolute value of begin and exclusive_end will be clamped to get_total_count(). So, to express “until the end”, you can simply pass a large value for exclusive_end, such as i32::MAX.

If either begin or exclusive_end are negative, they will be relative to the end of the NodePath.
For example, path.subpath(0, -2) is a shorthand for path.subpath(0, path.get_total_count() - 2).

Godot equivalent: slice

§Compatibility

The slice() behavior for Godot <= 4.3 is unintuitive, see #100954. godot-rust automatically changes this to the fixed version for Godot 4.4+, even when used in older versions. So, the behavior is always the same.

pub fn arg<T>(&self) -> impl AsArg<T>
where T: for<'a> From<&'a NodePath> + for<'a> ParamType<Arg<'a> = CowArg<'a, T>> + 'a,

Use as argument for an impl AsArg<GString|StringName> parameter.

This is a convenient way to convert arguments of similar string types.

§Example

PackedStringArray can insert elements using AsArg<GString>, so let’s pass a NodePath:

let node_path = NodePath::from("Node2D/Label");

let mut array = PackedStringArray::new();
array.push(node_path.arg());
§Generic bounds

The bounds are implementation-defined and may change at any time. Do not use this function in a generic context requiring T – use the From trait or ParamType in that case.

§

impl NodePath

pub fn is_absolute(&self) -> bool

pub fn get_concatenated_names(&self) -> StringName

pub fn get_concatenated_subnames(&self) -> StringName

pub fn get_as_property_path(&self) -> NodePath

pub fn is_empty(&self) -> bool

Trait Implementations§

§

impl Clone for NodePath

§

fn clone(&self) -> NodePath

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 Debug for NodePath

Uses literal syntax from GDScript: ^"node_path"

§

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

Formats the value using the given formatter. Read more
§

impl Default for NodePath

§

fn default() -> NodePath

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

impl Display for NodePath

§

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

Formats the value using the given formatter. Read more
§

impl Drop for NodePath

§

fn drop(&mut self)

Executes the destructor for this type. Read more
§

impl Export for NodePath

§

fn export_hint() -> PropertyHintInfo

The export info to use for an exported field of this type, if no other export info is specified.
§

impl From<&GString> for NodePath

§

fn from(string: &GString) -> NodePath

Converts to this type from the input type.
§

impl From<&NodePath> for GString

§

fn from(path: &NodePath) -> GString

Converts to this type from the input type.
§

impl From<&NodePath> for StringName

§

fn from(path: &NodePath) -> StringName

Converts to this type from the input type.
§

impl From<&String> for NodePath

§

fn from(s: &String) -> NodePath

Converts to this type from the input type.
§

impl From<&StringName> for NodePath

§

fn from(string_name: &StringName) -> NodePath

Converts to this type from the input type.
§

impl From<&str> for NodePath

§

fn from(s: &str) -> NodePath

Converts to this type from the input type.
§

impl From<GString> for NodePath

§

fn from(string: GString) -> NodePath

Converts this GString to a NodePath.

This is identical to NodePath::from(&string), and as such there is no performance benefit.

§

impl From<NodePath> for GString

§

fn from(path: NodePath) -> GString

Converts this NodePath to a GString.

This is identical to GString::from(&path), and as such there is no performance benefit.

§

impl From<NodePath> for StringName

§

fn from(path: NodePath) -> StringName

Converts this NodePath to a StringName.

This is identical to StringName::from(&path), and as such there is no performance benefit.

§

impl From<String> for NodePath

§

fn from(s: String) -> NodePath

Converts to this type from the input type.
§

impl From<StringName> for NodePath

§

fn from(string_name: StringName) -> NodePath

Converts this StringName to a NodePath.

This is identical to NodePath::from(&string_name), and as such there is no performance benefit.

§

impl FromGodot for NodePath

§

fn try_from_godot( via: <NodePath as GodotConvert>::Via, ) -> Result<NodePath, ConvertError>

Converts the Godot representation to this type, returning Err on failure.
§

fn from_godot(via: Self::Via) -> Self

⚠️ Converts the Godot representation to this type. Read more
§

fn try_from_variant(variant: &Variant) -> Result<Self, ConvertError>

Performs the conversion from a Variant, returning Err on failure.
§

fn from_variant(variant: &Variant) -> Self

⚠️ Performs the conversion from a Variant. Read more
§

impl FromStr for NodePath

§

type Err = Infallible

The associated error which can be returned from parsing.
§

fn from_str(string: &str) -> Result<NodePath, <NodePath as FromStr>::Err>

Parses a string s to return a value of this type. Read more
§

impl GodotConvert for NodePath

§

type Via = NodePath

The type through which Self is represented in Godot.
§

impl Hash for NodePath

§

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
§

impl ParamType for NodePath

§

fn owned_to_arg<'v>(self) -> <NodePath as ParamType>::Arg<'v>

Converts an owned value to the canonical argument type, which can be passed to impl AsArg<T>. Read more
§

impl PartialEq for NodePath

§

fn eq(&self, other: &NodePath) -> 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.
§

impl ToGodot for NodePath

§

type ToVia<'v> = <NodePath as GodotConvert>::Via

Target type of to_godot(), which can differ from Via for pass-by-reference types. Read more
§

fn to_godot(&self) -> <NodePath as ToGodot>::ToVia<'_>

Converts this type to the Godot type by reference, usually by cloning.
§

fn to_variant(&self) -> Variant

Converts this type to a Variant.
§

impl Var for NodePath

§

fn get_property(&self) -> <NodePath as GodotConvert>::Via

§

fn set_property(&mut self, value: <NodePath as GodotConvert>::Via)

§

fn var_hint() -> PropertyHintInfo

Specific property hints, only override if they deviate from GodotType::property_info, e.g. for enums/newtypes.
§

impl ArrayElement for NodePath

§

impl<'r> AsArg<NodePath> for &'r NodePath

§

impl AsArg<NodePath> for &String

§

impl AsArg<NodePath> for &str

§

impl Eq for NodePath

§

impl GodotType for NodePath

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

Source§

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

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. 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> 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> 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.