diff options
author | Nicholas Marriott <nicm@openbsd.org> | 2013-03-21 16:49:37 +0000 |
---|---|---|
committer | Nicholas Marriott <nicm@openbsd.org> | 2013-03-21 16:49:37 +0000 |
commit | 801d64a16e320f0f24dcc65d2da9eabb16b17dee (patch) | |
tree | 23694f18a024ae771ab63ee39c5ae1099b5f630c | |
parent | dd46c95e23e546dfe5ad66e8200d87b739c15db2 (diff) | |
download | rtmux-801d64a16e320f0f24dcc65d2da9eabb16b17dee.tar.gz rtmux-801d64a16e320f0f24dcc65d2da9eabb16b17dee.tar.bz2 rtmux-801d64a16e320f0f24dcc65d2da9eabb16b17dee.zip |
Add -c to refresh-client to set client size in control mode, based on
code from George Nachman.
-rw-r--r-- | cmd-refresh-client.c | 28 |
1 files changed, 25 insertions, 3 deletions
diff --git a/cmd-refresh-client.c b/cmd-refresh-client.c index 0ce7be9d..885e8165 100644 --- a/cmd-refresh-client.c +++ b/cmd-refresh-client.c @@ -28,8 +28,8 @@ enum cmd_retval cmd_refresh_client_exec(struct cmd *, struct cmd_ctx *); const struct cmd_entry cmd_refresh_client_entry = { "refresh-client", "refresh", - "St:", 0, 0, - "[-S] " CMD_TARGET_CLIENT_USAGE, + "C:St:", 0, 0, + "[-S] [-C size]" CMD_TARGET_CLIENT_USAGE, 0, NULL, NULL, @@ -41,11 +41,33 @@ cmd_refresh_client_exec(struct cmd *self, struct cmd_ctx *ctx) { struct args *args = self->args; struct client *c; + const char *size; + u_int w, h; if ((c = cmd_find_client(ctx, args_get(args, 't'))) == NULL) return (CMD_RETURN_ERROR); - if (args_has(args, 'S')) { + if (args_has(args, 'C')) { + if ((size = args_get(args, 'C')) == NULL) { + ctx->error(ctx, "missing size"); + return (CMD_RETURN_ERROR); + } + if (sscanf(size, "%u,%u", &w, &h) != 2) { + ctx->error(ctx, "bad size argument"); + return (CMD_RETURN_ERROR); + } + if (w < PANE_MINIMUM || w > 5000 || + h < PANE_MINIMUM || h > 5000) { + ctx->error(ctx, "size too small or too big"); + return (CMD_RETURN_ERROR); + } + if (!(c->flags & CLIENT_CONTROL)) { + ctx->error(ctx, "not a control client"); + return (CMD_RETURN_ERROR); + } + if (tty_set_size(&c->tty, w, h)) + recalculate_sizes(); + } else if (args_has(args, 'S')) { status_update_jobs(c); server_status_client(c); } else |