mirror of
https://github.com/tmate-io/tmate.git
synced 2024-11-08 09:14:22 +01:00
Make remain-on-exit work again when there is only one pane left, which was
broken sometime during the pane/layout changes. Reported/tested by Iain Morgan, thanks.
This commit is contained in:
parent
2de599ac0e
commit
da8401d8be
15
server.c
15
server.c
@ -966,7 +966,7 @@ server_check_window_content(
|
||||
return (1);
|
||||
}
|
||||
|
||||
/* Check if window still exists.. */
|
||||
/* Check if window still exists. */
|
||||
void
|
||||
server_check_window(struct window *w)
|
||||
{
|
||||
@ -984,13 +984,18 @@ server_check_window(struct window *w)
|
||||
wp = TAILQ_FIRST(&w->panes);
|
||||
while (wp != NULL) {
|
||||
wq = TAILQ_NEXT(wp, entry);
|
||||
if (wp->fd != -1)
|
||||
destroyed = 0;
|
||||
else if (!flag) {
|
||||
/*
|
||||
* If the pane has died and the remain-on-exit flag is not set,
|
||||
* remove the pane; otherwise, if the flag is set, don't allow
|
||||
* the window to be destroyed (or it'll close when the last
|
||||
* pane dies).
|
||||
*/
|
||||
if (wp->fd == -1 && !flag) {
|
||||
window_remove_pane(w, wp);
|
||||
server_redraw_window(w);
|
||||
layout_refresh(w, 0);
|
||||
}
|
||||
} else
|
||||
destroyed = 0;
|
||||
wp = wq;
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user