mirror of
https://github.com/fish-shell/fish-shell
synced 2025-01-13 21:44:16 +00:00
Factor pref_width into a function preferred_width()
Beginnings of some pager cleanup
This commit is contained in:
parent
85d697f13d
commit
d058d290be
2 changed files with 16 additions and 9 deletions
|
@ -88,10 +88,10 @@ line_t pager_t::completion_print_item(const wcstring &prefix, const comp_t *c, s
|
||||||
UNUSED(column);
|
UNUSED(column);
|
||||||
UNUSED(row);
|
UNUSED(row);
|
||||||
UNUSED(rendering);
|
UNUSED(rendering);
|
||||||
int comp_width, desc_width;
|
size_t comp_width, desc_width;
|
||||||
line_t line_data;
|
line_t line_data;
|
||||||
|
|
||||||
if (c->pref_width <= width) {
|
if (c->preferred_width() <= width) {
|
||||||
// The entry fits, we give it as much space as it wants.
|
// The entry fits, we give it as much space as it wants.
|
||||||
comp_width = c->comp_width;
|
comp_width = c->comp_width;
|
||||||
desc_width = c->desc_width;
|
desc_width = c->desc_width;
|
||||||
|
@ -293,9 +293,6 @@ void pager_t::measure_completion_infos(comp_info_list_t *infos, const wcstring &
|
||||||
|
|
||||||
// Compute desc_width.
|
// Compute desc_width.
|
||||||
comp->desc_width = fish_wcswidth(comp->desc.c_str());
|
comp->desc_width = fish_wcswidth(comp->desc.c_str());
|
||||||
|
|
||||||
// Compute preferred width.
|
|
||||||
comp->pref_width = comp->comp_width + comp->desc_width + (comp->desc_width ? 4 : 0);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
recalc_min_widths(infos);
|
recalc_min_widths(infos);
|
||||||
|
@ -417,7 +414,7 @@ bool pager_t::completion_try_print(size_t cols, const wcstring &prefix, const co
|
||||||
if (lst.size() <= col * row_count + row) continue;
|
if (lst.size() <= col * row_count + row) continue;
|
||||||
|
|
||||||
c = &lst.at(col * row_count + row);
|
c = &lst.at(col * row_count + row);
|
||||||
pref = c->pref_width;
|
pref = c->preferred_width();
|
||||||
min = c->min_width;
|
min = c->min_width;
|
||||||
|
|
||||||
if (col != cols - 1) {
|
if (col != cols - 1) {
|
||||||
|
|
16
src/pager.h
16
src/pager.h
|
@ -74,8 +74,6 @@ class pager_t {
|
||||||
size_t comp_width;
|
size_t comp_width;
|
||||||
/// On-screen width of the description information.
|
/// On-screen width of the description information.
|
||||||
size_t desc_width;
|
size_t desc_width;
|
||||||
/// Preferred total width.
|
|
||||||
size_t pref_width;
|
|
||||||
/// Minimum acceptable width.
|
/// Minimum acceptable width.
|
||||||
size_t min_width;
|
size_t min_width;
|
||||||
|
|
||||||
|
@ -85,8 +83,20 @@ class pager_t {
|
||||||
representative(L""),
|
representative(L""),
|
||||||
comp_width(0),
|
comp_width(0),
|
||||||
desc_width(0),
|
desc_width(0),
|
||||||
pref_width(0),
|
|
||||||
min_width(0) {}
|
min_width(0) {}
|
||||||
|
|
||||||
|
// Returns the width of the separator between the
|
||||||
|
// completion and description. If we have no description,
|
||||||
|
// we have no separator width
|
||||||
|
size_t separator_width() const {
|
||||||
|
return this->desc_width > 0 ? 4 : 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Returns the preferred width, containing the sum of the
|
||||||
|
// width of the completion, separator, and description
|
||||||
|
size_t preferred_width() const {
|
||||||
|
return this->comp_width + this->desc_width + this->separator_width();
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
Loading…
Reference in a new issue