mirror of
https://github.com/zed-industries/zed.git
synced 2024-12-24 17:28:40 +00:00
Fix infinite loop in select all matches
This commit is contained in:
parent
c074bfd441
commit
03d4191685
3 changed files with 28 additions and 7 deletions
|
@ -294,7 +294,7 @@
|
|||
"replace_newest": false
|
||||
}
|
||||
],
|
||||
"cmd-shift-d": "editor::SelectNextAll",
|
||||
"cmd-shift-d": "editor::SelectAllMatches",
|
||||
"ctrl-cmd-d": [
|
||||
"editor::SelectPrevious",
|
||||
{
|
||||
|
|
|
@ -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));
|
||||
|
||||
|
|
|
@ -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> {
|
||||
|
|
Loading…
Reference in a new issue