diff options
author | Justin M. Keyes <justinkz@gmail.com> | 2019-08-24 13:54:27 +0200 |
---|---|---|
committer | Justin M. Keyes <justinkz@gmail.com> | 2019-08-27 22:13:45 +0200 |
commit | eacc70fb3ebae6d76112ab10647a42339f5f223f (patch) | |
tree | ef498c6f108edc29498d319de32417d90d8c0bd7 /src/nvim/tui/input.c | |
parent | c95f5d166fad75ad8383f76675d06907687066a7 (diff) | |
download | rneovim-eacc70fb3ebae6d76112ab10647a42339f5f223f.tar.gz rneovim-eacc70fb3ebae6d76112ab10647a42339f5f223f.tar.bz2 rneovim-eacc70fb3ebae6d76112ab10647a42339f5f223f.zip |
API: nvim_paste
Diffstat (limited to 'src/nvim/tui/input.c')
-rw-r--r-- | src/nvim/tui/input.c | 40 |
1 files changed, 3 insertions, 37 deletions
diff --git a/src/nvim/tui/input.c b/src/nvim/tui/input.c index fc06f21339..33062e88d3 100644 --- a/src/nvim/tui/input.c +++ b/src/nvim/tui/input.c @@ -100,31 +100,6 @@ static void tinput_done_event(void **argv) input_done(); } -static Array string_to_array(const String input) -{ - Array ret = ARRAY_DICT_INIT; - for (size_t i = 0; i < input.size; i++) { - const char *start = input.data + i; - const char *end = xmemscan(start, NL, input.size - i); - const size_t line_len = (size_t)(end - start); - i += line_len; - - String s = { - .size = line_len, - .data = xmemdupz(start, line_len), - }; - memchrsub(s.data, NUL, NL, line_len); - ADD(ret, STRING_OBJ(s)); - // If line ends at end-of-buffer, add empty final item. - // This is "readfile()-style", see also ":help channel-lines". - if (i + 1 == input.size && end[0] == NL) { - ADD(ret, STRING_OBJ(cchar_to_string(NUL))); - } - } - - return ret; -} - static void tinput_wait_enqueue(void **argv) { TermInput *input = argv[0]; @@ -132,18 +107,9 @@ static void tinput_wait_enqueue(void **argv) const String keys = { .data = buf, .size = len }; if (input->paste) { Error err = ERROR_INIT; - Array args = ARRAY_DICT_INIT; - ADD(args, ARRAY_OBJ(string_to_array(keys))); - ADD(args, INTEGER_OBJ(input->paste)); - Object rv - = nvim_execute_lua(STATIC_CSTR_AS_STRING("return vim._paste(...)"), - args, &err); - input->paste = (rv.type == kObjectTypeBoolean && rv.data.boolean) - ? 2 // Paste phase: "continue". - : 0; // Abort paste if handler does not return true. - - api_free_object(rv); - api_free_array(args); + Boolean rv = nvim_paste(keys, input->paste, &err); + // Paste phase: "continue" (unless handler failed). + input->paste = rv && !ERROR_SET(&err) ? 2 : 0; rbuffer_consumed(input->key_buffer, len); rbuffer_reset(input->key_buffer); if (ERROR_SET(&err)) { |