fix spacing issue on colors

This commit is contained in:
Abin Simon 2019-03-11 20:42:16 +05:30 committed by Pierre Peltier
parent 27d57b2b86
commit c9b3550f61

View file

@ -281,13 +281,15 @@ fn get_visible_width(input: &str) -> usize {
// Search for every instance of "\e[" indicating the start of a color code // Search for every instance of "\e[" indicating the start of a color code
// then count the number of charactere between the string and the first 'm' // then count the number of charactere between the string and the first 'm'
// charactere indicating the end of the code color. // charactere indicating the end of the code color.
for (idx, _) in input.match_indices("\u{1b}[") { let matches: Vec<_> = input.match_indices("\u{1b}[").collect();
for c in input.chars().skip(idx) { if matches.len() > 0 {
for c in input.chars().skip(matches[0].0) {
nb_invisible_char += 1; nb_invisible_char += 1;
if c == 'm' { if c == 'm' {
break; break;
} }
} }
nb_invisible_char += 2;
} }
UnicodeWidthStr::width(input) - nb_invisible_char UnicodeWidthStr::width(input) - nb_invisible_char
@ -392,6 +394,7 @@ mod tests {
// Add 3 characters for the icons. // Add 3 characters for the icons.
(",!", 25), (",!", 25),
("ASCII1234-_", 14), ("ASCII1234-_", 14),
("File with space", 18),
("制作样本。", 13), ("制作样本。", 13),
("日本語", 9), ("日本語", 9),
("샘플은 무료로 드리겠습니다", 29), ("샘플은 무료로 드리겠습니다", 29),
@ -420,8 +423,9 @@ mod tests {
#[test] #[test]
fn test_display_get_visible_width_with_colors() { fn test_display_get_visible_width_with_colors() {
for (s, l) in &[ for (s, l) in &[
(",!", 24), (",!", 22),
("ASCII1234-_", 11), ("ASCII1234-_", 11),
("File with space", 15),
("制作样本。", 10), ("制作样本。", 10),
("日本語", 6), ("日本語", 6),
("샘플은 무료로 드리겠습니다", 26), ("샘플은 무료로 드리겠습니다", 26),
@ -447,7 +451,41 @@ mod tests {
assert_eq!(true, output.starts_with("\u{1b}[38;5;")); assert_eq!(true, output.starts_with("\u{1b}[38;5;"));
assert_eq!(true, output.ends_with("[0m")); assert_eq!(true, output.ends_with("[0m"));
println!("str: {:?}", output); assert_eq!(get_visible_width(&output), *l);
}
}
#[test]
fn test_display_get_visible_width_without_colors() {
for (s, l) in &[
(",!", 22),
("ASCII1234-_", 11),
("File with space", 15),
("制作样本。", 10),
("日本語", 6),
("샘플은 무료로 드리겠습니다", 26),
("👩🐩", 4),
("🔬", 2),
] {
let path = Path::new(s);
let name = Name::new(
&path,
FileType::File {
exec: false,
uid: false,
},
);
let output = name
.render(
&Colors::new(color::Theme::NoColor),
&Icons::new(icon::Theme::NoIcon),
)
.to_string();
// check if the color is present.
assert_eq!(false, output.starts_with("\u{1b}[38;5;"));
assert_eq!(false, output.ends_with("[0m"));
assert_eq!(get_visible_width(&output), *l); assert_eq!(get_visible_width(&output), *l);
} }
} }