mirror of
https://github.com/neovim/neovim.git
synced 2025-09-06 03:18:16 +00:00
Merge pull request #23908 from zeertzjq/vim-9.0.1600
vim-patch:9.0.{1600,1607}: screenpos() fixes
This commit is contained in:
@@ -1069,21 +1069,20 @@ void textpos2screenpos(win_T *wp, pos_T *pos, int *rowp, int *scolp, int *ccolp,
|
|||||||
bool visible_row = false;
|
bool visible_row = false;
|
||||||
bool is_folded = false;
|
bool is_folded = false;
|
||||||
|
|
||||||
if (pos->lnum >= wp->w_topline && pos->lnum <= wp->w_botline) {
|
|
||||||
linenr_T lnum = pos->lnum;
|
linenr_T lnum = pos->lnum;
|
||||||
|
if (lnum >= wp->w_topline && lnum <= wp->w_botline) {
|
||||||
is_folded = hasFoldingWin(wp, lnum, &lnum, NULL, true, NULL);
|
is_folded = hasFoldingWin(wp, lnum, &lnum, NULL, true, NULL);
|
||||||
row = plines_m_win(wp, wp->w_topline, lnum - 1) + 1;
|
row = plines_m_win(wp, wp->w_topline, lnum - 1) + 1;
|
||||||
// Add filler lines above this buffer line.
|
// Add filler lines above this buffer line.
|
||||||
row += win_get_fill(wp, lnum);
|
row += lnum == wp->w_topline ? wp->w_topfill : win_get_fill(wp, lnum);
|
||||||
visible_row = true;
|
visible_row = true;
|
||||||
} else if (!local || pos->lnum < wp->w_topline) {
|
} else if (!local || lnum < wp->w_topline) {
|
||||||
row = 0;
|
row = 0;
|
||||||
} else {
|
} else {
|
||||||
row = wp->w_height_inner;
|
row = wp->w_height_inner;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool existing_row = (pos->lnum > 0
|
bool existing_row = (lnum > 0 && lnum <= wp->w_buffer->b_ml.ml_line_count);
|
||||||
&& pos->lnum <= wp->w_buffer->b_ml.ml_line_count);
|
|
||||||
|
|
||||||
if ((local || visible_row) && existing_row) {
|
if ((local || visible_row) && existing_row) {
|
||||||
const colnr_T off = win_col_off(wp);
|
const colnr_T off = win_col_off(wp);
|
||||||
@@ -1091,6 +1090,7 @@ void textpos2screenpos(win_T *wp, pos_T *pos, int *rowp, int *scolp, int *ccolp,
|
|||||||
row += local ? 0 : wp->w_winrow + wp->w_winrow_off;
|
row += local ? 0 : wp->w_winrow + wp->w_winrow_off;
|
||||||
coloff = (local ? 0 : wp->w_wincol + wp->w_wincol_off) + 1 + off;
|
coloff = (local ? 0 : wp->w_wincol + wp->w_wincol_off) + 1 + off;
|
||||||
} else {
|
} else {
|
||||||
|
assert(lnum == pos->lnum);
|
||||||
getvcol(wp, pos, &scol, &ccol, &ecol);
|
getvcol(wp, pos, &scol, &ccol, &ecol);
|
||||||
|
|
||||||
// similar to what is done in validate_cursor_col()
|
// similar to what is done in validate_cursor_col()
|
||||||
@@ -1098,6 +1098,10 @@ void textpos2screenpos(win_T *wp, pos_T *pos, int *rowp, int *scolp, int *ccolp,
|
|||||||
col += off;
|
col += off;
|
||||||
int width = wp->w_width_inner - off + win_col_off2(wp);
|
int width = wp->w_width_inner - off + win_col_off2(wp);
|
||||||
|
|
||||||
|
if (lnum == wp->w_topline) {
|
||||||
|
col -= wp->w_skipcol;
|
||||||
|
}
|
||||||
|
|
||||||
// long line wrapping, adjust row
|
// long line wrapping, adjust row
|
||||||
if (wp->w_p_wrap && col >= (colnr_T)wp->w_width_inner && width > 0) {
|
if (wp->w_p_wrap && col >= (colnr_T)wp->w_width_inner && width > 0) {
|
||||||
// use same formula as what is used in curs_columns()
|
// use same formula as what is used in curs_columns()
|
||||||
|
@@ -38,8 +38,7 @@
|
|||||||
/// @param winheight when true limit to window height
|
/// @param winheight when true limit to window height
|
||||||
int plines_win(win_T *wp, linenr_T lnum, bool winheight)
|
int plines_win(win_T *wp, linenr_T lnum, bool winheight)
|
||||||
{
|
{
|
||||||
// Check for filler lines above this buffer line. When folded the result
|
// Check for filler lines above this buffer line.
|
||||||
// is one line anyway.
|
|
||||||
return plines_win_nofill(wp, lnum, winheight) + win_get_fill(wp, lnum);
|
return plines_win_nofill(wp, lnum, winheight) + win_get_fill(wp, lnum);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -199,16 +198,12 @@ int plines_win_col(win_T *wp, linenr_T lnum, long column)
|
|||||||
int plines_win_full(win_T *wp, linenr_T lnum, linenr_T *const nextp, bool *const foldedp,
|
int plines_win_full(win_T *wp, linenr_T lnum, linenr_T *const nextp, bool *const foldedp,
|
||||||
const bool cache, const bool winheight)
|
const bool cache, const bool winheight)
|
||||||
{
|
{
|
||||||
bool folded = hasFoldingWin(wp, lnum, NULL, nextp, cache, NULL);
|
bool folded = hasFoldingWin(wp, lnum, &lnum, nextp, cache, NULL);
|
||||||
if (foldedp) {
|
if (foldedp != NULL) {
|
||||||
*foldedp = folded;
|
*foldedp = folded;
|
||||||
}
|
}
|
||||||
if (folded) {
|
return ((folded ? 1 : plines_win_nofill(wp, lnum, winheight)) +
|
||||||
return 1;
|
(lnum == wp->w_topline ? wp->w_topfill : win_get_fill(wp, lnum)));
|
||||||
} else if (lnum == wp->w_topline) {
|
|
||||||
return plines_win_nofill(wp, lnum, winheight) + wp->w_topfill;
|
|
||||||
}
|
|
||||||
return plines_win(wp, lnum, winheight);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int plines_m_win(win_T *wp, linenr_T first, linenr_T last)
|
int plines_m_win(win_T *wp, linenr_T first, linenr_T last)
|
||||||
|
@@ -7,7 +7,6 @@ local insert = helpers.insert
|
|||||||
local funcs = helpers.funcs
|
local funcs = helpers.funcs
|
||||||
local meths = helpers.meths
|
local meths = helpers.meths
|
||||||
local exec = helpers.exec
|
local exec = helpers.exec
|
||||||
local exec_lua = helpers.exec_lua
|
|
||||||
local assert_alive = helpers.assert_alive
|
local assert_alive = helpers.assert_alive
|
||||||
|
|
||||||
|
|
||||||
@@ -1911,19 +1910,17 @@ describe("folded lines", function()
|
|||||||
end
|
end
|
||||||
end)
|
end)
|
||||||
|
|
||||||
it('fold attached virtual lines are drawn correctly #21837', function()
|
it('fold attached virtual lines are drawn and scrolled correctly #21837', function()
|
||||||
funcs.setline(1, 'line 1')
|
funcs.setline(1, 'line 1')
|
||||||
funcs.setline(2, 'line 2')
|
funcs.setline(2, 'line 2')
|
||||||
funcs.setline(3, 'line 3')
|
funcs.setline(3, 'line 3')
|
||||||
funcs.setline(4, 'line 4')
|
funcs.setline(4, 'line 4')
|
||||||
feed("zfj")
|
feed("zfj")
|
||||||
exec_lua([[
|
local ns = meths.create_namespace('ns')
|
||||||
local ns = vim.api.nvim_create_namespace("ns")
|
meths.buf_set_extmark(0, ns, 0, 0, { virt_lines_above = true, virt_lines = {{{"virt_line above line 1", ""}}} })
|
||||||
vim.api.nvim_buf_set_extmark(0, ns, 0, 0, { virt_lines_above = true, virt_lines = {{{"virt_line above line 1", ""}}} })
|
meths.buf_set_extmark(0, ns, 1, 0, { virt_lines = {{{"virt_line below line 2", ""}}} })
|
||||||
vim.api.nvim_buf_set_extmark(0, ns, 1, 0, { virt_lines = {{{"virt_line below line 2", ""}}} })
|
meths.buf_set_extmark(0, ns, 2, 0, { virt_lines_above = true, virt_lines = {{{"virt_line above line 3", ""}}} })
|
||||||
vim.api.nvim_buf_set_extmark(0, ns, 2, 0, { virt_lines_above = true, virt_lines = {{{"virt_line above line 3", ""}}} })
|
meths.buf_set_extmark(0, ns, 3, 0, { virt_lines = {{{"virt_line below line 4", ""}}} })
|
||||||
vim.api.nvim_buf_set_extmark(0, ns, 3, 0, { virt_lines = {{{"virt_line below line 4", ""}}} })
|
|
||||||
]])
|
|
||||||
if multigrid then
|
if multigrid then
|
||||||
screen:expect([[
|
screen:expect([[
|
||||||
## grid 1
|
## grid 1
|
||||||
@@ -2031,6 +2028,223 @@ describe("folded lines", function()
|
|||||||
|
|
|
|
||||||
]])
|
]])
|
||||||
end
|
end
|
||||||
|
|
||||||
|
meths.buf_set_extmark(0, ns, 1, 0, { virt_lines = {{{"more virt_line below line 2", ""}}} })
|
||||||
|
feed('G<C-E>')
|
||||||
|
if multigrid then
|
||||||
|
screen:expect([[
|
||||||
|
## grid 1
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[3:---------------------------------------------]|
|
||||||
|
## grid 2
|
||||||
|
line 1 |
|
||||||
|
line 2 |
|
||||||
|
virt_line below line 2 |
|
||||||
|
more virt_line below line 2 |
|
||||||
|
{5:+-- 2 lines: line 3·························}|
|
||||||
|
^line 5 |
|
||||||
|
{1:~ }|
|
||||||
|
## grid 3
|
||||||
|
|
|
||||||
|
]])
|
||||||
|
else
|
||||||
|
screen:expect([[
|
||||||
|
line 1 |
|
||||||
|
line 2 |
|
||||||
|
virt_line below line 2 |
|
||||||
|
more virt_line below line 2 |
|
||||||
|
{5:+-- 2 lines: line 3·························}|
|
||||||
|
^line 5 |
|
||||||
|
{1:~ }|
|
||||||
|
|
|
||||||
|
]])
|
||||||
|
end
|
||||||
|
|
||||||
|
feed('<C-E>')
|
||||||
|
if multigrid then
|
||||||
|
screen:expect([[
|
||||||
|
## grid 1
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[3:---------------------------------------------]|
|
||||||
|
## grid 2
|
||||||
|
line 2 |
|
||||||
|
virt_line below line 2 |
|
||||||
|
more virt_line below line 2 |
|
||||||
|
{5:+-- 2 lines: line 3·························}|
|
||||||
|
^line 5 |
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
## grid 3
|
||||||
|
|
|
||||||
|
]])
|
||||||
|
else
|
||||||
|
screen:expect([[
|
||||||
|
line 2 |
|
||||||
|
virt_line below line 2 |
|
||||||
|
more virt_line below line 2 |
|
||||||
|
{5:+-- 2 lines: line 3·························}|
|
||||||
|
^line 5 |
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
|
|
||||||
|
]])
|
||||||
|
end
|
||||||
|
|
||||||
|
feed('<C-E>')
|
||||||
|
if multigrid then
|
||||||
|
screen:expect([[
|
||||||
|
## grid 1
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[3:---------------------------------------------]|
|
||||||
|
## grid 2
|
||||||
|
virt_line below line 2 |
|
||||||
|
more virt_line below line 2 |
|
||||||
|
{5:+-- 2 lines: line 3·························}|
|
||||||
|
^line 5 |
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
## grid 3
|
||||||
|
|
|
||||||
|
]])
|
||||||
|
else
|
||||||
|
screen:expect([[
|
||||||
|
virt_line below line 2 |
|
||||||
|
more virt_line below line 2 |
|
||||||
|
{5:+-- 2 lines: line 3·························}|
|
||||||
|
^line 5 |
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
|
|
||||||
|
]])
|
||||||
|
end
|
||||||
|
|
||||||
|
feed('<C-E>')
|
||||||
|
if multigrid then
|
||||||
|
screen:expect([[
|
||||||
|
## grid 1
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[3:---------------------------------------------]|
|
||||||
|
## grid 2
|
||||||
|
more virt_line below line 2 |
|
||||||
|
{5:+-- 2 lines: line 3·························}|
|
||||||
|
^line 5 |
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
## grid 3
|
||||||
|
|
|
||||||
|
]])
|
||||||
|
else
|
||||||
|
screen:expect([[
|
||||||
|
more virt_line below line 2 |
|
||||||
|
{5:+-- 2 lines: line 3·························}|
|
||||||
|
^line 5 |
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
|
|
||||||
|
]])
|
||||||
|
end
|
||||||
|
|
||||||
|
feed('<C-E>')
|
||||||
|
if multigrid then
|
||||||
|
screen:expect([[
|
||||||
|
## grid 1
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[3:---------------------------------------------]|
|
||||||
|
## grid 2
|
||||||
|
{5:+-- 2 lines: line 3·························}|
|
||||||
|
^line 5 |
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
## grid 3
|
||||||
|
|
|
||||||
|
]])
|
||||||
|
else
|
||||||
|
screen:expect([[
|
||||||
|
{5:+-- 2 lines: line 3·························}|
|
||||||
|
^line 5 |
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
|
|
||||||
|
]])
|
||||||
|
end
|
||||||
|
|
||||||
|
feed('<C-E>')
|
||||||
|
if multigrid then
|
||||||
|
screen:expect([[
|
||||||
|
## grid 1
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[3:---------------------------------------------]|
|
||||||
|
## grid 2
|
||||||
|
^line 5 |
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
## grid 3
|
||||||
|
|
|
||||||
|
]])
|
||||||
|
else
|
||||||
|
screen:expect([[
|
||||||
|
^line 5 |
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
|
|
||||||
|
]])
|
||||||
|
end
|
||||||
end)
|
end)
|
||||||
|
|
||||||
it('Folded and Visual highlights are combined #19691', function()
|
it('Folded and Visual highlights are combined #19691', function()
|
||||||
|
@@ -1,12 +1,12 @@
|
|||||||
local helpers = require('test.functional.helpers')(after_each)
|
local helpers = require('test.functional.helpers')(after_each)
|
||||||
local clear, eq, meths = helpers.clear, helpers.eq, helpers.meths
|
local clear, eq, meths = helpers.clear, helpers.eq, helpers.meths
|
||||||
local command, funcs = helpers.command, helpers.funcs
|
local command, funcs = helpers.command, helpers.funcs
|
||||||
|
local feed = helpers.feed
|
||||||
|
|
||||||
before_each(clear)
|
before_each(clear)
|
||||||
|
|
||||||
describe('screenpos() function', function()
|
describe('screenpos() function', function()
|
||||||
it('works in floating window with border', function()
|
it('works in floating window with border', function()
|
||||||
local bufnr = meths.create_buf(false, true)
|
|
||||||
local opts = {
|
local opts = {
|
||||||
relative='editor',
|
relative='editor',
|
||||||
height=8,
|
height=8,
|
||||||
@@ -18,34 +18,56 @@ describe('screenpos() function', function()
|
|||||||
border='none',
|
border='none',
|
||||||
focusable=1
|
focusable=1
|
||||||
}
|
}
|
||||||
local float = meths.open_win(bufnr, false, opts)
|
local float = meths.open_win(meths.create_buf(false, true), false, opts)
|
||||||
command('redraw')
|
command('redraw')
|
||||||
local pos = funcs.screenpos(bufnr, 1, 1)
|
eq({row = 7, col = 9, endcol = 9, curscol = 9}, funcs.screenpos(float, 1, 1))
|
||||||
eq(7, pos.row)
|
|
||||||
eq(9, pos.col)
|
|
||||||
|
|
||||||
-- only left border
|
-- only left border
|
||||||
opts.border = {'', '', '', '', '', '', '', '|'}
|
opts.border = {'', '', '', '', '', '', '', '|'}
|
||||||
meths.win_set_config(float, opts)
|
meths.win_set_config(float, opts)
|
||||||
command('redraw')
|
command('redraw')
|
||||||
pos = funcs.screenpos(bufnr, 1, 1)
|
eq({row = 7, col = 10, endcol = 10, curscol = 10}, funcs.screenpos(float, 1, 1))
|
||||||
eq(7, pos.row)
|
|
||||||
eq(10, pos.col)
|
|
||||||
|
|
||||||
-- only top border
|
-- only top border
|
||||||
opts.border = {'', '_', '', '', '', '', '', ''}
|
opts.border = {'', '_', '', '', '', '', '', ''}
|
||||||
meths.win_set_config(float, opts)
|
meths.win_set_config(float, opts)
|
||||||
command('redraw')
|
command('redraw')
|
||||||
pos = funcs.screenpos(bufnr, 1, 1)
|
eq({row = 8, col = 9, endcol = 9, curscol = 9}, funcs.screenpos(float, 1, 1))
|
||||||
eq(8, pos.row)
|
|
||||||
eq(9, pos.col)
|
|
||||||
|
|
||||||
-- both left and top border
|
-- both left and top border
|
||||||
opts.border = 'single'
|
opts.border = 'single'
|
||||||
meths.win_set_config(float, opts)
|
meths.win_set_config(float, opts)
|
||||||
command('redraw')
|
command('redraw')
|
||||||
pos = funcs.screenpos(bufnr, 1, 1)
|
eq({row = 8, col = 10, endcol = 10, curscol = 10}, funcs.screenpos(float, 1, 1))
|
||||||
eq(8, pos.row)
|
end)
|
||||||
eq(10, pos.col)
|
|
||||||
|
it('works for folded line with virt_lines attached to line above', function()
|
||||||
|
meths.buf_set_lines(0, 0, -1, true, {'aaa', 'bbb', 'ccc', 'ddd'})
|
||||||
|
local ns = meths.create_namespace('')
|
||||||
|
meths.buf_set_extmark(0, ns, 0, 0, { virt_lines = {{{'abb'}}, {{'acc'}}, {{'add'}}} })
|
||||||
|
command('2,3fold')
|
||||||
|
eq({row = 5, col = 1, endcol = 1, curscol = 1}, funcs.screenpos(0, 2, 1))
|
||||||
|
eq({row = 5, col = 1, endcol = 1, curscol = 1}, funcs.screenpos(0, 3, 1))
|
||||||
|
eq({row = 6, col = 1, endcol = 1, curscol = 1}, funcs.screenpos(0, 4, 1))
|
||||||
|
|
||||||
|
feed('<C-E>')
|
||||||
|
eq({row = 4, col = 1, endcol = 1, curscol = 1}, funcs.screenpos(0, 2, 1))
|
||||||
|
eq({row = 4, col = 1, endcol = 1, curscol = 1}, funcs.screenpos(0, 3, 1))
|
||||||
|
eq({row = 5, col = 1, endcol = 1, curscol = 1}, funcs.screenpos(0, 4, 1))
|
||||||
|
|
||||||
|
feed('<C-E>')
|
||||||
|
eq({row = 3, col = 1, endcol = 1, curscol = 1}, funcs.screenpos(0, 2, 1))
|
||||||
|
eq({row = 3, col = 1, endcol = 1, curscol = 1}, funcs.screenpos(0, 3, 1))
|
||||||
|
eq({row = 4, col = 1, endcol = 1, curscol = 1}, funcs.screenpos(0, 4, 1))
|
||||||
|
|
||||||
|
feed('<C-E>')
|
||||||
|
eq({row = 2, col = 1, endcol = 1, curscol = 1}, funcs.screenpos(0, 2, 1))
|
||||||
|
eq({row = 2, col = 1, endcol = 1, curscol = 1}, funcs.screenpos(0, 3, 1))
|
||||||
|
eq({row = 3, col = 1, endcol = 1, curscol = 1}, funcs.screenpos(0, 4, 1))
|
||||||
|
|
||||||
|
feed('<C-E>')
|
||||||
|
eq({row = 1, col = 1, endcol = 1, curscol = 1}, funcs.screenpos(0, 2, 1))
|
||||||
|
eq({row = 1, col = 1, endcol = 1, curscol = 1}, funcs.screenpos(0, 3, 1))
|
||||||
|
eq({row = 2, col = 1, endcol = 1, curscol = 1}, funcs.screenpos(0, 4, 1))
|
||||||
end)
|
end)
|
||||||
end)
|
end)
|
||||||
|
@@ -127,6 +127,40 @@ func Test_screenpos()
|
|||||||
call assert_equal({'row': 0, 'col': 0, 'curscol': 0, 'endcol': 0},
|
call assert_equal({'row': 0, 'col': 0, 'curscol': 0, 'endcol': 0},
|
||||||
\ winid->screenpos(line('$'), 22))
|
\ winid->screenpos(line('$'), 22))
|
||||||
|
|
||||||
|
1split
|
||||||
|
normal G$
|
||||||
|
redraw
|
||||||
|
" w_skipcol should be subtracted
|
||||||
|
call assert_equal({'row': winrow + 0,
|
||||||
|
\ 'col': wincol + 20 - 1,
|
||||||
|
\ 'curscol': wincol + 20 - 1,
|
||||||
|
\ 'endcol': wincol + 20 - 1},
|
||||||
|
\ screenpos(win_getid(), line('.'), col('.')))
|
||||||
|
|
||||||
|
" w_leftcol should be subtracted
|
||||||
|
setlocal nowrap
|
||||||
|
normal 050zl$
|
||||||
|
call assert_equal({'row': winrow + 0,
|
||||||
|
\ 'col': wincol + 10 - 1,
|
||||||
|
\ 'curscol': wincol + 10 - 1,
|
||||||
|
\ 'endcol': wincol + 10 - 1},
|
||||||
|
\ screenpos(win_getid(), line('.'), col('.')))
|
||||||
|
|
||||||
|
" w_skipcol should only matter for the topline
|
||||||
|
" FIXME: This fails because pline_m_win() does not take w_skipcol into
|
||||||
|
" account. If it does, then other tests fail.
|
||||||
|
" wincmd +
|
||||||
|
" setlocal wrap smoothscroll
|
||||||
|
" call setline(line('$') + 1, 'last line')
|
||||||
|
" exe "normal \<C-E>G$"
|
||||||
|
" redraw
|
||||||
|
" call assert_equal({'row': winrow + 1,
|
||||||
|
" \ 'col': wincol + 9 - 1,
|
||||||
|
" \ 'curscol': wincol + 9 - 1,
|
||||||
|
" \ 'endcol': wincol + 9 - 1},
|
||||||
|
" \ screenpos(win_getid(), line('.'), col('.')))
|
||||||
|
close
|
||||||
|
|
||||||
close
|
close
|
||||||
call assert_equal({}, screenpos(999, 1, 1))
|
call assert_equal({}, screenpos(999, 1, 1))
|
||||||
|
|
||||||
@@ -170,6 +204,19 @@ func Test_screenpos_diff()
|
|||||||
windo diffthis
|
windo diffthis
|
||||||
wincmd w
|
wincmd w
|
||||||
call assert_equal(#{col: 3, row: 7, endcol: 3, curscol: 3}, screenpos(0, 4, 1))
|
call assert_equal(#{col: 3, row: 7, endcol: 3, curscol: 3}, screenpos(0, 4, 1))
|
||||||
|
call assert_equal(#{col: 3, row: 8, endcol: 3, curscol: 3}, screenpos(0, 5, 1))
|
||||||
|
exe "normal! 3\<C-E>"
|
||||||
|
call assert_equal(#{col: 3, row: 4, endcol: 3, curscol: 3}, screenpos(0, 4, 1))
|
||||||
|
call assert_equal(#{col: 3, row: 5, endcol: 3, curscol: 3}, screenpos(0, 5, 1))
|
||||||
|
exe "normal! \<C-E>"
|
||||||
|
call assert_equal(#{col: 3, row: 3, endcol: 3, curscol: 3}, screenpos(0, 4, 1))
|
||||||
|
call assert_equal(#{col: 3, row: 4, endcol: 3, curscol: 3}, screenpos(0, 5, 1))
|
||||||
|
exe "normal! \<C-E>"
|
||||||
|
call assert_equal(#{col: 3, row: 2, endcol: 3, curscol: 3}, screenpos(0, 4, 1))
|
||||||
|
call assert_equal(#{col: 3, row: 3, endcol: 3, curscol: 3}, screenpos(0, 5, 1))
|
||||||
|
exe "normal! \<C-E>"
|
||||||
|
call assert_equal(#{col: 3, row: 1, endcol: 3, curscol: 3}, screenpos(0, 4, 1))
|
||||||
|
call assert_equal(#{col: 3, row: 2, endcol: 3, curscol: 3}, screenpos(0, 5, 1))
|
||||||
|
|
||||||
windo diffoff
|
windo diffoff
|
||||||
bwipe!
|
bwipe!
|
||||||
|
Reference in New Issue
Block a user