[−][src]Struct rustc_ap_rustc_index::bit_set::BitSet
A fixed-size bitset type with a dense representation.
NOTE: Use GrowableBitSet
if you need support for resizing after creation.
T
is an index type, typically a newtyped usize
wrapper, but it can also
just be usize
.
All operations that involve an element will panic if the element is equal to or greater than the domain size. All operations that involve two bitsets will panic if the bitsets have differing domain sizes.
Methods
impl<T: Idx> BitSet<T>
[src]
pub fn new_empty(domain_size: usize) -> BitSet<T>
[src]
Creates a new, empty bitset with a given domain_size
.
pub fn new_filled(domain_size: usize) -> BitSet<T>
[src]
Creates a new, filled bitset with a given domain_size
.
pub fn domain_size(&self) -> usize
[src]
Gets the domain size.
pub fn clear(&mut self)
[src]
Clear all elements.
pub fn overwrite(&mut self, other: &BitSet<T>)
[src]
Efficiently overwrite self
with other
.
pub fn count(&self) -> usize
[src]
Count the number of set bits in the set.
pub fn contains(&self, elem: T) -> bool
[src]
Returns true
if self
contains elem
.
pub fn superset(&self, other: &BitSet<T>) -> bool
[src]
Is self
is a (non-strict) superset of other
?
pub fn is_empty(&self) -> bool
[src]
Is the set empty?
pub fn insert(&mut self, elem: T) -> bool
[src]
Insert elem
. Returns whether the set has changed.
pub fn insert_all(&mut self)
[src]
Sets all bits to true.
pub fn remove(&mut self, elem: T) -> bool
[src]
Returns true
if the set has changed.
pub fn union(&mut self, other: &impl UnionIntoBitSet<T>) -> bool
[src]
Sets self = self | other
and returns true
if self
changed
(i.e., if new bits were added).
pub fn subtract(&mut self, other: &impl SubtractFromBitSet<T>) -> bool
[src]
Sets self = self - other
and returns true
if self
changed.
(i.e., if any bits were removed).
pub fn intersect(&mut self, other: &BitSet<T>) -> bool
[src]
Sets self = self & other
and return true
if self
changed.
(i.e., if any bits were removed).
pub fn words(&self) -> &[Word]
[src]
Gets a slice of the underlying words.
pub fn iter(&self) -> BitIter<T>
[src]
Iterates over the indices of set bits in a sorted order.
pub fn to_hybrid(&self) -> HybridBitSet<T>
[src]
Duplicates the set as a hybrid set.
Trait Implementations
impl<T: Clone + Idx> Clone for BitSet<T>
[src]
impl<T: Idx> Debug for BitSet<T>
[src]
impl<T: Decodable + Idx> Decodable for BitSet<T>
[src]
impl<T: Encodable + Idx> Encodable for BitSet<T>
[src]
impl<T: Eq + Idx> Eq for BitSet<T>
[src]
impl<T: PartialEq + Idx> PartialEq<BitSet<T>> for BitSet<T>
[src]
impl<T: Idx> StructuralEq for BitSet<T>
[src]
impl<T: Idx> StructuralPartialEq for BitSet<T>
[src]
impl<T: Idx> SubtractFromBitSet<T> for BitSet<T>
[src]
fn subtract_from(&self, other: &mut BitSet<T>) -> bool
[src]
impl<T: Idx> ToString for BitSet<T>
[src]
impl<T: Idx> UnionIntoBitSet<T> for BitSet<T>
[src]
fn union_into(&self, other: &mut BitSet<T>) -> bool
[src]
Auto Trait Implementations
impl<T> RefUnwindSafe for BitSet<T> where
T: RefUnwindSafe,
T: RefUnwindSafe,
impl<T> Send for BitSet<T> where
T: Send,
T: Send,
impl<T> Sync for BitSet<T> where
T: Sync,
T: Sync,
impl<T> Unpin for BitSet<T> where
T: Unpin,
T: Unpin,
impl<T> UnwindSafe for BitSet<T> where
T: UnwindSafe,
T: UnwindSafe,
Blanket Implementations
impl<T> Any for T where
T: 'static + ?Sized,
[src]
T: 'static + ?Sized,
impl<T> Borrow<T> for T where
T: ?Sized,
[src]
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]
T: ?Sized,
fn borrow_mut(&mut self) -> &mut T
[src]
impl<T> Decodable for T where
T: UseSpecializedDecodable,
[src]
T: UseSpecializedDecodable,
impl<T> Encodable for T where
T: UseSpecializedEncodable + ?Sized,
[src]
T: UseSpecializedEncodable + ?Sized,
impl<Q, K> Equivalent<K> for Q where
K: Borrow<Q> + ?Sized,
Q: Eq + ?Sized,
[src]
K: Borrow<Q> + ?Sized,
Q: Eq + ?Sized,
fn equivalent(&self, key: &K) -> bool
[src]
impl<T> From<T> for T
[src]
impl<T, U> Into<U> for T where
U: From<T>,
[src]
U: From<T>,
impl<E> SpecializationError for E
[src]
default fn not_found<S, T>(
trait_name: &'static str,
method_name: &'static str
) -> E where
T: ?Sized,
[src]
trait_name: &'static str,
method_name: &'static str
) -> E where
T: ?Sized,
impl<T> ToOwned for T where
T: Clone,
[src]
T: Clone,
type Owned = T
The resulting type after obtaining ownership.
fn to_owned(&self) -> T
[src]
fn clone_into(&self, target: &mut T)
[src]
impl<T> ToString for T where
T: Display + ?Sized,
[src]
T: Display + ?Sized,
impl<T, U> TryFrom<U> for T where
U: Into<T>,
[src]
U: Into<T>,
type Error = Infallible
The type returned in the event of a conversion error.
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
[src]
impl<T, U> TryInto<U> for T where
U: TryFrom<T>,
[src]
U: TryFrom<T>,