mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-16 15:14:02 +00:00
Do not substitute Self
when in same impl block
This commit is contained in:
parent
6711ded5cd
commit
148bdf85f2
1 changed files with 35 additions and 6 deletions
|
@ -311,13 +311,17 @@ fn inline(
|
||||||
} else {
|
} else {
|
||||||
fn_body.clone_for_update()
|
fn_body.clone_for_update()
|
||||||
};
|
};
|
||||||
if let Some(t) = body.syntax().ancestors().find_map(ast::Impl::cast).and_then(|i| i.self_ty()) {
|
if let Some(imp) = body.syntax().ancestors().find_map(ast::Impl::cast) {
|
||||||
|
if !node.syntax().ancestors().any(|anc| &anc == imp.syntax()) {
|
||||||
|
if let Some(t) = imp.self_ty() {
|
||||||
body.syntax()
|
body.syntax()
|
||||||
.descendants_with_tokens()
|
.descendants_with_tokens()
|
||||||
.filter_map(NodeOrToken::into_token)
|
.filter_map(NodeOrToken::into_token)
|
||||||
.filter(|tok| tok.kind() == SyntaxKind::SELF_TYPE_KW)
|
.filter(|tok| tok.kind() == SyntaxKind::SELF_TYPE_KW)
|
||||||
.for_each(|tok| ted::replace(tok, t.syntax()));
|
.for_each(|tok| ted::replace(tok, t.syntax()));
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
let usages_for_locals = |local| {
|
let usages_for_locals = |local| {
|
||||||
Definition::Local(local)
|
Definition::Local(local)
|
||||||
.usages(sema)
|
.usages(sema)
|
||||||
|
@ -1221,6 +1225,31 @@ impl A {
|
||||||
fn main() {
|
fn main() {
|
||||||
A(114514);
|
A(114514);
|
||||||
}
|
}
|
||||||
|
"#,
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn inline_call_with_self_type_but_within_same_impl() {
|
||||||
|
check_assist(
|
||||||
|
inline_call,
|
||||||
|
r#"
|
||||||
|
struct A(u32);
|
||||||
|
impl A {
|
||||||
|
fn f() -> Self { Self(1919810) }
|
||||||
|
fn main() {
|
||||||
|
Self::f$0();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
"#,
|
||||||
|
r#"
|
||||||
|
struct A(u32);
|
||||||
|
impl A {
|
||||||
|
fn f() -> Self { Self(1919810) }
|
||||||
|
fn main() {
|
||||||
|
Self(1919810);
|
||||||
|
}
|
||||||
|
}
|
||||||
"#,
|
"#,
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue