mirror of
https://github.com/helix-editor/helix.git
synced 2025-04-03 19:07:44 +03:00
Fix panic in surround_replace/delete nested multi-cursor (#9815)
Test Document ------------- ``` {{ } } ``` Steps To Reproduce ------------------ 1. 2j # move_visual_line_down 1. C # copy_selection_on_next_line 1. mdm # surround_delete Debug ----- `assertion failed: last <= from', transaction.rs:597:13` Release ------- `called `Result::unwrap()` on an `Err` value: Char range out of bounds: char range 18446744073709551614..18446744073709551615, Rope/RopeSlice char length 7', ropey-1.6.1/src/rope.rs:546:37` Description ----------- Processing the surrounding pairs in order violates the assertion the ranges are ordered. To handle nested surrounds all positions have to be sorted. Also surround_replace has to track the proper replacement character for each position.
This commit is contained in:
parent
b93fae9c8b
commit
cb01e52cd8
2 changed files with 43 additions and 5 deletions
|
@ -577,6 +577,23 @@ async fn test_surround_replace() -> anyhow::Result<()> {
|
|||
))
|
||||
.await?;
|
||||
|
||||
test((
|
||||
platform_line(indoc! {"\
|
||||
{{
|
||||
|
||||
#(}|)#
|
||||
#[}|]#
|
||||
"}),
|
||||
"mrm)",
|
||||
platform_line(indoc! {"\
|
||||
((
|
||||
|
||||
#()|)#
|
||||
#[)|]#
|
||||
"}),
|
||||
))
|
||||
.await?;
|
||||
|
||||
Ok(())
|
||||
}
|
||||
|
||||
|
@ -604,5 +621,17 @@ async fn test_surround_delete() -> anyhow::Result<()> {
|
|||
))
|
||||
.await?;
|
||||
|
||||
test((
|
||||
platform_line(indoc! {"\
|
||||
{{
|
||||
|
||||
#(}|)#
|
||||
#[}|]#
|
||||
"}),
|
||||
"mdm",
|
||||
platform_line("\n\n#(\n|)##[\n|]#"),
|
||||
))
|
||||
.await?;
|
||||
|
||||
Ok(())
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue