Struct bitcoin_service_flags::ServiceFlags
source · pub struct ServiceFlags { /* private fields */ }Implementations§
source§impl ServiceFlags
impl ServiceFlags
sourcepub const NODE_NONE: Self = _
pub const NODE_NONE: Self = _
| @note | | When adding here, be sure to update | serviceFlagToStr too Nothing |
sourcepub const NODE_NETWORK: Self = _
pub const NODE_NETWORK: Self = _
| NODE_NETWORK means that the node is capable | of serving the complete block chain. It is | currently set by all Bitcoin Core non | pruned nodes, and is unset by SPV clients | or other light clients.
sourcepub const NODE_BLOOM: Self = _
pub const NODE_BLOOM: Self = _
| NODE_BLOOM means the node is capable and | willing to handle bloom-filtered | connections. | | Bitcoin Core nodes used to support this by | default, without advertising this bit, but | no longer do as of protocol version 70011 | (= NO_BLOOM_VERSION)
sourcepub const NODE_WITNESS: Self = _
pub const NODE_WITNESS: Self = _
| NODE_WITNESS indicates that a node | can be asked for blocks and transactions | including witness data. |
sourcepub const NODE_COMPACT_FILTERS: Self = _
pub const NODE_COMPACT_FILTERS: Self = _
| NODE_COMPACT_FILTERS means the node will | service basic block filter requests. | | See BIP157 and BIP158 for details on how | this is implemented.
sourcepub const NODE_NETWORK_LIMITED: Self = _
pub const NODE_NETWORK_LIMITED: Self = _
| NODE_NETWORK_LIMITED means the same as | NODE_NETWORK with the limitation of only | serving the last 288 (2 day) blocks | | See BIP159 for details on how this is | implemented.
sourcepub const fn from_bits(bits: u64) -> Option<Self>
pub const fn from_bits(bits: u64) -> Option<Self>
Convert from underlying bit representation, unless that representation contains bits that do not correspond to a flag.
sourcepub const fn from_bits_truncate(bits: u64) -> Self
pub const fn from_bits_truncate(bits: u64) -> Self
Convert from underlying bit representation, dropping any bits that do not correspond to flags.
sourcepub const unsafe fn from_bits_unchecked(bits: u64) -> Self
pub const unsafe fn from_bits_unchecked(bits: u64) -> Self
Convert from underlying bit representation, preserving all bits (even those not corresponding to a defined flag).
Safety
The caller of the bitflags! macro can chose to allow or
disallow extra bits for their bitflags type.
The caller of from_bits_unchecked() has to ensure that
all bits correspond to a defined flag or that extra bits
are valid for this bitflags type.
sourcepub const fn intersects(&self, other: Self) -> bool
pub const fn intersects(&self, other: Self) -> bool
Returns true if there are flags common to both self and other.
sourcepub const fn contains(&self, other: Self) -> bool
pub const fn contains(&self, other: Self) -> bool
Returns true if all of the flags in other are contained within self.
sourcepub fn set(&mut self, other: Self, value: bool)
pub fn set(&mut self, other: Self, value: bool)
Inserts or removes the specified flags depending on the passed value.
sourcepub const fn intersection(self, other: Self) -> Self
pub const fn intersection(self, other: Self) -> Self
Returns the intersection between the flags in self and
other.
Specifically, the returned set contains only the flags which are
present in both self and other.
This is equivalent to using the & operator (e.g.
ops::BitAnd), as in flags & other.
sourcepub const fn union(self, other: Self) -> Self
pub const fn union(self, other: Self) -> Self
Returns the union of between the flags in self and other.
Specifically, the returned set contains all flags which are
present in either self or other, including any which are
present in both (see Self::symmetric_difference if that
is undesirable).
This is equivalent to using the | operator (e.g.
ops::BitOr), as in flags | other.
sourcepub const fn difference(self, other: Self) -> Self
pub const fn difference(self, other: Self) -> Self
Returns the difference between the flags in self and other.
Specifically, the returned set contains all flags present in
self, except for the ones present in other.
It is also conceptually equivalent to the “bit-clear” operation:
flags & !other (and this syntax is also supported).
This is equivalent to using the - operator (e.g.
ops::Sub), as in flags - other.
sourcepub const fn symmetric_difference(self, other: Self) -> Self
pub const fn symmetric_difference(self, other: Self) -> Self
Returns the symmetric difference between the flags
in self and other.
Specifically, the returned set contains the flags present which
are present in self or other, but that are not present in
both. Equivalently, it contains the flags present in exactly
one of the sets self and other.
This is equivalent to using the ^ operator (e.g.
ops::BitXor), as in flags ^ other.
sourcepub const fn complement(self) -> Self
pub const fn complement(self) -> Self
Returns the complement of this set of flags.
Specifically, the returned set contains all the flags which are
not set in self, but which are allowed for this type.
Alternatively, it can be thought of as the set difference
between Self::all() and self (e.g. Self::all() - self)
This is equivalent to using the ! operator (e.g.
ops::Not), as in !flags.
Trait Implementations§
source§impl Binary for ServiceFlags
impl Binary for ServiceFlags
source§impl BitAnd<ServiceFlags> for ServiceFlags
impl BitAnd<ServiceFlags> for ServiceFlags
source§impl BitAndAssign<ServiceFlags> for ServiceFlags
impl BitAndAssign<ServiceFlags> for ServiceFlags
source§fn bitand_assign(&mut self, other: Self)
fn bitand_assign(&mut self, other: Self)
Disables all flags disabled in the set.
source§impl BitOr<ServiceFlags> for ServiceFlags
impl BitOr<ServiceFlags> for ServiceFlags
source§fn bitor(self, other: ServiceFlags) -> Self
fn bitor(self, other: ServiceFlags) -> Self
Returns the union of the two sets of flags.
§type Output = ServiceFlags
type Output = ServiceFlags
| operator.source§impl BitOrAssign<ServiceFlags> for ServiceFlags
impl BitOrAssign<ServiceFlags> for ServiceFlags
source§fn bitor_assign(&mut self, other: Self)
fn bitor_assign(&mut self, other: Self)
Adds the set of flags.
source§impl BitXor<ServiceFlags> for ServiceFlags
impl BitXor<ServiceFlags> for ServiceFlags
source§impl BitXorAssign<ServiceFlags> for ServiceFlags
impl BitXorAssign<ServiceFlags> for ServiceFlags
source§fn bitxor_assign(&mut self, other: Self)
fn bitxor_assign(&mut self, other: Self)
Toggles the set of flags.
source§impl Clone for ServiceFlags
impl Clone for ServiceFlags
source§fn clone(&self) -> ServiceFlags
fn clone(&self) -> ServiceFlags
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moresource§impl Debug for ServiceFlags
impl Debug for ServiceFlags
source§impl Default for ServiceFlags
impl Default for ServiceFlags
source§impl<'de> Deserialize<'de> for ServiceFlags
impl<'de> Deserialize<'de> for ServiceFlags
source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where __D: Deserializer<'de>,
source§impl Extend<ServiceFlags> for ServiceFlags
impl Extend<ServiceFlags> for ServiceFlags
source§fn extend<T: IntoIterator<Item = Self>>(&mut self, iterator: T)
fn extend<T: IntoIterator<Item = Self>>(&mut self, iterator: T)
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 From<u64> for ServiceFlags
impl From<u64> for ServiceFlags
source§impl FromIterator<ServiceFlags> for ServiceFlags
impl FromIterator<ServiceFlags> for ServiceFlags
source§fn from_iter<T: IntoIterator<Item = Self>>(iterator: T) -> Self
fn from_iter<T: IntoIterator<Item = Self>>(iterator: T) -> Self
source§impl Hash for ServiceFlags
impl Hash for ServiceFlags
source§impl LowerHex for ServiceFlags
impl LowerHex for ServiceFlags
source§impl Not for ServiceFlags
impl Not for ServiceFlags
source§impl Octal for ServiceFlags
impl Octal for ServiceFlags
source§impl Ord for ServiceFlags
impl Ord for ServiceFlags
source§fn cmp(&self, other: &ServiceFlags) -> Ordering
fn cmp(&self, other: &ServiceFlags) -> Ordering
1.21.0 · source§fn max(self, other: Self) -> Selfwhere
Self: Sized,
fn max(self, other: Self) -> Selfwhere Self: Sized,
source§impl PartialEq<ServiceFlags> for ServiceFlags
impl PartialEq<ServiceFlags> for ServiceFlags
source§fn eq(&self, other: &ServiceFlags) -> bool
fn eq(&self, other: &ServiceFlags) -> bool
self and other values to be equal, and is used
by ==.source§impl PartialOrd<ServiceFlags> for ServiceFlags
impl PartialOrd<ServiceFlags> for ServiceFlags
source§fn partial_cmp(&self, other: &ServiceFlags) -> Option<Ordering>
fn partial_cmp(&self, other: &ServiceFlags) -> Option<Ordering>
1.0.0 · source§fn le(&self, other: &Rhs) -> bool
fn le(&self, other: &Rhs) -> bool
self and other) and is used by the <=
operator. Read moresource§impl Serialize for ServiceFlags
impl Serialize for ServiceFlags
source§impl Sub<ServiceFlags> for ServiceFlags
impl Sub<ServiceFlags> for ServiceFlags
source§impl SubAssign<ServiceFlags> for ServiceFlags
impl SubAssign<ServiceFlags> for ServiceFlags
source§fn sub_assign(&mut self, other: Self)
fn sub_assign(&mut self, other: Self)
Disables all flags enabled in the set.
source§impl UpperHex for ServiceFlags
impl UpperHex for ServiceFlags
impl Copy for ServiceFlags
impl Eq for ServiceFlags
impl StructuralEq for ServiceFlags
impl StructuralPartialEq for ServiceFlags
Auto Trait Implementations§
impl RefUnwindSafe for ServiceFlags
impl Send for ServiceFlags
impl Sync for ServiceFlags
impl Unpin for ServiceFlags
impl UnwindSafe for ServiceFlags
Blanket Implementations§
§impl<T, U> CastInto<U> for Twhere
U: CastFrom<T>,
impl<T, U> CastInto<U> for Twhere U: CastFrom<T>,
source§impl<Q, K> Equivalent<K> for Qwhere
Q: Eq + ?Sized,
K: Borrow<Q> + ?Sized,
impl<Q, K> Equivalent<K> for Qwhere Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,
source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key and return true if they are equal.