mirror of
https://github.com/helix-editor/helix.git
synced 2025-04-04 11:27:46 +03:00
Switch to tabpad
configuration option (#3458)
Virtual whitespace tabs are created from the `tab` character padded with `tabpad` up to the tab width.
This commit is contained in:
parent
e61c0b461c
commit
ed74e6d5d4
3 changed files with 12 additions and 5 deletions
|
@ -192,7 +192,7 @@ Options for rendering whitespace with visible characters. Use `:set whitespace.r
|
|||
| Key | Description | Default |
|
||||
|-----|-------------|---------|
|
||||
| `render` | Whether to render whitespace. May either be `"all"` or `"none"`, or a table with sub-keys `space`, `tab`, and `newline`. | `"none"` |
|
||||
| `characters` | Literal characters to use when rendering whitespace. Sub-keys may be any of `tab`, `space`, `nbsp` or `newline` | See example below |
|
||||
| `characters` | Literal characters to use when rendering whitespace. Sub-keys may be any of `tab`, `space`, `nbsp`, `newline` or `tabpad` | See example below |
|
||||
|
||||
Example
|
||||
|
||||
|
@ -210,6 +210,7 @@ space = "·"
|
|||
nbsp = "⍽"
|
||||
tab = "→"
|
||||
newline = "⏎"
|
||||
tabpad = "·" # Tabs will look like "→···" (depending on tab width)
|
||||
```
|
||||
|
||||
### `[editor.indent-guides]` Section
|
||||
|
|
|
@ -390,19 +390,23 @@ impl EditorView {
|
|||
// of times than it is to always call Rope::slice/get_slice (it will internally always hit RSEnum::Light).
|
||||
let text = doc.text().slice(..);
|
||||
|
||||
let characters = &whitespace.characters;
|
||||
|
||||
let mut spans = Vec::new();
|
||||
let mut visual_x = 0u16;
|
||||
let mut line = 0u16;
|
||||
let tab_width = doc.tab_width();
|
||||
let tab = if whitespace.render.tab() == WhitespaceRenderValue::All {
|
||||
(1..tab_width).fold(whitespace.characters.tab.to_string(), |s, _| s + " ")
|
||||
std::iter::once(characters.tab)
|
||||
.chain(std::iter::repeat(characters.tabpad).take(tab_width - 1))
|
||||
.collect()
|
||||
} else {
|
||||
" ".repeat(tab_width)
|
||||
};
|
||||
let space = whitespace.characters.space.to_string();
|
||||
let nbsp = whitespace.characters.nbsp.to_string();
|
||||
let space = characters.space.to_string();
|
||||
let nbsp = characters.nbsp.to_string();
|
||||
let newline = if whitespace.render.newline() == WhitespaceRenderValue::All {
|
||||
whitespace.characters.newline.to_string()
|
||||
characters.newline.to_string()
|
||||
} else {
|
||||
" ".to_string()
|
||||
};
|
||||
|
|
|
@ -438,6 +438,7 @@ pub struct WhitespaceCharacters {
|
|||
pub space: char,
|
||||
pub nbsp: char,
|
||||
pub tab: char,
|
||||
pub tabpad: char,
|
||||
pub newline: char,
|
||||
}
|
||||
|
||||
|
@ -448,6 +449,7 @@ impl Default for WhitespaceCharacters {
|
|||
nbsp: '⍽', // U+237D
|
||||
tab: '→', // U+2192
|
||||
newline: '⏎', // U+23CE
|
||||
tabpad: ' ',
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue