#[non_exhaustive]pub enum Combiner {
AllOf(Vec<Predicate>),
AnyOf(Vec<Predicate>),
NoneOf(Vec<Predicate>),
}Expand description
The one-of combiner declared at the top level of a require or when
block. Exactly one variant is populated at parse time.
Marked #[non_exhaustive] so new combiner shapes (e.g. xor_of,
majority_of) can land without breaking external match sites.
Variants (Non-exhaustive)§
This enum is marked as non-exhaustive
Non-exhaustive enums could have additional variants added in future. Therefore, when matching against variants of non-exhaustive enums, an extra wildcard arm must be added to account for any future variants.
AllOf(Vec<Predicate>)
all_of: — every predicate must hold (AND).
AnyOf(Vec<Predicate>)
any_of: — at least one predicate must hold (OR).
NoneOf(Vec<Predicate>)
none_of: — no predicate may hold (NOR).
Implementations§
Source§impl Combiner
impl Combiner
Sourcepub fn from_mapping(
mapping: &Mapping,
depth: usize,
) -> Result<Self, PackParseError>
pub fn from_mapping( mapping: &Mapping, depth: usize, ) -> Result<Self, PackParseError>
Parse a combiner from a YAML mapping. Caller is responsible for handing down only the subset of keys relevant to combiner selection (typically the full mapping; non-combiner keys are ignored by this fn).
Exactly one of all_of / any_of / none_of must be present.
Trait Implementations§
impl Eq for Combiner
impl StructuralPartialEq for Combiner
Auto Trait Implementations§
impl Freeze for Combiner
impl RefUnwindSafe for Combiner
impl Send for Combiner
impl Sync for Combiner
impl Unpin for Combiner
impl UnsafeUnpin for Combiner
impl UnwindSafe for Combiner
Blanket Implementations§
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<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
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.Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
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> 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 more