aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorzeertzjq <zeertzjq@outlook.com>2021-11-11 09:34:23 +0800
committerzeertzjq <zeertzjq@outlook.com>2021-11-11 09:34:23 +0800
commit3b89fee24632cfddbff5714a509c1c3b72a235c5 (patch)
treedfa063d5cfbc997deffe75118e4cd6ba322a6781 /src
parent14def4d2271a5bc5e6e6e774d291a9e0fd2477e0 (diff)
downloadrneovim-3b89fee24632cfddbff5714a509c1c3b72a235c5.tar.gz
rneovim-3b89fee24632cfddbff5714a509c1c3b72a235c5.tar.bz2
rneovim-3b89fee24632cfddbff5714a509c1c3b72a235c5.zip
fix(channel): throw error if sending to internal channel w/o terminal
Prevent SIGABRT when sending to a channel created by nvim_open_term() after the associated terminal has been deleted.
Diffstat (limited to 'src')
-rw-r--r--src/nvim/channel.c6
1 files changed, 5 insertions, 1 deletions
diff --git a/src/nvim/channel.c b/src/nvim/channel.c
index 0eae87c1f8..9662f6205f 100644
--- a/src/nvim/channel.c
+++ b/src/nvim/channel.c
@@ -535,7 +535,11 @@ size_t channel_send(uint64_t id, char *data, size_t len, bool data_owned, const
goto retfree;
}
- if (chan->streamtype == kChannelStreamInternal && chan->term) {
+ if (chan->streamtype == kChannelStreamInternal) {
+ if (!chan->term) {
+ *error = _("Can't send data to closed stream");
+ goto retfree;
+ }
terminal_receive(chan->term, data, len);
written = len;
goto retfree;