get_buffer_lines: Return a string, when requested, on invalid input

Closes #7859
This commit is contained in:
James McCoy 2018-01-15 22:28:41 -05:00
parent c06995b34d
commit 514a51ef3e
No known key found for this signature in database
GPG Key ID: DFE691AE331BA3DB
2 changed files with 42 additions and 1 deletions

View File

@ -9259,7 +9259,9 @@ static void get_buffer_lines(buf_T *buf, linenr_T start, linenr_T end, int retli
rettv->vval.v_string = NULL;
if (buf == NULL || buf->b_ml.ml_mfp == NULL || start < 0 || end < start) {
tv_list_alloc_ret(rettv, 0);
if (retlist) {
tv_list_alloc_ret(rettv, 0);
}
return;
}

View File

@ -0,0 +1,39 @@
local helpers = require('test.functional.helpers')(after_each)
local call = helpers.call
local clear = helpers.clear
local eq = helpers.eq
local expect = helpers.expect
describe('getline', function()
before_each(function()
clear()
call('setline', 1, {'a', 'b', 'c'})
expect([[
a
b
c]])
end)
it('returns empty string for invalid line', function()
eq('', call('getline', -1))
eq('', call('getline', 0))
eq('', call('getline', 4))
end)
it('returns empty list for invalid range', function()
eq({}, call('getline', 2, 1))
eq({}, call('getline', -1, 1))
eq({}, call('getline', 4, 4))
end)
it('returns value of valid line', function()
eq('b', call('getline', 2))
eq('a', call('getline', '.'))
end)
it('returns value of valid range', function()
eq({'a', 'b'}, call('getline', 1, 2))
eq({'a', 'b', 'c'}, call('getline', 1, 4))
end)
end)