From 937c647f6802c6614e82f1f0275c1c067edd911a Mon Sep 17 00:00:00 2001 From: Aaron Feickert <66188213+AaronFeickert@users.noreply.github.com> Date: Sun, 22 Dec 2024 23:25:40 -0600 Subject: [PATCH] Add fine-grained control for scrollbar diagnostics --- assets/settings/default.json | 9 ++++++-- crates/editor/src/editor_settings.rs | 26 +++++++++++++++++++---- crates/editor/src/element.rs | 31 +++++++++++++++++++++++++--- 3 files changed, 57 insertions(+), 9 deletions(-) diff --git a/assets/settings/default.json b/assets/settings/default.json index 9f4f2dc34c..6c4db5fdf8 100644 --- a/assets/settings/default.json +++ b/assets/settings/default.json @@ -256,8 +256,13 @@ "search_results": true, // Whether to show selected symbol occurrences in the scrollbar. "selected_symbol": true, - // Whether to show diagnostic indicators in the scrollbar. - "diagnostics": true, + /// Which diagnostic indicators to show in the scrollbar. + /// "none": do not show any diagnostics + /// "error": show only errors + /// "warning": show only errors and warnings + /// "information": show only errors, warnings, and information + /// "all": show all diagnostics + "diagnostics": "all", /// Forcefully enable or disable the scrollbar for each axis "axes": { /// When false, forcefully disables the horizontal scrollbar. Otherwise, obey other settings. diff --git a/crates/editor/src/editor_settings.rs b/crates/editor/src/editor_settings.rs index d5cbb3e232..ee5a071e12 100644 --- a/crates/editor/src/editor_settings.rs +++ b/crates/editor/src/editor_settings.rs @@ -105,7 +105,7 @@ pub struct Scrollbar { pub git_diff: bool, pub selected_symbol: bool, pub search_results: bool, - pub diagnostics: bool, + pub diagnostics: ScrollbarDiagnostics, pub cursors: bool, pub axes: ScrollbarAxes, } @@ -150,6 +150,24 @@ pub struct ScrollbarAxes { pub vertical: bool, } +/// Which diagnostic indicators to show in the scrollbar. +/// +/// Default: all +#[derive(Copy, Clone, Debug, Serialize, Deserialize, JsonSchema, PartialEq, Eq)] +#[serde(rename_all = "snake_case")] +pub enum ScrollbarDiagnostics { + /// Show all diagnostic levels: hint, information, warnings, error. + All, + /// Show only the following diagnostic levels: information, warning, error. + Information, + /// Show only the following diagnostic levels: warning, error. + Warning, + /// Show only the following diagnostic level: error. + Error, + /// Do not show diagnostics. + None, +} + /// The key to use for adding multiple cursors /// /// Default: alt @@ -348,10 +366,10 @@ pub struct ScrollbarContent { /// /// Default: true pub selected_symbol: Option, - /// Whether to show diagnostic indicators in the scrollbar. + /// Which diagnostic indicators to show in the scrollbar. /// - /// Default: true - pub diagnostics: Option, + /// Default: all + pub diagnostics: Option, /// Whether to show cursor positions in the scrollbar. /// /// Default: true diff --git a/crates/editor/src/element.rs b/crates/editor/src/element.rs index 1f8925e48a..8dc3c5a22e 100644 --- a/crates/editor/src/element.rs +++ b/crates/editor/src/element.rs @@ -6,7 +6,7 @@ use crate::{ }, editor_settings::{ CurrentLineHighlight, DoubleClickInMultibuffer, MultiCursorModifier, ScrollBeyondLastLine, - ShowScrollbar, + ScrollbarDiagnostics, ShowScrollbar, }, git::blame::{CommitDetails, GitBlame}, hover_popover::{ @@ -1207,7 +1207,7 @@ impl EditorElement { (is_singleton && scrollbar_settings.selected_symbol && (editor.has_background_highlights::() || editor.has_background_highlights::())) || // Diagnostics - (is_singleton && scrollbar_settings.diagnostics && snapshot.buffer_snapshot.has_diagnostics()) + (is_singleton && scrollbar_settings.diagnostics != ScrollbarDiagnostics::None && snapshot.buffer_snapshot.has_diagnostics()) || // Cursors out of sight non_visible_cursors @@ -4590,13 +4590,38 @@ impl EditorElement { } } - if scrollbar_settings.diagnostics { + if scrollbar_settings.diagnostics != ScrollbarDiagnostics::None { let diagnostics = snapshot .buffer_snapshot .diagnostics_in_range::<_, Point>( Point::zero()..max_point, false, ) + // Don't show diagnostics the user doesn't care about + .filter(|diagnostic| { + match ( + scrollbar_settings.diagnostics, + diagnostic.diagnostic.severity, + ) { + (ScrollbarDiagnostics::All, _) => true, + ( + ScrollbarDiagnostics::Error, + DiagnosticSeverity::ERROR, + ) => true, + ( + ScrollbarDiagnostics::Warning, + DiagnosticSeverity::ERROR + | DiagnosticSeverity::WARNING, + ) => true, + ( + ScrollbarDiagnostics::Information, + DiagnosticSeverity::ERROR + | DiagnosticSeverity::WARNING + | DiagnosticSeverity::INFORMATION, + ) => true, + (_, _) => false, + } + }) // We want to sort by severity, in order to paint the most severe diagnostics last. .sorted_by_key(|diagnostic| { std::cmp::Reverse(diagnostic.diagnostic.severity)