Struct chalk_solve::rust_ir::FnDefDatum
source · pub struct FnDefDatum<I: Interner> {
pub id: FnDefId<I>,
pub sig: FnSig<I>,
pub binders: Binders<FnDefDatumBound<I>>,
}
Expand description
A rust intermediate representation (rust_ir) of a function definition/declaration. For example, in the following rust code:
ⓘ
fn foo<T>() -> i32 where T: Eq;
This would represent the declaration of foo
.
Note this is distinct from a function pointer, which points to a function with a given type signature, whereas this represents a specific function definition.
Fields§
§id: FnDefId<I>
§sig: FnSig<I>
§binders: Binders<FnDefDatumBound<I>>
Trait Implementations§
source§impl<I: Clone + Interner> Clone for FnDefDatum<I>
impl<I: Clone + Interner> Clone for FnDefDatum<I>
source§fn clone(&self) -> FnDefDatum<I>
fn clone(&self) -> FnDefDatum<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: PartialEq + Interner> PartialEq for FnDefDatum<I>
impl<I: PartialEq + Interner> PartialEq for FnDefDatum<I>
source§fn eq(&self, other: &FnDefDatum<I>) -> bool
fn eq(&self, other: &FnDefDatum<I>) -> bool
This method tests for
self
and other
values to be equal, and is used
by ==
.source§impl<I: Interner> RenderAsRust<I> for FnDefDatum<I>
impl<I: Interner> RenderAsRust<I> for FnDefDatum<I>
fn fmt(&self, s: &InternalWriterState<'_, I>, f: &mut Formatter<'_>) -> Result
fn display<'a>(
&'a self,
s: &'a InternalWriterState<'a, I>,
) -> DisplayRenderAsRust<'a, I, Self>where
Self: Sized,
source§impl<I: Interner> ToProgramClauses<I> for FnDefDatum<I>
impl<I: Interner> ToProgramClauses<I> for FnDefDatum<I>
source§fn to_program_clauses(
&self,
builder: &mut ClauseBuilder<'_, I>,
_environment: &Environment<I>,
)
fn to_program_clauses( &self, builder: &mut ClauseBuilder<'_, I>, _environment: &Environment<I>, )
Given the following function definition: fn bar<T>() where T: Eq
, generate:
-- Rule WellFormed-Type
forall<T> {
WF(bar<T>) :- WF(T: Eq)
}
-- Rule Implied-Bound-From-Type
forall<T> {
FromEnv(T: Eq) :- FromEnv(bar<T>).
}
forall<T> {
IsFullyVisible(bar<T>) :- IsFullyVisible(T).
}
source§impl<I: Interner> TypeVisitable<I> for FnDefDatum<I>
impl<I: Interner> TypeVisitable<I> for FnDefDatum<I>
Avoids visiting I::FnAbi
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.impl<I: Eq + Interner> Eq for FnDefDatum<I>
impl<I: Interner> StructuralPartialEq for FnDefDatum<I>
Auto Trait Implementations§
impl<I> Freeze for FnDefDatum<I>
impl<I> RefUnwindSafe for FnDefDatum<I>where
<I as Interner>::DefId: RefUnwindSafe,
<I as Interner>::FnAbi: RefUnwindSafe,
<I as Interner>::InternedVariableKinds: RefUnwindSafe,
<I as Interner>::InternedType: RefUnwindSafe,
<I as Interner>::InternedSubstitution: RefUnwindSafe,
<I as Interner>::InternedLifetime: RefUnwindSafe,
impl<I> Send for FnDefDatum<I>where
<I as Interner>::DefId: Send,
<I as Interner>::FnAbi: Send,
<I as Interner>::InternedVariableKinds: Send,
<I as Interner>::InternedType: Send,
<I as Interner>::InternedSubstitution: Send,
<I as Interner>::InternedLifetime: Send,
impl<I> Sync for FnDefDatum<I>where
<I as Interner>::DefId: Sync,
<I as Interner>::FnAbi: Sync,
<I as Interner>::InternedVariableKinds: Sync,
<I as Interner>::InternedType: Sync,
<I as Interner>::InternedSubstitution: Sync,
<I as Interner>::InternedLifetime: Sync,
impl<I> Unpin for FnDefDatum<I>where
<I as Interner>::DefId: Unpin,
<I as Interner>::FnAbi: Unpin,
<I as Interner>::InternedVariableKinds: Unpin,
<I as Interner>::InternedType: Unpin,
<I as Interner>::InternedSubstitution: Unpin,
<I as Interner>::InternedLifetime: Unpin,
impl<I> UnwindSafe for FnDefDatum<I>where
<I as Interner>::DefId: UnwindSafe,
<I as Interner>::FnAbi: UnwindSafe,
<I as Interner>::InternedVariableKinds: UnwindSafe,
<I as Interner>::InternedType: 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> Cast for T
impl<T> Cast for T
source§fn cast<U>(self, interner: <U as HasInterner>::Interner) -> Uwhere
Self: CastTo<U>,
U: HasInterner,
fn cast<U>(self, interner: <U as HasInterner>::Interner) -> Uwhere
Self: CastTo<U>,
U: HasInterner,
Cast a value to type
U
using CastTo
.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
)§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.§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, 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.