conjure_oxide

Struct RuleSet

Source
pub struct RuleSet<'a> {
    pub name: &'a str,
    pub order: u16,
    pub solver_families: &'a [SolverFamily],
    /* private fields */
}
Expand description

A structure representing a set of rules with a name, priority, and dependencies.

RuleSet is a way to group related rules together under a single name. You can think of it like a list of rules that belong to the same category. Each RuleSet can also have a number that tells it what order it should run in compared to other RuleSet instances. Additionally, a RuleSet can depend on other RuleSet instances, meaning it needs them to run first.

To make things efficient, RuleSet only figures out its rules and dependencies the first time they’re needed, and then it remembers them so it doesn’t have to do the work again.

§Fields

  • name: The name of the rule set.
  • order: A number that decides the order in which this RuleSet should be applied. If two RuleSet instances have the same rule but with different priorities, the one with the higher order number will be the one that is used.
  • rules: A lazily initialized map of rules to their priorities.
  • dependency_rs_names: The names of the rule sets that this rule set depends on.
  • dependencies: A lazily initialized set of RuleSet dependencies.
  • solver_families: The solver families that this rule set applies to.

Fields§

§name: &'a str

The name of the rule set.

§order: u16

Order of the RuleSet. Used to establish a consistent order of operations when resolving rules. If two RuleSets overlap (contain the same rule but with different priorities), the RuleSet with the higher order will be used as the source of truth.

§solver_families: &'a [SolverFamily]

The solver families that this rule set applies to.

Implementations§

Source§

impl<'a> RuleSet<'a>

Source

pub const fn new( name: &'a str, order: u16, dependencies: &'a [&'a str], solver_families: &'a [SolverFamily], ) -> RuleSet<'a>

Source

pub fn get_rules(&self) -> &HashMap<&'a Rule<'a>, u16>

Get the rules of this rule set, evaluating them lazily if necessary Returns a &HashMap<&Rule, u16> where the key is the rule and the value is the priority of the rule.

Source

pub fn get_dependencies(&self) -> &HashSet<&'static RuleSet<'_>>

Get the dependencies of this rule set, evaluating them lazily if necessary Returns a &HashSet<&RuleSet> of the rule sets that this rule set depends on.

Source

pub fn with_dependencies(&self) -> HashSet<&'static RuleSet<'_>>

Get the dependencies of this rule set, including itself

Trait Implementations§

Source§

impl<'a> Clone for RuleSet<'a>

Source§

fn clone(&self) -> RuleSet<'a>

Returns a copy of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl<'a> Debug for RuleSet<'a>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>

Formats the value using the given formatter. Read more
Source§

impl Display for RuleSet<'_>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>

Formats the value using the given formatter. Read more
Source§

impl Hash for RuleSet<'_>

Source§

fn hash<H>(&self, state: &mut H)
where H: Hasher,

Feeds this value into the given Hasher. Read more
1.3.0 · Source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
Source§

impl PartialEq for RuleSet<'_>

Source§

fn eq(&self, other: &RuleSet<'_>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Eq for RuleSet<'_>

Auto Trait Implementations§

§

impl<'a> !Freeze for RuleSet<'a>

§

impl<'a> RefUnwindSafe for RuleSet<'a>

§

impl<'a> Send for RuleSet<'a>

§

impl<'a> Sync for RuleSet<'a>

§

impl<'a> Unpin for RuleSet<'a>

§

impl<'a> UnwindSafe for RuleSet<'a>

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
Source§

impl<T> DynClone for T
where T: Clone,

Source§

fn __clone_box(&self, _: Private) -> *mut ()

Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided [Span], returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

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 more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

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
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T> ToString for T
where T: Display + ?Sized,

Source§

default fn to_string(&self) -> String

Converts the given value to a String. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V

§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a [WithDispatch] wrapper. Read more