[][src]Struct wayland_client::protocol::wl_data_device_manager::DndAction

pub struct DndAction { /* fields omitted */ }

drag and drop actions

This is a bitmask of the available/preferred actions in a drag-and-drop operation.

In the compositor, the selected action is a result of matching the actions offered by the source and destination sides. "action" events with a "none" action will be sent to both source and destination if there is no match. All further checks will effectively happen on (source actions ∩ destination actions).

In addition, compositors may also pick different actions in reaction to key modifiers being pressed. One common design that is used in major toolkits (and the behavior recommended for compositors) is:

  • If no modifiers are pressed, the first match (in bit order) will be used.
  • Pressing Shift selects "move", if enabled in the mask.
  • Pressing Control selects "copy", if enabled in the mask.

Behavior beyond that is considered implementation-dependent. Compositors may for example bind other modifiers (like Alt/Meta) or drags initiated with other buttons than BTN_LEFT to specific actions (e.g. "ask").

Methods

impl DndAction[src]

pub const None: DndAction[src]

no action

pub const Copy: DndAction[src]

copy action

pub const Move: DndAction[src]

move action

pub const Ask: DndAction[src]

ask action

pub const fn empty() -> DndAction[src]

Returns an empty set of flags

pub const fn all() -> DndAction[src]

Returns the set containing all flags.

pub const fn bits(&self) -> u32[src]

Returns the raw value of the flags currently stored.

pub fn from_bits(bits: u32) -> Option<DndAction>[src]

Convert from underlying bit representation, unless that representation contains bits that do not correspond to a flag.

pub const fn from_bits_truncate(bits: u32) -> DndAction[src]

Convert from underlying bit representation, dropping any bits that do not correspond to flags.

pub const unsafe fn from_bits_unchecked(bits: u32) -> DndAction[src]

Convert from underlying bit representation, preserving all bits (even those not corresponding to a defined flag).

pub const fn is_empty(&self) -> bool[src]

Returns true if no flags are currently stored.

pub const fn is_all(&self) -> bool[src]

Returns true if all flags are currently set.

pub const fn intersects(&self, other: DndAction) -> bool[src]

Returns true if there are flags common to both self and other.

pub const fn contains(&self, other: DndAction) -> bool[src]

Returns true all of the flags in other are contained within self.

pub fn insert(&mut self, other: DndAction)[src]

Inserts the specified flags in-place.

pub fn remove(&mut self, other: DndAction)[src]

Removes the specified flags in-place.

pub fn toggle(&mut self, other: DndAction)[src]

Toggles the specified flags in-place.

pub fn set(&mut self, other: DndAction, value: bool)[src]

Inserts or removes the specified flags depending on the passed value.

impl DndAction[src]

pub fn from_raw(n: u32) -> Option<DndAction>[src]

pub fn to_raw(&self) -> u32[src]

Trait Implementations

impl Binary for DndAction[src]

impl BitAnd<DndAction> for DndAction[src]

type Output = DndAction

The resulting type after applying the & operator.

fn bitand(self, other: DndAction) -> DndAction[src]

Returns the intersection between the two sets of flags.

impl BitAndAssign<DndAction> for DndAction[src]

fn bitand_assign(&mut self, other: DndAction)[src]

Disables all flags disabled in the set.

impl BitOr<DndAction> for DndAction[src]

type Output = DndAction

The resulting type after applying the | operator.

fn bitor(self, other: DndAction) -> DndAction[src]

Returns the union of the two sets of flags.

impl BitOrAssign<DndAction> for DndAction[src]

fn bitor_assign(&mut self, other: DndAction)[src]

Adds the set of flags.

impl BitXor<DndAction> for DndAction[src]

type Output = DndAction

The resulting type after applying the ^ operator.

fn bitxor(self, other: DndAction) -> DndAction[src]

Returns the left flags, but with all the right flags toggled.

impl BitXorAssign<DndAction> for DndAction[src]

fn bitxor_assign(&mut self, other: DndAction)[src]

Toggles the set of flags.

impl Clone for DndAction[src]

impl Copy for DndAction[src]

impl Debug for DndAction[src]

impl Eq for DndAction[src]

impl Extend<DndAction> for DndAction[src]

impl FromIterator<DndAction> for DndAction[src]

impl Hash for DndAction[src]

impl LowerHex for DndAction[src]

impl Not for DndAction[src]

type Output = DndAction

The resulting type after applying the ! operator.

fn not(self) -> DndAction[src]

Returns the complement of this set of flags.

impl Octal for DndAction[src]

impl Ord for DndAction[src]

impl PartialEq<DndAction> for DndAction[src]

impl PartialOrd<DndAction> for DndAction[src]

impl StructuralEq for DndAction[src]

impl StructuralPartialEq for DndAction[src]

impl Sub<DndAction> for DndAction[src]

type Output = DndAction

The resulting type after applying the - operator.

fn sub(self, other: DndAction) -> DndAction[src]

Returns the set difference of the two sets of flags.

impl SubAssign<DndAction> for DndAction[src]

fn sub_assign(&mut self, other: DndAction)[src]

Disables all flags enabled in the set.

impl UpperHex for DndAction[src]

Auto Trait Implementations

Blanket Implementations

impl<T> Any for T where
    T: 'static + ?Sized
[src]

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

impl<T> Downcast for T where
    T: Any
[src]

impl<T> DowncastSync for T where
    T: Send + Sync + Any
[src]

impl<T> From<T> for T[src]

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

impl<T> ToOwned for T where
    T: Clone
[src]

type Owned = T

The resulting type after obtaining ownership.

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

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

The type returned in the event of a conversion error.