[]Struct rubble::link::ad_structure::Flags

pub struct Flags { /* fields omitted */ }

BR/EDR and LE compatibility flags.

This is mandatory for most devices and can only be omitted if all flags are 0.

Methods

impl Flags

pub const LE_LIMITED_DISCOVERABLE: Flags

pub const LE_GENERAL_DISCOVERABLE: Flags

pub const BR_EDR_NOT_SUPPORTED: Flags

pub const SIMUL_LE_BR_CONTROLLER: Flags

pub const SIMUL_LE_BR_HOST: Flags

pub fn empty() -> Flags

Returns an empty set of flags.

pub fn all() -> Flags

Returns the set containing all flags.

pub fn bits(&self) -> u8

Returns the raw value of the flags currently stored.

pub fn from_bits(bits: u8) -> Option<Flags>

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

pub fn from_bits_truncate(bits: u8) -> Flags

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

pub fn is_empty(&self) -> bool

Returns true if no flags are currently stored.

pub fn is_all(&self) -> bool

Returns true if all flags are currently set.

pub fn intersects(&self, other: Flags) -> bool

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

pub fn contains(&self, other: Flags) -> bool

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

pub fn insert(&mut self, other: Flags)

Inserts the specified flags in-place.

pub fn remove(&mut self, other: Flags)

Removes the specified flags in-place.

pub fn toggle(&mut self, other: Flags)

Toggles the specified flags in-place.

pub fn set(&mut self, other: Flags, value: bool)

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

impl Flags[src]

pub fn discoverable() -> Flags[src]

Returns flags suitable for discoverable devices that want to establish a connection.

The created Flags value specifies that this device is not BR/EDR (classic Bluetooth) capable and is in General Discoverable mode.

pub fn broadcast() -> Flags[src]

Returns flags suitable for non-connectable devices that just broadcast advertising packets.

Creates a Flags value that specifies that BR/EDR (classic Bluetooth) is not supported and that this device is not discoverable.

pub fn to_u8(self) -> u8[src]

Returns the raw representation of the flags.

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

Returns a boolean indicating whether the device that sent this Flags value supports BR/EDR (aka "Classic Bluetooth").

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

Device operating in LE Limited Discoverable mode.

Either this or le_general_discoverable() must be set for the device to be discoverable. Note that "Broadcast Mode" still works with undiscoverable devices, since it doesn't need discovery or connections.

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

Device operating in LE General Discoverable mode.

Either this or le_limited_discoverable() must be set for the device to be discoverable. Note that "Broadcast Mode" still works with undiscoverable devices, since it doesn't need discovery or connections.

Trait Implementations

impl PartialEq<Flags> for Flags

impl Eq for Flags

impl Ord for Flags

fn max(self, other: Self) -> Self
1.21.0
[src]

Compares and returns the maximum of two values. Read more

fn min(self, other: Self) -> Self
1.21.0
[src]

Compares and returns the minimum of two values. Read more

fn clamp(self, min: Self, max: Self) -> Self[src]

🔬 This is a nightly-only experimental API. (clamp)

Restrict a value to a certain interval. Read more

impl PartialOrd<Flags> for Flags

impl Clone for Flags

fn clone_from(&mut self, source: &Self)
1.0.0
[src]

Performs copy-assignment from source. Read more

impl Copy for Flags

impl Debug for Flags

impl Sub<Flags> for Flags

type Output = Flags

The resulting type after applying the - operator.

fn sub(self, other: Flags) -> Flags

Returns the set difference of the two sets of flags.

impl<'a> From<Flags> for AdStructure<'a>[src]

impl Hash for Flags

fn hash_slice<H>(data: &[Self], state: &mut H) where
    H: Hasher
1.3.0
[src]

Feeds a slice of this type into the given [Hasher]. Read more

impl SubAssign<Flags> for Flags

fn sub_assign(&mut self, other: Flags)

Disables all flags enabled in the set.

impl Not for Flags

type Output = Flags

The resulting type after applying the ! operator.

fn not(self) -> Flags

Returns the complement of this set of flags.

impl BitAnd<Flags> for Flags

type Output = Flags

The resulting type after applying the & operator.

fn bitand(self, other: Flags) -> Flags

Returns the intersection between the two sets of flags.

impl BitOr<Flags> for Flags

type Output = Flags

The resulting type after applying the | operator.

fn bitor(self, other: Flags) -> Flags

Returns the union of the two sets of flags.

impl BitXor<Flags> for Flags

type Output = Flags

The resulting type after applying the ^ operator.

fn bitxor(self, other: Flags) -> Flags

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

impl BitAndAssign<Flags> for Flags

fn bitand_assign(&mut self, other: Flags)

Disables all flags disabled in the set.

impl BitOrAssign<Flags> for Flags

fn bitor_assign(&mut self, other: Flags)

Adds the set of flags.

impl BitXorAssign<Flags> for Flags

fn bitxor_assign(&mut self, other: Flags)

Toggles the set of flags.

impl Extend<Flags> for Flags

impl FromIterator<Flags> for Flags

impl Octal for Flags

impl Binary for Flags

impl LowerHex for Flags

impl UpperHex for Flags

Auto Trait Implementations

impl Send for Flags

impl Sync for Flags

Blanket Implementations

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

type Error = Infallible

The type returned in the event of a conversion error.

impl<T> From for T[src]

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

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

The type returned in the event of a conversion error.

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

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

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

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