Enum chalk_ir::GoalData[][src]

pub enum GoalData<I: Interner> {
    Quantified(QuantifierKind, Binders<Goal<I>>),
    Implies(ProgramClauses<I>, Goal<I>),
    All(Goals<I>),
    Not(Goal<I>),
    EqGoal(EqGoal<I>),
    SubtypeGoal(SubtypeGoal<I>),
    DomainGoal(DomainGoal<I>),
    CannotProve,
}
Expand description

A general goal; this is the full range of questions you can pose to Chalk.

Variants

Quantified

Introduces a binding at depth 0, shifting other bindings up (deBruijn index).

Tuple Fields of Quantified

0: QuantifierKind1: Binders<Goal<I>>
Implies

A goal that holds given some clauses (like an if-statement).

Tuple Fields of Implies

0: ProgramClauses<I>1: Goal<I>
All

List of goals that all should hold.

Tuple Fields of All

0: Goals<I>
Not

Negation: the inner goal should not hold.

Tuple Fields of Not

0: Goal<I>
EqGoal

Make two things equal; the rules for doing so are well known to the logic

Tuple Fields of EqGoal

0: EqGoal<I>
SubtypeGoal

Make one thing a subtype of another; the rules for doing so are well known to the logic

Tuple Fields of SubtypeGoal

0: SubtypeGoal<I>
DomainGoal

A “domain goal” indicates some base sort of goal that can be proven via program clauses

Tuple Fields of DomainGoal

0: DomainGoal<I>
CannotProve

Indicates something that cannot be proven to be true or false definitively. This can occur with overflow but also with unifications of skolemized variables like forall<X,Y> { X = Y }. Of course, that statement is false, as there exist types X, Y where X = Y is not true. But we treat it as “cannot prove” so that forall<X,Y> { not { X = Y } } also winds up as cannot prove.

Implementations

Create an interned goal.

Trait Implementations

Returns a copy of the value. Read more

Performs copy-assignment from source. Read more

Formats the value using the given formatter. Read more

The type of value that will be produced once folding is done. Typically this is Self, unless Self contains borrowed values, in which case owned values are produced (for example, one can fold over a &T value where T: Fold, in which case you get back a T, not a &T). Read more

Apply the given folder folder to self; binders is the number of binders that are in scope when beginning the folder. Typically binders starts as 0, but is adjusted when we encounter Binders<T> in the IR or other similar constructs. Read more

The interner associated with the type.

Feeds this value into the given Hasher. Read more

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

This method tests for self and other values to be equal, and is used by ==. Read more

This method tests for !=.

Apply the given visitor visitor to self; binders is the number of binders that are in scope when beginning the visitor. Typically binders starts as 0, but is adjusted when we encounter Binders<T> in the IR or other similar constructs. Read more

Uses the zipper to walk through two values, ensuring that they match.

Auto Trait Implementations

Blanket Implementations

Gets the TypeId of self. Read more

Immutably borrows from an owned value. Read more

Mutably borrows from an owned value. Read more

Cast a value to type U using CastTo.

Checks whether self and other could possibly match.

Performs the conversion.

Performs the conversion.

Shifts this term in one level of binders.

Shifts a term valid at outer_binder so that it is valid at the innermost binder. See DebruijnIndex::shifted_in_from for a detailed explanation. Read more

Shifts a term valid at the innermost binder so that it is valid at outer_binder. See DebruijnIndex::shifted_out_to for a detailed explanation. Read more

Shifts this term out one level of binders.

The resulting type after obtaining ownership.

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

🔬 This is a nightly-only experimental API. (toowned_clone_into)

recently added

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

The type returned in the event of a conversion error.

Performs the conversion.

The type returned in the event of a conversion error.

Performs the conversion.

Check whether there are free (non-bound) variables.