123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164 |
- /* $OpenBSD$ */
- /*
- * Copyright (c) 2009 Nicholas Marriott <nicholas.marriott@gmail.com>
- *
- * Permission to use, copy, modify, and distribute this software for any
- * purpose with or without fee is hereby granted, provided that the above
- * copyright notice and this permission notice appear in all copies.
- *
- * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
- * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
- * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
- * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
- * WHATSOEVER RESULTING FROM LOSS OF MIND, USE, DATA OR PROFITS, WHETHER
- * IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING
- * OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
- */
- #include <sys/types.h>
- #include "tmux.h"
- /*
- * Select pane.
- */
- enum cmd_retval cmd_select_pane_exec(struct cmd *, struct cmd_q *);
- const struct cmd_entry cmd_select_pane_entry = {
- .name = "select-pane",
- .alias = "selectp",
- .args = { "DdegLlMmP:Rt:U", 0, 0 },
- .usage = "[-DdegLlMmRU] [-P style] " CMD_TARGET_PANE_USAGE,
- .tflag = CMD_PANE,
- .flags = 0,
- .exec = cmd_select_pane_exec
- };
- const struct cmd_entry cmd_last_pane_entry = {
- .name = "last-pane",
- .alias = "lastp",
- .args = { "det:", 0, 0 },
- .usage = "[-de] " CMD_TARGET_WINDOW_USAGE,
- .tflag = CMD_WINDOW,
- .flags = 0,
- .exec = cmd_select_pane_exec
- };
- enum cmd_retval
- cmd_select_pane_exec(struct cmd *self, struct cmd_q *cmdq)
- {
- struct args *args = self->args;
- struct winlink *wl = cmdq->state.tflag.wl;
- struct window *w = wl->window;
- struct session *s = cmdq->state.tflag.s;
- struct window_pane *wp = cmdq->state.tflag.wp, *lastwp, *markedwp;
- const char *style;
- if (self->entry == &cmd_last_pane_entry || args_has(args, 'l')) {
- if (wl->window->last == NULL) {
- cmdq_error(cmdq, "no last pane");
- return (CMD_RETURN_ERROR);
- }
- if (args_has(self->args, 'e'))
- w->last->flags &= ~PANE_INPUTOFF;
- else if (args_has(self->args, 'd'))
- w->last->flags |= PANE_INPUTOFF;
- else {
- server_unzoom_window(w);
- window_redraw_active_switch(w, w->last);
- if (window_set_active_pane(w, w->last)) {
- server_status_window(w);
- server_redraw_window_borders(w);
- }
- }
- return (CMD_RETURN_NORMAL);
- }
- if (args_has(args, 'm') || args_has(args, 'M')) {
- if (args_has(args, 'm') && !window_pane_visible(wp))
- return (CMD_RETURN_NORMAL);
- lastwp = marked_pane.wp;
- if (args_has(args, 'M') || server_is_marked(s, wl, wp))
- server_clear_marked();
- else
- server_set_marked(s, wl, wp);
- markedwp = marked_pane.wp;
- if (lastwp != NULL) {
- server_redraw_window_borders(lastwp->window);
- server_status_window(lastwp->window);
- }
- if (markedwp != NULL) {
- server_redraw_window_borders(markedwp->window);
- server_status_window(markedwp->window);
- }
- return (CMD_RETURN_NORMAL);
- }
- if (args_has(self->args, 'P') || args_has(self->args, 'g')) {
- if (args_has(args, 'P')) {
- style = args_get(args, 'P');
- if (style_parse(&grid_default_cell, &wp->colgc,
- style) == -1) {
- cmdq_error(cmdq, "bad style: %s", style);
- return (CMD_RETURN_ERROR);
- }
- wp->flags |= PANE_REDRAW;
- }
- if (args_has(self->args, 'g'))
- cmdq_print(cmdq, "%s", style_tostring(&wp->colgc));
- return (CMD_RETURN_NORMAL);
- }
- if (args_has(self->args, 'L')) {
- server_unzoom_window(wp->window);
- wp = window_pane_find_left(wp);
- } else if (args_has(self->args, 'R')) {
- server_unzoom_window(wp->window);
- wp = window_pane_find_right(wp);
- } else if (args_has(self->args, 'U')) {
- server_unzoom_window(wp->window);
- wp = window_pane_find_up(wp);
- } else if (args_has(self->args, 'D')) {
- server_unzoom_window(wp->window);
- wp = window_pane_find_down(wp);
- }
- if (wp == NULL)
- return (CMD_RETURN_NORMAL);
- if (args_has(self->args, 'e')) {
- wp->flags &= ~PANE_INPUTOFF;
- return (CMD_RETURN_NORMAL);
- }
- if (args_has(self->args, 'd')) {
- wp->flags |= PANE_INPUTOFF;
- return (CMD_RETURN_NORMAL);
- }
- if (wp == w->active)
- return (CMD_RETURN_NORMAL);
- server_unzoom_window(wp->window);
- if (!window_pane_visible(wp)) {
- cmdq_error(cmdq, "pane not visible");
- return (CMD_RETURN_ERROR);
- }
- window_redraw_active_switch(w, wp);
- if (window_set_active_pane(w, wp)) {
- server_status_window(w);
- server_redraw_window_borders(w);
- }
- return (CMD_RETURN_NORMAL);
- }
|