diff options
-rw-r--r-- | src/nvim/api/vim.c | 28 | ||||
-rw-r--r-- | test/functional/api/vim_spec.lua | 43 |
2 files changed, 52 insertions, 19 deletions
diff --git a/src/nvim/api/vim.c b/src/nvim/api/vim.c index 31ddfa57f1..bafb21bd4e 100644 --- a/src/nvim/api/vim.c +++ b/src/nvim/api/vim.c @@ -1206,21 +1206,18 @@ Dictionary nvim_get_namespaces(void) return retval; } -/// @param lines contents. One empty line for no-op, zero lines to emulate error +/// Inserts text at cursor. +/// +/// Compare |:put| and |p| which are always linewise. +/// +/// @param lines contents /// @param type type ("c", "l", "b") or empty to guess from contents -/// @param name if emulates put from a register, otherwise empty -/// @param prev True to emulate "P" otherwise "p" -/// @param count repeat count -/// @param[out] err details of an error that have occurred, if any. -void nvim_put(ArrayOf(String) lines, String type, String regname, Boolean prev, Integer count, Error *err) +/// @param direction behave like |P| instead of |p| +/// @param[out] err Error details, if any +void nvim_put(ArrayOf(String) lines, String type, Boolean direction, + Error *err) FUNC_API_SINCE(6) { - if (regname.size > 1) { - api_set_error(err, - kErrorTypeValidation, - "regname must be a single ASCII char or the empty string"); - return; - } yankreg_T *reg = xcalloc(sizeof(yankreg_T), 1); if (!prepare_yankreg_from_object(reg, type, lines.size)) { api_set_error(err, @@ -1229,6 +1226,9 @@ void nvim_put(ArrayOf(String) lines, String type, String regname, Boolean prev, type.data); return; } + if (lines.size == 0) { + goto cleanup; // Nothing to do. + } for (size_t i = 0; i < lines.size; i++) { if (lines.items[i].type != kObjectTypeString) { @@ -1244,7 +1244,6 @@ void nvim_put(ArrayOf(String) lines, String type, String regname, Boolean prev, finish_yankreg_from_object(reg, false); - int name = regname.size ? regname.data[0] : NUL; bool VIsual_was_active = VIsual_active; int flags = 0; if (State & INSERT) { @@ -1253,13 +1252,12 @@ void nvim_put(ArrayOf(String) lines, String type, String regname, Boolean prev, // TODO: fix VIsual when cursor is before, or emulate the delete as well flags |= lt(VIsual, curwin->w_cursor) ? PUT_CURSEND : 0; } - do_put(name, reg, prev ? BACKWARD : FORWARD, (long)count, flags); + do_put(0, reg, direction ? BACKWARD : FORWARD, 1, flags); VIsual_active = VIsual_was_active; cleanup: free_register(reg); xfree(reg); - } /// Subscribes to event broadcasts. diff --git a/test/functional/api/vim_spec.lua b/test/functional/api/vim_spec.lua index 0cd81619c1..09c297940c 100644 --- a/test/functional/api/vim_spec.lua +++ b/test/functional/api/vim_spec.lua @@ -5,6 +5,7 @@ local NIL = helpers.NIL local clear, nvim, eq, neq = helpers.clear, helpers.nvim, helpers.eq, helpers.neq local command = helpers.command local eval = helpers.eval +local expect = helpers.expect local funcs = helpers.funcs local iswin = helpers.iswin local meth_pcall = helpers.meth_pcall @@ -365,6 +366,40 @@ describe('API', function() end) end) + describe('nvim_put', function() + it('inserts text', function() + -- linewise + nvim('put', {'line 1','line 2','line 3'}, 'l', false) + expect([[ + + line 1 + line 2 + line 3]]) + command('%delete _') + -- charwise + nvim('put', {'line 1','line 2','line 3'}, 'c', false) + expect([[ + line 1 + line 2 + line 3]]) + -- blockwise + nvim('put', {'AA','BB'}, 'b', false) + expect([[ + lAAine 1 + lBBine 2 + line 3]]) + command('%delete _') + -- Empty lines list. + nvim('put', {}, 'c', false) + expect([[]]) + -- Single empty line. + nvim('put', {''}, 'c', false) + expect([[ + ]]) + eq('', nvim('eval', 'v:errmsg')) + end) + end) + describe('nvim_strwidth', function() it('works', function() eq(3, nvim('strwidth', 'abc')) @@ -626,12 +661,12 @@ describe('API', function() -- Make any RPC request (can be non-async: op-pending does not block). nvim('get_current_buf') -- Buffer should not change. - helpers.expect([[ + expect([[ FIRST LINE SECOND LINE]]) -- Now send input to complete the operator. nvim('input', 'j') - helpers.expect([[ + expect([[ first line second line]]) end) @@ -664,7 +699,7 @@ describe('API', function() nvim('get_api_info') -- Send input to complete the mapping. nvim('input', 'd') - helpers.expect([[ + expect([[ FIRST LINE SECOND LINE]]) eq('it worked...', helpers.eval('g:foo')) @@ -680,7 +715,7 @@ describe('API', function() nvim('get_api_info') -- Send input to complete the mapping. nvim('input', 'x') - helpers.expect([[ + expect([[ FIRST LINE SECOND LINfooE]]) end) |