mirror of
https://github.com/fish-shell/fish-shell
synced 2025-01-27 12:15:08 +00:00
Stop including spacer width in width_by_column in pager
Additional refactoring to remove some sketchy-looking arithmetic
This commit is contained in:
parent
2d5ce72cb4
commit
8041913e7a
2 changed files with 18 additions and 29 deletions
|
@ -140,12 +140,12 @@ line_t pager_t::completion_print_item(const wcstring &prefix, const comp_t *c, s
|
||||||
/// style.
|
/// style.
|
||||||
///
|
///
|
||||||
/// \param cols number of columns to print in
|
/// \param cols number of columns to print in
|
||||||
/// \param width_per_column An array specifying the width of each column
|
/// \param width_by_column An array specifying the width of each column
|
||||||
/// \param row_start The first row to print
|
/// \param row_start The first row to print
|
||||||
/// \param row_stop the row after the last row to print
|
/// \param row_stop the row after the last row to print
|
||||||
/// \param prefix The string to print before each completion
|
/// \param prefix The string to print before each completion
|
||||||
/// \param lst The list of completions to print
|
/// \param lst The list of completions to print
|
||||||
void pager_t::completion_print(size_t cols, const int *width_per_column, size_t row_start,
|
void pager_t::completion_print(size_t cols, const size_t *width_by_column, size_t row_start,
|
||||||
size_t row_stop, const wcstring &prefix, const comp_info_list_t &lst,
|
size_t row_stop, const wcstring &prefix, const comp_info_list_t &lst,
|
||||||
page_rendering_t *rendering) const {
|
page_rendering_t *rendering) const {
|
||||||
// Teach the rendering about the rows it printed.
|
// Teach the rendering about the rows it printed.
|
||||||
|
@ -154,14 +154,12 @@ void pager_t::completion_print(size_t cols, const int *width_per_column, size_t
|
||||||
rendering->row_start = row_start;
|
rendering->row_start = row_start;
|
||||||
rendering->row_end = row_stop;
|
rendering->row_end = row_stop;
|
||||||
|
|
||||||
size_t rows = (lst.size() - 1) / cols + 1;
|
size_t rows = divide_round_up(lst.size(), cols);
|
||||||
|
|
||||||
size_t effective_selected_idx = this->visual_selected_completion_index(rows, cols);
|
size_t effective_selected_idx = this->visual_selected_completion_index(rows, cols);
|
||||||
|
|
||||||
for (size_t row = row_start; row < row_stop; row++) {
|
for (size_t row = row_start; row < row_stop; row++) {
|
||||||
for (size_t col = 0; col < cols; col++) {
|
for (size_t col = 0; col < cols; col++) {
|
||||||
int is_last = (col == (cols - 1));
|
|
||||||
|
|
||||||
if (lst.size() <= col * rows + row) continue;
|
if (lst.size() <= col * rows + row) continue;
|
||||||
|
|
||||||
size_t idx = col * rows + row;
|
size_t idx = col * rows + row;
|
||||||
|
@ -171,7 +169,7 @@ void pager_t::completion_print(size_t cols, const int *width_per_column, size_t
|
||||||
// Print this completion on its own "line".
|
// Print this completion on its own "line".
|
||||||
line_t line = completion_print_item(
|
line_t line = completion_print_item(
|
||||||
prefix, el, row, col,
|
prefix, el, row, col,
|
||||||
width_per_column[col] - (is_last ? 0 : PAGER_SPACER_STRING_WIDTH), row % 2,
|
width_by_column[col], row % 2,
|
||||||
is_selected, rendering);
|
is_selected, rendering);
|
||||||
|
|
||||||
// If there's more to come, append two spaces.
|
// If there's more to come, append two spaces.
|
||||||
|
@ -351,11 +349,9 @@ void pager_t::set_term_size(int w, int h) {
|
||||||
/// the specified number of columns. Always succeeds if cols is 1.
|
/// the specified number of columns. Always succeeds if cols is 1.
|
||||||
bool pager_t::completion_try_print(size_t cols, const wcstring &prefix, const comp_info_list_t &lst,
|
bool pager_t::completion_try_print(size_t cols, const wcstring &prefix, const comp_info_list_t &lst,
|
||||||
page_rendering_t *rendering, size_t suggested_start_row) const {
|
page_rendering_t *rendering, size_t suggested_start_row) const {
|
||||||
|
assert(cols > 0);
|
||||||
// The calculated preferred width of each column.
|
// The calculated preferred width of each column.
|
||||||
int width_by_column[PAGER_MAX_COLS] = {0};
|
size_t width_by_column[PAGER_MAX_COLS] = {0};
|
||||||
|
|
||||||
// Set to one if the list should be printed at this width.
|
|
||||||
bool print = false;
|
|
||||||
|
|
||||||
// Compute the effective term width and term height, accounting for disclosure.
|
// Compute the effective term width and term height, accounting for disclosure.
|
||||||
size_t term_width = this->available_term_width;
|
size_t term_width = this->available_term_width;
|
||||||
|
@ -390,31 +386,24 @@ bool pager_t::completion_try_print(size_t cols, const wcstring &prefix, const co
|
||||||
for (size_t row = 0; row < row_count; row++) {
|
for (size_t row = 0; row < row_count; row++) {
|
||||||
const size_t comp_idx = col * row_count + row;
|
const size_t comp_idx = col * row_count + row;
|
||||||
if (comp_idx >= lst.size()) continue;
|
if (comp_idx >= lst.size()) continue;
|
||||||
const comp_t *c = &lst.at(comp_idx);
|
const comp_t &c = lst.at(comp_idx);
|
||||||
|
width_by_column[col] = std::max(width_by_column[col], c.preferred_width());
|
||||||
// If we are not the last column, add two spaces after us
|
|
||||||
// to pad for the next column
|
|
||||||
const size_t column_padding = ((col+1 == cols) ? 0 : 2);
|
|
||||||
const size_t space_required = c->preferred_width() + column_padding;
|
|
||||||
|
|
||||||
width_by_column[col] = maxi(size_t(width_by_column[col]), space_required);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Compute total preferred width
|
bool print;
|
||||||
const size_t pref_tot_width = std::accumulate(width_by_column, width_by_column + cols, 0);
|
assert(cols >= 1);
|
||||||
|
|
||||||
// Force fit if one column.
|
// Force fit if one column.
|
||||||
if (cols == 1) {
|
if (cols == 1) {
|
||||||
if (pref_tot_width > term_width) {
|
width_by_column[0] = std::min(width_by_column[0], term_width);
|
||||||
width_by_column[0] = term_width;
|
|
||||||
}
|
|
||||||
print = true;
|
|
||||||
} else if (pref_tot_width <= term_width) {
|
|
||||||
// Terminal is wide enough. Print the list!
|
|
||||||
print = true;
|
print = true;
|
||||||
|
} else {
|
||||||
|
// Compute total preferred width, plus spacing
|
||||||
|
assert(cols > 0);
|
||||||
|
size_t total_width_needed = std::accumulate(width_by_column, width_by_column + cols, 0);
|
||||||
|
total_width_needed += (cols - 1) * PAGER_SPACER_STRING_WIDTH;
|
||||||
|
print = (total_width_needed <= term_width);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!print) {
|
if (!print) {
|
||||||
return false; // no need to continue
|
return false; // no need to continue
|
||||||
}
|
}
|
||||||
|
|
|
@ -118,7 +118,7 @@ class pager_t {
|
||||||
|
|
||||||
bool completion_info_passes_filter(const comp_t &info) const;
|
bool completion_info_passes_filter(const comp_t &info) const;
|
||||||
|
|
||||||
void completion_print(size_t cols, const int *width_per_column, size_t row_start, size_t row_stop,
|
void completion_print(size_t cols, const size_t *width_per_column, size_t row_start, size_t row_stop,
|
||||||
const wcstring &prefix, const comp_info_list_t &lst,
|
const wcstring &prefix, const comp_info_list_t &lst,
|
||||||
page_rendering_t *rendering) const;
|
page_rendering_t *rendering) const;
|
||||||
line_t completion_print_item(const wcstring &prefix, const comp_t *c, size_t row, size_t column,
|
line_t completion_print_item(const wcstring &prefix, const comp_t *c, size_t row, size_t column,
|
||||||
|
|
Loading…
Reference in a new issue