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() -> Environment

Creates a new empty environment.

Source

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

Stores a value in the environment indexed by type K.

§Arguments
  • value - The value to store
Source

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

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 Environment

Installs a plugin into the environment.

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

Source

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

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, V>( &mut self, hook: impl Fn(&Environment, T) -> V + 'static, )
where T: ViewConfiguration, V: View,

Inserts a view configuration hook into the environment.

Hooks allow you to intercept and modify view configurations globally.

Source

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

Removes a value from the environment by its type.

Source

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

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>(&self) -> Option<&T>
where T: 'static,

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§

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<(), Error>

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

Extracts the Environment itself by creating a clone.

Source§

impl MetadataKey for Environment

Auto Trait Implementations§

Blanket Implementations§

§

impl<T> Any for T
where T: 'static + ?Sized,

§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

impl<T> Borrow<T> for T
where T: ?Sized,

§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
§

impl<T> BorrowMut<T> for T
where T: ?Sized,

§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
§

impl<T> CloneToUninit for T
where T: Clone,

§

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
§

impl<T> From<T> for T

§

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> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
§

impl<T, U> Into<U> for T
where U: From<T>,

§

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> Same for T

Source§

type Output = T

Should always be Self
§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more