summaryrefslogtreecommitdiffstats
path: root/cmd-kill-pane.c
diff options
context:
space:
mode:
authorNicholas Marriott <nicm@openbsd.org>2009-10-24 10:12:39 +0000
committerNicholas Marriott <nicm@openbsd.org>2009-10-24 10:12:39 +0000
commitdf818c1b69aed575d009221cdc4e9dc81135ed6c (patch)
tree0522e09c718a0e5ba2bf92100064b40ee1621dae /cmd-kill-pane.c
parentc2b8f3b55a15e61ce5d1c601c75eca7a81006e0a (diff)
-a option to kill all except current pane. From Tiago Cunha, thanks!
Diffstat (limited to 'cmd-kill-pane.c')
-rw-r--r--cmd-kill-pane.c23
1 files changed, 18 insertions, 5 deletions
diff --git a/cmd-kill-pane.c b/cmd-kill-pane.c
index 38d0daef..351ef0c8 100644
--- a/cmd-kill-pane.c
+++ b/cmd-kill-pane.c
@@ -30,8 +30,8 @@ int cmd_kill_pane_exec(struct cmd *, struct cmd_ctx *);
const struct cmd_entry cmd_kill_pane_entry = {
"kill-pane", "killp",
- CMD_TARGET_PANE_USAGE,
- 0, 0,
+ "[-a] " CMD_TARGET_PANE_USAGE,
+ 0, CMD_CHFLAG('a'),
cmd_target_init,
cmd_target_parse,
cmd_kill_pane_exec,
@@ -44,7 +44,7 @@ cmd_kill_pane_exec(struct cmd *self, struct cmd_ctx *ctx)
{
struct cmd_target_data *data = self->data;
struct winlink *wl;
- struct window_pane *wp;
+ struct window_pane *loopwp, *nextwp, *wp;
if ((wl = cmd_find_pane(ctx, data->target, NULL, &wp)) == NULL)
return (-1);
@@ -56,8 +56,21 @@ cmd_kill_pane_exec(struct cmd *self, struct cmd_ctx *ctx)
return (0);
}
- layout_close_pane(wp);
- window_remove_pane(wl->window, wp);
+ if (data->chflags & CMD_CHFLAG('a')) {
+ loopwp = TAILQ_FIRST(&wl->window->panes);
+ while (loopwp != NULL) {
+ nextwp = TAILQ_NEXT(loopwp, entry);
+ if (loopwp != wp) {
+ layout_close_pane(loopwp);
+ window_remove_pane(wl->window, loopwp);
+ }
+ loopwp = nextwp;
+ }
+ } else {
+ layout_close_pane(wp);
+ window_remove_pane(wl->window, wp);
+ }
server_redraw_window(wl->window);
+
return (0);
}