Add back in column truncation (#3061)

This commit is contained in:
Jonathan Turner 2021-02-16 07:15:16 +13:00 committed by GitHub
parent 2a96152a43
commit e1cb026184
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -963,6 +963,38 @@ fn get_max_column_widths(processed_table: &ProcessedTable) -> Vec<usize> {
output output
} }
pub fn maybe_truncate_columns(termwidth: usize, processed_table: &mut ProcessedTable) {
// Make sure we have enough space for the columns we have
let max_num_of_columns = termwidth / 10;
// If we have too many columns, truncate the table
if max_num_of_columns < processed_table.headers.len() {
processed_table.headers.truncate(max_num_of_columns);
for entry in processed_table.data.iter_mut() {
entry.truncate(max_num_of_columns);
}
processed_table.headers.push(ProcessedCell {
contents: vec![vec![Subline {
subline: "...",
width: 3,
}]],
style: TextStyle::basic_center(),
});
for entry in processed_table.data.iter_mut() {
entry.push(ProcessedCell {
contents: vec![vec![Subline {
subline: "...",
width: 3,
}]],
style: TextStyle::basic_center(),
}); // ellipsis is centred
}
}
}
pub fn draw_table(table: &Table, termwidth: usize, color_hm: &HashMap<String, Style>) { pub fn draw_table(table: &Table, termwidth: usize, color_hm: &HashMap<String, Style>) {
// Remove the edges, if used // Remove the edges, if used
let termwidth = if table.theme.print_left_border && table.theme.print_right_border { let termwidth = if table.theme.print_left_border && table.theme.print_right_border {
@ -973,12 +1005,13 @@ pub fn draw_table(table: &Table, termwidth: usize, color_hm: &HashMap<String, St
termwidth termwidth
}; };
let processed_table = process_table(table); let mut processed_table = process_table(table);
let max_per_column = get_max_column_widths(&processed_table); let max_per_column = get_max_column_widths(&processed_table);
// maybe_truncate_columns(&mut headers, &mut entries, termwidth); maybe_truncate_columns(termwidth, &mut processed_table);
let headers_len = table.headers.len();
let headers_len = processed_table.headers.len();
// fix the length of the table if there are no headers: // fix the length of the table if there are no headers:
let headers_len = if headers_len == 0 { let headers_len = if headers_len == 0 {