aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorBjörn Linse <bjorn.linse@gmail.com>2018-12-01 16:44:36 +0100
committerBjörn Linse <bjorn.linse@gmail.com>2018-12-03 10:42:00 +0100
commit8b42249cddf6b257e2eee808a41f3d6dd5af6846 (patch)
tree72de67ecda2504f44f5183daaddb60809e855415 /src
parent07ad5d71ab97a84dc9c59b3507bf7898040d24cf (diff)
downloadrneovim-8b42249cddf6b257e2eee808a41f3d6dd5af6846.tar.gz
rneovim-8b42249cddf6b257e2eee808a41f3d6dd5af6846.tar.bz2
rneovim-8b42249cddf6b257e2eee808a41f3d6dd5af6846.zip
RPC: turn errors from async calls into notifications
Previously, nvim sent a response with invalid request id (UINT64_MAX). In functionaltests, catch unexpected error notifications in after_each().
Diffstat (limited to 'src')
-rw-r--r--src/nvim/msgpack_rpc/channel.c11
1 files changed, 10 insertions, 1 deletions
diff --git a/src/nvim/msgpack_rpc/channel.c b/src/nvim/msgpack_rpc/channel.c
index 3356cdc61e..46a9e95b91 100644
--- a/src/nvim/msgpack_rpc/channel.c
+++ b/src/nvim/msgpack_rpc/channel.c
@@ -641,7 +641,16 @@ static WBuffer *serialize_response(uint64_t channel_id,
{
msgpack_packer pac;
msgpack_packer_init(&pac, sbuffer, msgpack_sbuffer_write);
- msgpack_rpc_serialize_response(response_id, err, arg, &pac);
+ if (ERROR_SET(err) && response_id == NO_RESPONSE) {
+ Array args = ARRAY_DICT_INIT;
+ ADD(args, INTEGER_OBJ(err->type));
+ ADD(args, STRING_OBJ(cstr_to_string(err->msg)));
+ msgpack_rpc_serialize_request(0, cstr_as_string("nvim_error_event"),
+ args, &pac);
+ api_free_array(args);
+ } else {
+ msgpack_rpc_serialize_response(response_id, err, arg, &pac);
+ }
log_server_msg(channel_id, sbuffer);
WBuffer *rv = wstream_new_buffer(xmemdup(sbuffer->data, sbuffer->size),
sbuffer->size,