diff options
| author | roife <roifewu@gmail.com> | 2023-12-09 17:00:31 +0800 |
|---|---|---|
| committer | roife <roifewu@gmail.com> | 2023-12-09 17:11:48 +0800 |
| commit | 63d2f353d98a9b8cdbabbf0e5b135a8be9d8e3c1 (patch) | |
| tree | 356ad7cf3e0915a810dde1d62356c2c5bb8da098 | |
| parent | 19387d3077c4c81e4a89ecec62917221fed26541 (diff) | |
| download | rust-63d2f353d98a9b8cdbabbf0e5b135a8be9d8e3c1.tar.gz rust-63d2f353d98a9b8cdbabbf0e5b135a8be9d8e3c1.zip | |
fix: fix 'introduce_named_generic' for impl inside types
| -rw-r--r-- | crates/ide-assists/src/handlers/introduce_named_generic.rs | 20 |
1 files changed, 19 insertions, 1 deletions
diff --git a/crates/ide-assists/src/handlers/introduce_named_generic.rs b/crates/ide-assists/src/handlers/introduce_named_generic.rs index b0d35c02d67..e90a1ed79b4 100644 --- a/crates/ide-assists/src/handlers/introduce_named_generic.rs +++ b/crates/ide-assists/src/handlers/introduce_named_generic.rs @@ -18,7 +18,7 @@ use crate::{utils::suggest_name, AssistContext, AssistId, AssistKind, Assists}; // ``` pub(crate) fn introduce_named_generic(acc: &mut Assists, ctx: &AssistContext<'_>) -> Option<()> { let impl_trait_type = ctx.find_node_at_offset::<ast::ImplTraitType>()?; - let param = impl_trait_type.syntax().parent().and_then(ast::Param::cast)?; + let param = impl_trait_type.syntax().ancestors().find_map(|node| ast::Param::cast(node))?; let fn_ = param.syntax().ancestors().find_map(ast::Fn::cast)?; let type_bound_list = impl_trait_type.type_bound_list()?; @@ -149,4 +149,22 @@ fn foo< r#"fn foo<$0F: Foo + Bar>(bar: F) {}"#, ); } + + #[test] + fn replace_impl_with_mut() { + check_assist( + introduce_named_generic, + r#"fn f(iter: &mut $0impl Iterator<Item = i32>) {}"#, + r#"fn f<$0I: Iterator<Item = i32>>(iter: &mut I) {}"#, + ); + } + + #[test] + fn replace_impl_inside() { + check_assist( + introduce_named_generic, + r#"fn f(x: &mut Vec<$0impl Iterator<Item = i32>>) {}"#, + r#"fn f<$0I: Iterator<Item = i32>>(x: &mut Vec<I>) {}"#, + ); + } } |
