pub enum FilterResolved {
Eq(Attribute, PartialValue, Option<NonZeroU8>),
Cnt(Attribute, PartialValue, Option<NonZeroU8>),
Stw(Attribute, PartialValue, Option<NonZeroU8>),
Enw(Attribute, PartialValue, Option<NonZeroU8>),
Pres(Attribute, Option<NonZeroU8>),
LessThan(Attribute, PartialValue, Option<NonZeroU8>),
Or(Vec<FilterResolved>, Option<NonZeroU8>),
And(Vec<FilterResolved>, Option<NonZeroU8>),
Inclusion(Vec<FilterResolved>, Option<NonZeroU8>),
AndNot(Box<FilterResolved>, Option<NonZeroU8>),
}
Expand description
This is the fully resolved internal representation. Note the lack of Not and selfUUID because these are resolved into And(Pres(class), AndNot(term)) and Eq(uuid, …). Importantly, we make this accessible to Entry so that it can then match on filters internally.
Each filter that has been resolved also has been enriched with metadata about its index, and index slope. For the purpose of this module, consider slope as a “weight” where small value - faster index, larger value - slower index. This metadata is extremely important for the query optimiser to make decisions about how to re-arrange queries correctly.
Variants§
Eq(Attribute, PartialValue, Option<NonZeroU8>)
Cnt(Attribute, PartialValue, Option<NonZeroU8>)
Stw(Attribute, PartialValue, Option<NonZeroU8>)
Enw(Attribute, PartialValue, Option<NonZeroU8>)
Pres(Attribute, Option<NonZeroU8>)
LessThan(Attribute, PartialValue, Option<NonZeroU8>)
Or(Vec<FilterResolved>, Option<NonZeroU8>)
And(Vec<FilterResolved>, Option<NonZeroU8>)
Inclusion(Vec<FilterResolved>, Option<NonZeroU8>)
AndNot(Box<FilterResolved>, Option<NonZeroU8>)
Implementations§
Trait Implementations§
source§impl Clone for FilterResolved
impl Clone for FilterResolved
source§fn clone(&self) -> FilterResolved
fn clone(&self) -> FilterResolved
Returns a copy of the value. Read more
1.0.0 · 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 FilterResolved
impl Debug for FilterResolved
source§impl Ord for FilterResolved
impl Ord for FilterResolved
source§fn cmp(&self, rhs: &FilterResolved) -> Ordering
fn cmp(&self, rhs: &FilterResolved) -> Ordering
Ordering of filters for optimisation and subsequent dead term elimination.
1.21.0 · source§fn max(self, other: Self) -> Selfwhere
Self: Sized,
fn max(self, other: Self) -> Selfwhere
Self: Sized,
Compares and returns the maximum of two values. Read more
source§impl PartialEq for FilterResolved
impl PartialEq for FilterResolved
source§impl PartialOrd for FilterResolved
impl PartialOrd for FilterResolved
impl Eq for FilterResolved
Auto Trait Implementations§
impl Freeze for FilterResolved
impl RefUnwindSafe for FilterResolved
impl Send for FilterResolved
impl Sync for FilterResolved
impl Unpin for FilterResolved
impl UnwindSafe for FilterResolved
Blanket Implementations§
§impl<'a, T> AsTaggedExplicit<'a> for Twhere
T: 'a,
impl<'a, T> AsTaggedExplicit<'a> for Twhere
T: 'a,
§impl<'a, T> AsTaggedImplicit<'a> for Twhere
T: 'a,
impl<'a, T> AsTaggedImplicit<'a> for Twhere
T: 'a,
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§unsafe fn clone_to_uninit(&self, dst: *mut T)
unsafe fn clone_to_uninit(&self, dst: *mut T)
🔬This is a nightly-only experimental API. (
clone_to_uninit
)§impl<Q, K> Comparable<K> for Q
impl<Q, K> Comparable<K> for Q
§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Checks if this value is equivalent to the given key. Read more
§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key
and return true
if they are equal.source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key
and return true
if they are equal.§impl<T> FutureExt for T
impl<T> FutureExt for T
§fn with_context(self, otel_cx: Context) -> WithContext<Self>
fn with_context(self, otel_cx: Context) -> WithContext<Self>
§fn with_current_context(self) -> WithContext<Self>
fn with_current_context(self) -> WithContext<Self>
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
source§impl<T> IntoEither for T
impl<T> IntoEither for T
source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moresource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moresource§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
Wrap the input message
T
in a tonic::Request