pub struct SerialControlFlag(/* private fields */);Expand description
MAVLink bitmask enum SERIAL_CONTROL_FLAG for common dialect.
SERIAL_CONTROL flags (bitmask)
Implementations§
Source§impl SerialControlFlag
impl SerialControlFlag
Sourcepub const REPLY: SerialControlFlag
pub const REPLY: SerialControlFlag
SERIAL_CONTROL_FLAG_REPLY flag.
Set if this is a reply
Sourcepub const RESPOND: SerialControlFlag
pub const RESPOND: SerialControlFlag
SERIAL_CONTROL_FLAG_RESPOND flag.
Set if the sender wants the receiver to send a response as another SERIAL_CONTROL message
Sourcepub const EXCLUSIVE: SerialControlFlag
pub const EXCLUSIVE: SerialControlFlag
SERIAL_CONTROL_FLAG_EXCLUSIVE flag.
Set if access to the serial port should be removed from whatever driver is currently using it, giving exclusive access to the SERIAL_CONTROL protocol. The port can be handed back by sending a request without this flag set
Sourcepub const BLOCKING: SerialControlFlag
pub const BLOCKING: SerialControlFlag
SERIAL_CONTROL_FLAG_BLOCKING flag.
Block on writes to the serial port
Sourcepub const MULTI: SerialControlFlag
pub const MULTI: SerialControlFlag
SERIAL_CONTROL_FLAG_MULTI flag.
Send multiple replies until port is drained
Source§impl SerialControlFlag
impl SerialControlFlag
Sourcepub const fn empty() -> SerialControlFlag
pub const fn empty() -> SerialControlFlag
Get a flags value with all bits unset.
Sourcepub const fn all() -> SerialControlFlag
pub const fn all() -> SerialControlFlag
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<SerialControlFlag>
pub const fn from_bits(bits: u8) -> Option<SerialControlFlag>
Convert from a bits value.
This method will return None if any unknown bits are set.
Sourcepub const fn from_bits_truncate(bits: u8) -> SerialControlFlag
pub const fn from_bits_truncate(bits: u8) -> SerialControlFlag
Convert from a bits value, unsetting any unknown bits.
Sourcepub const fn from_bits_retain(bits: u8) -> SerialControlFlag
pub const fn from_bits_retain(bits: u8) -> SerialControlFlag
Convert from a bits value exactly.
Sourcepub fn from_name(name: &str) -> Option<SerialControlFlag>
pub fn from_name(name: &str) -> Option<SerialControlFlag>
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: SerialControlFlag) -> bool
pub const fn intersects(&self, other: SerialControlFlag) -> bool
Whether any set bits in a source flags value are also set in a target flags value.
Sourcepub const fn contains(&self, other: SerialControlFlag) -> bool
pub const fn contains(&self, other: SerialControlFlag) -> bool
Whether all set bits in a source flags value are also set in a target flags value.
Sourcepub fn insert(&mut self, other: SerialControlFlag)
pub fn insert(&mut self, other: SerialControlFlag)
The bitwise or (|) of the bits in two flags values.
Sourcepub fn remove(&mut self, other: SerialControlFlag)
pub fn remove(&mut self, other: SerialControlFlag)
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: SerialControlFlag)
pub fn toggle(&mut self, other: SerialControlFlag)
The bitwise exclusive-or (^) of the bits in two flags values.
Sourcepub fn set(&mut self, other: SerialControlFlag, value: bool)
pub fn set(&mut self, other: SerialControlFlag, value: bool)
Call insert when value is true or remove when value is false.
Sourcepub const fn intersection(self, other: SerialControlFlag) -> SerialControlFlag
pub const fn intersection(self, other: SerialControlFlag) -> SerialControlFlag
The bitwise and (&) of the bits in two flags values.
Sourcepub const fn union(self, other: SerialControlFlag) -> SerialControlFlag
pub const fn union(self, other: SerialControlFlag) -> SerialControlFlag
The bitwise or (|) of the bits in two flags values.
Sourcepub const fn difference(self, other: SerialControlFlag) -> SerialControlFlag
pub const fn difference(self, other: SerialControlFlag) -> SerialControlFlag
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: SerialControlFlag,
) -> SerialControlFlag
pub const fn symmetric_difference( self, other: SerialControlFlag, ) -> SerialControlFlag
The bitwise exclusive-or (^) of the bits in two flags values.
Sourcepub const fn complement(self) -> SerialControlFlag
pub const fn complement(self) -> SerialControlFlag
The bitwise negation (!) of the bits in a flags value, truncating the result.
Source§impl SerialControlFlag
impl SerialControlFlag
Sourcepub const fn iter(&self) -> Iter<SerialControlFlag> ⓘ
pub const fn iter(&self) -> Iter<SerialControlFlag> ⓘ
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<SerialControlFlag> ⓘ
pub const fn iter_names(&self) -> IterNames<SerialControlFlag> ⓘ
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 SerialControlFlag
impl Binary for SerialControlFlag
Source§impl BitAnd for SerialControlFlag
impl BitAnd for SerialControlFlag
Source§fn bitand(self, other: SerialControlFlag) -> SerialControlFlag
fn bitand(self, other: SerialControlFlag) -> SerialControlFlag
The bitwise and (&) of the bits in two flags values.
Source§type Output = SerialControlFlag
type Output = SerialControlFlag
& operator.Source§impl BitAndAssign for SerialControlFlag
impl BitAndAssign for SerialControlFlag
Source§fn bitand_assign(&mut self, other: SerialControlFlag)
fn bitand_assign(&mut self, other: SerialControlFlag)
The bitwise and (&) of the bits in two flags values.
Source§impl BitOr for SerialControlFlag
impl BitOr for SerialControlFlag
Source§fn bitor(self, other: SerialControlFlag) -> SerialControlFlag
fn bitor(self, other: SerialControlFlag) -> SerialControlFlag
The bitwise or (|) of the bits in two flags values.
Source§type Output = SerialControlFlag
type Output = SerialControlFlag
| operator.Source§impl BitOrAssign for SerialControlFlag
impl BitOrAssign for SerialControlFlag
Source§fn bitor_assign(&mut self, other: SerialControlFlag)
fn bitor_assign(&mut self, other: SerialControlFlag)
The bitwise or (|) of the bits in two flags values.
Source§impl BitXor for SerialControlFlag
impl BitXor for SerialControlFlag
Source§fn bitxor(self, other: SerialControlFlag) -> SerialControlFlag
fn bitxor(self, other: SerialControlFlag) -> SerialControlFlag
The bitwise exclusive-or (^) of the bits in two flags values.
Source§type Output = SerialControlFlag
type Output = SerialControlFlag
^ operator.Source§impl BitXorAssign for SerialControlFlag
impl BitXorAssign for SerialControlFlag
Source§fn bitxor_assign(&mut self, other: SerialControlFlag)
fn bitxor_assign(&mut self, other: SerialControlFlag)
The bitwise exclusive-or (^) of the bits in two flags values.
Source§impl Clone for SerialControlFlag
impl Clone for SerialControlFlag
Source§fn clone(&self) -> SerialControlFlag
fn clone(&self) -> SerialControlFlag
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl Debug for SerialControlFlag
impl Debug for SerialControlFlag
Source§impl Default for SerialControlFlag
impl Default for SerialControlFlag
Source§fn default() -> SerialControlFlag
fn default() -> SerialControlFlag
Source§impl<'de> Deserialize<'de> for SerialControlFlag
impl<'de> Deserialize<'de> for SerialControlFlag
Source§fn deserialize<__D>(
__deserializer: __D,
) -> Result<SerialControlFlag, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(
__deserializer: __D,
) -> Result<SerialControlFlag, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
Source§impl Extend<SerialControlFlag> for SerialControlFlag
impl Extend<SerialControlFlag> for SerialControlFlag
Source§fn extend<T>(&mut self, iterator: T)where
T: IntoIterator<Item = SerialControlFlag>,
fn extend<T>(&mut self, iterator: T)where
T: IntoIterator<Item = SerialControlFlag>,
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 SerialControlFlag
impl Flags for SerialControlFlag
Source§const FLAGS: &'static [Flag<SerialControlFlag>]
const FLAGS: &'static [Flag<SerialControlFlag>]
Source§fn from_bits_retain(bits: u8) -> SerialControlFlag
fn from_bits_retain(bits: u8) -> SerialControlFlag
Source§fn contains_unknown_bits(&self) -> bool
fn contains_unknown_bits(&self) -> bool
true if any unknown bits are set.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<SerialControlFlag> for SerialControlFlag
impl FromIterator<SerialControlFlag> for SerialControlFlag
Source§fn from_iter<T>(iterator: T) -> SerialControlFlagwhere
T: IntoIterator<Item = SerialControlFlag>,
fn from_iter<T>(iterator: T) -> SerialControlFlagwhere
T: IntoIterator<Item = SerialControlFlag>,
The bitwise or (|) of the bits in each flags value.
Source§impl IntoIterator for SerialControlFlag
impl IntoIterator for SerialControlFlag
Source§type Item = SerialControlFlag
type Item = SerialControlFlag
Source§type IntoIter = Iter<SerialControlFlag>
type IntoIter = Iter<SerialControlFlag>
Source§fn into_iter(self) -> <SerialControlFlag as IntoIterator>::IntoIter
fn into_iter(self) -> <SerialControlFlag as IntoIterator>::IntoIter
Source§impl LowerHex for SerialControlFlag
impl LowerHex for SerialControlFlag
Source§impl NamedType for SerialControlFlag
impl NamedType for SerialControlFlag
fn sid() -> SpectaID
Source§fn named_data_type(
type_map: &mut TypeCollection,
generics: &[DataType],
) -> NamedDataType
fn named_data_type( type_map: &mut TypeCollection, generics: &[DataType], ) -> NamedDataType
Source§fn definition_named_data_type(type_map: &mut TypeCollection) -> NamedDataType
fn definition_named_data_type(type_map: &mut TypeCollection) -> NamedDataType
Source§impl Not for SerialControlFlag
impl Not for SerialControlFlag
Source§fn not(self) -> SerialControlFlag
fn not(self) -> SerialControlFlag
The bitwise negation (!) of the bits in a flags value, truncating the result.
Source§type Output = SerialControlFlag
type Output = SerialControlFlag
! operator.Source§impl Octal for SerialControlFlag
impl Octal for SerialControlFlag
Source§impl PartialEq for SerialControlFlag
impl PartialEq for SerialControlFlag
Source§impl Serialize for SerialControlFlag
impl Serialize for SerialControlFlag
Source§fn serialize<__S>(
&self,
__serializer: __S,
) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>where
__S: Serializer,
fn serialize<__S>(
&self,
__serializer: __S,
) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>where
__S: Serializer,
Source§impl Sub for SerialControlFlag
impl Sub for SerialControlFlag
Source§fn sub(self, other: SerialControlFlag) -> SerialControlFlag
fn sub(self, other: SerialControlFlag) -> SerialControlFlag
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 = SerialControlFlag
type Output = SerialControlFlag
- operator.Source§impl SubAssign for SerialControlFlag
impl SubAssign for SerialControlFlag
Source§fn sub_assign(&mut self, other: SerialControlFlag)
fn sub_assign(&mut self, other: SerialControlFlag)
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§impl Type for SerialControlFlag
impl Type for SerialControlFlag
Source§fn inline(type_map: &mut TypeCollection, generics: Generics<'_>) -> DataType
fn inline(type_map: &mut TypeCollection, generics: Generics<'_>) -> DataType
Source§fn reference(type_map: &mut TypeCollection, generics: &[DataType]) -> Reference
fn reference(type_map: &mut TypeCollection, generics: &[DataType]) -> Reference
definition will be put into the type map.