CommandArgs

Struct CommandArgs 

Source
pub struct CommandArgs {
    pub timestamp: DInstant,
    pub param: Option<CommandParam>,
    pub scope: CommandScope,
    pub target: Option<WidgetPath>,
    pub enabled: bool,
    pub propagation: EventPropagationHandle,
}
Expand description

Event args for command events.

Fields§

§timestamp: DInstant

Instant the event happened.

§param: Option<CommandParam>

Optional parameter for the command handler.

§scope: CommandScope

Scope of command that notified.

§target: Option<WidgetPath>

Target widget.

  • If the scope is App this is None.
  • If the scope is Window this is the window root widget, if the window was found.
  • If the scope is Widget this is the widget, if it was found.
§enabled: bool

If the command was enabled when the command notified.

If false the command primary action must not run, but a secondary “disabled interaction” that indicates what conditions enable the command is recommended.

Note that this is the Command::is_enabled value, it is true id any handle is enabled, the local handler might still be disabled.

§propagation: EventPropagationHandle

Propagation handle associated with this event instance.

Cloned arguments share the same handle, some arguments may also share the handle of another event if they share the same cause.

Implementations§

Source§

impl CommandArgs

Source

pub fn new( timestamp: impl Into<DInstant>, propagation: EventPropagationHandle, param: impl Into<Option<CommandParam>>, scope: impl Into<CommandScope>, target: impl Into<Option<WidgetPath>>, enabled: impl Into<bool>, ) -> CommandArgs

New args from values that convert into the argument types.

§Panics

Panics if the arguments are invalid.

Source

pub fn try_new( timestamp: impl Into<DInstant>, propagation: EventPropagationHandle, param: impl Into<Option<CommandParam>>, scope: impl Into<CommandScope>, target: impl Into<Option<WidgetPath>>, enabled: impl Into<bool>, ) -> Result<CommandArgs, Txt>

New args from values that convert into the argument types.

Returns an error if the constructed arguments are invalid.

Source

pub fn now( param: impl Into<Option<CommandParam>>, scope: impl Into<CommandScope>, target: impl Into<Option<WidgetPath>>, enabled: impl Into<bool>, ) -> CommandArgs

Arguments for event that happened now (INSTANT.now).

§Panics

Panics if the arguments are invalid.

Source

pub fn try_now( param: impl Into<Option<CommandParam>>, scope: impl Into<CommandScope>, target: impl Into<Option<WidgetPath>>, enabled: impl Into<bool>, ) -> Result<CommandArgs, Txt>

Arguments for event that happened now (INSTANT.now).

Returns an error if the constructed arguments are invalid.

Source

pub fn validate(&self) -> Result<(), Txt>

Validates if the target matches the scope.

Source

pub fn assert_valid(&self)

Panics if the arguments are invalid.

Source§

impl CommandArgs

Source

pub fn param<T>(&self) -> Option<&T>
where T: Any,

Returns a reference to a parameter of T if parameter is set to a value of T.

Source

pub fn enabled_param<T>(&self) -> Option<&T>
where T: Any,

Returns param if is enabled.

Source

pub fn disabled_param<T>(&self) -> Option<&T>
where T: Any,

Returns param if is not enabled.

Source

pub fn scope_matches(&self, direct_only: bool, scope: CommandScope) -> bool

If direct_only is enabled only matches exact command scope matches, otherwise the app scope matches all args, the window scope matches all events for the window or widgets in the window and the widget scope matches the widget and all descendants.

Trait Implementations§

Source§

impl AnyEventArgs for CommandArgs

Source§

fn is_in_target(&self, id: WidgetId) -> bool

Broadcast to all if the scope is App, otherwise if is in target.

Source§

fn timestamp(&self) -> DInstant

Instant this event update happened.
Source§

fn propagation(&self) -> &EventPropagationHandle

Propagation handle associated with this event instance. Read more
Source§

fn clone_boxed(&self) -> Box<dyn AnyEventArgs>

Clone the args to a new box.
Source§

impl Clone for CommandArgs

Source§

fn clone(&self) -> CommandArgs

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 CommandArgs

Source§

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

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

impl PartialEq for CommandArgs

Source§

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

impl EventArgs for CommandArgs

Source§

impl StructuralPartialEq for CommandArgs

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
§

impl<T> AnyEq for T
where T: Any + PartialEq,

§

fn equals(&self, other: &(dyn Any + 'static)) -> bool

§

fn as_any(&self) -> &(dyn Any + 'static)

Source§

impl<T> AnyVarValue for T
where T: Debug + PartialEq + Clone + Any + Send + Sync,

Source§

fn clone_boxed(&self) -> BoxAnyVarValue

Clone the value.
Source§

fn eq_any(&self, other: &(dyn AnyVarValue + 'static)) -> bool

Gets if self and other are equal.
Source§

fn type_name(&self) -> &'static str

Value type name. Read more
Source§

fn try_swap(&mut self, other: &mut (dyn AnyVarValue + 'static)) -> bool

Swap value with other if both are of the same type.
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
§

impl<T> Downcast for T
where T: Any,

§

fn into_any(self: Box<T>) -> Box<dyn Any>

Convert Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can then be further downcast into Box<ConcreteType> where ConcreteType implements Trait.
§

fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>

Convert Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be further downcast into Rc<ConcreteType> where ConcreteType implements Trait.
§

fn as_any(&self) -> &(dyn Any + 'static)

Convert &Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &Any’s vtable from &Trait’s.
§

fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)

Convert &mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &mut Any’s vtable from &mut Trait’s.
§

impl<T> DowncastSync for T
where T: Any + Send + Sync,

§

fn into_any_arc(self: Arc<T>) -> Arc<dyn Any + Send + Sync>

Convert Arc<Trait> (where Trait: Downcast) to Arc<Any>. Arc<Any> can then be further downcast into Arc<ConcreteType> where ConcreteType implements Trait.
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<S> FromSample<S> for S

§

fn from_sample_(s: S) -> S

Source§

impl<T> FsChangeNote for T
where T: Debug + Any + Send + Sync,

Source§

fn as_any(&self) -> &(dyn Any + 'static)

Access any.
§

impl<T> Instrument for T

§

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

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

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
§

impl<F, T> IntoSample<T> for F
where T: FromSample<F>,

§

fn into_sample(self) -> T

Source§

impl<T> IntoVar<T> for T
where T: VarValue,

Source§

fn into_var(self) -> Var<T>

§

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

Source§

type Output = T

Should always be Self
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
§

impl<T, U> ToSample<U> for T
where U: FromSample<T>,

§

fn to_sample_(self) -> U

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.
§

impl<T> WithSubscriber for T

§

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
§

fn with_current_subscriber(self) -> WithDispatch<Self>

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

impl<S, T> Duplex<S> for T
where T: FromSample<S> + ToSample<S>,

Source§

impl<T> IntoValue<T> for T
where T: VarValue,

Source§

impl<T> StateValue for T
where T: Any + Send + Sync,

Source§

impl<T> VarValue for T