Reset flags on every loop or it is displayed too often, from Chris
[tmux-openbsd.git] / cmd-kill-pane.c
blob215c8ed769dad2f69822323f9e5d07908a688500
1 /* $OpenBSD$ */
3 /*
4 * Copyright (c) 2009 Nicholas Marriott <nicm@users.sourceforge.net>
6 * Permission to use, copy, modify, and distribute this software for any
7 * purpose with or without fee is hereby granted, provided that the above
8 * copyright notice and this permission notice appear in all copies.
10 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
11 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
12 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
13 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
14 * WHATSOEVER RESULTING FROM LOSS OF MIND, USE, DATA OR PROFITS, WHETHER
15 * IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING
16 * OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
19 #include <sys/types.h>
21 #include <stdlib.h>
23 #include "tmux.h"
26 * Kill pane.
29 int cmd_kill_pane_exec(struct cmd *, struct cmd_ctx *);
31 const struct cmd_entry cmd_kill_pane_entry = {
32 "kill-pane", "killp",
33 "at:", 0, 0,
34 "[-a] " CMD_TARGET_PANE_USAGE,
36 NULL,
37 NULL,
38 cmd_kill_pane_exec
41 int
42 cmd_kill_pane_exec(struct cmd *self, struct cmd_ctx *ctx)
44 struct args *args = self->args;
45 struct winlink *wl;
46 struct window_pane *loopwp, *nextwp, *wp;
48 if ((wl = cmd_find_pane(ctx, args_get(args, 't'), NULL, &wp)) == NULL)
49 return (-1);
51 if (window_count_panes(wl->window) == 1) {
52 /* Only one pane, kill the window. */
53 server_kill_window(wl->window);
54 recalculate_sizes();
55 return (0);
58 if (args_has(self->args, 'a')) {
59 loopwp = TAILQ_FIRST(&wl->window->panes);
60 while (loopwp != NULL) {
61 nextwp = TAILQ_NEXT(loopwp, entry);
62 if (loopwp != wp) {
63 layout_close_pane(loopwp);
64 window_remove_pane(wl->window, loopwp);
66 loopwp = nextwp;
68 } else {
69 layout_close_pane(wp);
70 window_remove_pane(wl->window, wp);
72 server_redraw_window(wl->window);
74 return (0);