diff options
| author | A4-Tacks <wdsjxhno1001@163.com> | 2025-07-19 15:00:54 +0800 | 
|---|---|---|
| committer | A4-Tacks <wdsjxhno1001@163.com> | 2025-07-19 15:01:13 +0800 | 
| commit | 54d974324c9770b9368194ca3c916fb5a5b6c9a4 (patch) | |
| tree | aa044b07e03509734d9e49e0f6c4954b11e44ef9 | |
| parent | 0901d513d89b38175e64c3ebee13d8d44ae6e943 (diff) | |
| download | rust-54d974324c9770b9368194ca3c916fb5a5b6c9a4.tar.gz rust-54d974324c9770b9368194ca3c916fb5a5b6c9a4.zip | |
Add Deref -> DerefMut for generate_mut_trait_impl
| -rw-r--r-- | src/tools/rust-analyzer/crates/ide-assists/src/handlers/generate_mut_trait_impl.rs | 37 | 
1 files changed, 37 insertions, 0 deletions
| diff --git a/src/tools/rust-analyzer/crates/ide-assists/src/handlers/generate_mut_trait_impl.rs b/src/tools/rust-analyzer/crates/ide-assists/src/handlers/generate_mut_trait_impl.rs index 4ddab2cfad0..dc26ec79a74 100644 --- a/src/tools/rust-analyzer/crates/ide-assists/src/handlers/generate_mut_trait_impl.rs +++ b/src/tools/rust-analyzer/crates/ide-assists/src/handlers/generate_mut_trait_impl.rs @@ -134,6 +134,9 @@ fn get_trait_mut(apply_trait: &hir::Trait, famous: FamousDefs<'_, '_>) -> Option if trait_ == famous.core_borrow_Borrow().as_ref() { return Some("BorrowMut"); } + if trait_ == famous.core_ops_Deref().as_ref() { + return Some("DerefMut"); + } None } @@ -142,6 +145,7 @@ fn process_method_name(name: ast::Name) -> Option<(ast::Name, &'static str)> { "index" => "index_mut", "as_ref" => "as_mut", "borrow" => "borrow_mut", + "deref" => "deref_mut", _ => return None, }; Some((name, new_name)) @@ -260,6 +264,39 @@ impl core::convert::AsRef<i32> for Foo { } "#, ); + + check_assist( + generate_mut_trait_impl, + r#" +//- minicore: deref +struct Foo(i32); + +impl core::ops::Deref$0 for Foo { + type Target = i32; + + fn deref(&self) -> &Self::Target { + &self.0 + } +} +"#, + r#" +struct Foo(i32); + +$0impl core::ops::DerefMut for Foo { + fn deref_mut(&mut self) -> &mut Self::Target { + &mut self.0 + } +} + +impl core::ops::Deref for Foo { + type Target = i32; + + fn deref(&self) -> &Self::Target { + &self.0 + } +} +"#, + ); } #[test] | 
