settings_inspect_utils::managed_inspect_map

Struct ManagedInspectMap

Source
pub struct ManagedInspectMap<V> { /* private fields */ }
Expand description

A map that wraps an inspect node and attaches all inserted values to the node.

This class can either be explicitly given an inspect node through ManagedInspectMap::with_node or can create its own inspect node when included in a struct that derives Inspect or when [ManagedInspectMap::with_inspect] is called.

Implementations§

Source§

impl<V> ManagedInspectMap<V>
where for<'a> &'a mut V: Inspect,

Source

pub fn with_node(node: Node) -> Self

Creates a new ManagedInspectMap that attaches inserted values to the given node.

Source

pub fn map(&self) -> &HashMap<String, V>

Returns a reference to the underlying map. Clients should not insert values into the map through this reference.

Source

pub fn map_mut(&mut self) -> &mut HashMap<String, V>

Returns a mutable reference to the underlying map. Clients should not insert values into the map through this reference.

Source

pub fn insert(&mut self, key: String, value: V) -> Option<V>

Inserts the given value into the map and attach it to the inspect tree. Returns the previous value with the given key, if any.

Source

pub fn insert_with_property_name( &mut self, map_key: String, property_name: String, value: V, ) -> Option<V>

Inserts the given value into the map and attaches it to the inspect tree with a different name. Returns the previous value with the given map key, if any.

This is useful for cases where the unique key for the map is not useful for actually recording to inspect.

Source

pub fn get_or_insert_with( &mut self, key: String, value: impl FnOnce() -> V, ) -> &mut V

Returns a mutable reference to the value at the given key, inserting a value if not present.

Source

pub fn get_mut(&mut self, key: &str) -> Option<&mut V>

Returns a mutable reference to the entry at key.

Source

pub fn get(&self, key: &str) -> Option<&V>

Returns an immutable reference to the entry at key.

Source

pub fn inspect_node(&self) -> &Node

Returns a reference to the inspect node associated with this map.

Trait Implementations§

Source§

impl<V: Default> Default for ManagedInspectMap<V>

Source§

fn default() -> ManagedInspectMap<V>

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

impl<V> Inspect for &mut ManagedInspectMap<V>
where for<'a> &'a mut V: Inspect,

Source§

fn iattach( self, parent: &Node, name: impl AsRef<str>, ) -> Result<(), AttachError>

Attaches self to the inspect tree, under parent[name]. Note that: Read more

Auto Trait Implementations§

§

impl<V> Freeze for ManagedInspectMap<V>

§

impl<V> !RefUnwindSafe for ManagedInspectMap<V>

§

impl<V> Send for ManagedInspectMap<V>
where V: Send,

§

impl<V> Sync for ManagedInspectMap<V>
where V: Sync,

§

impl<V> Unpin for ManagedInspectMap<V>
where V: Unpin,

§

impl<V> !UnwindSafe for ManagedInspectMap<V>

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, D> Encode<Ambiguous1, D> for T
where D: ResourceDialect,

Source§

unsafe fn encode( self, _encoder: &mut Encoder<'_, D>, _offset: usize, _depth: Depth, ) -> Result<(), Error>

Encodes the object into the encoder’s buffers. Any handles stored in the object are swapped for Handle::INVALID. Read more
Source§

impl<T, D> Encode<Ambiguous2, D> for T
where D: ResourceDialect,

Source§

unsafe fn encode( self, _encoder: &mut Encoder<'_, D>, _offset: usize, _depth: Depth, ) -> Result<(), Error>

Encodes the object into the encoder’s buffers. Any handles stored in the object are swapped for Handle::INVALID. 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.

§

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<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<T> WithInspect for T
where &'a mut T: for<'a> Inspect,

Source§

fn with_inspect( self, parent: &Node, name: impl AsRef<str>, ) -> Result<T, AttachError>

Attaches self to the inspect tree. It is recommended to invoke this as part of construction. For example: Read more