pub struct SurrogateBitmap(pub RoaringBitmap);Expand description
A dense set of Surrogate values backed by a roaring bitmap.
Used as the prefilter currency flowing between engines in a
PhysicalPlan: the planner may embed a SurrogateBitmap produced
by one engine sub-plan directly into another engine’s prefilter
slot without any ID translation step.
Tuple Fields§
§0: RoaringBitmapImplementations§
Source§impl SurrogateBitmap
impl SurrogateBitmap
Source§impl SurrogateBitmap
impl SurrogateBitmap
Sourcepub fn intersect(&self, other: &Self) -> Self
pub fn intersect(&self, other: &Self) -> Self
Return the intersection of self and other as a new bitmap.
Sourcepub fn difference(&self, other: &Self) -> Self
pub fn difference(&self, other: &Self) -> Self
Return the set difference self \ other as a new bitmap.
Sourcepub fn is_subset_of(&self, other: &Self) -> bool
pub fn is_subset_of(&self, other: &Self) -> bool
Return true if every element of self is also in other.
Sourcepub fn intersect_in_place(&mut self, other: &Self)
pub fn intersect_in_place(&mut self, other: &Self)
Mutate self in place to hold only elements also in other.
Sourcepub fn union_in_place(&mut self, other: &Self)
pub fn union_in_place(&mut self, other: &Self)
Mutate self in place to hold the union with other.
Trait Implementations§
Source§impl Clone for SurrogateBitmap
impl Clone for SurrogateBitmap
Source§fn clone(&self) -> SurrogateBitmap
fn clone(&self) -> SurrogateBitmap
Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreSource§impl Debug for SurrogateBitmap
impl Debug for SurrogateBitmap
Source§impl Default for SurrogateBitmap
impl Default for SurrogateBitmap
Source§impl<'de> Deserialize<'de> for SurrogateBitmap
impl<'de> Deserialize<'de> for SurrogateBitmap
Source§fn deserialize<D: Deserializer<'de>>(deserializer: D) -> Result<Self, D::Error>
fn deserialize<D: Deserializer<'de>>(deserializer: D) -> Result<Self, D::Error>
Deserialize this value from the given Serde deserializer. Read more
Source§impl FromIterator<Surrogate> for SurrogateBitmap
impl FromIterator<Surrogate> for SurrogateBitmap
Source§impl<'a> FromMessagePack<'a> for SurrogateBitmap
impl<'a> FromMessagePack<'a> for SurrogateBitmap
Source§impl PartialEq for SurrogateBitmap
impl PartialEq for SurrogateBitmap
Source§fn eq(&self, other: &SurrogateBitmap) -> bool
fn eq(&self, other: &SurrogateBitmap) -> bool
Tests for
self and other values to be equal, and is used by ==.Source§impl Serialize for SurrogateBitmap
impl Serialize for SurrogateBitmap
Source§impl ToMessagePack for SurrogateBitmap
impl ToMessagePack for SurrogateBitmap
impl StructuralPartialEq for SurrogateBitmap
Auto Trait Implementations§
impl Freeze for SurrogateBitmap
impl RefUnwindSafe for SurrogateBitmap
impl Send for SurrogateBitmap
impl Sync for SurrogateBitmap
impl Unpin for SurrogateBitmap
impl UnsafeUnpin for SurrogateBitmap
impl UnwindSafe for SurrogateBitmap
Blanket Implementations§
Source§impl<T> ArchivePointee for T
impl<T> ArchivePointee for T
Source§type ArchivedMetadata = ()
type ArchivedMetadata = ()
The archived version of the pointer metadata for this type.
Source§fn pointer_metadata(
_: &<T as ArchivePointee>::ArchivedMetadata,
) -> <T as Pointee>::Metadata
fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata
Converts some archived metadata to the pointer metadata for itself.
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> LayoutRaw for T
impl<T> LayoutRaw for T
Source§fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
Returns the layout of the type.
Source§impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
Source§unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
Returns whether the given value has been niched. Read more
Source§fn resolve_niched(out: Place<NichedOption<T, N1>>)
fn resolve_niched(out: Place<NichedOption<T, N1>>)
Writes data to
out indicating that a T is niched.Source§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
Source§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
The inverse inclusion map: attempts to construct
self from the equivalent element of its
superset. Read moreSource§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
Checks if
self is actually part of its subset T (and can be converted to it).Source§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
Use with care! Same as
self.to_subset but without any property checks. Always succeeds.Source§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
The inclusion map: converts
self to the equivalent element of its superset.