mirror of
https://github.com/fish-shell/fish-shell
synced 2025-01-13 05:28:49 +00:00
Don't show the pager on terminals of height less than 4
Prevents some potential overflow bugs and janky UI
This commit is contained in:
parent
54dd4b7ed6
commit
ffd4754cb2
1 changed files with 6 additions and 4 deletions
|
@ -26,6 +26,9 @@ typedef std::vector<comp_t> comp_info_list_t;
|
||||||
/// The minimum width (in characters) the terminal must to show completions at all.
|
/// The minimum width (in characters) the terminal must to show completions at all.
|
||||||
#define PAGER_MIN_WIDTH 16
|
#define PAGER_MIN_WIDTH 16
|
||||||
|
|
||||||
|
/// Minimum height to show completions
|
||||||
|
#define PAGER_MIN_HEIGHT 4
|
||||||
|
|
||||||
/// The maximum number of columns of completion to attempt to fit onto the screen.
|
/// The maximum number of columns of completion to attempt to fit onto the screen.
|
||||||
#define PAGER_MAX_COLS 6
|
#define PAGER_MAX_COLS 6
|
||||||
|
|
||||||
|
@ -379,9 +382,11 @@ bool pager_t::completion_try_print(size_t cols, const wcstring &prefix, const co
|
||||||
// The calculated preferred width of each column.
|
// The calculated preferred width of each column.
|
||||||
size_t width_by_column[PAGER_MAX_COLS] = {0};
|
size_t width_by_column[PAGER_MAX_COLS] = {0};
|
||||||
|
|
||||||
|
// Skip completions on tiny terminals.
|
||||||
|
if (this->available_term_width < PAGER_MIN_WIDTH || this->available_term_height < PAGER_MIN_HEIGHT) return true;
|
||||||
|
|
||||||
// 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;
|
||||||
// FIXME arithmetic
|
|
||||||
size_t term_height = this->available_term_height - 1 - (search_field_shown ? 1 : 0); // we always subtract 1 to make room for a comment row
|
size_t term_height = this->available_term_height - 1 - (search_field_shown ? 1 : 0); // we always subtract 1 to make room for a comment row
|
||||||
if (!this->fully_disclosed) {
|
if (!this->fully_disclosed) {
|
||||||
term_height = mini(term_height, (size_t)PAGER_UNDISCLOSED_MAX_ROWS);
|
term_height = mini(term_height, (size_t)PAGER_UNDISCLOSED_MAX_ROWS);
|
||||||
|
@ -404,9 +409,6 @@ bool pager_t::completion_try_print(size_t cols, const wcstring &prefix, const co
|
||||||
rendering->remaining_to_disclose = 0;
|
rendering->remaining_to_disclose = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Skip completions on tiny terminals.
|
|
||||||
if (term_width < PAGER_MIN_WIDTH) return true;
|
|
||||||
|
|
||||||
// Calculate how wide the list would be.
|
// Calculate how wide the list would be.
|
||||||
for (size_t col = 0; col < cols; col++) {
|
for (size_t col = 0; col < cols; col++) {
|
||||||
for (size_t row = 0; row < row_count; row++) {
|
for (size_t row = 0; row < row_count; row++) {
|
||||||
|
|
Loading…
Reference in a new issue