Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

add customizable read-only indicator to statusbar #2862

Closed
wants to merge 44 commits into from
Closed
Show file tree
Hide file tree
Changes from 3 commits
Commits
Show all changes
44 commits
Select commit Hold shift + click to select a range
681d34b
initial implementation of bufferline
aaron404 Jun 13, 2022
fc8df18
fixed lint
aaron404 Jun 13, 2022
860ec7c
changed to 'bufferline', added enum for config modes, some cleanup
aaron404 Jun 13, 2022
4cb66c3
fixed lint
aaron404 Jun 13, 2022
479823d
added file modification indicator
aaron404 Jun 13, 2022
a2c6199
removed redundant code, added proper themeing with fallback, changed …
aaron404 Jun 14, 2022
1eca21e
add read-only flag to statusbar
sbromberger Jun 22, 2022
b36ce8f
doc cleanup
sbromberger Jun 23, 2022
824cbc6
map_or instead of map_or_else
sbromberger Jun 23, 2022
2bbd316
remove commented code
aaron404 Jun 23, 2022
b7d26ce
Merge branch 'master' into 497-add-bufferline
aaron404 Jun 23, 2022
039ac47
Update helix-term/src/ui/editor.rs
sbromberger Jun 23, 2022
ecb9c23
Update helix-term/src/ui/editor.rs
aaron404 Jun 23, 2022
1fe3e70
renamed FileStat / file_stat to WritePermission/write_permission
sbromberger Jun 25, 2022
6bb75fa
Merge branch 'sbromberger/read-only-indicator' of github.com:sbromber…
sbromberger Jun 25, 2022
f39b2fa
add ui.bufferline.background key for themes
aaron404 Jun 28, 2022
d80a9fd
address PR comments
aaron404 Jun 29, 2022
fe102bc
merge master
aaron404 Jun 29, 2022
8dfb9fe
Update helix-term/src/ui/editor.rs
aaron404 Jun 29, 2022
db5f30a
simplify computation of editor area:
aaron404 Jun 29, 2022
7ff2ff5
change to set_stringn to avoid overflow
aaron404 Jul 3, 2022
7fdb653
Merge branch 'master' into 497-add-bufferline
aaron404 Jul 5, 2022
c3a8892
Merge branch 'master' into sbromberger/read-only-indicator
sbromberger Jul 21, 2022
9c1eab4
refactor ro indicator given customizable statusline
sbromberger Jul 21, 2022
f926824
corrected docs for filename and ro indicator
sbromberger Jul 21, 2022
8d59fe9
Update configuration.md
sbromberger Jul 22, 2022
fda90d0
remove commented code
sbromberger Jul 23, 2022
0cb3dff
addressed pr comments
aaron404 Jul 24, 2022
0e3caa6
Merge branch 'helix-editor:master' into 497-add-bufferline
aaron404 Jul 25, 2022
5e7ccc9
Merge pull request #1 from sbromberger/patch-1
aaron404 Jul 26, 2022
303a721
Merge branch 'master' into sbromberger/read-only-indicator
sbromberger Jul 26, 2022
ec6d12f
fix build error
aaron404 Jul 27, 2022
5136a1b
Merge branch 'master' into sbromberger/read-only-indicator
sbromberger Jul 27, 2022
2874fa6
Merge branch 'master' into sbromberger/read-only-indicator
sbromberger Jul 31, 2022
3ad44f9
Update helix-view/src/document.rs
sbromberger Jul 31, 2022
e8a230a
Update helix-view/src/document.rs
sbromberger Jul 31, 2022
2922e68
Merge branch 'sbromberger/read-only-indicator' of github.com:sbromber…
sbromberger Jul 31, 2022
3ecea29
merge master, plus readonly->readonly_indicator
sbromberger Jul 31, 2022
cc3ab9f
needs more bikeshed
sbromberger Jul 31, 2022
042805d
address pr comments
aaron404 Aug 31, 2022
12846be
revert accidental change
aaron404 Aug 31, 2022
20ecab4
Merge commit 'refs/pull/2759/head' of https://github.com/helix-editor…
sbromberger Sep 1, 2022
346734c
Merge branch 'master' of https://github.com/helix-editor/helix
sbromberger Sep 2, 2022
30edb39
Merge branch 'master' into sbromberger/read-only-indicator
sbromberger Sep 2, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions book/src/configuration.md
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,7 @@ hidden = false
| `auto-info` | Whether to display infoboxes | `true` |
| `true-color` | Set to `true` to override automatic detection of terminal truecolor support in the event of a false negative. | `false` |
| `rulers` | List of column positions at which to display the rulers. Can be overridden by language specific `rulers` in `languages.toml` file. | `[]` |
| `read-only-indicator` | String to display next to filename in statusbar if file is read-only. | `[RO]` |

### `[editor.lsp]` Section

