mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-15 22:54:00 +00:00
Auto merge of #18050 - rust-lang:davidbarsky/push-uyvtlsvoqrxw, r=Veykril
assist: ensure `replace_qualified_name_with_use` applies to the first path segment This change helps a bit with the discoverability of `replace_qualified_name_with_use`. Specifically, it ensures that a cursor on the first path segment (e.g., `$0std::fmt::Debug`, where `$0` is the cursor) would result in an import along the lines of `use std::fmt;` and `fmt::Debug;` at the usage sites.
This commit is contained in:
commit
a90d78f327
1 changed files with 25 additions and 9 deletions
|
@ -29,7 +29,7 @@ pub(crate) fn replace_qualified_name_with_use(
|
||||||
acc: &mut Assists,
|
acc: &mut Assists,
|
||||||
ctx: &AssistContext<'_>,
|
ctx: &AssistContext<'_>,
|
||||||
) -> Option<()> {
|
) -> Option<()> {
|
||||||
let original_path: ast::Path = ctx.find_node_at_offset()?;
|
let mut original_path: ast::Path = ctx.find_node_at_offset()?;
|
||||||
// We don't want to mess with use statements
|
// We don't want to mess with use statements
|
||||||
if original_path.syntax().ancestors().find_map(ast::UseTree::cast).is_some() {
|
if original_path.syntax().ancestors().find_map(ast::UseTree::cast).is_some() {
|
||||||
cov_mark::hit!(not_applicable_in_use);
|
cov_mark::hit!(not_applicable_in_use);
|
||||||
|
@ -37,8 +37,7 @@ pub(crate) fn replace_qualified_name_with_use(
|
||||||
}
|
}
|
||||||
|
|
||||||
if original_path.qualifier().is_none() {
|
if original_path.qualifier().is_none() {
|
||||||
cov_mark::hit!(dont_import_trivial_paths);
|
original_path = original_path.parent_path()?;
|
||||||
return None;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// only offer replacement for non assoc items
|
// only offer replacement for non assoc items
|
||||||
|
@ -236,12 +235,6 @@ fs::Path
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
|
||||||
fn dont_import_trivial_paths() {
|
|
||||||
cov_mark::check!(dont_import_trivial_paths);
|
|
||||||
check_assist_not_applicable(replace_qualified_name_with_use, r"impl foo$0 for () {}");
|
|
||||||
}
|
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_replace_not_applicable_in_use() {
|
fn test_replace_not_applicable_in_use() {
|
||||||
cov_mark::check!(not_applicable_in_use);
|
cov_mark::check!(not_applicable_in_use);
|
||||||
|
@ -271,6 +264,29 @@ fn main() {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn assist_runs_on_first_segment() {
|
||||||
|
check_assist(
|
||||||
|
replace_qualified_name_with_use,
|
||||||
|
r"
|
||||||
|
mod std { pub mod fmt { pub trait Debug {} } }
|
||||||
|
fn main() {
|
||||||
|
$0std::fmt::Debug;
|
||||||
|
let x: std::fmt::Debug = std::fmt::Debug;
|
||||||
|
}
|
||||||
|
",
|
||||||
|
r"
|
||||||
|
use std::fmt;
|
||||||
|
|
||||||
|
mod std { pub mod fmt { pub trait Debug {} } }
|
||||||
|
fn main() {
|
||||||
|
fmt::Debug;
|
||||||
|
let x: fmt::Debug = fmt::Debug;
|
||||||
|
}
|
||||||
|
",
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn does_not_replace_in_submodules() {
|
fn does_not_replace_in_submodules() {
|
||||||
check_assist(
|
check_assist(
|
||||||
|
|
Loading…
Reference in a new issue