mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-04 01:08:47 +00:00
fix(extract_module): nearby imports deletion causing panic
This commit is contained in:
parent
57861bd99e
commit
ddd59b9a9a
1 changed files with 57 additions and 1 deletions
|
@ -180,6 +180,7 @@ 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);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -439,9 +440,30 @@ impl Module {
|
||||||
ctx,
|
ctx,
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
|
if import_paths_to_be_removed.len() > 0 {
|
||||||
|
// Text ranges recieved here for imports are extended to the
|
||||||
|
// next/previous comma which can cause intersections among them
|
||||||
|
// and later deletion of these can cause panics similar
|
||||||
|
// to reported in #11766. So to mitigate it, we
|
||||||
|
// check for intersection between all current members
|
||||||
|
// and if it exists we combine both text ranges into
|
||||||
|
// one
|
||||||
|
for i in 0..import_paths_to_be_removed.len() {
|
||||||
|
if let Some(_) =
|
||||||
|
import_paths_to_be_removed[i].intersect(import_path)
|
||||||
|
{
|
||||||
|
import_paths_to_be_removed[i] =
|
||||||
|
import_paths_to_be_removed[i]
|
||||||
|
.cover(import_path);
|
||||||
|
} else {
|
||||||
import_paths_to_be_removed.push(import_path);
|
import_paths_to_be_removed.push(import_path);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
import_paths_to_be_removed.push(import_path);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1495,4 +1517,38 @@ mod modname {
|
||||||
",
|
",
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_issue_11766() {
|
||||||
|
//https://github.com/rust-lang/rust-analyzer/issues/11766
|
||||||
|
check_assist(
|
||||||
|
extract_module,
|
||||||
|
r"
|
||||||
|
mod x {
|
||||||
|
pub struct Foo;
|
||||||
|
pub struct Bar;
|
||||||
|
}
|
||||||
|
|
||||||
|
use x::{Bar, Foo};
|
||||||
|
|
||||||
|
$0type A = (Foo, Bar);$0
|
||||||
|
",
|
||||||
|
r"
|
||||||
|
mod x {
|
||||||
|
pub struct Foo;
|
||||||
|
pub struct Bar;
|
||||||
|
}
|
||||||
|
|
||||||
|
use x::{};
|
||||||
|
|
||||||
|
mod modname {
|
||||||
|
use super::x::Bar;
|
||||||
|
|
||||||
|
use super::x::Foo;
|
||||||
|
|
||||||
|
pub(crate) type A = (Foo, Bar);
|
||||||
|
}
|
||||||
|
",
|
||||||
|
)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue