mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-04 01:08:47 +00:00
fix(extract_module): import resolution for items of submodules
This commit is contained in:
parent
ddd59b9a9a
commit
89f449b75d
1 changed files with 20 additions and 5 deletions
|
@ -180,7 +180,6 @@ pub(crate) fn extract_module(acc: &mut Assists, ctx: &AssistContext) -> Option<(
|
||||||
}
|
}
|
||||||
|
|
||||||
for import_path_text_range in import_paths_to_be_removed {
|
for import_path_text_range in import_paths_to_be_removed {
|
||||||
println!("Deleting : {:?}", import_path_text_range);
|
|
||||||
builder.delete(import_path_text_range);
|
builder.delete(import_path_text_range);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -565,12 +564,23 @@ impl Module {
|
||||||
} else if exists_inside_sel && !exists_outside_sel {
|
} else if exists_inside_sel && !exists_outside_sel {
|
||||||
//Changes to be made inside new module, and remove import from outside
|
//Changes to be made inside new module, and remove import from outside
|
||||||
|
|
||||||
if let Some((use_tree_str, text_range_opt)) =
|
if let Some((mut use_tree_str, text_range_opt)) =
|
||||||
self.process_use_stmt_for_import_resolve(use_stmt_opt, node_syntax)
|
self.process_use_stmt_for_import_resolve(use_stmt_opt, node_syntax)
|
||||||
{
|
{
|
||||||
if let Some(text_range) = text_range_opt {
|
if let Some(text_range) = text_range_opt {
|
||||||
import_path_to_be_removed = Some(text_range);
|
import_path_to_be_removed = Some(text_range);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if source_exists_outside_sel_in_same_mod {
|
||||||
|
let first_path_in_use_tree = use_tree_str[use_tree_str.len() - 1].to_string();
|
||||||
|
if !first_path_in_use_tree.contains("super")
|
||||||
|
&& !first_path_in_use_tree.contains("crate")
|
||||||
|
{
|
||||||
|
let super_path = make::ext::ident_path("super");
|
||||||
|
use_tree_str.push(super_path);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
use_tree_str_opt = Some(use_tree_str);
|
use_tree_str_opt = Some(use_tree_str);
|
||||||
} else if source_exists_outside_sel_in_same_mod {
|
} else if source_exists_outside_sel_in_same_mod {
|
||||||
self.make_use_stmt_of_node_with_super(node_syntax);
|
self.make_use_stmt_of_node_with_super(node_syntax);
|
||||||
|
@ -580,10 +590,15 @@ impl Module {
|
||||||
if let Some(use_tree_str) = use_tree_str_opt {
|
if let Some(use_tree_str) = use_tree_str_opt {
|
||||||
let mut use_tree_str = use_tree_str;
|
let mut use_tree_str = use_tree_str;
|
||||||
use_tree_str.reverse();
|
use_tree_str.reverse();
|
||||||
if use_tree_str[0].to_string().contains("super") {
|
|
||||||
|
if !(!exists_outside_sel && exists_inside_sel && source_exists_outside_sel_in_same_mod)
|
||||||
|
{
|
||||||
|
let first_path_in_use_tree = use_tree_str[0].to_string();
|
||||||
|
if first_path_in_use_tree.contains("super") {
|
||||||
let super_path = make::ext::ident_path("super");
|
let super_path = make::ext::ident_path("super");
|
||||||
use_tree_str.insert(0, super_path)
|
use_tree_str.insert(0, super_path)
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
let use_ =
|
let use_ =
|
||||||
make::use_(None, make::use_tree(make::join_paths(use_tree_str), None, None, false));
|
make::use_(None, make::use_tree(make::join_paths(use_tree_str), None, None, false));
|
||||||
|
|
Loading…
Reference in a new issue