mirror of
https://github.com/sharkdp/bat.git
synced 2025-01-19 20:19:09 +01:00
Use ↹
character if tab-width == 1.
This commit is contained in:
parent
ecd862d9ff
commit
8fa8f44706
@ -11,6 +11,8 @@ contexts:
|
|||||||
scope: support.function.show-nonprintable.space
|
scope: support.function.show-nonprintable.space
|
||||||
- match: "├─*┤"
|
- match: "├─*┤"
|
||||||
scope: constant.character.escape.show-nonprintable.tab
|
scope: constant.character.escape.show-nonprintable.tab
|
||||||
|
- match: "↹"
|
||||||
|
scope: constant.character.escape.show-nonprintable.tab
|
||||||
- match: ""
|
- match: ""
|
||||||
scope: keyword.operator.show-nonprintable.newline
|
scope: keyword.operator.show-nonprintable.newline
|
||||||
- match: "␍"
|
- match: "␍"
|
||||||
|
@ -36,13 +36,7 @@ pub fn expand_tabs(line: &str, width: usize, cursor: &mut usize) -> String {
|
|||||||
pub fn replace_nonprintable(input: &mut Vec<u8>, output: &mut Vec<u8>, tab_width: usize) {
|
pub fn replace_nonprintable(input: &mut Vec<u8>, output: &mut Vec<u8>, tab_width: usize) {
|
||||||
output.clear();
|
output.clear();
|
||||||
|
|
||||||
let tab_width = if tab_width == 0 {
|
let tab_width = if tab_width == 0 { 4 } else { tab_width };
|
||||||
4
|
|
||||||
} else if tab_width == 1 {
|
|
||||||
2
|
|
||||||
} else {
|
|
||||||
tab_width
|
|
||||||
};
|
|
||||||
|
|
||||||
for chr in input {
|
for chr in input {
|
||||||
match *chr {
|
match *chr {
|
||||||
@ -50,10 +44,14 @@ pub fn replace_nonprintable(input: &mut Vec<u8>, output: &mut Vec<u8>, tab_width
|
|||||||
b' ' => output.extend_from_slice("•".as_bytes()),
|
b' ' => output.extend_from_slice("•".as_bytes()),
|
||||||
// tab
|
// tab
|
||||||
b'\t' => {
|
b'\t' => {
|
||||||
|
if tab_width == 1 {
|
||||||
|
output.extend_from_slice("↹".as_bytes());
|
||||||
|
} else {
|
||||||
output.extend_from_slice("├".as_bytes());
|
output.extend_from_slice("├".as_bytes());
|
||||||
output.extend_from_slice("─".repeat(tab_width - 2).as_bytes());
|
output.extend_from_slice("─".repeat(tab_width - 2).as_bytes());
|
||||||
output.extend_from_slice("┤".as_bytes());
|
output.extend_from_slice("┤".as_bytes());
|
||||||
}
|
}
|
||||||
|
}
|
||||||
// new line
|
// new line
|
||||||
b'\n' => output.extend_from_slice("".as_bytes()),
|
b'\n' => output.extend_from_slice("".as_bytes()),
|
||||||
// carriage return
|
// carriage return
|
||||||
|
Loading…
Reference in New Issue
Block a user