fix: reorder dyn bounds on render

This commit is contained in:
Ryo Yoshida 2022-10-10 19:32:24 +09:00
parent 3a69435af7
commit 5e43ea96aa
No known key found for this signature in database
GPG key ID: E25698A930586171
2 changed files with 33 additions and 1 deletions

View file

@ -751,9 +751,19 @@ impl HirDisplay for Ty {
} }
TyKind::BoundVar(idx) => idx.hir_fmt(f)?, TyKind::BoundVar(idx) => idx.hir_fmt(f)?,
TyKind::Dyn(dyn_ty) => { TyKind::Dyn(dyn_ty) => {
// Reorder bounds to satisfy `write_bounds_like_dyn_trait()`'s expectation.
// FIXME: `Iterator::partition_in_place()` or `Vec::drain_filter()` may make it
// more efficient when either of them hits stable.
let mut bounds: SmallVec<[_; 4]> =
dyn_ty.bounds.skip_binders().iter(Interner).cloned().collect();
let (auto_traits, others): (SmallVec<[_; 4]>, _) =
bounds.drain(1..).partition(|b| b.skip_binders().trait_id().is_some());
bounds.extend(others);
bounds.extend(auto_traits);
write_bounds_like_dyn_trait_with_prefix( write_bounds_like_dyn_trait_with_prefix(
"dyn", "dyn",
dyn_ty.bounds.skip_binders().interned(), &bounds,
SizedByDefault::NotSized, SizedByDefault::NotSized,
f, f,
)?; )?;

View file

@ -55,6 +55,28 @@ fn main() {
); );
} }
#[test]
fn render_dyn_ty_independent_of_order() {
check_types_source_code(
r#"
auto trait Send {}
trait A {
type Assoc;
}
trait B: A {}
fn test(
_: &(dyn A<Assoc = ()> + Send),
//^ &(dyn A<Assoc = ()> + Send)
_: &(dyn Send + A<Assoc = ()>),
//^ &(dyn A<Assoc = ()> + Send)
_: &dyn B<Assoc = ()>,
//^ &(dyn B<Assoc = ()>)
) {}
"#,
);
}
#[test] #[test]
fn render_dyn_for_ty() { fn render_dyn_for_ty() {
// FIXME // FIXME