aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTiago Cunha <tcunha@gmx.com>2012-04-24 16:20:18 +0000
committerTiago Cunha <tcunha@gmx.com>2012-04-24 16:20:18 +0000
commit6df8953f4f93b6dad98ac7f16f9c7f5eec02622c (patch)
tree5f0111349f6f48974563729d884d392881eb1445
parent00e2e357406be926027659a7dce894e8d263c4ca (diff)
downloadrtmux-6df8953f4f93b6dad98ac7f16f9c7f5eec02622c.tar.gz
rtmux-6df8953f4f93b6dad98ac7f16f9c7f5eec02622c.tar.bz2
rtmux-6df8953f4f93b6dad98ac7f16f9c7f5eec02622c.zip
Sync OpenBSD patchset 1097:
Add window-status-separator option, from Thomas Adam.
-rw-r--r--options-table.c5
-rw-r--r--status.c16
-rw-r--r--tmux.14
3 files changed, 21 insertions, 4 deletions
diff --git a/options-table.c b/options-table.c
index 1eb50e45..c03295ff 100644
--- a/options-table.c
+++ b/options-table.c
@@ -690,6 +690,11 @@ const struct options_table_entry window_options_table[] = {
.default_str = "#I:#W#F"
},
+ { .name = "window-status-separator",
+ .type = OPTIONS_TABLE_STRING,
+ .default_str = " "
+ },
+
{ .name = "wrap-search",
.type = OPTIONS_TABLE_FLAG,
.default_num = 1
diff --git a/status.c b/status.c
index 8a5f20b0..ab505a5a 100644
--- a/status.c
+++ b/status.c
@@ -160,11 +160,12 @@ status_redraw(struct client *c)
struct winlink *wl;
struct screen old_status, window_list;
struct grid_cell stdgc, lgc, rgc, gc;
+ struct options *oo;
time_t t;
- char *left, *right;
+ char *left, *right, *sep;
u_int offset, needed;
u_int wlstart, wlwidth, wlavailable, wloffset, wlsize;
- size_t llen, rlen;
+ size_t llen, rlen, seplen;
int larrow, rarrow, utf8flag;
/* No status line? */
@@ -230,7 +231,11 @@ status_redraw(struct client *c)
if (wl == s->curw)
wloffset = wlwidth;
- wlwidth += wl->status_width + 1;
+
+ oo = &wl->window->options;
+ sep = options_get_string(oo, "window-status-separator");
+ seplen = screen_write_strlen(utf8flag, "%s", sep);
+ wlwidth += wl->status_width + seplen;
}
/* Create a new screen for the window list. */
@@ -241,7 +246,10 @@ status_redraw(struct client *c)
RB_FOREACH(wl, winlinks, &s->windows) {
screen_write_cnputs(&ctx,
-1, &wl->status_cell, utf8flag, "%s", wl->status_text);
- screen_write_putc(&ctx, &stdgc, ' ');
+
+ oo = &wl->window->options;
+ sep = options_get_string(oo, "window-status-separator");
+ screen_write_nputs(&ctx, -1, &stdgc, utf8flag, "%s", sep);
}
screen_write_stop(&ctx);
diff --git a/tmux.1 b/tmux.1
index e4b942f2..8e3ceda8 100644
--- a/tmux.1
+++ b/tmux.1
@@ -2704,6 +2704,10 @@ option for details of special character sequences available.
The default is
.Ql #I:#W#F .
.Pp
+.It Ic window-status-separator Ar string
+Sets the separator drawn between windows in the status line.
+The default is a single space character.
+.Pp
.It Xo Ic xterm-keys
.Op Ic on | off
.Xc