Expand Down
15 changes: 11 additions & 4 deletions helix-term/src/ui/editor.rs
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ use helix_core::{
LineEnding, Position, Range, Selection, Transaction,
};
use helix_view::{
document::{Mode, SCRATCH_BUFFER_NAME},
document::{FileStat, Mode, SCRATCH_BUFFER_NAME},
editor::{CompleteAction, CursorShapeConfig},
graphics::{Color, CursorKind, Modifier, Rect, Style},
input::KeyEvent,
Expand Down Expand Up @@ -157,7 +157,7 @@ impl EditorView {
.area
.clip_top(view.area.height.saturating_sub(1))
.clip_bottom(1); // -1 from bottom to remove commandline
self.render_statusline(doc, view, statusline_area, surface, theme, is_focused);
self.render_statusline(editor, doc, view, statusline_area, surface, is_focused);
}

pub fn render_rulers(
Expand Down Expand Up @@ -688,15 +688,16 @@ impl EditorView {

pub fn render_statusline(
&self,
editor: &Editor,
doc: &Document,
view: &View,
viewport: Rect,
surface: &mut Surface,
theme: &Theme,
is_focused: bool,
) {
use tui::text::{Span, Spans};

let theme = &editor.theme;
//-------------------------------
// Left side of the status line.
//-------------------------------
Expand Down Expand Up @@ -808,13 +809,19 @@ impl EditorView {
//-------------------------------
// Middle / File path / Title
//-------------------------------
let modified = if doc.is_modified() { "[+]" } else { "" };
let readonly = if doc.file_stat == FileStat::ReadOnly {
editor.config().read_only_indicator.to_string()
} else {
String::new()
};
let title = {
let rel_path = doc.relative_path();
let path = rel_path
.as_ref()
.map(|p| p.to_string_lossy())
.unwrap_or_else(|| SCRATCH_BUFFER_NAME.into());
format!("{}{}", path, if doc.is_modified() { "[+]" } else { "" })
format!("{}{}{}", readonly, path, modified)
sbromberger marked this conversation as resolved.
Show resolved Hide resolved
};

surface.set_string_truncated(
Expand Down
22 changes: 21 additions & 1 deletion helix-view/src/document.rs
Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,13 @@ pub enum Mode {
Insert = 2,
}

#[derive(Debug, Copy, Clone, PartialEq, Eq, Hash, Serialize)]
pub enum FileStat {
sbromberger marked this conversation as resolved.
Show resolved Hide resolved
Writable,
ReadOnly,
Unknown,
}

impl Display for Mode {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
match self {
Expand Down Expand Up @@ -121,9 +128,11 @@ pub struct Document {

diagnostics: Vec<Diagnostic>,
language_server: Option<Arc<helix_lsp::Client>>,
/// Mode of file - currently read-only, writable, or unknown.
sbromberger marked this conversation as resolved.
Show resolved Hide resolved
pub file_stat: FileStat,
}

use std::{fmt, mem};
use std::{fmt, fs, mem};
impl fmt::Debug for Document {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
f.debug_struct("Document")
Expand All @@ -143,6 +152,7 @@ impl fmt::Debug for Document {
.field("version", &self.version)
.field("modified_since_accessed", &self.modified_since_accessed)
.field("diagnostics", &self.diagnostics)
.field("file mode", &self.file_stat)
// .field("language_server", &self.language_server)
.finish()
}
Expand Down Expand Up @@ -361,6 +371,7 @@ impl Document {
last_saved_revision: 0,
modified_since_accessed: false,
language_server: None,
file_stat: FileStat::Unknown,
}
}

Expand Down Expand Up @@ -391,6 +402,15 @@ impl Document {
}

doc.detect_indent_and_line_ending();
// this seems overly complex but should make it easier
// to extend doc.file_stat with more information in the future.
doc.file_stat = fs::metadata(path).map_or(FileStat::Unknown, |f| {
if f.permissions().readonly() {
FileStat::ReadOnly
} else {
FileStat::Writable
}
});

Ok(doc)
}
Expand Down
4 changes: 4 additions & 0 deletions helix-view/src/editor.rs
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,8 @@ use serde::{ser::SerializeMap, Deserialize, Deserializer, Serialize, Serializer}

use arc_swap::access::{DynAccess, DynGuard};

const DEFAULT_READ_ONLY_INDICATOR: &str = "[RO]";

fn deserialize_duration_millis<'de, D>(deserializer: D) -> Result<Duration, D::Error>
where
D: serde::Deserializer<'de>,
Expand Down Expand Up @@ -158,6 +160,7 @@ pub struct Config {
pub whitespace: WhitespaceConfig,
/// Vertical indent width guides.
pub indent_guides: IndentGuidesConfig,
pub read_only_indicator: String,
}

#[derive(Debug, Default, Clone, PartialEq, Serialize, Deserialize)]
Expand Down Expand Up @@ -410,6 +413,7 @@ impl Default for Config {
rulers: Vec::new(),
whitespace: WhitespaceConfig::default(),
indent_guides: IndentGuidesConfig::default(),
read_only_indicator: DEFAULT_READ_ONLY_INDICATOR.to_string(),
}
}
}
Expand Down