pub struct WidgetId(/* private fields */);Expand description
Unique ID of a widget.
§Name
IDs are only unique for the same process.
You can associate a name with an ID to give it a persistent identifier.
§Memory
The internal number is a NonZeroU64, that means that
Option<WidgetId>
and
WidgetId
are the same size as u64.
§As Hash
The generated internal number has good statistical distribution and can be used as its own hash,
although it is not cryptographically safe, as it is simply a sequential counter scrambled using splitmix64.
§Static
The unique ID cannot be generated at compile time, but you can use the new_static constructor to
create a lightweight lazy ID factory that will generate the ID on the first get.
Implementations§
source§impl WidgetId
impl WidgetId
sourcepub fn new_unique() -> Self
pub fn new_unique() -> Self
Generates a new unique ID.
sourcepub const fn new_static() -> StaticWidgetId
pub const fn new_static() -> StaticWidgetId
New static ID that will be generated on the first get.
sourcepub fn sequential(self) -> u64
pub fn sequential(self) -> u64
Un-scramble the underlying value to get the original sequential count number.
If two IDs, id0 and id1 where generated by the same thread then id0.sequential() < id1.sequential().
sourcepub fn from_raw(raw: u64) -> Self
pub fn from_raw(raw: u64) -> Self
Creates an ID from a raw value.
The value must not be zero, panics if it is, the value must have been provided by get otherwise
the ID will not be unique.
sourcepub fn from_sequential(num: u64) -> Self
pub fn from_sequential(num: u64) -> Self
Creates an ID from a sequential number.
§Safety
The value must not be zero, panics if it is, the value must have been provided by sequential otherwise
the ID will not be unique.
source§impl WidgetId
impl WidgetId
sourcepub fn named(name: impl Into<Txt>) -> Self
pub fn named(name: impl Into<Txt>) -> Self
Get or generate an ID with associated name.
If the name is already associated with an ID, returns it.
If the name is new, generates a new ID and associated it with the name.
If name is an empty string just returns a new ID.
sourcepub fn debug_named(name: impl Into<Txt>) -> Self
pub fn debug_named(name: impl Into<Txt>) -> Self
Calls named in a debug build and new_unique in a release build.
The named function causes a hash-map lookup, but if you are only naming a widget to find
it in the Inspector you don’t need that lookup in a release build, so you can set the id
to this function call instead.
sourcepub fn named_new(name: impl Into<Txt>) -> Result<Self, IdNameError<Self>>
pub fn named_new(name: impl Into<Txt>) -> Result<Self, IdNameError<Self>>
Generate a new ID with associated name.
If the name is already associated with an ID, returns the NameUsed error.
If the name is an empty string just returns a new ID.
sourcepub fn set_name(self, name: impl Into<Txt>) -> Result<(), IdNameError<Self>>
pub fn set_name(self, name: impl Into<Txt>) -> Result<(), IdNameError<Self>>
Associate a name with the ID, if it is not named.
If the name is already associated with a different ID, returns the NameUsed error.
If the ID is already named, with a name different from name, returns the AlreadyNamed error.
If the name is an empty string or already is the name of the ID, does nothing.
Trait Implementations§
source§impl<'de> Deserialize<'de> for WidgetId
impl<'de> Deserialize<'de> for WidgetId
source§fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>where
D: Deserializer<'de>,
fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>where
D: Deserializer<'de>,
source§impl From<&'static StaticWidgetId> for WidgetId
impl From<&'static StaticWidgetId> for WidgetId
source§fn from(st: &'static StaticWidgetId) -> WidgetId
fn from(st: &'static StaticWidgetId) -> WidgetId
source§impl From<&'static str> for WidgetId
impl From<&'static str> for WidgetId
source§fn from(name: &'static str) -> Self
fn from(name: &'static str) -> Self
Calls WidgetId::named.
source§impl From<WidgetId> for AccessNodeId
impl From<WidgetId> for AccessNodeId
source§impl From<WidgetId> for CommandScope
impl From<WidgetId> for CommandScope
source§impl IntoVar<AccessNodeId> for WidgetId
impl IntoVar<AccessNodeId> for WidgetId
source§impl PartialEq for WidgetId
impl PartialEq for WidgetId
impl Copy for WidgetId
impl Eq for WidgetId
impl IntoValue<AccessNodeId> for WidgetId
impl IntoValue<Option<WidgetId>> for WidgetId
impl IntoValue<WidgetId> for &'static StaticWidgetId
impl IntoValue<WidgetId> for &'static str
impl IntoValue<WidgetId> for Cow<'static, str>
impl IntoValue<WidgetId> for String
impl IntoValue<WidgetId> for Txt
impl IntoValue<WidgetId> for char
impl NoUninit for WidgetId
impl PodInOption for WidgetId
impl ZeroableInOption for WidgetId
Auto Trait Implementations§
impl Freeze for WidgetId
impl RefUnwindSafe for WidgetId
impl Send for WidgetId
impl Sync for WidgetId
impl Unpin for WidgetId
impl UnwindSafe for WidgetId
Blanket Implementations§
source§impl<T> AnyVarValue for Twhere
T: VarValue,
impl<T> AnyVarValue for Twhere
T: VarValue,
source§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
dyn Any methods.source§fn clone_boxed(&self) -> Box<dyn AnyVarValue>
fn clone_boxed(&self) -> Box<dyn AnyVarValue>
source§fn clone_boxed_var(&self) -> Box<dyn AnyVar>
fn clone_boxed_var(&self) -> Box<dyn AnyVar>
LocalVar<Self>.