Environment

Struct Environment 

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

An Environment stores a map of types to values.

Each type can have at most one value in the environment. The environment is used to pass contextual information from parent views to child views.

§Examples

use waterui_core::Environment;

let mut env = Environment::new();
env.insert(String::from("hello"));

// Get the value back
assert_eq!(env.get::<String>(), Some(&String::from("hello")));

// Remove the value
env.remove::<String>();
assert_eq!(env.get::<String>(), None);

Implementations§

Source§

impl Environment

Source

pub const fn new() -> Self

Creates a new empty environment.

Source

pub fn store<K: 'static, V: 'static>(self, value: V) -> Self

Stores a value in the environment indexed by type K.

§Arguments
  • value - The value to store
Source

pub fn query<K: 'static, V: 'static>(&self) -> Option<&V>

Queries for a value in the environment indexed by type K.

§Returns

An optional reference to the stored value

Source

pub fn install(&mut self, plugin: impl Plugin) -> &mut Self

Installs a plugin into the environment.

Plugins can register values or modifiers that will be available to all views.

Source

pub fn insert<T: 'static>(&mut self, value: T)

Inserts a value into the environment.

If a value of the same type already exists, it will be replaced.

Source

pub fn insert_hook<T: ViewConfiguration, V: View>( &mut self, hook: impl Fn(&Self, T) -> V + 'static, )

Inserts a view configuration hook into the environment.

Hooks allow you to intercept and modify view configurations globally.

Source

pub fn remove<T: 'static>(&mut self)

Removes a value from the environment by its type.

Source

pub fn with<T: 'static>(&mut self, value: T) -> &mut Self

Adds a value to the environment and returns the modified environment.

This is a fluent interface for chaining multiple additions.

Source

pub fn get<T: 'static>(&self) -> Option<&T>

Retrieves a reference to a value from the environment by its type.

Returns None if no value of the requested type exists.

§Panics

This function will panic if a value of the requested type exists in the environment, but the stored value cannot be downcast to the requested type. This should never happen if only insert and with are used to add values.

Trait Implementations§

Source§

impl Clone for Environment

Source§

fn clone(&self) -> Environment

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 Environment

Source§

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

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

impl Default for Environment

Source§

fn default() -> Environment

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

impl Extractor for Environment

Source§

fn extract(env: &Environment) -> Result<Self, Error>

Extracts the Environment itself by creating a clone.

Source§

impl MetadataKey for Environment

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, 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<T> IdentifiableExt for T

Source§

fn use_id<F, Id>(self, f: F) -> UseId<Self, F>
where F: Fn(&Self) -> Id, Id: Ord + Hash,

Wraps the value in a UseId with the provided identification function.
Source§

fn self_id(self) -> SelfId<Self>

Wraps the value in a SelfId, making the value serve as its own identifier.
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, 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.