mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-27 12:25:05 +00:00
Fix autoimport not choosing the deepest use tree in some situations
This commit is contained in:
parent
1ca41f2118
commit
6d1b4ffa2e
1 changed files with 37 additions and 6 deletions
|
@ -124,9 +124,9 @@ fn fmt_segments_raw(segments: &[SmolStr], buf: &mut String) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Returns the numeber of common segments.
|
/// Returns the number of common segments.
|
||||||
fn compare_path_segments(left: &[SmolStr], right: &[ast::PathSegment]) -> usize {
|
fn compare_path_segments(left: &[SmolStr], right: &[ast::PathSegment]) -> usize {
|
||||||
left.iter().zip(right).filter(|(l, r)| compare_path_segment(l, r)).count()
|
left.iter().zip(right).take_while(|(l, r)| compare_path_segment(l, r)).count()
|
||||||
}
|
}
|
||||||
|
|
||||||
fn compare_path_segment(a: &SmolStr, b: &ast::PathSegment) -> bool {
|
fn compare_path_segment(a: &SmolStr, b: &ast::PathSegment) -> bool {
|
||||||
|
@ -147,7 +147,7 @@ fn compare_path_segment_with_name(a: &SmolStr, b: &ast::Name) -> bool {
|
||||||
a == b.text()
|
a == b.text()
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Clone)]
|
#[derive(Clone, Debug)]
|
||||||
enum ImportAction {
|
enum ImportAction {
|
||||||
Nothing,
|
Nothing,
|
||||||
// Add a brand new use statement.
|
// Add a brand new use statement.
|
||||||
|
@ -217,10 +217,18 @@ impl ImportAction {
|
||||||
(
|
(
|
||||||
ImportAction::AddNestedImport { common_segments: n, .. },
|
ImportAction::AddNestedImport { common_segments: n, .. },
|
||||||
ImportAction::AddInTreeList { common_segments: m, .. },
|
ImportAction::AddInTreeList { common_segments: m, .. },
|
||||||
) => n > m,
|
)
|
||||||
(
|
| (
|
||||||
ImportAction::AddInTreeList { common_segments: n, .. },
|
ImportAction::AddInTreeList { common_segments: n, .. },
|
||||||
ImportAction::AddNestedImport { common_segments: m, .. },
|
ImportAction::AddNestedImport { common_segments: m, .. },
|
||||||
|
)
|
||||||
|
| (
|
||||||
|
ImportAction::AddInTreeList { common_segments: n, .. },
|
||||||
|
ImportAction::AddInTreeList { common_segments: m, .. },
|
||||||
|
)
|
||||||
|
| (
|
||||||
|
ImportAction::AddNestedImport { common_segments: n, .. },
|
||||||
|
ImportAction::AddNestedImport { common_segments: m, .. },
|
||||||
) => n > m,
|
) => n > m,
|
||||||
(ImportAction::AddInTreeList { .. }, _) => true,
|
(ImportAction::AddInTreeList { .. }, _) => true,
|
||||||
(ImportAction::AddNestedImport { .. }, ImportAction::Nothing) => false,
|
(ImportAction::AddNestedImport { .. }, ImportAction::Nothing) => false,
|
||||||
|
@ -289,7 +297,7 @@ fn walk_use_tree_for_best_action(
|
||||||
common if common == left.len() && left.len() == right.len() => {
|
common if common == left.len() && left.len() == right.len() => {
|
||||||
// e.g: target is std::fmt and we can have
|
// e.g: target is std::fmt and we can have
|
||||||
// 1- use std::fmt;
|
// 1- use std::fmt;
|
||||||
// 2- use std::fmt:{ ... }
|
// 2- use std::fmt::{ ... }
|
||||||
if let Some(list) = tree_list {
|
if let Some(list) = tree_list {
|
||||||
// In case 2 we need to add self to the nested list
|
// In case 2 we need to add self to the nested list
|
||||||
// unless it's already there
|
// unless it's already there
|
||||||
|
@ -867,6 +875,29 @@ impl Display<|> for Foo {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_auto_import_use_nested_import() {
|
||||||
|
check_assist(
|
||||||
|
add_import,
|
||||||
|
"
|
||||||
|
use crate::{
|
||||||
|
ty::{Substs, Ty},
|
||||||
|
AssocItem,
|
||||||
|
};
|
||||||
|
|
||||||
|
fn foo() { crate::ty::lower<|>::trait_env() }
|
||||||
|
",
|
||||||
|
"
|
||||||
|
use crate::{
|
||||||
|
ty::{Substs, Ty, lower},
|
||||||
|
AssocItem,
|
||||||
|
};
|
||||||
|
|
||||||
|
fn foo() { lower<|>::trait_env() }
|
||||||
|
",
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_auto_import_alias() {
|
fn test_auto_import_alias() {
|
||||||
check_assist(
|
check_assist(
|
||||||
|
|
Loading…
Reference in a new issue