summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBenjamin Sago <ogham@bsago.me>2020-10-24 19:39:22 +0100
committerBenjamin Sago <ogham@bsago.me>2020-10-24 19:41:07 +0100
commit51be9f4c43e61bbea61e70e1459e494207d1d979 (patch)
treef9dcc057302c79f5ed96f9c1d94aba0cc8513b04
parentc83359225b3037483aeb96d7562cd7bc8de6c0b8 (diff)
Introduce EXA_ICON_SPACING environment variablebetter-icons
This commit remove the extra space that was added between icons and file names in commit 128fadd, and adds an option to put them back. Re-fixes GH-619 and fixes GH-541.
-rw-r--r--man/exa.1.md6
-rw-r--r--src/options/file_name.rs26
-rw-r--r--src/options/vars.rs6
-rw-r--r--src/options/view.rs2
-rw-r--r--src/output/file_name.rs32
-rw-r--r--xtests/icons.toml35
-rw-r--r--xtests/outputs/exts_oneline_icons.ansitxt52
-rw-r--r--xtests/outputs/files_grid_icons.ansitxt13
-rw-r--r--xtests/outputs/files_long_grid_icons.ansitxt78
-rw-r--r--xtests/outputs/files_long_icons.ansitxt78
-rw-r--r--xtests/outputs/files_long_tree_icons.ansitxt80
-rw-r--r--xtests/outputs/files_oneline_icons.ansitxt78
-rw-r--r--xtests/outputs/files_tree_icons.ansitxt80
-rw-r--r--xtests/outputs/links_oneline_icons.ansitxt20
-rw-r--r--xtests/outputs/links_oneline_icons_width0.ansitxt10
-rw-r--r--xtests/outputs/links_oneline_icons_width2.ansitxt10
-rw-r--r--xtests/outputs/links_oneline_icons_width3.ansitxt10
-rw-r--r--xtests/outputs/permissions_oneline_icons.ansitxt44
18 files changed, 389 insertions, 271 deletions
diff --git a/man/exa.1.md b/man/exa.1.md
index 5525b93..a0a97de 100644
--- a/man/exa.1.md
+++ b/man/exa.1.md
@@ -208,6 +208,12 @@ Limits the grid-details view (‘`exa --grid --long`’) so it’s only activate
With widescreen displays, it’s possible for the grid to look very wide and sparse, on just one or two lines with none of the columns lining up.
By specifying a minimum number of rows, you can only use the view if it’s going to be worth using.
+## `EXA_ICON_SPACING`
+
+Specifies the number of spaces to print between an icon (see the ‘`--icons`’ option) and its file name.
+
+Different terminals display icons differently, as they usually take up more than one character width on screen, so there’s no “standard” number of spaces that exa can use to separate an icon from text. One space may place the icon too close to the text, and two spaces may place it too far away. So the choice is left up to the user to configure depending on their terminal emulator.
+
## `LS_COLORS`, `EXA_COLORS`
Specifies the colour scheme used to highlight files based on their name and kind, as well as highlighting metadata and parts of the UI.
diff --git a/src/options/file_name.rs b/src/options/file_name.rs
index 283562a..d29f454 100644
--- a/src/options/file_name.rs
+++ b/src/options/file_name.rs
@@ -1,15 +1,16 @@
use crate::options::{flags, OptionsError};
use crate::options::parser::MatchedFlags;
+use crate::options::vars::{self, Vars};
-use crate::output::file_name::{Options, Classify};
+use crate::output::file_name::{Options, Classify, ShowIcons};
impl Options {
- pub fn deduce(matches: &MatchedFlags<'_>) -> Result<Self, OptionsError> {
+ pub fn deduce<V: Vars>(matches: &MatchedFlags<'_>, vars: &V) -> Result<Self, OptionsError> {
let classify = Classify::deduce(matches)?;
- let icons = matches.has(&flags::ICONS)?;
+ let show_icons = ShowIcons::deduce(matches, vars)?;
- Ok(Self { classify, icons })
+ Ok(Self { classify, show_icons })
}
}
@@ -21,3 +22,20 @@ impl Classify {
else { Ok(Self::JustFilenames) }
}
}
+
+impl ShowIcons {
+ pub fn deduce<V: Vars>(matches: &MatchedFlags<'_>, vars: &V) -> Result<Self, OptionsError> {
+ if ! matches.has(&flags::ICONS)? {
+ Ok(Self::Off)
+ }
+ else if let Some(columns) = vars.get(vars::EXA_ICON_SPACING).and_then(|s| s.into_string().ok()) {
+ match columns.parse() {
+ Ok(width) => Ok(Self::On(width)),
+ Err(e) => Err(OptionsError::FailedParse(e)),
+ }
+ }
+ else {
+ Ok(Self::On(1))
+ }
+ }
+}
diff --git a/src/options/vars.rs b/src/options/vars.rs
index 8c87332..a8fc40e 100644
--- a/src/options/vars.rs
+++ b/src/options/vars.rs
@@ -39,6 +39,12 @@ pub static EXA_DEBUG: &str = "EXA_DEBUG";
/// number of rows of output.
pub static EXA_GRID_ROWS: &str = "EXA_GRID_ROWS";
+/// Environment variable used to specify how many spaces to print between an
+/// icon and its file name. Different terminals display icons differently,
+/// with 1 space bringing them too close together or 2 spaces putting them too
+/// far apart, so this may be necessary depending on how they are shown.
+pub static EXA_ICON_SPACING: &str = "EXA_ICON_SPACING";
+
/// Mockable wrapper for `std::env::var_os`.
pub trait Vars {
diff --git a/src/options/view.rs b/src/options/view.rs
index bb97286..9ad42ae 100644
--- a/src/options/view.rs
+++ b/src/options/view.rs
@@ -12,7 +12,7 @@ impl View {
pub fn deduce<V: Vars>(matches: &MatchedFlags<'_>, vars: &V) -> Result<Self, OptionsError> {
let mode = Mode::deduce(matches, vars)?;
let width = TerminalWidth::deduce(vars)?;
- let file_style = FileStyle::deduce(matches)?;
+ let file_style = FileStyle::deduce(matches, vars)?;
Ok(Self { mode, width, file_style })
}
}
diff --git a/src/output/file_name.rs b/src/output/file_name.rs
index ff61035..bcd4b47 100644
--- a/src/output/file_name.rs
+++ b/src/output/file_name.rs
@@ -18,7 +18,7 @@ pub struct Options {
pub classify: Classify,
/// Whether to prepend icon characters before file names.
- pub icons: bool,
+ pub show_icons: ShowIcons,
}
impl Options {
@@ -72,6 +72,19 @@ impl Default for Classify {
}
+/// Whether and how to show icons.
+#[derive(PartialEq, Debug, Copy, Clone)]
+pub enum ShowIcons {
+
+ /// Don’t show icons at all.
+ Off,
+
+ /// Show icons next to file names, with the given number of spaces between
+ /// the icon and the file name.
+ On(u32),
+}
+
+
/// A **file name** holds all the information necessary to display the name
/// of the given file. This is used in all of the views.
pub struct FileName<'a, 'dir, C> {
@@ -112,12 +125,17 @@ impl<'a, 'dir, C: Colours> FileName<'a, 'dir, C> {
pub fn paint(&self) -> TextCellContents {
let mut bits = Vec::new();
- if self.options.icons {
+ if let ShowIcons::On(spaces_count) = self.options.show_icons {
let style = iconify_style(self.style());
let file_icon = icon_for_file(self.file).to_string();
bits.push(style.paint(file_icon));
- bits.push(Style::default().paint(" "));
+
+ match spaces_count {
+ 1 => bits.push(Style::default().paint(" ")),
+ 2 => bits.push(Style::default().paint(" ")),
+ n => bits.push(Style::default().paint(spaces(n))),
+ }
}
if self.file.parent_dir.is_none() {
@@ -152,7 +170,7 @@ impl<'a, 'dir, C: Colours> FileName<'a, 'dir, C> {
if ! target.name.is_empty() {
let target_options = Options {
classify: Classify::JustFilenames,
- icons: false,
+ show_icons: ShowIcons::Off,
};
let target = FileName {
@@ -320,3 +338,9 @@ pub trait Colours: FiletypeColours {
fn colour_file(&self, file: &File<'_>) -> Style;
}
+
+
+/// Generate a string made of `n` spaces.
+fn spaces(width: u32) -> String {
+ (0 .. width).into_iter().map(|_| ' ').collect()
+}
diff --git a/xtests/icons.toml b/xtests/icons.toml
index d0d6f66..6a1029d 100644
--- a/xtests/icons.toml
+++ b/xtests/icons.toml
@@ -77,3 +77,38 @@ stdout = { file = "outputs/links_oneline_icons.ansitxt" }
stderr = { empty = true }
status = 0
tags = [ 'oneline', 'icons' ]
+
+
+# icon spacing tests
+
+[[cmd]]
+name = "‘EXA_ICON_SPACING=0 exa -1 --icons’ puts no spaces between icons and file names"
+shell = "EXA_ICON_SPACING=0 exa -1 --icons /testcases/links"
+stdout = { file = "outputs/links_oneline_icons_width0.ansitxt" }
+stderr = { empty = true }
+status = 0
+tags = [ 'env', 'oneline', 'icons' ]
+
+[[cmd]]
+name = "‘EXA_ICON_SPACING=1 exa -1 --icons’ puts one space between icons and file names"
+shell = "EXA_ICON_SPACING=1 exa -1 --icons /testcases/links"
+stdout = { file = "outputs/links_oneline_icons.ansitxt" } # same as the default
+stderr = { empty = true }
+status = 0
+tags = [ 'env', 'oneline', 'icons' ]
+
+[[cmd]]
+name = "‘EXA_ICON_SPACING=2 exa -1 --icons’ puts two spaces between icons and file names"
+shell = "EXA_ICON_SPACING=2 exa -1 --icons /testcases/links"
+stdout = { file = "outputs/links_oneline_icons_width2.ansitxt" }
+stderr = { empty = true }
+status = 0
+tags = [ 'env', 'oneline', 'icons' ]
+
+[[cmd]]
+name = "‘EXA_ICON_SPACING=3 exa -1 --icons’ puts three spaces between icons and file names"
+shell = "EXA_ICON_SPACING=3 exa -1 --icons /testcases/links"
+stdout = { file = "outputs/links_oneline_icons_width3.ansitxt" }
+stderr = { empty = true }
+status = 0
+tags = [ 'env', 'oneline', 'icons' ]
diff --git a/xtests/outputs/exts_oneline_icons.ansitxt b/xtests/outputs/exts_oneline_icons.ansitxt
index 54a4734..fa484ef 100644
--- a/xtests/outputs/exts_oneline_icons.ansitxt
+++ b/xtests/outputs/exts_oneline_icons.ansitxt
@@ -1,26 +1,26 @@
- #SAVEFILE#
- backup~
- compiled.class
- compiled.coffee
- compiled.js
- compiled.o
- compressed.deb
- compressed.tar.gz
- compressed.tar.xz
- compressed.tgz
- compressed.txz
- COMPRESSED.ZIP
- crypto.asc
- crypto.signature
- document.pdf
- DOCUMENT.XLSX
- file.tmp
- IMAGE.PNG
- image.svg
- lossless.flac
- lossless.wav
- Makefile
- music.mp3
- MUSIC.OGG
- VIDEO.AVI
- video.wmv
+ #SAVEFILE#
+ backup~
+ compiled.class
+ compiled.coffee
+ compiled.js
+ compiled.o
+ compressed.deb
+ compressed.tar.gz
+ compressed.tar.xz
+ compressed.tgz
+ compressed.txz
+ COMPRESSED.ZIP
+ crypto.asc
+ crypto.signature
+ document.pdf
+ DOCUMENT.XLSX
+ file.tmp
+ IMAGE.PNG
+ image.svg
+ lossless.flac
+ lossless.wav
+ Makefile
+ music.mp3
+ MUSIC.OGG
+ VIDEO.AVI
+ video.wmv
diff --git a/xtests/outputs/files_grid_icons.ansitxt b/xtests/outputs/files_grid_icons.ansitxt
index b686046..ce58378 100644
--- a/xtests/outputs/files_grid_icons.ansitxt
+++ b/xtests/outputs/files_grid_icons.ansitxt
@@ -1,7 +1,6 @@
- 1_bytes  3_KiB  5_MiB  8_bytes  10_KiB  12_MiB
- 1_KiB  3_MiB  6_bytes  8_KiB  10_MiB  13_bytes
- 1_MiB  4_bytes  6_KiB  8_MiB  11_bytes  13_KiB
- 2_bytes  4_KiB  6_MiB  9_bytes  11_KiB  13_MiB
- 2_KiB  4_MiB  7_bytes  9_KiB  11_MiB
- 2_MiB  5_bytes  7_KiB  9_MiB  12_bytes
- 3_bytes  5_KiB  7_MiB  10_bytes  12_KiB
+ 1_bytes  3_bytes  5_bytes  7_bytes  9_bytes  11_bytes  13_bytes
+ 1_KiB  3_KiB  5_KiB  7_KiB  9_KiB  11_KiB  13_KiB
+ 1_MiB  3_MiB  5_MiB  7_MiB  9_MiB  11_MiB  13_MiB
+ 2_bytes  4_bytes  6_bytes  8_bytes  10_bytes  12_bytes
+ 2_KiB  4_KiB  6_KiB  8_KiB  10_KiB  12_KiB
+ 2_MiB  4_MiB  6_MiB  8_MiB  10_MiB  12_MiB
diff --git a/xtests/outputs/files_long_grid_icons.ansitxt b/xtests/outputs/files_long_grid_icons.ansitxt
index 01c102b..5807ff1 100644
--- a/xtests/outputs/files_long_grid_icons.ansitxt
+++ b/xtests/outputs/files_long_grid_icons.ansitxt
@@ -1,39 +1,39 @@
-.rw-r--r-- 1 cassowary  1 Jan 12:34  1_bytes
-.rw-r--r-- 1.0k cassowary  1 Jan 12:34  1_KiB
-.rw-r--r-- 1.0M cassowary  1 Jan 12:34  1_MiB
-.rw-r--r-- 2 cassowary  1 Jan 12:34  2_bytes
-.rw-r--r-- 2.0k cassowary  1 Jan 12:34  2_KiB
-.rw-r--r-- 2.1M cassowary  1 Jan 12:34  2_MiB
-.rw-r--r-- 3 cassowary  1 Jan 12:34  3_bytes
-.rw-r--r-- 3.1k cassowary  1 Jan 12:34  3_KiB
-.rw-r--r-- 3.1M cassowary  1 Jan 12:34  3_MiB
-.rw-r--r-- 4 cassowary  1 Jan 12:34  4_bytes
-.rw-r--r-- 4.1k cassowary  1 Jan 12:34  4_KiB
-.rw-r--r-- 4.2M cassowary  1 Jan 12:34  4_MiB
-.rw-r--r-- 5 cassowary  1 Jan 12:34  5_bytes
-.rw-r--r-- 5.1k cassowary  1 Jan 12:34  5_KiB
-.rw-r--r-- 5.2M cassowary  1 Jan 12:34  5_MiB
-.rw-r--r-- 6 cassowary  1 Jan 12:34  6_bytes
-.rw-r--r-- 6.1k cassowary  1 Jan 12:34  6_KiB
-.rw-r--r-- 6.3M cassowary  1 Jan 12:34  6_MiB
-.rw-r--r-- 7 cassowary  1 Jan 12:34  7_bytes
-.rw-r--r-- 7.2k cassowary  1 Jan 12:34  7_KiB
-.rw-r--r-- 7.3M cassowary  1 Jan 12:34  7_MiB
-.rw-r--r-- 8 cassowary  1 Jan 12:34  8_bytes
-.rw-r--r-- 8.2k cassowary  1 Jan 12:34  8_KiB
-.rw-r--r-- 8.4M cassowary  1 Jan 12:34  8_MiB
-.rw-r--r-- 9 cassowary  1 Jan 12:34  9_bytes
-.rw-r--r-- 9.2k cassowary  1 Jan 12:34  9_KiB
-.rw-r--r-- 9.4M cassowary  1 Jan 12:34  9_MiB
-.rw-r--r-- 10 cassowary  1 Jan 12:34  10_bytes
-.rw-r--r-- 10k cassowary  1 Jan 12:34  10_KiB
-.rw-r--r-- 10M cassowary  1 Jan 12:34  10_MiB
-.rw-r--r-- 11 cassowary  1 Jan 12:34  11_bytes
-.rw-r--r-- 11k cassowary  1 Jan 12:34  11_KiB
-.rw-r--r-- 11M cassowary  1 Jan 12:34  11_MiB
-.rw-r--r-- 12 cassowary  1 Jan 12:34  12_bytes
-.rw-r--r-- 12k cassowary  1 Jan 12:34  12_KiB
-.rw-r--r-- 12M cassowary  1 Jan 12:34  12_MiB
-.rw-r--r-- 13 cassowary  1 Jan 12:34  13_bytes
-.rw-r--r-- 13k cassowary  1 Jan 12:34  13_KiB
-.rw-r--r-- 13M cassowary  1 Jan 12:34  13_MiB
+.rw-r--r-- 1 cassowary  1 Jan 12:34  1_bytes
+.rw-r--r-- 1.0k cassowary  1 Jan 12:34  1_KiB
+.rw-r--r-- 1.0M cassowary  1 Jan 12:34  1_MiB
+.rw-r--r-- 2 cassowary  1 Jan 12:34  2_bytes
+.rw-r--r-- 2.0k cassowary  1 Jan 12:34  2_KiB
+.rw-r--r-- 2.1M cassowary  1 Jan 12:34  2_MiB
+.rw-r--r-- 3 cassowary  1 Jan 12:34  3_bytes
+.rw-r--r-- 3.1k cassowary  1 Jan 12:34  3_KiB
+.rw-r--r-- 3.1M cassowary  1 Jan 12:34  3_MiB
+.rw-r--r-- 4 cassowary  1 Jan 12:34  4_bytes
+.rw-r--r-- 4.1k cassowary  1 Jan 12:34  4_KiB
+.rw-r--r-- 4.2M cassowary  1 Jan 12:34  4_MiB
+.rw-r--r-- 5 cassowary  1 Jan 12:34  5_bytes
+.rw-r--r-- 5.1k cassowary  1 Jan 12:34  5_KiB
+.rw-r--r-- 5.2M cassowary  1 Jan 12:34  5_MiB
+.rw-r--r-- 6 cassowary  1 Jan 12:34  6_bytes
+.rw-r--r-- 6.1k cassowary  1 Jan 12:34  6_KiB
+.rw-r--r-- 6.3M cassowary  1 Jan 12:34  6_MiB
+.rw-r--r-- 7 cassowary  1 Jan 12:34  7_bytes
+.rw-r--r-- 7.2k cassowary  1 Jan 12:34  7_KiB
+.rw-r--r-- 7.3M cassowary  1 Jan 12:34  7_MiB
+.rw-r--r-- 8 cassowary  1 Jan 12:34  8_bytes
+.rw-r--r-- 8.2k cassowary  1 Jan 12:34  8_KiB
+.rw-r--r-- 8.4M cassowary  1 Jan 12:34  8_MiB
+.rw-r--r-- 9 cassowary  1 Jan 12:34  9_bytes
+.rw-r--r-- 9.2k cassowary  1 Jan 12:34  9_KiB
+.rw-r--r-- 9.4M cassowary  1 Jan 12:34  9_MiB
+.rw-r--r-- 10 cassowary  1 Jan 12:34  10_bytes
+.rw-r--r-- 10k cassowary  1 Jan 12:34  10_KiB
+.rw-r--r-- 10M cassowary  1 Jan 12:34  10_MiB
+.rw-r--r-- 11 cassowary  1 Jan 12:34  11_bytes
+.rw-r--r-- 11k cassowary  1 Jan 12:34  11_KiB
+.rw-r--r-- 11M cassowary  1 Jan 12:34  11_MiB
+.rw-r--r-- 12 cassowary  1 Jan 12:34  12_bytes
+.rw-r--r-- 12k cassowary  1 Jan 12:34  12_KiB
+.rw-r--r-- 12M cassowary  1 Jan 12:34  12_MiB
+.rw-r--r-- 13 cassowary  1 Jan 12:34  13_bytes
+.rw-r--r-- 13k cassowary  1 Jan 12:34  13_KiB
+.rw-r--r-- 13M cassowary  1 Jan 12:34  13_MiB
diff --git a/xtests/outputs/files_long_icons.ansitxt b/xtests/outputs/files_long_icons.ansitxt
index 01c102b..5807ff1 100644
--- a/xtests/outputs/files_long_icons.ansitxt
+++ b/xtests/outputs/files_long_icons.ansitxt
@@ -1,39 +1,39 @@
-.rw-r--r-- 1 cassowary  1 Jan 12:34  1_bytes
-.rw-r--r-- 1.0k cassowary  1 Jan 12:34  1_KiB
-.rw-r--r-- 1.0M cassowary  1 Jan 12:34  1_MiB
-.rw-r--r-- 2 cassowary  1 Jan 12:34  2_bytes
-.rw-r--r-- 2.0k cassowary  1 Jan 12:34  2_KiB
-.rw-r--r-- 2.1M cassowary  1 Jan 12:34  2_MiB
-.rw-r--r-- 3 cassowary  1 Jan 12:34  3_bytes
-.rw-r--r-- 3.1k cassowary  1 Jan 12:34  3_KiB
-.rw-r--r-- 3.1M cassowary  1 Jan 12:34  3_MiB
-.rw-r--r-- 4 cassowary  1 Jan 12:34  4_bytes
-.rw-r--r-- 4.1k cassowary  1 Jan 12:34  4_KiB
-.rw-r--r-- 4.2M cassowary  1 Jan 12:34  4_MiB
-.rw-r--r-- 5 cassowary  1 Jan 12:34  5_bytes
-.rw-r--r-- 5.1k cassowary  1 Jan 12:34  5_KiB
-.rw-r--r-- 5.2M cassowary  1 Jan 12:34  5_MiB
-.rw-r--r-- 6 cassowary  1 Jan 12:34  6_bytes
-.rw-r--r-- 6.1k cassowary  1 Jan 12:34  6_KiB
-.rw-r--r-- 6.3M cassowary  1 Jan 12:34  6_MiB
-.rw-r--r-- 7 cassowary  1 Jan 12:34  7_bytes
-.rw-r--r-- 7.2k cassowary  1 Jan 12:34  7_KiB
-.rw-r--r-- 7.3M cassowary  1 Jan 12:34  7_MiB
-.rw-r--r-- 8 cassowary  1 Jan 12:34  8_bytes
-.rw-r--r-- 8.2k cassowary  1 Jan 12:34  8_KiB
-.rw-r--r-- 8.4M cassowary  1 Jan 12:34  8_MiB
-.rw-r--r-- 9 cassowary  1 Jan 12:34  9_bytes
-.rw-r--r-- 9.2k cassowary  1 Jan 12:34  9_KiB
-.rw-r--r-- 9.4M cassowary  1 Jan 12:34  9_MiB
-.rw-r--r-- 10 cassowary  1 Jan 12:34  10_bytes
-.rw-r--r-- 10k cassowary  1 Jan 12:34  10_KiB
-.rw-r--r-- 10M cassowary  1 Jan 12:34  10_MiB
-.rw-r--r-- 11 cassowary  1 Jan 12:34  11_bytes
-.rw-r--r-- 11k cassowary  1 Jan 12:34  11_KiB
-.rw-r--r-- 11M cassowary  1 Jan 12:34  11_MiB
-.rw-r--r-- 12 cassowary  1 Jan 12:34  12_bytes
-.rw-r--r-- 12k cassowary  1 Jan 12:34  12_KiB
-.rw-r--r-- 12M cassowary  1 Jan 12:34  12_MiB
-.rw-r--r-- 13 cassowary  1 Jan 12:34  13_bytes
-.rw-r--r-- 13k cassowary  1 Jan 12:34  13_KiB
-.rw-r--r-- 13M cassowary  1 Jan 12:34  13_MiB
+.rw-r--r-- 1 cassowary  1 Jan 12:34  1_bytes
+.rw-r--r-- 1.0k cassowary  1 Jan 12:34  1_KiB
+.rw-r--r-- 1.0M cassowary  1 Jan 12:34  1_MiB
+.rw-r--r-- 2 cassowary  1 Jan 12:34  2_bytes
+.rw-r--r-- 2.0k cassowary  1 Jan 12:34  2_KiB
+.rw-r--r-- 2.1M cassowary  1 Jan 12:34  2_MiB
+.rw-r--r-- 3 cassowary  1 Jan 12:34  3_bytes
+.rw-r--r-- 3.1k cassowary  1 Jan 12:34  3_KiB
+.rw-r--r-- 3.1M cassowary  1 Jan 12:34  3_MiB
+.rw-r--r-- 4 cassowary  1 Jan 12:34  4_bytes
+.rw-r--r-- 4.1k cassowary  1 Jan 12:34  4_KiB
+.rw-r--r-- 4.2M cassowary  1 Jan 12:34  4_MiB
+.rw-r--r-- 5 cassowary  1 Jan 12:34  5_bytes
+.rw-r--r-- 5.1k cassowary  1 Jan 12:34  5_KiB
+.rw-r--r-- 5.2M cassowary  1 Jan 12:34  5_MiB
+.rw-r--r-- 6 cassowary  1 Jan 12:34  6_bytes
+.rw-r--r-- 6.1k cassowary  1 Jan 12:34  6_KiB
+.rw-r--r-- 6.3M cassowary  1 Jan 12:34  6_MiB
+.rw-r--r-- 7 cassowary  1 Jan 12:34  7_bytes
+.rw-r--r-- 7.2k cassowary  1 Jan 12:34  7_KiB
+.rw-r--r-- 7.3M cassowary  1 Jan 12:34  7_MiB
+.rw-r--r-- 8 cassowary  1 Jan 12:34  8_bytes
+.rw-r--r-- 8.2k cassowary  1 Jan 12:34  8_KiB
+.rw-r--r-- 8.4M cassowary  1 Jan 12:34  8_MiB
+.rw-r--r-- 9 cassowary  1 Jan 12:34  9_bytes
+.rw-r--r-- 9.2k cassowary  1 Jan 12:34  9_KiB
+.rw-r--r-- 9.4M cassowary  1 Jan 12:34  9_MiB
+.rw-r--r-- 10 cassowary  1 Jan 12:34  10_bytes
+.rw-r--r-- 10k cassowary  1 Jan 12:34  10_KiB
+.rw-r--r-- 10M cassowary  1 Jan 12:34  10_MiB
+.rw-r--r-- 11 cassowary  1 Jan 12:34  11_bytes
+.rw-r--r-- 11k cassowary  1 Jan 12:34  11_KiB
+.rw-r--r-- 11M cassowary  1 Jan 12:34  11_MiB
+.rw-r--r-- 12 cassowary  1 Jan 12:34  12_bytes
+.rw-r--r-- 12k cassowary  1 Jan 12:34  12_KiB
+.rw-r--r-- 12M cassowary  1 Jan 12:34  12_MiB
+.rw-r--r-- 13 cassowary  1 Jan 12:34  13_bytes
+.rw-r--r-- 13k cassowary  1 Jan 12:34  13_KiB
+.rw-r--r-- 13M cassowary  1 Jan 12:34  13_MiB
diff --git a/xtests/outputs/files_long_tree_icons.ansitxt b/xtests/outputs/files_long_tree_icons.ansitxt
index 0c8b18d..ab16fda 100644
--- a/xtests/outputs/files_long_tree_icons.ansitxt
+++ b/xtests/outputs/files_long_tree_icons.ansitxt
@@ -1,40 +1,40 @@
-drwxrwxr-x - vagrant 18 Oct 00:18  /testcases/files
-.rw-r--r-- 1 cassowary  1 Jan 12:34 ├──  1_bytes
-.rw-r--r-- 1.0k cassowary  1 Jan 12:34 ├──  1_KiB
-.rw-r--r-- 1.0M cassowary  1 Jan 12:34 ├──  1_MiB
-.rw-r--r-- 2 cassowary  1 Jan 12:34 ├──  2_bytes
-.rw-r--r-- 2.0k cassowary  1 Jan 12:34 ├──  2_KiB
-.rw-r--r-- 2.1M cassowary  1 Jan 12:34 ├──  2_MiB
-.rw-r--r-- 3 cassowary  1 Jan 12:34 ├──  3_bytes
-.rw-r--r-- 3.1k cassowary  1 Jan 12:34 ├──  3_KiB
-.rw-r--r-- 3.1M cassowary  1 Jan 12:34 ├──  3_MiB
-.rw-r--r-- 4 cassowary  1 Jan 12:34 ├──  4_bytes
-.rw-r--r-- 4.1k cassowary  1 Jan 12:34 ├──  4_KiB
-.rw-r--r-- 4.2M cassowary  1 Jan 12:34 ├──  4_MiB
-.rw-r--r-- 5 cassowary  1 Jan 12:34 ├──  5_bytes
-.rw-r--r-- 5.1k cassowary  1 Jan 12:34 ├──  5_KiB
-.rw-r--r-- 5.2M cassowary  1 Jan 12:34 ├──  5_MiB
-.rw-r--r-- 6 cassowary  1 Jan 12:34 ├──  6_bytes
-.rw-r--r-- 6.1k cassowary  1 Jan 12:34 ├──  6_KiB
-.rw-r--r-- 6.3M cassowary  1 Jan 12:34 ├──  6_MiB
-.rw-r--r-- 7 cassowary  1 Jan 12:34 ├──  7_bytes
-.rw-r--r-- 7.2k cassowary  1 Jan 12:34 ├──  7_KiB
-.rw-r--r-- 7.3M cassowary  1 Jan 12:34 ├──  7_MiB
-.rw-r--r-- 8 cassowary  1 Jan 12:34 ├──  8_bytes
-.rw-r--r-- 8.2k cassowary  1 Jan 12:34 ├──  8_KiB
-.rw-r--r-- 8.4M cassowary  1 Jan 12:34 ├──  8_MiB
-.rw-r--r-- 9 cassowary  1 Jan 12:34 ├──  9_bytes
-.rw-r--r-- 9.2k cassowary  1 Jan 12:34 ├──  9_KiB
-.rw-r--r-- 9.4M cassowary  1 Jan 12:34 ├──  9_MiB
-.rw-r--r-- 10 cassowary  1 Jan 12:34 ├──  10_bytes
-.rw-r--r-- 10k cassowary  1 Jan 12:34 ├──  10_KiB
-.rw-r--r-- 10M cassowary  1 Jan 12:34 ├──  10_MiB
-.rw-r--r-- 11 cassowary  1 Jan 12:34 ├──  11_bytes
-.rw-r--r-- 11k cassowary  1 Jan 12:34 ├──  11_KiB
-.rw-r--r-- 11M cassowary  1 Jan 12:34 ├──  11_MiB
-.rw-r[38