Fix infinite loop in select all matches

This commit is contained in:
Mikayla 2023-09-20 08:00:55 -07:00
parent c074bfd441
commit 03d4191685
No known key found for this signature in database
3 changed files with 28 additions and 7 deletions

View file

@ -294,7 +294,7 @@
"replace_newest": false
}
],
"cmd-shift-d": "editor::SelectNextAll",
"cmd-shift-d": "editor::SelectAllMatches",
"ctrl-cmd-d": [
"editor::SelectPrevious",
{

View file

@ -130,7 +130,7 @@ pub struct SelectPrevious {
}
#[derive(Clone, Deserialize, PartialEq, Default)]
pub struct SelectNextAll {
pub struct SelectAllMatches {
#[serde(default)]
pub replace_newest: bool,
}
@ -331,7 +331,7 @@ impl_actions!(
[
SelectNext,
SelectPrevious,
SelectNextAll,
SelectAllMatches,
SelectToBeginningOfLine,
SelectToEndOfLine,
ToggleCodeActions,
@ -732,13 +732,22 @@ struct AddSelectionsState {
stack: Vec<usize>,
}
#[derive(Clone, Debug)]
#[derive(Clone)]
struct SelectNextState {
query: AhoCorasick,
wordwise: bool,
done: bool,
}
impl std::fmt::Debug for SelectNextState {
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
f.debug_struct(std::any::type_name::<Self>())
.field("wordwise", &self.wordwise)
.field("done", &self.done)
.finish()
}
}
#[derive(Debug)]
struct AutocloseRegion {
selection_id: usize,
@ -5985,7 +5994,9 @@ impl Editor {
.stream_find_iter(bytes_before_first_selection)
.map(|result| (0, result)),
);
for (start_offset, query_match) in query_matches {
(start_offset, &query_match);
let query_match = query_match.unwrap(); // can only fail due to I/O
let offset_range =
start_offset + query_match.start()..start_offset + query_match.end();
@ -5996,8 +6007,14 @@ impl Editor {
|| (!movement::is_inside_word(&display_map, display_range.start)
&& !movement::is_inside_word(&display_map, display_range.end))
{
next_selected_range = Some(offset_range);
break;
if selections
.iter()
.find(|selection| selection.equals(&offset_range))
.is_none()
{
next_selected_range = Some(offset_range);
break;
}
}
}
@ -6046,7 +6063,7 @@ impl Editor {
Ok(())
}
pub fn select_all_matches(&mut self, action: &SelectNextAll, cx: &mut ViewContext<Self>) {
pub fn select_all_matches(&mut self, action: &SelectAllMatches, cx: &mut ViewContext<Self>) {
self.push_to_selection_history();
let display_map = self.display_map.update(cx, |map, cx| map.snapshot(cx));

View file

@ -100,6 +100,10 @@ impl Selection<usize> {
reversed: false,
}
}
pub fn equals(&self, offset_range: &Range<usize>) -> bool {
self.start == offset_range.start && self.end == offset_range.end
}
}
impl Selection<Anchor> {