From 4c0e1d22e6e2e6e4da36a95f22633af392e43528 Mon Sep 17 00:00:00 2001 From: Nicholas Marriott Date: Tue, 17 Aug 2021 20:17:22 +0000 Subject: Treat a pane that has died the same as no pane when sending data to control mode clients, GitHub issue 2828. --- usr.bin/tmux/control.c | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) (limited to 'usr.bin/tmux') diff --git a/usr.bin/tmux/control.c b/usr.bin/tmux/control.c index ee6d34c60a9..6e05f444e32 100644 --- a/usr.bin/tmux/control.c +++ b/usr.bin/tmux/control.c @@ -1,4 +1,4 @@ -/* $OpenBSD: control.c,v 1.45 2020/09/18 11:20:59 nicm Exp $ */ +/* $OpenBSD: control.c,v 1.46 2021/08/17 20:17:21 nicm Exp $ */ /* * Copyright (c) 2012 Nicholas Marriott @@ -665,7 +665,7 @@ control_write_pending(struct client *c, struct control_pane *cp, size_t limit) uint64_t age, t = get_timer(); wp = control_window_pane(c, cp->pane); - if (wp == NULL) { + if (wp == NULL || wp->fd == -1) { TAILQ_FOREACH_SAFE(cb, &cp->blocks, entry, cb1) { TAILQ_REMOVE(&cp->blocks, cb, entry); control_free_block(cs, cb); @@ -865,7 +865,7 @@ control_check_subs_pane(struct client *c, struct control_sub *csub) struct control_sub_pane *csp, find; wp = window_pane_find_by_id(csub->id); - if (wp == NULL) + if (wp == NULL || wp->fd == -1) return; w = wp->window; -- cgit v1.2.3