mirror of
https://github.com/rust-lang/rust-analyzer
synced 2024-12-28 14:03:35 +00:00
fix: handle synonymous imports in 'merge imports'
This commit is contained in:
parent
a62ea0a59e
commit
87a3ab4658
2 changed files with 82 additions and 5 deletions
|
@ -164,6 +164,7 @@ impl Merge for ast::UseTree {
|
|||
}
|
||||
}
|
||||
|
||||
#[derive(Debug)]
|
||||
enum Edit {
|
||||
Remove(Either<ast::Use, ast::UseTree>),
|
||||
Replace(SyntaxNode, SyntaxNode),
|
||||
|
@ -733,4 +734,72 @@ use std::{
|
|||
r"use std::fmt::{Debug, Display};",
|
||||
);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn test_merge_with_synonymous_imports_1() {
|
||||
check_assist(
|
||||
merge_imports,
|
||||
r"
|
||||
mod top {
|
||||
pub(crate) mod a {
|
||||
pub(crate) struct A;
|
||||
}
|
||||
pub(crate) mod b {
|
||||
pub(crate) struct B;
|
||||
pub(crate) struct D;
|
||||
}
|
||||
}
|
||||
|
||||
use top::a::A;
|
||||
use $0top::b::{B, B as C};
|
||||
",
|
||||
r"
|
||||
mod top {
|
||||
pub(crate) mod a {
|
||||
pub(crate) struct A;
|
||||
}
|
||||
pub(crate) mod b {
|
||||
pub(crate) struct B;
|
||||
pub(crate) struct D;
|
||||
}
|
||||
}
|
||||
|
||||
use top::{a::A, b::{B, B as C}};
|
||||
",
|
||||
);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn test_merge_with_synonymous_imports_2() {
|
||||
check_assist(
|
||||
merge_imports,
|
||||
r"
|
||||
mod top {
|
||||
pub(crate) mod a {
|
||||
pub(crate) struct A;
|
||||
}
|
||||
pub(crate) mod b {
|
||||
pub(crate) struct B;
|
||||
pub(crate) struct D;
|
||||
}
|
||||
}
|
||||
|
||||
use top::a::A;
|
||||
use $0top::b::{B as D, B as C};
|
||||
",
|
||||
r"
|
||||
mod top {
|
||||
pub(crate) mod a {
|
||||
pub(crate) struct A;
|
||||
}
|
||||
pub(crate) mod b {
|
||||
pub(crate) struct B;
|
||||
pub(crate) struct D;
|
||||
}
|
||||
}
|
||||
|
||||
use top::{a::A, b::{B as D, B as C}};
|
||||
",
|
||||
);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -93,17 +93,25 @@ fn try_merge_trees_mut(lhs: &ast::UseTree, rhs: &ast::UseTree, merge: MergeBehav
|
|||
let rhs_path = rhs.path()?;
|
||||
|
||||
let (lhs_prefix, rhs_prefix) = common_prefix(&lhs_path, &rhs_path)?;
|
||||
if !(lhs.is_simple_path()
|
||||
if lhs.is_simple_path()
|
||||
&& rhs.is_simple_path()
|
||||
&& lhs_path == lhs_prefix
|
||||
&& rhs_path == rhs_prefix)
|
||||
&& rhs_path == rhs_prefix
|
||||
{
|
||||
lhs.split_prefix(&lhs_prefix);
|
||||
rhs.split_prefix(&rhs_prefix);
|
||||
} else {
|
||||
// we can't merge if the renames are different (`A as a` and `A as b`),
|
||||
// and we can safely return here
|
||||
let lhs_name = lhs.rename().and_then(|lhs_name| lhs_name.name());
|
||||
let rhs_name = rhs.rename().and_then(|rhs_name| rhs_name.name());
|
||||
if lhs_name != rhs_name {
|
||||
return None;
|
||||
}
|
||||
|
||||
ted::replace(lhs.syntax(), rhs.syntax());
|
||||
// we can safely return here, in this case `recursive_merge` doesn't do anything
|
||||
return Some(());
|
||||
} else {
|
||||
lhs.split_prefix(&lhs_prefix);
|
||||
rhs.split_prefix(&rhs_prefix);
|
||||
}
|
||||
}
|
||||
recursive_merge(lhs, rhs, merge)
|
||||
|
|
Loading…
Reference in a new issue