From 4d314b2dd039933e5aab50b3b33fa492dc4988d0 Mon Sep 17 00:00:00 2001 From: Mikayla Maki Date: Mon, 15 Apr 2024 14:44:14 -0700 Subject: [PATCH] Increase the context in other multibuffers (#10582) This moves the diagnostics and find all references to be in line with the search pane. This also centralizes the constant into the editor code base. Release Notes: - Increased diagnostic context to match the project search context. --- crates/diagnostics/src/diagnostics.rs | 42 ++++++++++++++++++++------- crates/editor/src/editor.rs | 5 ++-- crates/search/src/project_search.rs | 4 +-- 3 files changed, 36 insertions(+), 15 deletions(-) diff --git a/crates/diagnostics/src/diagnostics.rs b/crates/diagnostics/src/diagnostics.rs index 11bac433fd..fc7f8de8a0 100644 --- a/crates/diagnostics/src/diagnostics.rs +++ b/crates/diagnostics/src/diagnostics.rs @@ -44,8 +44,6 @@ use workspace::{ actions!(diagnostics, [Deploy, ToggleWarnings]); -const CONTEXT_LINE_COUNT: u32 = 1; - pub fn init(cx: &mut AppContext) { ProjectDiagnosticsSettings::register(cx); cx.observe_new_views(ProjectDiagnosticsEditor::register) @@ -63,6 +61,7 @@ struct ProjectDiagnosticsEditor { paths_to_update: HashMap>, current_diagnostics: HashMap>, include_warnings: bool, + context: u32, _subscriptions: Vec, } @@ -116,7 +115,8 @@ impl ProjectDiagnosticsEditor { workspace.register_action(Self::deploy); } - fn new( + fn new_with_context( + context: u32, project_handle: Model, workspace: WeakView, cx: &mut ViewContext, @@ -181,6 +181,7 @@ impl ProjectDiagnosticsEditor { let summary = project.diagnostic_summary(false, cx); let mut this = Self { project: project_handle, + context, summary, workspace, excerpts, @@ -200,6 +201,19 @@ impl ProjectDiagnosticsEditor { this } + fn new( + project_handle: Model, + workspace: WeakView, + cx: &mut ViewContext, + ) -> Self { + Self::new_with_context( + editor::DEFAULT_MULTIBUFFER_CONTEXT, + project_handle, + workspace, + cx, + ) + } + fn deploy(workspace: &mut Workspace, _: &Deploy, cx: &mut ViewContext) { if let Some(existing) = workspace.item_of_type::(cx) { workspace.activate_item(&existing, cx); @@ -430,18 +444,16 @@ impl ProjectDiagnosticsEditor { let resolved_entry = entry.map(|e| e.resolve::(&snapshot)); if let Some((range, start_ix)) = &mut pending_range { if let Some(entry) = resolved_entry.as_ref() { - if entry.range.start.row - <= range.end.row + 1 + CONTEXT_LINE_COUNT * 2 - { + if entry.range.start.row <= range.end.row + 1 + self.context * 2 { range.end = range.end.max(entry.range.end); continue; } } let excerpt_start = - Point::new(range.start.row.saturating_sub(CONTEXT_LINE_COUNT), 0); + Point::new(range.start.row.saturating_sub(self.context), 0); let excerpt_end = snapshot.clip_point( - Point::new(range.end.row + CONTEXT_LINE_COUNT, u32::MAX), + Point::new(range.end.row + self.context, u32::MAX), Bias::Left, ); let excerpt_id = excerpts @@ -1030,7 +1042,12 @@ mod tests { // Open the project diagnostics view while there are already diagnostics. let view = window.build_view(cx, |cx| { - ProjectDiagnosticsEditor::new(project.clone(), workspace.downgrade(), cx) + ProjectDiagnosticsEditor::new_with_context( + 1, + project.clone(), + workspace.downgrade(), + cx, + ) }); view.next_notification(cx).await; @@ -1340,7 +1357,12 @@ mod tests { let workspace = window.root(cx).unwrap(); let view = window.build_view(cx, |cx| { - ProjectDiagnosticsEditor::new(project.clone(), workspace.downgrade(), cx) + ProjectDiagnosticsEditor::new_with_context( + 1, + project.clone(), + workspace.downgrade(), + cx, + ) }); // Two language servers start updating diagnostics diff --git a/crates/editor/src/editor.rs b/crates/editor/src/editor.rs index 3df1fa6732..1eb6963eee 100644 --- a/crates/editor/src/editor.rs +++ b/crates/editor/src/editor.rs @@ -138,6 +138,7 @@ use workspace::{ use crate::hover_links::find_url; +pub const DEFAULT_MULTIBUFFER_CONTEXT: u32 = 2; const CURSOR_BLINK_INTERVAL: Duration = Duration::from_millis(500); const MAX_LINE_LEN: usize = 1024; const MIN_NAVIGATION_HISTORY_ROW_DELTA: i64 = 10; @@ -3738,7 +3739,7 @@ impl Editor { buffer .edited_ranges_for_transaction::(transaction) .collect(), - 1, + DEFAULT_MULTIBUFFER_CONTEXT, cx, ), ); @@ -8007,7 +8008,7 @@ impl Editor { ranges_to_highlight.extend(multibuffer.push_excerpts_with_context_lines( location.buffer.clone(), ranges_for_buffer, - 1, + DEFAULT_MULTIBUFFER_CONTEXT, cx, )) } diff --git a/crates/search/src/project_search.rs b/crates/search/src/project_search.rs index f8f5e9f9c5..65ca55c5b7 100644 --- a/crates/search/src/project_search.rs +++ b/crates/search/src/project_search.rs @@ -54,8 +54,6 @@ struct ActiveSettings(HashMap, ProjectSearchSettings>); impl Global for ActiveSettings {} -const SEARCH_CONTEXT: u32 = 2; - pub fn init(cx: &mut AppContext) { cx.set_global(ActiveSettings::default()); cx.observe_new_views(|workspace: &mut Workspace, _cx| { @@ -234,7 +232,7 @@ impl ProjectSearch { excerpts.stream_excerpts_with_context_lines( buffer, ranges, - SEARCH_CONTEXT, + editor::DEFAULT_MULTIBUFFER_CONTEXT, cx, ) })