diff options
author | Alex Auvolat <alex@adnab.me> | 2022-05-18 22:35:49 +0200 |
---|---|---|
committer | Alex Auvolat <alex@adnab.me> | 2022-05-18 22:35:49 +0200 |
commit | 99976e11f880b39c1c57f66c68f19d8c54ad6c1f (patch) | |
tree | d0607d9fd176127e3a1733a794ebe95185620486 /src/util | |
parent | 5367f8adb2aab70a5478c43b93de7051a93d831b (diff) | |
parent | 64c193e3dbb536d5d3c2881bc9aebbb3e4e6272e (diff) | |
download | garage-99976e11f880b39c1c57f66c68f19d8c54ad6c1f.tar.gz garage-99976e11f880b39c1c57f66c68f19d8c54ad6c1f.zip |
Merge branch 'main' into admin-api
Diffstat (limited to 'src/util')
-rw-r--r-- | src/util/formater.rs | 28 | ||||
-rw-r--r-- | src/util/lib.rs | 1 |
2 files changed, 29 insertions, 0 deletions
diff --git a/src/util/formater.rs b/src/util/formater.rs new file mode 100644 index 00000000..95324f9a --- /dev/null +++ b/src/util/formater.rs @@ -0,0 +1,28 @@ +pub fn format_table(data: Vec<String>) { + let data = data + .iter() + .map(|s| s.split('\t').collect::<Vec<_>>()) + .collect::<Vec<_>>(); + + let columns = data.iter().map(|row| row.len()).fold(0, std::cmp::max); + let mut column_size = vec![0; columns]; + + let mut out = String::new(); + + for row in data.iter() { + for (i, col) in row.iter().enumerate() { + column_size[i] = std::cmp::max(column_size[i], col.chars().count()); + } + } + + for row in data.iter() { + for (col, col_len) in row[..row.len() - 1].iter().zip(column_size.iter()) { + out.push_str(col); + (0..col_len - col.chars().count() + 2).for_each(|_| out.push(' ')); + } + out.push_str(row[row.len() - 1]); + out.push('\n'); + } + + print!("{}", out); +} diff --git a/src/util/lib.rs b/src/util/lib.rs index e83fc2e6..d8ffdd0b 100644 --- a/src/util/lib.rs +++ b/src/util/lib.rs @@ -8,6 +8,7 @@ pub mod config; pub mod crdt; pub mod data; pub mod error; +pub mod formater; pub mod metrics; pub mod persister; pub mod sled_counter; |