diff options
author | Thomas Adam <thomas@xteddy.org> | 2020-01-13 10:01:27 +0000 |
---|---|---|
committer | Thomas Adam <thomas@xteddy.org> | 2020-01-13 10:01:27 +0000 |
commit | 8457f54edcdfdf7b6e48a291808135258abfe5b8 (patch) | |
tree | ec28f5aff04e065ffb07447e3b8fb1730c307cb2 /window.c | |
parent | 3e701309a4edb10b6092a4f4801fa50c3277afe9 (diff) | |
parent | 835a6c0cf088437e318783c96b142c7dc26c290f (diff) | |
download | rtmux-8457f54edcdfdf7b6e48a291808135258abfe5b8.tar.gz rtmux-8457f54edcdfdf7b6e48a291808135258abfe5b8.tar.bz2 rtmux-8457f54edcdfdf7b6e48a291808135258abfe5b8.zip |
Merge branch 'obsd-master'
Diffstat (limited to 'window.c')
-rw-r--r-- | window.c | 14 |
1 files changed, 8 insertions, 6 deletions
@@ -1239,7 +1239,7 @@ window_pane_reset_mode_all(struct window_pane *wp) window_pane_reset_mode(wp); } -void +int window_pane_key(struct window_pane *wp, struct client *c, struct session *s, struct winlink *wl, key_code key, struct mouse_event *m) { @@ -1247,23 +1247,24 @@ window_pane_key(struct window_pane *wp, struct client *c, struct session *s, struct window_pane *wp2; if (KEYC_IS_MOUSE(key) && m == NULL) - return; + return (-1); wme = TAILQ_FIRST(&wp->modes); if (wme != NULL) { wp->modelast = time(NULL); if (wme->mode->key != NULL) wme->mode->key(wme, c, s, wl, (key & ~KEYC_XTERM), m); - return; + return (0); } if (wp->fd == -1 || wp->flags & PANE_INPUTOFF) - return; + return (0); - input_key(wp, key, m); + if (input_key(wp, key, m) != 0) + return (-1); if (KEYC_IS_MOUSE(key)) - return; + return (0); if (options_get_number(wp->window->options, "synchronize-panes")) { TAILQ_FOREACH(wp2, &wp->window->panes, entry) { if (wp2 != wp && @@ -1274,6 +1275,7 @@ window_pane_key(struct window_pane *wp, struct client *c, struct session *s, input_key(wp2, key, NULL); } } + return (0); } int |