Struct druid::SingleUse

source ·
pub struct SingleUse<T>(_);
Expand description

A wrapper type for Command payloads that should only be used once.

This is useful if you have some resource that cannot be cloned, and you wish to send it to another widget.

Examples

use druid::{Command, Selector, SingleUse, Target};

struct CantClone(u8);

let selector = Selector::new("use-once");
let num = CantClone(42);
let command = selector.with(SingleUse::new(num));

let payload: &SingleUse<CantClone> = command.get_unchecked(selector);
if let Some(num) = payload.take() {
    // now you own the data
    assert_eq!(num.0, 42);
}

// subsequent calls will return `None`
assert!(payload.take().is_none());

Implementations§

source§

impl<T: Any> SingleUse<T>

source

pub fn new(data: T) -> Self

Create a new single-use payload.

source

pub fn take(&self) -> Option<T>

Takes the value, leaving a None in its place.

Auto Trait Implementations§

§

impl<T> RefUnwindSafe for SingleUse<T>

§

impl<T> Send for SingleUse<T>where T: Send,

§

impl<T> Sync for SingleUse<T>where T: Send,

§

impl<T> Unpin for SingleUse<T>where T: Unpin,

§

impl<T> UnwindSafe for SingleUse<T>

Blanket Implementations§

source§

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

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

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

const: unstable · source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

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

const: unstable · source§

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

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

const: unstable · source§

fn from(t: T) -> T

Returns the argument unchanged.

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

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

const: unstable · 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> RoundFrom<T> for T

§

fn round_from(x: T) -> T

Performs the conversion.
§

impl<T, U> RoundInto<U> for Twhere U: RoundFrom<T>,

§

fn round_into(self) -> U

Performs the conversion.
source§

impl<T> Same<T> for T

§

type Output = T

Should always be Self
source§

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

§

type Error = Infallible

The type returned in the event of a conversion error.
const: unstable · source§

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

Performs the conversion.
source§

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

§

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

The type returned in the event of a conversion error.
const: unstable · source§

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

Performs the conversion.
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