version 1.5, 2009/07/26 12:58:44 |
version 1.6, 2009/07/30 13:45:56 |
|
|
|
|
const struct cmd_entry cmd_resize_pane_entry = { |
const struct cmd_entry cmd_resize_pane_entry = { |
"resize-pane", "resizep", |
"resize-pane", "resizep", |
CMD_PANE_WINDOW_USAGE "[-DU] [adjustment]", |
"[-DU] " CMD_TARGET_PANE_USAGE " [adjustment]", |
CMD_ARG01, |
CMD_ARG01, |
CMD_CHFLAG('D')|CMD_CHFLAG('L')|CMD_CHFLAG('R')|CMD_CHFLAG('U'), |
CMD_CHFLAG('D')|CMD_CHFLAG('L')|CMD_CHFLAG('R')|CMD_CHFLAG('U'), |
cmd_resize_pane_init, |
cmd_resize_pane_init, |
cmd_pane_parse, |
cmd_target_parse, |
cmd_resize_pane_exec, |
cmd_resize_pane_exec, |
cmd_pane_free, |
cmd_target_free, |
cmd_pane_print |
cmd_target_print |
}; |
}; |
|
|
void |
void |
cmd_resize_pane_init(struct cmd *self, int key) |
cmd_resize_pane_init(struct cmd *self, int key) |
{ |
{ |
struct cmd_pane_data *data; |
struct cmd_target_data *data; |
|
|
cmd_pane_init(self, key); |
cmd_target_init(self, key); |
data = self->data; |
data = self->data; |
|
|
if (key == (KEYC_UP | KEYC_CTRL)) |
if (key == (KEYC_UP | KEYC_CTRL)) |
|
|
int |
int |
cmd_resize_pane_exec(struct cmd *self, struct cmd_ctx *ctx) |
cmd_resize_pane_exec(struct cmd *self, struct cmd_ctx *ctx) |
{ |
{ |
struct cmd_pane_data *data = self->data; |
struct cmd_target_data *data = self->data; |
struct winlink *wl; |
struct winlink *wl; |
const char *errstr; |
const char *errstr; |
struct window_pane *wp; |
struct window_pane *wp; |
u_int adjust; |
u_int adjust; |
|
|
if ((wl = cmd_find_window(ctx, data->target, NULL)) == NULL) |
if ((wl = cmd_find_pane(ctx, data->target, NULL, &wp)) == NULL) |
return (-1); |
return (-1); |
if (data->pane == -1) |
|
wp = wl->window->active; |
|
else { |
|
wp = window_pane_at_index(wl->window, data->pane); |
|
if (wp == NULL) { |
|
ctx->error(ctx, "no pane: %d", data->pane); |
|
return (-1); |
|
} |
|
} |
|
|
|
if (data->arg == NULL) |
if (data->arg == NULL) |
adjust = 1; |
adjust = 1; |