version 1.9, 2009/12/03 22:50:10 |
version 1.10, 2011/01/04 00:42:46 |
|
|
|
|
const struct cmd_entry cmd_break_pane_entry = { |
const struct cmd_entry cmd_break_pane_entry = { |
"break-pane", "breakp", |
"break-pane", "breakp", |
CMD_TARGET_PANE_USAGE " [-d]", |
"dt:", 0, 0, |
0, "d", |
"[-d] " CMD_TARGET_PANE_USAGE, |
cmd_target_init, |
0, |
cmd_target_parse, |
NULL, |
cmd_break_pane_exec, |
NULL, |
cmd_target_free, |
cmd_break_pane_exec |
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_target_data *data = self->data; |
struct args *args = self->args; |
struct winlink *wl; |
struct winlink *wl; |
struct session *s; |
struct session *s; |
struct window_pane *wp; |
struct window_pane *wp; |
|
|
char *cause; |
char *cause; |
int base_idx; |
int base_idx; |
|
|
if ((wl = cmd_find_pane(ctx, data->target, &s, &wp)) == NULL) |
if ((wl = cmd_find_pane(ctx, args_get(args, 't'), &s, &wp)) == NULL) |
return (-1); |
return (-1); |
|
|
if (window_count_panes(wl->window) == 1) { |
if (window_count_panes(wl->window) == 1) { |
|
|
|
|
base_idx = options_get_number(&s->options, "base-index"); |
base_idx = options_get_number(&s->options, "base-index"); |
wl = session_attach(s, w, -1 - base_idx, &cause); /* can't fail */ |
wl = session_attach(s, w, -1 - base_idx, &cause); /* can't fail */ |
if (!cmd_check_flag(data->chflags, 'd')) |
if (!args_has(self->args, 'd')) |
session_select(s, wl->idx); |
session_select(s, wl->idx); |
|
|
server_redraw_session(s); |
server_redraw_session(s); |