From e8c2b18dcec2c2c6ddc672386ce903fb6181b932 Mon Sep 17 00:00:00 2001 From: nicm Date: Thu, 2 Aug 2018 07:55:16 +0000 Subject: [PATCH] Make display-panes block the client until a pane is chosen or it times out. --- usr.bin/tmux/cmd-display-panes.c | 31 +++++++++++++++++-------------- usr.bin/tmux/tmux.h | 3 ++- 2 files changed, 19 insertions(+), 15 deletions(-) diff --git a/usr.bin/tmux/cmd-display-panes.c b/usr.bin/tmux/cmd-display-panes.c index 17ee70cf544..ff7d33c395f 100644 --- a/usr.bin/tmux/cmd-display-panes.c +++ b/usr.bin/tmux/cmd-display-panes.c @@ -1,4 +1,4 @@ -/* $OpenBSD: cmd-display-panes.c,v 1.20 2017/08/16 12:12:54 nicm Exp $ */ +/* $OpenBSD: cmd-display-panes.c,v 1.21 2018/08/02 07:55:16 nicm Exp $ */ /* * Copyright (c) 2009 Nicholas Marriott @@ -55,6 +55,7 @@ cmd_display_panes_exec(struct cmd *self, struct cmdq_item *item) if ((c = cmd_find_client(item, args_get(args, 't'), 0)) == NULL) return (CMD_RETURN_ERROR); + s = c->session; if (c->identify_callback != NULL) return (CMD_RETURN_NORMAL); @@ -64,7 +65,7 @@ cmd_display_panes_exec(struct cmd *self, struct cmdq_item *item) c->identify_callback_data = xstrdup(args->argv[0]); else c->identify_callback_data = xstrdup("select-pane -t '%%'"); - s = c->session; + c->identify_callback_item = item; if (args_has(args, 'd')) { delay = args_strtonum(args, 'd', 0, UINT_MAX, &cause); @@ -77,7 +78,7 @@ cmd_display_panes_exec(struct cmd *self, struct cmdq_item *item) delay = options_get_number(s->options, "display-panes-time"); server_client_set_identify(c, delay); - return (CMD_RETURN_NORMAL); + return (CMD_RETURN_WAIT); } static enum cmd_retval @@ -96,34 +97,36 @@ cmd_display_panes_callback(struct client *c, struct window_pane *wp) { struct cmd_list *cmdlist; struct cmdq_item *new_item; - char *template, *cmd, *expanded, *cause; + char *cmd, *expanded, *cause; - template = c->identify_callback_data; if (wp == NULL) goto out; + xasprintf(&expanded, "%%%u", wp->id); - cmd = cmd_template_replace(template, expanded, 1); + cmd = cmd_template_replace(c->identify_callback_data, expanded, 1); cmdlist = cmd_string_parse(cmd, NULL, 0, &cause); - if (cmdlist == NULL) { - if (cause != NULL) { - new_item = cmdq_get_callback(cmd_display_panes_error, - cause); - } else - new_item = NULL; - } else { + if (cmdlist == NULL && cause != NULL) + new_item = cmdq_get_callback(cmd_display_panes_error, cause); + else if (cmdlist == NULL) + new_item = NULL; + else { new_item = cmdq_get_command(cmdlist, NULL, NULL, 0); cmd_list_free(cmdlist); } if (new_item != NULL) - cmdq_append(c, new_item); + cmdq_insert_after(c->identify_callback_item, new_item); free(cmd); free(expanded); out: + c->identify_callback_item->flags &= ~CMDQ_WAITING; + c->identify_callback_item = NULL; + free(c->identify_callback_data); c->identify_callback_data = NULL; + c->identify_callback = NULL; } diff --git a/usr.bin/tmux/tmux.h b/usr.bin/tmux/tmux.h index 42fe0ecdd8b..92ee0021af6 100644 --- a/usr.bin/tmux/tmux.h +++ b/usr.bin/tmux/tmux.h @@ -1,4 +1,4 @@ -/* $OpenBSD: tmux.h,v 1.831 2018/07/31 11:49:26 nicm Exp $ */ +/* $OpenBSD: tmux.h,v 1.832 2018/08/02 07:55:16 nicm Exp $ */ /* * Copyright (c) 2007 Nicholas Marriott @@ -1357,6 +1357,7 @@ struct client { void (*identify_callback)(struct client *, struct window_pane *); void *identify_callback_data; + struct cmdq_item *identify_callback_item; char *message_string; struct event message_timer; -- 2.20.1