summaryrefslogtreecommitdiffstats
path: root/cmd-display-message.c
diff options
context:
space:
mode:
authornicm <nicm>2023-02-05 21:15:32 +0000
committernicm <nicm>2023-02-05 21:15:32 +0000
commit93b1b781504f8de30f1858a4d0cf013396143c53 (patch)
treedb08d6daad277090c8763a1689f3f11591795123 /cmd-display-message.c
parentf10854cfc5e43f646b02b3031bfc4bc3f5f6c513 (diff)
Extend display-message to work for control clients. GitHub issue 3449.
Diffstat (limited to 'cmd-display-message.c')
-rw-r--r--cmd-display-message.c16
1 files changed, 11 insertions, 5 deletions
diff --git a/cmd-display-message.c b/cmd-display-message.c
index f5e91020..512509f0 100644
--- a/cmd-display-message.c
+++ b/cmd-display-message.c
@@ -68,9 +68,10 @@ cmd_display_message_exec(struct cmd *self, struct cmdq_item *item)
struct window_pane *wp = target->wp;
const char *template;
char *msg, *cause;
- int delay = -1, flags;
+ int delay = -1, flags, Nflag = args_has(args, 'N');
struct format_tree *ft;
u_int count = args_count(args);
+ struct evbuffer *evb;
if (args_has(args, 'I')) {
if (wp == NULL)
@@ -141,10 +142,15 @@ cmd_display_message_exec(struct cmd *self, struct cmdq_item *item)
cmdq_error(item, "%s", msg);
else if (args_has(args, 'p'))
cmdq_print(item, "%s", msg);
- else if (tc != NULL) {
- status_message_set(tc, delay, 0, args_has(args, 'N'), "%s",
- msg);
- }
+ else if (tc != NULL && (tc->flags & CLIENT_CONTROL)) {
+ evb = evbuffer_new();
+ if (evb == NULL)
+ fatalx("out of memory");
+ evbuffer_add_printf(evb, "%%message %s", msg);
+ server_client_print(tc, 0, evb);
+ evbuffer_free(evb);
+ } else if (tc != NULL)
+ status_message_set(tc, delay, 0, Nflag, "%s", msg);
free(msg);
format_free(ft);