summaryrefslogtreecommitdiffstats
path: root/format.c
diff options
context:
space:
mode:
authorThomas Adam <thomas@xteddy.org>2020-02-14 16:01:26 +0000
committerThomas Adam <thomas@xteddy.org>2020-02-14 16:01:26 +0000
commitc391d50cbb79407be95204a41713f0ab66fbc7e6 (patch)
tree6372e718dbdb1d1addb3fa8b94ca5894230c98be /format.c
parent9900ccd04ee5204b3ce0fcf375daa1f3c6686ede (diff)
parent58b47bf01b4136a7f90cb6852b0ecb1b414e4494 (diff)
Merge branch 'obsd-master'
Diffstat (limited to 'format.c')
-rw-r--r--format.c42
1 files changed, 40 insertions, 2 deletions
diff --git a/format.c b/format.c
index 0d3e26d7..79e99b61 100644
--- a/format.c
+++ b/format.c
@@ -895,6 +895,44 @@ format_cb_pane_in_mode(struct format_tree *ft, struct format_entry *fe)
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. */
static void
format_cb_cursor_character(struct format_tree *ft, struct format_entry *fe)
@@ -2546,9 +2584,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_bottom", "%u", wp->yoff + wp->sy - 1);
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_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);
if (wme != NULL) {