Skip to content

Commit

Permalink
Add a doc comment for super_traits
Browse files Browse the repository at this point in the history
Co-authored-by: Ryo Yoshida <low.ryoshida@gmail.com>
  • Loading branch information
WaffleLapkin and lowr committed Jan 2, 2025
1 parent 68e7b98 commit 98cd031
Showing 1 changed file with 21 additions and 0 deletions.
21 changes: 21 additions & 0 deletions chalk-solve/src/clauses/super_traits.rs
Original file line number Diff line number Diff line change
Expand Up @@ -73,6 +73,27 @@ pub(super) fn push_trait_super_clauses<I: Interner>(
}
}

/// Returns super-`TraitRef`s and super-`Projection`s that are quantified over the parameters of
/// `trait_id` and relevant higher-ranked lifetimes. The outer `Binders` is for the former and the
/// inner `Binders` is for the latter.
///
/// For example, given the following trait definitions and `C` as `trait_id`,
///
/// ```
/// trait A<'a, T> {}
/// trait B<'b, U> where Self: for<'x> A<'x, U> {}
/// trait C<'c, V> where Self: B<'c, V> {}
/// ```
///
/// returns the following quantified `TraitRef`s.
///
/// ```notrust
/// for<Self, 'c, V> {
/// for<'x> { Self: A<'x, V> }
/// for<> { Self: B<'c, V> }
/// for<> { Self: C<'c, V> }
/// }
/// ```
pub(crate) fn super_traits<I: Interner>(
db: &dyn RustIrDatabase<I>,
trait_id: TraitId<I>,
Expand Down

0 comments on commit 98cd031

Please sign in to comment.