diff options
author | Alexis Kalabura | 2022-07-21 04:03:12 +0000 |
---|---|---|
committer | GitHub | 2022-07-21 04:03:12 +0000 |
commit | 8b2a14153b0d21391e06636d0df7e8cc1b8143c4 (patch) | |
tree | 1acd64f439523618eec4ccc8ad049d68fb748c90 | |
parent | 906259cc41cc251dbbe1802e3a5e54a566a7d8d2 (diff) |
add statusline element to display file line endings (#3113)
* add statusline element to display file line endings
* run cargo fmt --all
* change the word *ending* from plural to singular
* support for the unicode-lines feature flag
-rw-r--r-- | book/src/configuration.md | 3 | ||||
-rw-r--r-- | helix-term/src/commands/typed.rs | 5 | ||||
-rw-r--r-- | helix-term/src/ui/statusline.rs | 26 | ||||
-rw-r--r-- | helix-view/src/editor.rs | 3 |
4 files changed, 33 insertions, 4 deletions
diff --git a/book/src/configuration.md b/book/src/configuration.md index c209dc3d..4eab4a48 100644 --- a/book/src/configuration.md +++ b/book/src/configuration.md @@ -62,7 +62,7 @@ Statusline elements can be defined as follows: [editor.statusline] left = ["mode", "spinner"] center = ["file-name"] -right = ["diagnostics", "selections", "position", "file-encoding", "file-type"] +right = ["diagnostics", "selections", "position", "file-encoding", "file-line-ending", "file-type"] ``` The following elements can be configured: @@ -73,6 +73,7 @@ The following elements can be configured: | `spinner` | A progress spinner indicating LSP activity | | `file-name` | The path/name of the opened file | | `file-encoding` | The encoding of the opened file if it differs from UTF-8 | +| `file-line-ending` | The file line endings (CRLF or LF) | | `file-type` | The type of the opened file | | `diagnostics` | The number of warnings and/or errors | | `selections` | The number of active selections | diff --git a/helix-term/src/commands/typed.rs b/helix-term/src/commands/typed.rs index fb03af44..d6db117e 100644 --- a/helix-term/src/commands/typed.rs +++ b/helix-term/src/commands/typed.rs @@ -413,12 +413,11 @@ fn set_line_ending( // Attempt to parse argument as a line ending. let line_ending = match arg { - // We check for CR first because it shares a common prefix with CRLF. - #[cfg(feature = "unicode-lines")] - arg if arg.starts_with("cr") => CR, arg if arg.starts_with("crlf") => Crlf, arg if arg.starts_with("lf") => LF, #[cfg(feature = "unicode-lines")] + arg if arg.starts_with("cr") => CR, + #[cfg(feature = "unicode-lines")] arg if arg.starts_with("ff") => FF, #[cfg(feature = "unicode-lines")] arg if arg.starts_with("nel") => Nel, diff --git a/helix-term/src/ui/statusline.rs b/helix-term/src/ui/statusline.rs index 895043cd..85992c60 100644 --- a/helix-term/src/ui/statusline.rs +++ b/helix-term/src/ui/statusline.rs @@ -138,6 +138,7 @@ where helix_view::editor::StatusLineElement::Spinner => render_lsp_spinner, helix_view::editor::StatusLineElement::FileName => render_file_name, helix_view::editor::StatusLineElement::FileEncoding => render_file_encoding, + helix_view::editor::StatusLineElement::FileLineEnding => render_file_line_ending, helix_view::editor::StatusLineElement::FileType => render_file_type, helix_view::editor::StatusLineElement::Diagnostics => render_diagnostics, helix_view::editor::StatusLineElement::Selections => render_selections, @@ -280,6 +281,31 @@ where } } +fn render_file_line_ending<F>(context: &mut RenderContext, write: F) +where + F: Fn(&mut RenderContext, String, Option<Style>) + Copy, +{ + use helix_core::LineEnding::*; + let line_ending = match context.doc.line_ending { + Crlf => "CRLF", + LF => "LF", + #[cfg(feature = "unicode-lines")] + VT => "VT", // U+000B -- VerticalTab + #[cfg(feature = "unicode-lines")] + FF => "FF", // U+000C -- FormFeed + #[cfg(feature = "unicode-lines")] + CR => "CR", // U+000D -- CarriageReturn + #[cfg(feature = "unicode-lines")] + Nel => "NEL", // U+0085 -- NextLine + #[cfg(feature = "unicode-lines")] + LS => "LS", // U+2028 -- Line Separator + #[cfg(feature = "unicode-lines")] + PS => "PS", // U+2029 -- ParagraphSeparator + }; + + write(context, format!(" {} ", line_ending), None); +} + fn render_file_type<F>(context: &mut RenderContext, write: F) where F: Fn(&mut RenderContext, String, Option<Style>) + Copy, diff --git a/helix-view/src/editor.rs b/helix-view/src/editor.rs index 0178d399..7ac52f50 100644 --- a/helix-view/src/editor.rs +++ b/helix-view/src/editor.rs @@ -232,6 +232,9 @@ pub enum StatusLineElement { /// The file encoding FileEncoding, + /// The file line endings (CRLF or LF) + FileLineEnding, + /// The file type (language ID or "text") FileType, |