Struct chalk_ir::ProgramClauses
source · [−]pub struct ProgramClauses<I: Interner> { /* private fields */ }Expand description
List of interned elements.
Implementations
sourceimpl<I: Interner> ProgramClauses<I>
impl<I: Interner> ProgramClauses<I>
sourcepub fn interned(&self) -> &I::InternedProgramClauses
pub fn interned(&self) -> &I::InternedProgramClauses
Get the interned elements.
sourcepub fn as_slice(&self, interner: I) -> &[ProgramClause<I>]
pub fn as_slice(&self, interner: I) -> &[ProgramClause<I>]
Returns a slice containing the elements.
sourcepub fn at(&self, interner: I, index: usize) -> &ProgramClause<I>
pub fn at(&self, interner: I, index: usize) -> &ProgramClause<I>
Index into the sequence.
sourcepub fn iter(&self, interner: I) -> Iter<'_, ProgramClause<I>>
pub fn iter(&self, interner: I) -> Iter<'_, ProgramClause<I>>
Get an iterator over the elements of the sequence.
sourceimpl<I: Interner> ProgramClauses<I>
impl<I: Interner> ProgramClauses<I>
sourcepub fn from_fallible<E>(
interner: I,
elements: impl IntoIterator<Item = Result<impl CastTo<ProgramClause<I>>, E>>
) -> Result<Self, E>
pub fn from_fallible<E>(
interner: I,
elements: impl IntoIterator<Item = Result<impl CastTo<ProgramClause<I>>, E>>
) -> Result<Self, E>
Tries to create a sequence using an iterator of element-like things.
sourcepub fn from_iter(
interner: I,
elements: impl IntoIterator<Item = impl CastTo<ProgramClause<I>>>
) -> Self
pub fn from_iter(
interner: I,
elements: impl IntoIterator<Item = impl CastTo<ProgramClause<I>>>
) -> Self
Create a sequence from elements
sourcepub fn from1(interner: I, element: impl CastTo<ProgramClause<I>>) -> Self
pub fn from1(interner: I, element: impl CastTo<ProgramClause<I>>) -> Self
Create a sequence from a single element.
Trait Implementations
sourceimpl<I: Clone + Interner> Clone for ProgramClauses<I> where
I::InternedProgramClauses: Clone,
impl<I: Clone + Interner> Clone for ProgramClauses<I> where
I::InternedProgramClauses: Clone,
sourcefn clone(&self) -> ProgramClauses<I>
fn clone(&self) -> ProgramClauses<I>
Returns a copy of the value. Read more
1.0.0 · sourcefn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from source. Read more
sourceimpl<I: Interner> Debug for ProgramClauses<I>
impl<I: Interner> Debug for ProgramClauses<I>
sourceimpl<I: Interner> Fold<I> for ProgramClauses<I>
impl<I: Interner> Fold<I> for ProgramClauses<I>
type Result = ProgramClauses<I>
type Result = ProgramClauses<I>
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
sourcefn fold_with<E>(
self,
folder: &mut dyn Folder<I, Error = E>,
outer_binder: DebruijnIndex
) -> Result<Self::Result, E>
fn fold_with<E>(
self,
folder: &mut dyn Folder<I, Error = E>,
outer_binder: DebruijnIndex
) -> Result<Self::Result, 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. Read more
sourceimpl<I: Interner> HasInterner for ProgramClauses<I>
impl<I: Interner> HasInterner for ProgramClauses<I>
type Interner = I
type Interner = I
The interner associated with the type.
sourceimpl<I: Hash + Interner> Hash for ProgramClauses<I> where
I::InternedProgramClauses: Hash,
impl<I: Hash + Interner> Hash for ProgramClauses<I> where
I::InternedProgramClauses: Hash,
sourceimpl<I: Ord + Interner> Ord for ProgramClauses<I> where
I::InternedProgramClauses: Ord,
impl<I: Ord + Interner> Ord for ProgramClauses<I> where
I::InternedProgramClauses: Ord,
sourceimpl<I: PartialEq + Interner> PartialEq<ProgramClauses<I>> for ProgramClauses<I> where
I::InternedProgramClauses: PartialEq,
impl<I: PartialEq + Interner> PartialEq<ProgramClauses<I>> for ProgramClauses<I> where
I::InternedProgramClauses: PartialEq,
sourcefn eq(&self, other: &ProgramClauses<I>) -> bool
fn eq(&self, other: &ProgramClauses<I>) -> bool
This method tests for self and other values to be equal, and is used
by ==. Read more
sourcefn ne(&self, other: &ProgramClauses<I>) -> bool
fn ne(&self, other: &ProgramClauses<I>) -> bool
This method tests for !=.
sourceimpl<I: PartialOrd + Interner> PartialOrd<ProgramClauses<I>> for ProgramClauses<I> where
I::InternedProgramClauses: PartialOrd,
impl<I: PartialOrd + Interner> PartialOrd<ProgramClauses<I>> for ProgramClauses<I> where
I::InternedProgramClauses: PartialOrd,
sourcefn partial_cmp(&self, other: &ProgramClauses<I>) -> Option<Ordering>
fn partial_cmp(&self, other: &ProgramClauses<I>) -> Option<Ordering>
This method returns an ordering between self and other values if one exists. Read more
1.0.0 · sourcefn lt(&self, other: &Rhs) -> bool
fn lt(&self, other: &Rhs) -> bool
This method tests less than (for self and other) and is used by the < operator. Read more
1.0.0 · sourcefn le(&self, other: &Rhs) -> bool
fn le(&self, other: &Rhs) -> bool
This method tests less than or equal to (for self and other) and is used by the <=
operator. Read more
sourceimpl<I: Interner> Visit<I> for ProgramClauses<I>
impl<I: Interner> Visit<I> for ProgramClauses<I>
sourcefn visit_with<B>(
&self,
visitor: &mut dyn Visitor<I, BreakTy = B>,
outer_binder: DebruijnIndex
) -> ControlFlow<B>
fn visit_with<B>(
&self,
visitor: &mut dyn Visitor<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. Read more
sourceimpl<I: Interner> Zip<I> for ProgramClauses<I>
impl<I: Interner> Zip<I> for ProgramClauses<I>
impl<I: Copy + Interner> Copy for ProgramClauses<I> where
I::InternedProgramClauses: Copy,
impl<I: Eq + Interner> Eq for ProgramClauses<I> where
I::InternedProgramClauses: Eq,
impl<I: Interner> StructuralEq for ProgramClauses<I>
impl<I: Interner> StructuralPartialEq for ProgramClauses<I>
Auto Trait Implementations
impl<I> RefUnwindSafe for ProgramClauses<I> where
<I as Interner>::InternedProgramClauses: RefUnwindSafe,
impl<I> Send for ProgramClauses<I> where
<I as Interner>::InternedProgramClauses: Send,
impl<I> Sync for ProgramClauses<I> where
<I as Interner>::InternedProgramClauses: Sync,
impl<I> Unpin for ProgramClauses<I> where
<I as Interner>::InternedProgramClauses: Unpin,
impl<I> UnwindSafe for ProgramClauses<I> where
<I as Interner>::InternedProgramClauses: UnwindSafe,
Blanket Implementations
sourceimpl<T> BorrowMut<T> for T where
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
const: unstable · sourcefn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
sourceimpl<T> Cast for T
impl<T> Cast for T
sourcefn cast<U>(self, interner: U::Interner) -> U where
Self: CastTo<U>,
U: HasInterner,
fn cast<U>(self, interner: U::Interner) -> U where
Self: CastTo<U>,
U: HasInterner,
Cast a value to type U using CastTo.
sourceimpl<T, I> CouldMatch<T> for T where
T: Zip<I> + HasInterner<Interner = I> + ?Sized,
I: Interner,
impl<T, I> CouldMatch<T> for T where
T: Zip<I> + HasInterner<Interner = I> + ?Sized,
I: Interner,
sourcefn 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.
sourceimpl<T, I> Shift<I> for T where
T: Fold<I>,
I: Interner,
impl<T, I> Shift<I> for T where
T: Fold<I>,
I: Interner,
sourcefn shifted_in(self, interner: I) -> <T as Fold<I>>::Result
fn shifted_in(self, interner: I) -> <T as Fold<I>>::Result
Shifts this term in one level of binders.
sourcefn shifted_in_from(
self,
interner: I,
source_binder: DebruijnIndex
) -> <T as Fold<I>>::Result
fn shifted_in_from(
self,
interner: I,
source_binder: DebruijnIndex
) -> <T as Fold<I>>::Result
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
sourcefn shifted_out_to(
self,
interner: I,
target_binder: DebruijnIndex
) -> Result<<T as Fold<I>>::Result, NoSolution>
fn shifted_out_to(
self,
interner: I,
target_binder: DebruijnIndex
) -> Result<<T as Fold<I>>::Result, 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. Read more
sourcefn shifted_out(self, interner: I) -> Result<<T as Fold<I>>::Result, NoSolution>
fn shifted_out(self, interner: I) -> Result<<T as Fold<I>>::Result, NoSolution>
Shifts this term out one level of binders.
sourceimpl<T> ToOwned for T where
T: Clone,
impl<T> ToOwned for T where
T: Clone,
type Owned = T
type Owned = T
The resulting type after obtaining ownership.
sourcefn clone_into(&self, target: &mut T)
fn clone_into(&self, target: &mut T)
toowned_clone_into)Uses borrowed data to replace owned data, usually by cloning. Read more