diff options
| author | Jake Heinz <jh@discordapp.com> | 2023-04-04 06:50:20 +0000 |
|---|---|---|
| committer | Jake Heinz <jh@discordapp.com> | 2023-04-04 06:50:20 +0000 |
| commit | 94e6a6642c0c4aacc3cc30163c0a7d3d27386ae8 (patch) | |
| tree | 1577535fe17d4caa5d779ac48cc4dc7b8b25a040 | |
| parent | f070093462bee3d0560b9c532870e51352ce0ceb (diff) | |
| download | rust-94e6a6642c0c4aacc3cc30163c0a7d3d27386ae8.tar.gz rust-94e6a6642c0c4aacc3cc30163c0a7d3d27386ae8.zip | |
assist: autoderef in generate delegate methods
| -rw-r--r-- | crates/ide-assists/src/handlers/generate_delegate_methods.rs | 55 |
1 files changed, 48 insertions, 7 deletions
diff --git a/crates/ide-assists/src/handlers/generate_delegate_methods.rs b/crates/ide-assists/src/handlers/generate_delegate_methods.rs index ed1b8f4e28d..483ed165a55 100644 --- a/crates/ide-assists/src/handlers/generate_delegate_methods.rs +++ b/crates/ide-assists/src/handlers/generate_delegate_methods.rs @@ -65,14 +65,17 @@ pub(crate) fn generate_delegate_methods(acc: &mut Assists, ctx: &AssistContext<' let sema_field_ty = ctx.sema.resolve_type(&field_ty)?; let krate = sema_field_ty.krate(ctx.db()); let mut methods = vec![]; - sema_field_ty.iterate_assoc_items(ctx.db(), krate, |item| { - if let hir::AssocItem::Function(f) = item { - if f.self_param(ctx.db()).is_some() && f.is_visible_from(ctx.db(), current_module) { - methods.push(f) + + for ty in sema_field_ty.autoderef(ctx.db()) { + ty.iterate_assoc_items(ctx.db(), krate, |item| { + if let hir::AssocItem::Function(f) = item { + if f.self_param(ctx.db()).is_some() && f.is_visible_from(ctx.db(), current_module) { + methods.push(f) + } } - } - Option::<()>::None - }); + Option::<()>::None + }); + } for method in methods { let adt = ast::Adt::Struct(strukt.clone()); @@ -315,6 +318,44 @@ impl<T> Person<T> { } #[test] + fn test_generates_delegate_autoderef() { + check_assist( + generate_delegate_methods, + r#" +//- minicore: deref +struct Age(u8); +impl Age { + fn age(&self) -> u8 { + self.0 + } +} +struct AgeDeref(Age); +impl core::ops::Deref for AgeDeref { type Target = Age; } +struct Person { + ag$0e: AgeDeref, +} +impl Person {}"#, + r#" +struct Age(u8); +impl Age { + fn age(&self) -> u8 { + self.0 + } +} +struct AgeDeref(Age); +impl core::ops::Deref for AgeDeref { type Target = Age; } +struct Person { + age: AgeDeref, +} +impl Person { + $0fn age(&self) -> u8 { + self.age.age() + } +}"#, + ); + } + + #[test] fn test_generate_delegate_visibility() { check_assist_not_applicable( generate_delegate_methods, |
