mirror of
https://github.com/neovim/neovim.git
synced 2025-10-22 17:11:49 +00:00
Add test case for fold on multigrid
This commit is contained in:
@@ -10,11 +10,16 @@ local source = helpers.source
|
|||||||
local assert_alive = helpers.assert_alive
|
local assert_alive = helpers.assert_alive
|
||||||
|
|
||||||
describe("folded lines", function()
|
describe("folded lines", function()
|
||||||
|
before_each(function()
|
||||||
|
clear()
|
||||||
|
end)
|
||||||
|
|
||||||
|
local function with_ext_multigrid(multigrid)
|
||||||
local screen
|
local screen
|
||||||
before_each(function()
|
before_each(function()
|
||||||
clear()
|
clear()
|
||||||
screen = Screen.new(45, 8)
|
screen = Screen.new(45, 8)
|
||||||
screen:attach({rgb=true})
|
screen:attach({rgb=true, ext_multigrid=multigrid})
|
||||||
screen:set_default_attr_ids({
|
screen:set_default_attr_ids({
|
||||||
[1] = {bold = true, foreground = Screen.colors.Blue1},
|
[1] = {bold = true, foreground = Screen.colors.Blue1},
|
||||||
[2] = {reverse = true},
|
[2] = {reverse = true},
|
||||||
@@ -32,6 +37,29 @@ describe("folded lines", function()
|
|||||||
command("set signcolumn=yes:9")
|
command("set signcolumn=yes:9")
|
||||||
feed("i<cr><esc>")
|
feed("i<cr><esc>")
|
||||||
feed("vkzf")
|
feed("vkzf")
|
||||||
|
if multigrid then
|
||||||
|
screen:expect([[
|
||||||
|
## grid 1
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[3:---------------------------------------------]|
|
||||||
|
## grid 2
|
||||||
|
{7: }{5:^+-- 2 lines: ·············}|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
## grid 3
|
||||||
|
|
|
||||||
|
]])
|
||||||
|
else
|
||||||
screen:expect([[
|
screen:expect([[
|
||||||
{7: }{5:^+-- 2 lines: ·············}|
|
{7: }{5:^+-- 2 lines: ·············}|
|
||||||
{1:~ }|
|
{1:~ }|
|
||||||
@@ -42,6 +70,7 @@ describe("folded lines", function()
|
|||||||
{1:~ }|
|
{1:~ }|
|
||||||
|
|
|
|
||||||
]])
|
]])
|
||||||
|
end
|
||||||
end)
|
end)
|
||||||
|
|
||||||
it("highlighting with relative line numbers", function()
|
it("highlighting with relative line numbers", function()
|
||||||
@@ -52,6 +81,29 @@ describe("folded lines", function()
|
|||||||
funcs.setline(3, '{{{1')
|
funcs.setline(3, '{{{1')
|
||||||
funcs.setline(4, 'line 2')
|
funcs.setline(4, 'line 2')
|
||||||
feed("j")
|
feed("j")
|
||||||
|
if multigrid then
|
||||||
|
screen:expect([[
|
||||||
|
## grid 1
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[3:---------------------------------------------]|
|
||||||
|
## grid 2
|
||||||
|
{7:+ }{8: 1 }{5:+-- 2 lines: ·························}|
|
||||||
|
{7:+ }{9: 0 }{5:^+-- 2 lines: ·························}|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
## grid 3
|
||||||
|
:set foldcolumn=2 |
|
||||||
|
]])
|
||||||
|
else
|
||||||
screen:expect([[
|
screen:expect([[
|
||||||
{7:+ }{8: 1 }{5:+-- 2 lines: ·························}|
|
{7:+ }{8: 1 }{5:+-- 2 lines: ·························}|
|
||||||
{7:+ }{9: 0 }{5:^+-- 2 lines: ·························}|
|
{7:+ }{9: 0 }{5:^+-- 2 lines: ·························}|
|
||||||
@@ -62,6 +114,7 @@ describe("folded lines", function()
|
|||||||
{1:~ }|
|
{1:~ }|
|
||||||
:set foldcolumn=2 |
|
:set foldcolumn=2 |
|
||||||
]])
|
]])
|
||||||
|
end
|
||||||
end)
|
end)
|
||||||
|
|
||||||
it("works with multibyte fillchars", function()
|
it("works with multibyte fillchars", function()
|
||||||
@@ -78,7 +131,30 @@ describe("folded lines", function()
|
|||||||
feed('zf4j')
|
feed('zf4j')
|
||||||
feed('zf2j')
|
feed('zf2j')
|
||||||
feed('zO')
|
feed('zO')
|
||||||
screen:expect{grid=[[
|
if multigrid then
|
||||||
|
screen:expect([[
|
||||||
|
## grid 1
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[3:---------------------------------------------]|
|
||||||
|
## grid 2
|
||||||
|
{7:▾▾}^aa |
|
||||||
|
{7:││}bb |
|
||||||
|
{7:││}cc |
|
||||||
|
{7:││}dd |
|
||||||
|
{7:││}ee |
|
||||||
|
{7:│ }ff |
|
||||||
|
{1:~ }|
|
||||||
|
## grid 3
|
||||||
|
:1 |
|
||||||
|
]])
|
||||||
|
else
|
||||||
|
screen:expect([[
|
||||||
{7:▾▾}^aa |
|
{7:▾▾}^aa |
|
||||||
{7:││}bb |
|
{7:││}bb |
|
||||||
{7:││}cc |
|
{7:││}cc |
|
||||||
@@ -87,10 +163,34 @@ describe("folded lines", function()
|
|||||||
{7:│ }ff |
|
{7:│ }ff |
|
||||||
{1:~ }|
|
{1:~ }|
|
||||||
:1 |
|
:1 |
|
||||||
]]}
|
]])
|
||||||
|
end
|
||||||
|
|
||||||
feed_command("set rightleft")
|
feed_command("set rightleft")
|
||||||
screen:expect{grid=[[
|
if multigrid then
|
||||||
|
screen:expect([[
|
||||||
|
## grid 1
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[3:---------------------------------------------]|
|
||||||
|
## grid 2
|
||||||
|
a^a{7:▾▾}|
|
||||||
|
bb{7:││}|
|
||||||
|
cc{7:││}|
|
||||||
|
dd{7:││}|
|
||||||
|
ee{7:││}|
|
||||||
|
ff{7: │}|
|
||||||
|
{1: ~}|
|
||||||
|
## grid 3
|
||||||
|
:set rightleft |
|
||||||
|
]])
|
||||||
|
else
|
||||||
|
screen:expect([[
|
||||||
a^a{7:▾▾}|
|
a^a{7:▾▾}|
|
||||||
bb{7:││}|
|
bb{7:││}|
|
||||||
cc{7:││}|
|
cc{7:││}|
|
||||||
@@ -99,11 +199,36 @@ describe("folded lines", function()
|
|||||||
ff{7: │}|
|
ff{7: │}|
|
||||||
{1: ~}|
|
{1: ~}|
|
||||||
:set rightleft |
|
:set rightleft |
|
||||||
]]}
|
]])
|
||||||
|
end
|
||||||
|
|
||||||
feed_command("set norightleft")
|
feed_command("set norightleft")
|
||||||
|
if multigrid then
|
||||||
|
meths.input_mouse('left', 'press', '', 2, 0, 1)
|
||||||
|
screen:expect([[
|
||||||
|
## grid 1
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[3:---------------------------------------------]|
|
||||||
|
## grid 2
|
||||||
|
{7:▾▸}{5:^+--- 5 lines: aa··························}|
|
||||||
|
{7:│ }ff |
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
## grid 3
|
||||||
|
:set norightleft |
|
||||||
|
]])
|
||||||
|
else
|
||||||
meths.input_mouse('left', 'press', '', 0, 0, 1)
|
meths.input_mouse('left', 'press', '', 0, 0, 1)
|
||||||
screen:expect{grid=[[
|
screen:expect([[
|
||||||
{7:▾▸}{5:^+--- 5 lines: aa··························}|
|
{7:▾▸}{5:^+--- 5 lines: aa··························}|
|
||||||
{7:│ }ff |
|
{7:│ }ff |
|
||||||
{1:~ }|
|
{1:~ }|
|
||||||
@@ -112,7 +237,8 @@ describe("folded lines", function()
|
|||||||
{1:~ }|
|
{1:~ }|
|
||||||
{1:~ }|
|
{1:~ }|
|
||||||
:set norightleft |
|
:set norightleft |
|
||||||
]]}
|
]])
|
||||||
|
end
|
||||||
end)
|
end)
|
||||||
|
|
||||||
it("works with multibyte text", function()
|
it("works with multibyte text", function()
|
||||||
@@ -122,6 +248,29 @@ describe("folded lines", function()
|
|||||||
insert([[
|
insert([[
|
||||||
å 语 x̨̣̘̫̲͚͎̎͂̀̂͛͛̾͢͟ العَرَبِيَّة
|
å 语 x̨̣̘̫̲͚͎̎͂̀̂͛͛̾͢͟ العَرَبِيَّة
|
||||||
möre text]])
|
möre text]])
|
||||||
|
if multigrid then
|
||||||
|
screen:expect([[
|
||||||
|
## grid 1
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[3:---------------------------------------------]|
|
||||||
|
## grid 2
|
||||||
|
å 语 x̎͂̀̂͛͛ ﺎﻠﻋَﺮَﺒِﻳَّﺓ |
|
||||||
|
möre tex^t |
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
## grid 3
|
||||||
|
|
|
||||||
|
]])
|
||||||
|
else
|
||||||
screen:expect([[
|
screen:expect([[
|
||||||
å 语 x̎͂̀̂͛͛ ﺎﻠﻋَﺮَﺒِﻳَّﺓ |
|
å 语 x̎͂̀̂͛͛ ﺎﻠﻋَﺮَﺒِﻳَّﺓ |
|
||||||
möre tex^t |
|
möre tex^t |
|
||||||
@@ -132,9 +281,33 @@ describe("folded lines", function()
|
|||||||
{1:~ }|
|
{1:~ }|
|
||||||
|
|
|
|
||||||
]])
|
]])
|
||||||
|
end
|
||||||
|
|
||||||
feed('vkzf')
|
feed('vkzf')
|
||||||
screen:expect{grid=[[
|
if multigrid then
|
||||||
|
screen:expect([[
|
||||||
|
## grid 1
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[3:---------------------------------------------]|
|
||||||
|
## grid 2
|
||||||
|
{5:^+-- 2 lines: å 语 x̎͂̀̂͛͛ العَرَبِيَّة·················}|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
## grid 3
|
||||||
|
|
|
||||||
|
]])
|
||||||
|
else
|
||||||
|
screen:expect([[
|
||||||
{5:^+-- 2 lines: å 语 x̎͂̀̂͛͛ العَرَبِيَّة·················}|
|
{5:^+-- 2 lines: å 语 x̎͂̀̂͛͛ العَرَبِيَّة·················}|
|
||||||
{1:~ }|
|
{1:~ }|
|
||||||
{1:~ }|
|
{1:~ }|
|
||||||
@@ -143,9 +316,33 @@ describe("folded lines", function()
|
|||||||
{1:~ }|
|
{1:~ }|
|
||||||
{1:~ }|
|
{1:~ }|
|
||||||
|
|
|
|
||||||
]]}
|
]])
|
||||||
|
end
|
||||||
|
|
||||||
feed_command("set noarabicshape")
|
feed_command("set noarabicshape")
|
||||||
|
if multigrid then
|
||||||
|
screen:expect([[
|
||||||
|
## grid 1
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[3:---------------------------------------------]|
|
||||||
|
## grid 2
|
||||||
|
{5:^+-- 2 lines: å 语 x̎͂̀̂͛͛ العَرَبِيَّة·················}|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
## grid 3
|
||||||
|
:set noarabicshape |
|
||||||
|
]])
|
||||||
|
else
|
||||||
screen:expect([[
|
screen:expect([[
|
||||||
{5:^+-- 2 lines: å 语 x̎͂̀̂͛͛ العَرَبِيَّة·················}|
|
{5:^+-- 2 lines: å 语 x̎͂̀̂͛͛ العَرَبِيَّة·················}|
|
||||||
{1:~ }|
|
{1:~ }|
|
||||||
@@ -156,8 +353,32 @@ describe("folded lines", function()
|
|||||||
{1:~ }|
|
{1:~ }|
|
||||||
:set noarabicshape |
|
:set noarabicshape |
|
||||||
]])
|
]])
|
||||||
|
end
|
||||||
|
|
||||||
feed_command("set number foldcolumn=2")
|
feed_command("set number foldcolumn=2")
|
||||||
|
if multigrid then
|
||||||
|
screen:expect([[
|
||||||
|
## grid 1
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[3:---------------------------------------------]|
|
||||||
|
## grid 2
|
||||||
|
{7:+ }{8: 1 }{5:^+-- 2 lines: å 语 x̎͂̀̂͛͛ العَرَبِيَّة···········}|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
## grid 3
|
||||||
|
:set number foldcolumn=2 |
|
||||||
|
]])
|
||||||
|
else
|
||||||
screen:expect([[
|
screen:expect([[
|
||||||
{7:+ }{8: 1 }{5:^+-- 2 lines: å 语 x̎͂̀̂͛͛ العَرَبِيَّة···········}|
|
{7:+ }{8: 1 }{5:^+-- 2 lines: å 语 x̎͂̀̂͛͛ العَرَبِيَّة···········}|
|
||||||
{1:~ }|
|
{1:~ }|
|
||||||
@@ -168,9 +389,33 @@ describe("folded lines", function()
|
|||||||
{1:~ }|
|
{1:~ }|
|
||||||
:set number foldcolumn=2 |
|
:set number foldcolumn=2 |
|
||||||
]])
|
]])
|
||||||
|
end
|
||||||
|
|
||||||
-- Note: too much of the folded line gets cut off.This is a vim bug.
|
-- Note: too much of the folded line gets cut off.This is a vim bug.
|
||||||
feed_command("set rightleft")
|
feed_command("set rightleft")
|
||||||
|
if multigrid then
|
||||||
|
screen:expect([[
|
||||||
|
## grid 1
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[3:---------------------------------------------]|
|
||||||
|
## grid 2
|
||||||
|
{5:···········ةيَّبِرَعَلا x̎͂̀̂͛͛ 语 å :senil 2 --^+}{8: 1 }{7: +}|
|
||||||
|
{1: ~}|
|
||||||
|
{1: ~}|
|
||||||
|
{1: ~}|
|
||||||
|
{1: ~}|
|
||||||
|
{1: ~}|
|
||||||
|
{1: ~}|
|
||||||
|
## grid 3
|
||||||
|
:set rightleft |
|
||||||
|
]])
|
||||||
|
else
|
||||||
screen:expect([[
|
screen:expect([[
|
||||||
{5:···········ةيَّبِرَعَلا x̎͂̀̂͛͛ 语 å :senil 2 --^+}{8: 1 }{7: +}|
|
{5:···········ةيَّبِرَعَلا x̎͂̀̂͛͛ 语 å :senil 2 --^+}{8: 1 }{7: +}|
|
||||||
{1: ~}|
|
{1: ~}|
|
||||||
@@ -181,8 +426,32 @@ describe("folded lines", function()
|
|||||||
{1: ~}|
|
{1: ~}|
|
||||||
:set rightleft |
|
:set rightleft |
|
||||||
]])
|
]])
|
||||||
|
end
|
||||||
|
|
||||||
feed_command("set nonumber foldcolumn=0")
|
feed_command("set nonumber foldcolumn=0")
|
||||||
|
if multigrid then
|
||||||
|
screen:expect([[
|
||||||
|
## grid 1
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[3:---------------------------------------------]|
|
||||||
|
## grid 2
|
||||||
|
{5:·················ةيَّبِرَعَلا x̎͂̀̂͛͛ 语 å :senil 2 --^+}|
|
||||||
|
{1: ~}|
|
||||||
|
{1: ~}|
|
||||||
|
{1: ~}|
|
||||||
|
{1: ~}|
|
||||||
|
{1: ~}|
|
||||||
|
{1: ~}|
|
||||||
|
## grid 3
|
||||||
|
:set nonumber foldcolumn=0 |
|
||||||
|
]])
|
||||||
|
else
|
||||||
screen:expect([[
|
screen:expect([[
|
||||||
{5:·················ةيَّبِرَعَلا x̎͂̀̂͛͛ 语 å :senil 2 --^+}|
|
{5:·················ةيَّبِرَعَلا x̎͂̀̂͛͛ 语 å :senil 2 --^+}|
|
||||||
{1: ~}|
|
{1: ~}|
|
||||||
@@ -193,8 +462,32 @@ describe("folded lines", function()
|
|||||||
{1: ~}|
|
{1: ~}|
|
||||||
:set nonumber foldcolumn=0 |
|
:set nonumber foldcolumn=0 |
|
||||||
]])
|
]])
|
||||||
|
end
|
||||||
|
|
||||||
feed_command("set arabicshape")
|
feed_command("set arabicshape")
|
||||||
|
if multigrid then
|
||||||
|
screen:expect([[
|
||||||
|
## grid 1
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[3:---------------------------------------------]|
|
||||||
|
## grid 2
|
||||||
|
{5:·················ةيَّبِرَعَلا x̎͂̀̂͛͛ 语 å :senil 2 --^+}|
|
||||||
|
{1: ~}|
|
||||||
|
{1: ~}|
|
||||||
|
{1: ~}|
|
||||||
|
{1: ~}|
|
||||||
|
{1: ~}|
|
||||||
|
{1: ~}|
|
||||||
|
## grid 3
|
||||||
|
:set arabicshape |
|
||||||
|
]])
|
||||||
|
else
|
||||||
screen:expect([[
|
screen:expect([[
|
||||||
{5:·················ةيَّبِرَعَلا x̎͂̀̂͛͛ 语 å :senil 2 --^+}|
|
{5:·················ةيَّبِرَعَلا x̎͂̀̂͛͛ 语 å :senil 2 --^+}|
|
||||||
{1: ~}|
|
{1: ~}|
|
||||||
@@ -205,8 +498,32 @@ describe("folded lines", function()
|
|||||||
{1: ~}|
|
{1: ~}|
|
||||||
:set arabicshape |
|
:set arabicshape |
|
||||||
]])
|
]])
|
||||||
|
end
|
||||||
|
|
||||||
feed('zo')
|
feed('zo')
|
||||||
|
if multigrid then
|
||||||
|
screen:expect([[
|
||||||
|
## grid 1
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[3:---------------------------------------------]|
|
||||||
|
## grid 2
|
||||||
|
ﺔﻴَّﺑِﺮَﻌَ^ﻟﺍ x̎͂̀̂͛͛ 语 å|
|
||||||
|
txet eröm|
|
||||||
|
{1: ~}|
|
||||||
|
{1: ~}|
|
||||||
|
{1: ~}|
|
||||||
|
{1: ~}|
|
||||||
|
{1: ~}|
|
||||||
|
## grid 3
|
||||||
|
:set arabicshape |
|
||||||
|
]])
|
||||||
|
else
|
||||||
screen:expect([[
|
screen:expect([[
|
||||||
ﺔﻴَّﺑِﺮَﻌَ^ﻟﺍ x̎͂̀̂͛͛ 语 å|
|
ﺔﻴَّﺑِﺮَﻌَ^ﻟﺍ x̎͂̀̂͛͛ 语 å|
|
||||||
txet eröm|
|
txet eröm|
|
||||||
@@ -217,8 +534,32 @@ describe("folded lines", function()
|
|||||||
{1: ~}|
|
{1: ~}|
|
||||||
:set arabicshape |
|
:set arabicshape |
|
||||||
]])
|
]])
|
||||||
|
end
|
||||||
|
|
||||||
feed_command('set noarabicshape')
|
feed_command('set noarabicshape')
|
||||||
|
if multigrid then
|
||||||
|
screen:expect([[
|
||||||
|
## grid 1
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[3:---------------------------------------------]|
|
||||||
|
## grid 2
|
||||||
|
ةيَّبِرَعَ^لا x̎͂̀̂͛͛ 语 å|
|
||||||
|
txet eröm|
|
||||||
|
{1: ~}|
|
||||||
|
{1: ~}|
|
||||||
|
{1: ~}|
|
||||||
|
{1: ~}|
|
||||||
|
{1: ~}|
|
||||||
|
## grid 3
|
||||||
|
:set noarabicshape |
|
||||||
|
]])
|
||||||
|
else
|
||||||
screen:expect([[
|
screen:expect([[
|
||||||
ةيَّبِرَعَ^لا x̎͂̀̂͛͛ 语 å|
|
ةيَّبِرَعَ^لا x̎͂̀̂͛͛ 语 å|
|
||||||
txet eröm|
|
txet eröm|
|
||||||
@@ -229,6 +570,7 @@ describe("folded lines", function()
|
|||||||
{1: ~}|
|
{1: ~}|
|
||||||
:set noarabicshape |
|
:set noarabicshape |
|
||||||
]])
|
]])
|
||||||
|
end
|
||||||
|
|
||||||
end)
|
end)
|
||||||
|
|
||||||
@@ -239,6 +581,28 @@ describe("folded lines", function()
|
|||||||
feed_command("/omega")
|
feed_command("/omega")
|
||||||
|
|
||||||
feed("<cr>q:")
|
feed("<cr>q:")
|
||||||
|
if multigrid then
|
||||||
|
screen:expect([[
|
||||||
|
## grid 1
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
{2:[No Name] }|
|
||||||
|
[4:---------------------------------------------]|
|
||||||
|
[4:---------------------------------------------]|
|
||||||
|
[4:---------------------------------------------]|
|
||||||
|
[4:---------------------------------------------]|
|
||||||
|
{3:[Command Line] }|
|
||||||
|
[3:---------------------------------------------]|
|
||||||
|
## grid 2
|
||||||
|
|
|
||||||
|
## grid 3
|
||||||
|
: |
|
||||||
|
## grid 4
|
||||||
|
{1::}set foldmethod=manual |
|
||||||
|
{1::}let x = 1 |
|
||||||
|
{1::}^ |
|
||||||
|
{1:~ }|
|
||||||
|
]])
|
||||||
|
else
|
||||||
screen:expect([[
|
screen:expect([[
|
||||||
|
|
|
|
||||||
{2:[No Name] }|
|
{2:[No Name] }|
|
||||||
@@ -249,8 +613,31 @@ describe("folded lines", function()
|
|||||||
{3:[Command Line] }|
|
{3:[Command Line] }|
|
||||||
: |
|
: |
|
||||||
]])
|
]])
|
||||||
|
end
|
||||||
|
|
||||||
feed("kzfk")
|
feed("kzfk")
|
||||||
|
if multigrid then
|
||||||
|
screen:expect([[
|
||||||
|
## grid 1
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
{2:[No Name] }|
|
||||||
|
[4:---------------------------------------------]|
|
||||||
|
[4:---------------------------------------------]|
|
||||||
|
[4:---------------------------------------------]|
|
||||||
|
[4:---------------------------------------------]|
|
||||||
|
{3:[Command Line] }|
|
||||||
|
[3:---------------------------------------------]|
|
||||||
|
## grid 2
|
||||||
|
|
|
||||||
|
## grid 3
|
||||||
|
: |
|
||||||
|
## grid 4
|
||||||
|
{1::}{5:^+-- 2 lines: set foldmethod=manual·········}|
|
||||||
|
{1::} |
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
]])
|
||||||
|
else
|
||||||
screen:expect([[
|
screen:expect([[
|
||||||
|
|
|
|
||||||
{2:[No Name] }|
|
{2:[No Name] }|
|
||||||
@@ -261,8 +648,32 @@ describe("folded lines", function()
|
|||||||
{3:[Command Line] }|
|
{3:[Command Line] }|
|
||||||
: |
|
: |
|
||||||
]])
|
]])
|
||||||
|
end
|
||||||
|
|
||||||
feed("<cr>")
|
feed("<cr>")
|
||||||
|
if multigrid then
|
||||||
|
screen:expect([[
|
||||||
|
## grid 1
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[3:---------------------------------------------]|
|
||||||
|
## grid 2
|
||||||
|
^ |
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
## grid 3
|
||||||
|
: |
|
||||||
|
]])
|
||||||
|
else
|
||||||
screen:expect([[
|
screen:expect([[
|
||||||
^ |
|
^ |
|
||||||
{1:~ }|
|
{1:~ }|
|
||||||
@@ -273,8 +684,31 @@ describe("folded lines", function()
|
|||||||
{1:~ }|
|
{1:~ }|
|
||||||
: |
|
: |
|
||||||
]])
|
]])
|
||||||
|
end
|
||||||
|
|
||||||
feed("/<c-f>")
|
feed("/<c-f>")
|
||||||
|
if multigrid then
|
||||||
|
screen:expect([[
|
||||||
|
## grid 1
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
{2:[No Name] }|
|
||||||
|
[5:---------------------------------------------]|
|
||||||
|
[5:---------------------------------------------]|
|
||||||
|
[5:---------------------------------------------]|
|
||||||
|
[5:---------------------------------------------]|
|
||||||
|
{3:[Command Line] }|
|
||||||
|
[3:---------------------------------------------]|
|
||||||
|
## grid 2
|
||||||
|
|
|
||||||
|
## grid 3
|
||||||
|
/ |
|
||||||
|
## grid 5
|
||||||
|
{1:/}alpha |
|
||||||
|
{1:/}{6:omega} |
|
||||||
|
{1:/}^ |
|
||||||
|
{1:~ }|
|
||||||
|
]])
|
||||||
|
else
|
||||||
screen:expect([[
|
screen:expect([[
|
||||||
|
|
|
|
||||||
{2:[No Name] }|
|
{2:[No Name] }|
|
||||||
@@ -285,8 +719,31 @@ describe("folded lines", function()
|
|||||||
{3:[Command Line] }|
|
{3:[Command Line] }|
|
||||||
/ |
|
/ |
|
||||||
]])
|
]])
|
||||||
|
end
|
||||||
|
|
||||||
feed("ggzfG")
|
feed("ggzfG")
|
||||||
|
if multigrid then
|
||||||
|
screen:expect([[
|
||||||
|
## grid 1
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
{2:[No Name] }|
|
||||||
|
[5:---------------------------------------------]|
|
||||||
|
[5:---------------------------------------------]|
|
||||||
|
[5:---------------------------------------------]|
|
||||||
|
[5:---------------------------------------------]|
|
||||||
|
{3:[Command Line] }|
|
||||||
|
[3:---------------------------------------------]|
|
||||||
|
## grid 2
|
||||||
|
|
|
||||||
|
## grid 3
|
||||||
|
/ |
|
||||||
|
## grid 5
|
||||||
|
{1:/}{5:^+-- 3 lines: alpha·························}|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
]])
|
||||||
|
else
|
||||||
screen:expect([[
|
screen:expect([[
|
||||||
|
|
|
|
||||||
{2:[No Name] }|
|
{2:[No Name] }|
|
||||||
@@ -297,6 +754,7 @@ describe("folded lines", function()
|
|||||||
{3:[Command Line] }|
|
{3:[Command Line] }|
|
||||||
/ |
|
/ |
|
||||||
]])
|
]])
|
||||||
|
end
|
||||||
|
|
||||||
end)
|
end)
|
||||||
|
|
||||||
@@ -309,7 +767,30 @@ describe("folded lines", function()
|
|||||||
|
|
||||||
feed("zfj")
|
feed("zfj")
|
||||||
command("set foldcolumn=0")
|
command("set foldcolumn=0")
|
||||||
screen:expect{grid=[[
|
if multigrid then
|
||||||
|
screen:expect([[
|
||||||
|
## grid 1
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[3:---------------------------------------------]|
|
||||||
|
## grid 2
|
||||||
|
{5:^+-- 2 lines: line 1·························}|
|
||||||
|
line 3 |
|
||||||
|
line 4 |
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
## grid 3
|
||||||
|
|
|
||||||
|
]])
|
||||||
|
else
|
||||||
|
screen:expect([[
|
||||||
{5:^+-- 2 lines: line 1·························}|
|
{5:^+-- 2 lines: line 1·························}|
|
||||||
line 3 |
|
line 3 |
|
||||||
line 4 |
|
line 4 |
|
||||||
@@ -318,10 +799,34 @@ describe("folded lines", function()
|
|||||||
{1:~ }|
|
{1:~ }|
|
||||||
{1:~ }|
|
{1:~ }|
|
||||||
|
|
|
|
||||||
]]}
|
]])
|
||||||
|
end
|
||||||
-- should adapt to the current nesting of folds (e.g., 1)
|
-- should adapt to the current nesting of folds (e.g., 1)
|
||||||
command("set foldcolumn=auto:1")
|
command("set foldcolumn=auto:1")
|
||||||
screen:expect{grid=[[
|
if multigrid then
|
||||||
|
screen:expect([[
|
||||||
|
## grid 1
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[3:---------------------------------------------]|
|
||||||
|
## grid 2
|
||||||
|
{7:+}{5:^+-- 2 lines: line 1························}|
|
||||||
|
{7: }line 3 |
|
||||||
|
{7: }line 4 |
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
## grid 3
|
||||||
|
|
|
||||||
|
]])
|
||||||
|
else
|
||||||
|
screen:expect([[
|
||||||
{7:+}{5:^+-- 2 lines: line 1························}|
|
{7:+}{5:^+-- 2 lines: line 1························}|
|
||||||
{7: }line 3 |
|
{7: }line 3 |
|
||||||
{7: }line 4 |
|
{7: }line 4 |
|
||||||
@@ -330,11 +835,35 @@ describe("folded lines", function()
|
|||||||
{1:~ }|
|
{1:~ }|
|
||||||
{1:~ }|
|
{1:~ }|
|
||||||
|
|
|
|
||||||
]]}
|
]])
|
||||||
|
end
|
||||||
-- fdc should not change with a new fold as the maximum is 1
|
-- fdc should not change with a new fold as the maximum is 1
|
||||||
feed("zf3j")
|
feed("zf3j")
|
||||||
|
|
||||||
screen:expect{grid=[[
|
if multigrid then
|
||||||
|
screen:expect([[
|
||||||
|
## grid 1
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[3:---------------------------------------------]|
|
||||||
|
## grid 2
|
||||||
|
{7:+}{5:^+-- 4 lines: line 1························}|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
## grid 3
|
||||||
|
|
|
||||||
|
]])
|
||||||
|
else
|
||||||
|
screen:expect([[
|
||||||
{7:+}{5:^+-- 4 lines: line 1························}|
|
{7:+}{5:^+-- 4 lines: line 1························}|
|
||||||
{1:~ }|
|
{1:~ }|
|
||||||
{1:~ }|
|
{1:~ }|
|
||||||
@@ -343,12 +872,36 @@ describe("folded lines", function()
|
|||||||
{1:~ }|
|
{1:~ }|
|
||||||
{1:~ }|
|
{1:~ }|
|
||||||
|
|
|
|
||||||
]]}
|
]])
|
||||||
|
end
|
||||||
|
|
||||||
-- relax the maximum fdc thus fdc should expand to
|
-- relax the maximum fdc thus fdc should expand to
|
||||||
-- accomodate the current number of folds
|
-- accomodate the current number of folds
|
||||||
command("set foldcolumn=auto:4")
|
command("set foldcolumn=auto:4")
|
||||||
screen:expect{grid=[[
|
if multigrid then
|
||||||
|
screen:expect([[
|
||||||
|
## grid 1
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[3:---------------------------------------------]|
|
||||||
|
## grid 2
|
||||||
|
{7:+ }{5:^+-- 4 lines: line 1·······················}|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
## grid 3
|
||||||
|
|
|
||||||
|
]])
|
||||||
|
else
|
||||||
|
screen:expect([[
|
||||||
{7:+ }{5:^+-- 4 lines: line 1·······················}|
|
{7:+ }{5:^+-- 4 lines: line 1·······················}|
|
||||||
{1:~ }|
|
{1:~ }|
|
||||||
{1:~ }|
|
{1:~ }|
|
||||||
@@ -357,7 +910,8 @@ describe("folded lines", function()
|
|||||||
{1:~ }|
|
{1:~ }|
|
||||||
{1:~ }|
|
{1:~ }|
|
||||||
|
|
|
|
||||||
]]}
|
]])
|
||||||
|
end
|
||||||
end)
|
end)
|
||||||
|
|
||||||
it('does not crash when foldtext is longer than columns #12988', function()
|
it('does not crash when foldtext is longer than columns #12988', function()
|
||||||
@@ -369,7 +923,30 @@ describe("folded lines", function()
|
|||||||
command('set foldtext=MyFoldText()')
|
command('set foldtext=MyFoldText()')
|
||||||
feed("i<cr><esc>")
|
feed("i<cr><esc>")
|
||||||
feed("vkzf")
|
feed("vkzf")
|
||||||
screen:expect{grid=[[
|
if multigrid then
|
||||||
|
screen:expect([[
|
||||||
|
## grid 1
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[2:---------------------------------------------]|
|
||||||
|
[3:---------------------------------------------]|
|
||||||
|
## grid 2
|
||||||
|
{5:^---------------------------------------------}|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
{1:~ }|
|
||||||
|
## grid 3
|
||||||
|
|
|
||||||
|
]])
|
||||||
|
else
|
||||||
|
screen:expect([[
|
||||||
{5:^---------------------------------------------}|
|
{5:^---------------------------------------------}|
|
||||||
{1:~ }|
|
{1:~ }|
|
||||||
{1:~ }|
|
{1:~ }|
|
||||||
@@ -378,7 +955,17 @@ describe("folded lines", function()
|
|||||||
{1:~ }|
|
{1:~ }|
|
||||||
{1:~ }|
|
{1:~ }|
|
||||||
|
|
|
|
||||||
]]}
|
]])
|
||||||
|
end
|
||||||
assert_alive()
|
assert_alive()
|
||||||
end)
|
end)
|
||||||
|
end
|
||||||
|
|
||||||
|
describe("with ext_multigrid", function()
|
||||||
|
with_ext_multigrid(true)
|
||||||
|
end)
|
||||||
|
|
||||||
|
describe('without ext_multigrid', function()
|
||||||
|
with_ext_multigrid(false)
|
||||||
|
end)
|
||||||
end)
|
end)
|
||||||
|
Reference in New Issue
Block a user