Fix top/bottom pane calculation with pane border status enabled,

reported by Stanislav Spassov.
This commit is contained in:
nicm 2020-02-14 13:57:58 +00:00
parent f48b041cf2
commit 58b47bf01b
2 changed files with 54 additions and 9 deletions

View File

@ -880,6 +880,44 @@ format_cb_pane_in_mode(struct format_tree *ft, struct format_entry *fe)
xasprintf(&fe->value, "%u", n); xasprintf(&fe->value, "%u", n);
} }
/* Callback for pane_at_top. */
static void
format_cb_pane_at_top(struct format_tree *ft, struct format_entry *fe)
{
struct window_pane *wp = ft->wp;
struct window *w = wp->window;
int status, flag;
if (wp == NULL)
return;
status = options_get_number(w->options, "pane-border-status");
if (status == PANE_STATUS_TOP)
flag = (wp->yoff == 1);
else
flag = (wp->yoff == 0);
xasprintf(&fe->value, "%d", flag);
}
/* Callback for pane_at_bottom. */
static void
format_cb_pane_at_bottom(struct format_tree *ft, struct format_entry *fe)
{
struct window_pane *wp = ft->wp;
struct window *w = wp->window;
int status, flag;
if (wp == NULL)
return;
status = options_get_number(w->options, "pane-border-status");
if (status == PANE_STATUS_BOTTOM)
flag = (wp->yoff + wp->sy == w->sy - 1);
else
flag = (wp->yoff + wp->sy == w->sy);
xasprintf(&fe->value, "%d", flag);
}
/* Callback for cursor_character. */ /* Callback for cursor_character. */
static void static void
format_cb_cursor_character(struct format_tree *ft, struct format_entry *fe) format_cb_cursor_character(struct format_tree *ft, struct format_entry *fe)
@ -2531,9 +2569,9 @@ format_defaults_pane(struct format_tree *ft, struct window_pane *wp)
format_add(ft, "pane_right", "%u", wp->xoff + wp->sx - 1); format_add(ft, "pane_right", "%u", wp->xoff + wp->sx - 1);
format_add(ft, "pane_bottom", "%u", wp->yoff + wp->sy - 1); format_add(ft, "pane_bottom", "%u", wp->yoff + wp->sy - 1);
format_add(ft, "pane_at_left", "%d", wp->xoff == 0); format_add(ft, "pane_at_left", "%d", wp->xoff == 0);
format_add(ft, "pane_at_top", "%d", wp->yoff == 0); format_add_cb(ft, "pane_at_top", format_cb_pane_at_top);
format_add(ft, "pane_at_right", "%d", wp->xoff + wp->sx == w->sx); format_add(ft, "pane_at_right", "%d", wp->xoff + wp->sx == w->sx);
format_add(ft, "pane_at_bottom", "%d", wp->yoff + wp->sy == w->sy); format_add_cb(ft, "pane_at_bottom", format_cb_pane_at_bottom);
wme = TAILQ_FIRST(&wp->modes); wme = TAILQ_FIRST(&wp->modes);
if (wme != NULL) { if (wme != NULL) {

View File

@ -541,31 +541,38 @@ window_get_active_at(struct window *w, u_int x, u_int y)
struct window_pane * struct window_pane *
window_find_string(struct window *w, const char *s) window_find_string(struct window *w, const char *s)
{ {
u_int x, y; u_int x, y, top = 0, bottom = w->sy - 1;
int status;
x = w->sx / 2; x = w->sx / 2;
y = w->sy / 2; y = w->sy / 2;
status = options_get_number(w->options, "pane-border-status");
if (status == PANE_STATUS_TOP)
top++;
else if (status == PANE_STATUS_BOTTOM)
bottom--;
if (strcasecmp(s, "top") == 0) if (strcasecmp(s, "top") == 0)
y = 0; y = top;
else if (strcasecmp(s, "bottom") == 0) else if (strcasecmp(s, "bottom") == 0)
y = w->sy - 1; y = bottom;
else if (strcasecmp(s, "left") == 0) else if (strcasecmp(s, "left") == 0)
x = 0; x = 0;
else if (strcasecmp(s, "right") == 0) else if (strcasecmp(s, "right") == 0)
x = w->sx - 1; x = w->sx - 1;
else if (strcasecmp(s, "top-left") == 0) { else if (strcasecmp(s, "top-left") == 0) {
x = 0; x = 0;
y = 0; y = top;
} else if (strcasecmp(s, "top-right") == 0) { } else if (strcasecmp(s, "top-right") == 0) {
x = w->sx - 1; x = w->sx - 1;
y = 0; y = top;
} else if (strcasecmp(s, "bottom-left") == 0) { } else if (strcasecmp(s, "bottom-left") == 0) {
x = 0; x = 0;
y = w->sy - 1; y = bottom;
} else if (strcasecmp(s, "bottom-right") == 0) { } else if (strcasecmp(s, "bottom-right") == 0) {
x = w->sx - 1; x = w->sx - 1;
y = w->sy - 1; y = bottom;
} else } else
return (NULL); return (NULL);