From c489bf0a1e5d1ef7dfd886a95b638fa7bfa1fbe2 Mon Sep 17 00:00:00 2001 From: Nicholas Marriott Date: Mon, 11 May 2020 09:18:00 +0100 Subject: Support embedded styles in the display-message message, GitHub issue 2206. --- status.c | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) (limited to 'status.c') diff --git a/status.c b/status.c index 375cad4d..b5fa0824 100644 --- a/status.c +++ b/status.c @@ -423,7 +423,7 @@ status_redraw(struct client *c) /* Set a status line message. */ void -status_message_set(struct client *c, const char *fmt, ...) +status_message_set(struct client *c, int ignore_styles, const char *fmt, ...) { struct timeval tv; va_list ap; @@ -433,6 +433,7 @@ status_message_set(struct client *c, const char *fmt, ...) status_push_screen(c); va_start(ap, fmt); + c->message_ignore_styles = ignore_styles; xvasprintf(&c->message_string, fmt, ap); va_end(ap); @@ -515,7 +516,10 @@ status_message_redraw(struct client *c) for (offset = 0; offset < c->tty.sx; offset++) screen_write_putc(&ctx, &gc, ' '); screen_write_cursormove(&ctx, 0, lines - 1, 0); - screen_write_nputs(&ctx, len, &gc, "%s", c->message_string); + if (c->message_ignore_styles) + screen_write_nputs(&ctx, len, &gc, "%s", c->message_string); + else + format_draw(&ctx, &gc, c->tty.sx, c->message_string, NULL); screen_write_stop(&ctx); if (grid_compare(sl->active->grid, old_screen.grid) == 0) { -- cgit