aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorhlpr98 <hlpr98@gmail.com>2022-03-16 21:01:18 +0100
committerbfredl <bjorn.linse@gmail.com>2022-03-17 19:20:13 +0100
commit663616033834c5da3b8f48b0bd0db783fc92db31 (patch)
tree33952e4ac6f3bddf46d987f20303883444002974
parentd238b8f6003d34cae7f65ff7585b48a2cd9449fb (diff)
downloadrneovim-663616033834c5da3b8f48b0bd0db783fc92db31.tar.gz
rneovim-663616033834c5da3b8f48b0bd0db783fc92db31.tar.bz2
rneovim-663616033834c5da3b8f48b0bd0db783fc92db31.zip
feat(ui_client): pass user input to remote server
-rw-r--r--src/nvim/tui/input.c13
1 files changed, 12 insertions, 1 deletions
diff --git a/src/nvim/tui/input.c b/src/nvim/tui/input.c
index 26b3dd6e92..faae921a68 100644
--- a/src/nvim/tui/input.c
+++ b/src/nvim/tui/input.c
@@ -19,6 +19,7 @@
# include "nvim/os/os_win_console.h"
#endif
#include "nvim/event/rstream.h"
+#include "nvim/msgpack_rpc/channel.h"
#define KEY_BUFFER_SIZE 0xfff
@@ -134,7 +135,17 @@ static void tinput_wait_enqueue(void **argv)
rbuffer_consumed(input->key_buffer, len);
rbuffer_reset(input->key_buffer);
} else {
- const size_t consumed = input_enqueue(keys);
+ size_t consumed;
+ if (ui_client_channel_id) {
+ Array args = ARRAY_DICT_INIT;
+ Error err = ERROR_INIT;
+ ADD(args, STRING_OBJ(copy_string(keys)));
+ // TODO(bfredl): could be non-blocking now with paste?
+ Object result = rpc_send_call(ui_client_channel_id, "nvim_input", args, &err);
+ consumed = result.type == kObjectTypeInteger ? (size_t)result.data.integer : 0;
+ } else {
+ consumed = input_enqueue(keys);
+ }
if (consumed) {
rbuffer_consumed(input->key_buffer, consumed);
}