aboutsummaryrefslogtreecommitdiff
path: root/cmd-select-window.c
diff options
context:
space:
mode:
Diffstat (limited to 'cmd-select-window.c')
-rw-r--r--cmd-select-window.c31
1 files changed, 15 insertions, 16 deletions
diff --git a/cmd-select-window.c b/cmd-select-window.c
index 6aeaad22..c414af3a 100644
--- a/cmd-select-window.c
+++ b/cmd-select-window.c
@@ -26,39 +26,38 @@
* Select window by index.
*/
-void cmd_select_window_init(struct cmd *, int);
+void cmd_select_window_key_binding(struct cmd *, int);
int cmd_select_window_exec(struct cmd *, struct cmd_ctx *);
const struct cmd_entry cmd_select_window_entry = {
"select-window", "selectw",
+ "t:", 0, 0,
CMD_TARGET_WINDOW_USAGE,
- 0, "",
- cmd_select_window_init,
- cmd_target_parse,
- cmd_select_window_exec,
- cmd_target_free,
- cmd_target_print
+ 0,
+ cmd_select_window_key_binding,
+ NULL,
+ cmd_select_window_exec
};
void
-cmd_select_window_init(struct cmd *self, int key)
+cmd_select_window_key_binding(struct cmd *self, int key)
{
- struct cmd_target_data *data;
+ char tmp[16];
- cmd_target_init(self, key);
- data = self->data;
+ xsnprintf(tmp, sizeof tmp, ":%d", key - '0');
- xasprintf(&data->target, ":%d", key - '0');
+ self->args = args_create(0);
+ args_set(self->args, 't', tmp);
}
int
cmd_select_window_exec(struct cmd *self, struct cmd_ctx *ctx)
{
- struct cmd_target_data *data = self->data;
- struct winlink *wl;
- struct session *s;
+ struct args *args = self->args;
+ struct winlink *wl;
+ struct session *s;
- if ((wl = cmd_find_window(ctx, data->target, &s)) == NULL)
+ if ((wl = cmd_find_window(ctx, args_get(args, 't'), &s)) == NULL)
return (-1);
if (session_select(s, wl->idx) == 0)