mirror of
https://github.com/nushell/nushell
synced 2025-01-13 13:49:21 +00:00
4401924128
With this comes a new `unicode-width` as I remember there was some issue
with `ratatui`.
And a bit of refactorings which are ment to reduce code lines while not
breaking anything.
Not yet complete, I think I'll try to improve some more places,
just wanted to trigger CI 😄
And yessssssssss we have a new `unicode-width` but I sort of doubtful,
I mean the original issue with emojie.
I think it may require an additional "clean" call.
I am just saying I was not testing it with that case of complex emojies.
---------
Signed-off-by: Maxim Zhiburt <zhiburt@gmail.com>
111 lines
2.5 KiB
Rust
111 lines
2.5 KiB
Rust
#![allow(dead_code)]
|
|
|
|
use nu_protocol::TrimStrategy;
|
|
use nu_table::{string_width, NuTable, TableTheme};
|
|
use tabled::grid::records::vec_records::Text;
|
|
|
|
#[derive(Debug, Clone)]
|
|
pub struct TestCase {
|
|
theme: TableTheme,
|
|
with_header: bool,
|
|
with_footer: bool,
|
|
with_index: bool,
|
|
expand: bool,
|
|
strategy: TrimStrategy,
|
|
termwidth: usize,
|
|
expected: Option<String>,
|
|
}
|
|
|
|
impl TestCase {
|
|
pub fn new(termwidth: usize) -> Self {
|
|
Self {
|
|
termwidth,
|
|
expected: None,
|
|
theme: TableTheme::basic(),
|
|
with_header: false,
|
|
with_footer: false,
|
|
with_index: false,
|
|
expand: false,
|
|
strategy: TrimStrategy::truncate(None),
|
|
}
|
|
}
|
|
|
|
pub fn expected(mut self, value: Option<String>) -> Self {
|
|
self.expected = value;
|
|
self
|
|
}
|
|
|
|
pub fn theme(mut self, theme: TableTheme) -> Self {
|
|
self.theme = theme;
|
|
self
|
|
}
|
|
|
|
pub fn expand(mut self) -> Self {
|
|
self.expand = true;
|
|
self
|
|
}
|
|
|
|
pub fn header(mut self) -> Self {
|
|
self.with_header = true;
|
|
self
|
|
}
|
|
|
|
pub fn footer(mut self) -> Self {
|
|
self.with_footer = true;
|
|
self
|
|
}
|
|
|
|
pub fn index(mut self) -> Self {
|
|
self.with_index = true;
|
|
self
|
|
}
|
|
|
|
pub fn trim(mut self, trim: TrimStrategy) -> Self {
|
|
self.strategy = trim;
|
|
self
|
|
}
|
|
}
|
|
|
|
type Data = Vec<Vec<Text<String>>>;
|
|
|
|
pub fn test_table<I>(data: Data, tests: I)
|
|
where
|
|
I: IntoIterator<Item = TestCase>,
|
|
{
|
|
for (i, test) in tests.into_iter().enumerate() {
|
|
let actual = create_table(data.clone(), test.clone());
|
|
|
|
assert_eq!(
|
|
actual, test.expected,
|
|
"\nfail i={:?} termwidth={}",
|
|
i, test.termwidth
|
|
);
|
|
|
|
if let Some(table) = actual {
|
|
assert!(string_width(&table) <= test.termwidth);
|
|
}
|
|
}
|
|
}
|
|
|
|
pub fn create_table(data: Data, case: TestCase) -> Option<String> {
|
|
let mut table = NuTable::from(data);
|
|
table.set_theme(case.theme);
|
|
table.set_structure(case.with_index, case.with_header, case.with_footer);
|
|
table.set_trim(case.strategy);
|
|
table.set_strategy(case.expand);
|
|
|
|
table.draw(case.termwidth)
|
|
}
|
|
|
|
pub fn create_row(count_columns: usize) -> Vec<Text<String>> {
|
|
let mut row = Vec::with_capacity(count_columns);
|
|
for i in 0..count_columns {
|
|
row.push(Text::new(i.to_string()));
|
|
}
|
|
|
|
row
|
|
}
|
|
|
|
pub fn cell(text: &str) -> Text<String> {
|
|
Text::new(text.to_string())
|
|
}
|