mirror of
https://github.com/nushell/nushell.git
synced 2025-01-03 04:50:28 +01:00
Fix unicode word wrapping with ansi-cut (#767)
Ansi-cut expects ranges of character numbers (of the non-ansi control sequence characters) instead of byte indices. This fixes the panics when wrapping of non-unicode lines (which exceed the demanded number of characters as byte indices). Also rectifies some wrong wrapping of unicdoe containing lines that don't panic
This commit is contained in:
parent
ac36f32647
commit
01e691c5ba
@ -152,7 +152,7 @@ fn split_word(cell_width: usize, word: &str) -> Vec<Subline> {
|
||||
let mut end_index;
|
||||
|
||||
let word_no_ansi = strip_ansi(word);
|
||||
for c in word_no_ansi.char_indices() {
|
||||
for c in word_no_ansi.chars().enumerate() {
|
||||
if let Some(width) = c.1.width() {
|
||||
end_index = c.0;
|
||||
if current_width + width > cell_width {
|
||||
@ -169,7 +169,7 @@ fn split_word(cell_width: usize, word: &str) -> Vec<Subline> {
|
||||
}
|
||||
}
|
||||
|
||||
if start_index != word.len() {
|
||||
if start_index != word_no_ansi.chars().count() {
|
||||
output.push(Subline {
|
||||
subline: word.cut(start_index..),
|
||||
width: current_width,
|
||||
|
Loading…
Reference in New Issue
Block a user