Struct chalk_ir::ProgramClauseImplication
source · pub struct ProgramClauseImplication<I: Interner> {
pub consequence: DomainGoal<I>,
pub conditions: Goals<I>,
pub constraints: Constraints<I>,
pub priority: ClausePriority,
}
Expand description
Represents one clause of the form consequence :- conditions
where
conditions = cond_1 && cond_2 && ...
is the conjunction of the individual
conditions.
Fields§
§consequence: DomainGoal<I>
The consequence of the clause, which holds if the conditions holds.
conditions: Goals<I>
The condition goals that should hold.
constraints: Constraints<I>
The lifetime constraints that should be proven.
priority: ClausePriority
The relative priority of the implication.
Implementations§
source§impl<I: Interner> ProgramClauseImplication<I>
impl<I: Interner> ProgramClauseImplication<I>
sourcepub fn debug(&self, interner: I) -> ProgramClauseImplicationDebug<'_, I>
pub fn debug(&self, interner: I) -> ProgramClauseImplicationDebug<'_, I>
Show debug output for the program clause implication.
source§impl<I: Interner> ProgramClauseImplication<I>
impl<I: Interner> ProgramClauseImplication<I>
sourcepub fn into_from_env_clause(self, interner: I) -> ProgramClauseImplication<I>
pub fn into_from_env_clause(self, interner: I) -> ProgramClauseImplication<I>
Change the implication into an application holding a FromEnv
goal.
Trait Implementations§
source§impl<I: Clone + Interner> Clone for ProgramClauseImplication<I>
impl<I: Clone + Interner> Clone for ProgramClauseImplication<I>
source§fn clone(&self) -> ProgramClauseImplication<I>
fn clone(&self) -> ProgramClauseImplication<I>
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<I: Interner> Debug for ProgramClauseImplication<I>
impl<I: Interner> Debug for ProgramClauseImplication<I>
source§impl<I: Interner> HasInterner for ProgramClauseImplication<I>
impl<I: Interner> HasInterner for ProgramClauseImplication<I>
source§impl<I: PartialEq + Interner> PartialEq for ProgramClauseImplication<I>
impl<I: PartialEq + Interner> PartialEq for ProgramClauseImplication<I>
source§fn eq(&self, other: &ProgramClauseImplication<I>) -> bool
fn eq(&self, other: &ProgramClauseImplication<I>) -> bool
This method tests for
self
and other
values to be equal, and is used
by ==
.source§impl<I: Interner> TypeFoldable<I> for ProgramClauseImplication<I>
impl<I: Interner> TypeFoldable<I> for ProgramClauseImplication<I>
source§fn try_fold_with<E>(
self,
folder: &mut dyn FallibleTypeFolder<I, Error = E>,
outer_binder: DebruijnIndex,
) -> Result<Self, E>
fn try_fold_with<E>( self, folder: &mut dyn FallibleTypeFolder<I, Error = E>, outer_binder: DebruijnIndex, ) -> Result<Self, E>
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.source§fn fold_with(
self,
folder: &mut dyn TypeFolder<I>,
outer_binder: DebruijnIndex,
) -> Self
fn fold_with( self, folder: &mut dyn TypeFolder<I>, outer_binder: DebruijnIndex, ) -> Self
A convenient alternative to
try_fold_with
for use with infallible
folders. Do not override this method, to ensure coherence with
try_fold_with
.source§impl<I: Interner> TypeVisitable<I> for ProgramClauseImplication<I>
impl<I: Interner> TypeVisitable<I> for ProgramClauseImplication<I>
source§fn visit_with<B>(
&self,
visitor: &mut dyn TypeVisitor<I, BreakTy = B>,
outer_binder: DebruijnIndex,
) -> ControlFlow<B>
fn visit_with<B>( &self, visitor: &mut dyn TypeVisitor<I, BreakTy = B>, outer_binder: DebruijnIndex, ) -> ControlFlow<B>
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.source§impl<I: Interner> Zip<I> for ProgramClauseImplication<I>
impl<I: Interner> Zip<I> for ProgramClauseImplication<I>
impl<I: Eq + Interner> Eq for ProgramClauseImplication<I>
impl<I: Interner> StructuralPartialEq for ProgramClauseImplication<I>
Auto Trait Implementations§
impl<I> Freeze for ProgramClauseImplication<I>where
<I as Interner>::InternedGoals: Freeze,
<I as Interner>::InternedConstraints: Freeze,
<I as Interner>::InternedType: Freeze,
<I as Interner>::DefId: Freeze,
<I as Interner>::InternedSubstitution: Freeze,
<I as Interner>::InternedLifetime: Freeze,
impl<I> RefUnwindSafe for ProgramClauseImplication<I>where
<I as Interner>::InternedGoals: RefUnwindSafe,
<I as Interner>::InternedConstraints: RefUnwindSafe,
<I as Interner>::InternedType: RefUnwindSafe,
<I as Interner>::DefId: RefUnwindSafe,
<I as Interner>::InternedSubstitution: RefUnwindSafe,
<I as Interner>::InternedLifetime: RefUnwindSafe,
impl<I> Send for ProgramClauseImplication<I>where
<I as Interner>::InternedGoals: Send,
<I as Interner>::InternedConstraints: Send,
<I as Interner>::InternedType: Send,
<I as Interner>::DefId: Send,
<I as Interner>::InternedSubstitution: Send,
<I as Interner>::InternedLifetime: Send,
impl<I> Sync for ProgramClauseImplication<I>where
<I as Interner>::InternedGoals: Sync,
<I as Interner>::InternedConstraints: Sync,
<I as Interner>::InternedType: Sync,
<I as Interner>::DefId: Sync,
<I as Interner>::InternedSubstitution: Sync,
<I as Interner>::InternedLifetime: Sync,
impl<I> Unpin for ProgramClauseImplication<I>where
<I as Interner>::InternedGoals: Unpin,
<I as Interner>::InternedConstraints: Unpin,
<I as Interner>::InternedType: Unpin,
<I as Interner>::DefId: Unpin,
<I as Interner>::InternedSubstitution: Unpin,
<I as Interner>::InternedLifetime: Unpin,
impl<I> UnwindSafe for ProgramClauseImplication<I>where
<I as Interner>::InternedGoals: UnwindSafe,
<I as Interner>::InternedConstraints: UnwindSafe,
<I as Interner>::InternedType: UnwindSafe,
<I as Interner>::DefId: UnwindSafe,
<I as Interner>::InternedSubstitution: UnwindSafe,
<I as Interner>::InternedLifetime: UnwindSafe,
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§default unsafe fn clone_to_uninit(&self, dst: *mut T)
default unsafe fn clone_to_uninit(&self, dst: *mut T)
🔬This is a nightly-only experimental API. (
clone_to_uninit
)source§impl<T, I> CouldMatch<T> for T
impl<T, I> CouldMatch<T> for T
source§fn could_match(
&self,
interner: I,
db: &dyn UnificationDatabase<I>,
other: &T,
) -> bool
fn could_match( &self, interner: I, db: &dyn UnificationDatabase<I>, other: &T, ) -> bool
Checks whether
self
and other
could possibly match.source§impl<T, I> Shift<I> for Twhere
T: TypeFoldable<I>,
I: Interner,
impl<T, I> Shift<I> for Twhere
T: TypeFoldable<I>,
I: Interner,
source§fn shifted_in(self, interner: I) -> T
fn shifted_in(self, interner: I) -> T
Shifts this term in one level of binders.
source§fn shifted_in_from(self, interner: I, source_binder: DebruijnIndex) -> T
fn shifted_in_from(self, interner: I, source_binder: DebruijnIndex) -> T
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.source§fn shifted_out_to(
self,
interner: I,
target_binder: DebruijnIndex,
) -> Result<T, NoSolution>
fn shifted_out_to( self, interner: I, target_binder: DebruijnIndex, ) -> Result<T, NoSolution>
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.source§fn shifted_out(self, interner: I) -> Result<T, NoSolution>
fn shifted_out(self, interner: I) -> Result<T, NoSolution>
Shifts this term out one level of binders.
source§impl<T, I> VisitExt<I> for Twhere
I: Interner,
T: TypeVisitable<I>,
impl<T, I> VisitExt<I> for Twhere
I: Interner,
T: TypeVisitable<I>,
source§fn has_free_vars(&self, interner: I) -> bool
fn has_free_vars(&self, interner: I) -> bool
Check whether there are free (non-bound) variables.