version 1.4, 2009/07/26 12:58:44 |
version 1.5, 2009/07/30 13:45:56 |
|
|
|
|
const struct cmd_entry cmd_break_pane_entry = { |
const struct cmd_entry cmd_break_pane_entry = { |
"break-pane", "breakp", |
"break-pane", "breakp", |
CMD_PANE_WINDOW_USAGE " [-d]", |
CMD_TARGET_PANE_USAGE " [-d]", |
0, CMD_CHFLAG('d'), |
0, CMD_CHFLAG('d'), |
cmd_pane_init, |
cmd_target_init, |
cmd_pane_parse, |
cmd_target_parse, |
cmd_break_pane_exec, |
cmd_break_pane_exec, |
cmd_pane_free, |
cmd_target_free, |
cmd_pane_print |
cmd_target_print |
}; |
}; |
|
|
int |
int |
cmd_break_pane_exec(struct cmd *self, struct cmd_ctx *ctx) |
cmd_break_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; |
struct session *s; |
struct session *s; |
struct window_pane *wp; |
struct window_pane *wp; |
struct window *w; |
struct window *w; |
char *cause; |
char *cause; |
|
|
if ((wl = cmd_find_window(ctx, data->target, &s)) == NULL) |
if ((wl = cmd_find_pane(ctx, data->target, &s, &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 (window_count_panes(wl->window) == 1) { |
if (window_count_panes(wl->window) == 1) { |
ctx->error(ctx, "can't break pane: %d", data->pane); |
ctx->error(ctx, "can't break with only one pane"); |
return (-1); |
return (-1); |
} |
} |
|
|