pub struct KeyModifiers(/* private fields */);Expand description
Represents key modifiers (shift, control, alt, etc.).
Note: SUPER, HYPER, and META can only be read if
KeyboardEnhancementFlags::DISAMBIGUATE_ESCAPE_CODES has been enabled with
PushKeyboardEnhancementFlags.
Implementations§
Source§impl KeyModifiers
impl KeyModifiers
pub const SHIFT: KeyModifiers
pub const CONTROL: KeyModifiers
pub const ALT: KeyModifiers
pub const SUPER: KeyModifiers
pub const HYPER: KeyModifiers
pub const META: KeyModifiers
pub const NONE: KeyModifiers
Source§impl KeyModifiers
impl KeyModifiers
Sourcepub const fn empty() -> KeyModifiers
pub const fn empty() -> KeyModifiers
Get a flags value with all bits unset.
Sourcepub const fn all() -> KeyModifiers
pub const fn all() -> KeyModifiers
Get a flags value with all known bits set.
Sourcepub const fn bits(&self) -> u8
pub const fn bits(&self) -> u8
Get the underlying bits value.
The returned value is exactly the bits set in this flags value.
Sourcepub const fn from_bits(bits: u8) -> Option<KeyModifiers>
pub const fn from_bits(bits: u8) -> Option<KeyModifiers>
Convert from a bits value.
This method will return None if any unknown bits are set.
Sourcepub const fn from_bits_truncate(bits: u8) -> KeyModifiers
pub const fn from_bits_truncate(bits: u8) -> KeyModifiers
Convert from a bits value, unsetting any unknown bits.
Sourcepub const fn from_bits_retain(bits: u8) -> KeyModifiers
pub const fn from_bits_retain(bits: u8) -> KeyModifiers
Convert from a bits value exactly.
Sourcepub fn from_name(name: &str) -> Option<KeyModifiers>
pub fn from_name(name: &str) -> Option<KeyModifiers>
Get a flags value with the bits of a flag with the given name set.
This method will return None if name is empty or doesn’t
correspond to any named flag.
Sourcepub const fn intersects(&self, other: KeyModifiers) -> bool
pub const fn intersects(&self, other: KeyModifiers) -> bool
Whether any set bits in a source flags value are also set in a target flags value.
Sourcepub const fn contains(&self, other: KeyModifiers) -> bool
pub const fn contains(&self, other: KeyModifiers) -> bool
Whether all set bits in a source flags value are also set in a target flags value.
Sourcepub fn insert(&mut self, other: KeyModifiers)
pub fn insert(&mut self, other: KeyModifiers)
The bitwise or (|) of the bits in two flags values.
Sourcepub fn remove(&mut self, other: KeyModifiers)
pub fn remove(&mut self, other: KeyModifiers)
The intersection of a source flags value with the complement of a target flags value (&!).
This method is not equivalent to self & !other when other has unknown bits set.
remove won’t truncate other, but the ! operator will.
Sourcepub fn toggle(&mut self, other: KeyModifiers)
pub fn toggle(&mut self, other: KeyModifiers)
The bitwise exclusive-or (^) of the bits in two flags values.
Sourcepub fn set(&mut self, other: KeyModifiers, value: bool)
pub fn set(&mut self, other: KeyModifiers, value: bool)
Call insert when value is true or remove when value is false.
Sourcepub const fn intersection(self, other: KeyModifiers) -> KeyModifiers
pub const fn intersection(self, other: KeyModifiers) -> KeyModifiers
The bitwise and (&) of the bits in two flags values.
Sourcepub const fn union(self, other: KeyModifiers) -> KeyModifiers
pub const fn union(self, other: KeyModifiers) -> KeyModifiers
The bitwise or (|) of the bits in two flags values.
Sourcepub const fn difference(self, other: KeyModifiers) -> KeyModifiers
pub const fn difference(self, other: KeyModifiers) -> KeyModifiers
The intersection of a source flags value with the complement of a target flags value (&!).
This method is not equivalent to self & !other when other has unknown bits set.
difference won’t truncate other, but the ! operator will.
Sourcepub const fn symmetric_difference(self, other: KeyModifiers) -> KeyModifiers
pub const fn symmetric_difference(self, other: KeyModifiers) -> KeyModifiers
The bitwise exclusive-or (^) of the bits in two flags values.
Sourcepub const fn complement(self) -> KeyModifiers
pub const fn complement(self) -> KeyModifiers
The bitwise negation (!) of the bits in a flags value, truncating the result.
Source§impl KeyModifiers
impl KeyModifiers
Sourcepub const fn iter(&self) -> Iter<KeyModifiers>
pub const fn iter(&self) -> Iter<KeyModifiers>
Yield a set of contained flags values.
Each yielded flags value will correspond to a defined named flag. Any unknown bits will be yielded together as a final flags value.
Sourcepub const fn iter_names(&self) -> IterNames<KeyModifiers>
pub const fn iter_names(&self) -> IterNames<KeyModifiers>
Yield a set of contained named flags values.
This method is like iter, except only yields bits in contained named flags.
Any unknown bits, or bits not corresponding to a contained flag will not be yielded.
Trait Implementations§
Source§impl Binary for KeyModifiers
impl Binary for KeyModifiers
Source§impl BitAnd for KeyModifiers
impl BitAnd for KeyModifiers
Source§fn bitand(self, other: KeyModifiers) -> KeyModifiers
fn bitand(self, other: KeyModifiers) -> KeyModifiers
The bitwise and (&) of the bits in two flags values.
Source§type Output = KeyModifiers
type Output = KeyModifiers
& operator.Source§impl BitAndAssign for KeyModifiers
impl BitAndAssign for KeyModifiers
Source§fn bitand_assign(&mut self, other: KeyModifiers)
fn bitand_assign(&mut self, other: KeyModifiers)
The bitwise and (&) of the bits in two flags values.
Source§impl BitOr for KeyModifiers
impl BitOr for KeyModifiers
Source§fn bitor(self, other: KeyModifiers) -> KeyModifiers
fn bitor(self, other: KeyModifiers) -> KeyModifiers
The bitwise or (|) of the bits in two flags values.
Source§type Output = KeyModifiers
type Output = KeyModifiers
| operator.Source§impl BitOrAssign for KeyModifiers
impl BitOrAssign for KeyModifiers
Source§fn bitor_assign(&mut self, other: KeyModifiers)
fn bitor_assign(&mut self, other: KeyModifiers)
The bitwise or (|) of the bits in two flags values.
Source§impl BitXor for KeyModifiers
impl BitXor for KeyModifiers
Source§fn bitxor(self, other: KeyModifiers) -> KeyModifiers
fn bitxor(self, other: KeyModifiers) -> KeyModifiers
The bitwise exclusive-or (^) of the bits in two flags values.
Source§type Output = KeyModifiers
type Output = KeyModifiers
^ operator.Source§impl BitXorAssign for KeyModifiers
impl BitXorAssign for KeyModifiers
Source§fn bitxor_assign(&mut self, other: KeyModifiers)
fn bitxor_assign(&mut self, other: KeyModifiers)
The bitwise exclusive-or (^) of the bits in two flags values.
Source§impl Clone for KeyModifiers
impl Clone for KeyModifiers
Source§fn clone(&self) -> KeyModifiers
fn clone(&self) -> KeyModifiers
1.0.0 (const: unstable) · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreimpl Copy for KeyModifiers
Source§impl Debug for KeyModifiers
impl Debug for KeyModifiers
Source§impl Display for KeyModifiers
impl Display for KeyModifiers
Source§fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>
fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>
Formats the key modifiers using the given formatter.
The key modifiers are joined by a + character.
§Platform-specific Notes
On macOS, the control, alt, and super keys is displayed as “Control”, “Option”, and “Command” respectively. See https://support.apple.com/guide/applestyleguide/welcome/1.0/web.
On Windows, the super key is displayed as “Windows” and the control key is displayed as “Ctrl”. See https://learn.microsoft.com/en-us/style-guide/a-z-word-list-term-collections/term-collections/keys-keyboard-shortcuts.
On other platforms, the super key is referred to as “Super” and the control key is displayed as “Ctrl”.
impl Eq for KeyModifiers
Source§impl Extend<KeyModifiers> for KeyModifiers
impl Extend<KeyModifiers> for KeyModifiers
Source§fn extend<T>(&mut self, iterator: T)where
T: IntoIterator<Item = KeyModifiers>,
fn extend<T>(&mut self, iterator: T)where
T: IntoIterator<Item = KeyModifiers>,
The bitwise or (|) of the bits in each flags value.
Source§fn extend_one(&mut self, item: A)
fn extend_one(&mut self, item: A)
extend_one)Source§fn extend_reserve(&mut self, additional: usize)
fn extend_reserve(&mut self, additional: usize)
extend_one)Source§impl Flags for KeyModifiers
impl Flags for KeyModifiers
Source§const FLAGS: &'static [Flag<KeyModifiers>]
const FLAGS: &'static [Flag<KeyModifiers>]
Source§fn from_bits_retain(bits: u8) -> KeyModifiers
fn from_bits_retain(bits: u8) -> KeyModifiers
Source§fn from_bits_truncate(bits: Self::Bits) -> Self
fn from_bits_truncate(bits: Self::Bits) -> Self
Source§fn from_name(name: &str) -> Option<Self>
fn from_name(name: &str) -> Option<Self>
Source§fn iter_names(&self) -> IterNames<Self>
fn iter_names(&self) -> IterNames<Self>
Source§fn intersects(&self, other: Self) -> boolwhere
Self: Sized,
fn intersects(&self, other: Self) -> boolwhere
Self: Sized,
Source§fn contains(&self, other: Self) -> boolwhere
Self: Sized,
fn contains(&self, other: Self) -> boolwhere
Self: Sized,
Source§fn insert(&mut self, other: Self)where
Self: Sized,
fn insert(&mut self, other: Self)where
Self: Sized,
|) of the bits in two flags values.Source§fn remove(&mut self, other: Self)where
Self: Sized,
fn remove(&mut self, other: Self)where
Self: Sized,
&!). Read moreSource§fn toggle(&mut self, other: Self)where
Self: Sized,
fn toggle(&mut self, other: Self)where
Self: Sized,
^) of the bits in two flags values.Source§fn intersection(self, other: Self) -> Self
fn intersection(self, other: Self) -> Self
&) of the bits in two flags values.Source§fn difference(self, other: Self) -> Self
fn difference(self, other: Self) -> Self
&!). Read moreSource§fn symmetric_difference(self, other: Self) -> Self
fn symmetric_difference(self, other: Self) -> Self
^) of the bits in two flags values.Source§fn complement(self) -> Self
fn complement(self) -> Self
!) of the bits in a flags value, truncating the result.Source§impl FromIterator<KeyModifiers> for KeyModifiers
impl FromIterator<KeyModifiers> for KeyModifiers
Source§fn from_iter<T>(iterator: T) -> KeyModifierswhere
T: IntoIterator<Item = KeyModifiers>,
fn from_iter<T>(iterator: T) -> KeyModifierswhere
T: IntoIterator<Item = KeyModifiers>,
The bitwise or (|) of the bits in each flags value.
Source§impl Hash for KeyModifiers
impl Hash for KeyModifiers
Source§impl IntoIterator for KeyModifiers
impl IntoIterator for KeyModifiers
Source§type Item = KeyModifiers
type Item = KeyModifiers
Source§type IntoIter = Iter<KeyModifiers>
type IntoIter = Iter<KeyModifiers>
Source§fn into_iter(self) -> <KeyModifiers as IntoIterator>::IntoIter
fn into_iter(self) -> <KeyModifiers as IntoIterator>::IntoIter
Source§impl LowerHex for KeyModifiers
impl LowerHex for KeyModifiers
Source§impl Not for KeyModifiers
impl Not for KeyModifiers
Source§fn not(self) -> KeyModifiers
fn not(self) -> KeyModifiers
The bitwise negation (!) of the bits in a flags value, truncating the result.
Source§type Output = KeyModifiers
type Output = KeyModifiers
! operator.Source§impl Octal for KeyModifiers
impl Octal for KeyModifiers
Source§impl PartialEq for KeyModifiers
impl PartialEq for KeyModifiers
Source§fn eq(&self, other: &KeyModifiers) -> bool
fn eq(&self, other: &KeyModifiers) -> bool
self and other values to be equal, and is used by ==.Source§impl PartialOrd for KeyModifiers
impl PartialOrd for KeyModifiers
impl StructuralPartialEq for KeyModifiers
Source§impl Sub for KeyModifiers
impl Sub for KeyModifiers
Source§fn sub(self, other: KeyModifiers) -> KeyModifiers
fn sub(self, other: KeyModifiers) -> KeyModifiers
The intersection of a source flags value with the complement of a target flags value (&!).
This method is not equivalent to self & !other when other has unknown bits set.
difference won’t truncate other, but the ! operator will.
Source§type Output = KeyModifiers
type Output = KeyModifiers
- operator.Source§impl SubAssign for KeyModifiers
impl SubAssign for KeyModifiers
Source§fn sub_assign(&mut self, other: KeyModifiers)
fn sub_assign(&mut self, other: KeyModifiers)
The intersection of a source flags value with the complement of a target flags value (&!).
This method is not equivalent to self & !other when other has unknown bits set.
difference won’t truncate other, but the ! operator will.