aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/nvim/api/vim.c28
-rw-r--r--test/functional/api/vim_spec.lua43
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)