aboutsummaryrefslogtreecommitdiff
path: root/test/functional/legacy/breakindent_spec.lua
diff options
context:
space:
mode:
Diffstat (limited to 'test/functional/legacy/breakindent_spec.lua')
-rw-r--r--test/functional/legacy/breakindent_spec.lua78
1 files changed, 65 insertions, 13 deletions
diff --git a/test/functional/legacy/breakindent_spec.lua b/test/functional/legacy/breakindent_spec.lua
index 3913ba935a..cf0065f394 100644
--- a/test/functional/legacy/breakindent_spec.lua
+++ b/test/functional/legacy/breakindent_spec.lua
@@ -12,9 +12,9 @@ describe('breakindent', function()
it('cursor shown at correct position with showbreak', function()
local screen = Screen.new(75, 6)
screen:set_default_attr_ids({
- [0] = {bold = true, foreground = Screen.colors.Blue}, -- NonText
- [1] = {background = Screen.colors.Grey, foreground = Screen.colors.DarkBlue}, -- SignColumn
- [2] = {bold = true}, -- ModeMsg
+ [0] = { bold = true, foreground = Screen.colors.Blue }, -- NonText
+ [1] = { background = Screen.colors.Grey, foreground = Screen.colors.DarkBlue }, -- SignColumn
+ [2] = { bold = true }, -- ModeMsg
})
screen:attach()
exec([[
@@ -26,13 +26,12 @@ describe('breakindent', function()
eval repeat('x', &columns - leftcol - 1)->setline(1)
eval 'second line'->setline(2)
]])
+
feed('AX')
screen:expect([[
{1: }xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxX|
{1: }^second line |
- {0:~ }|
- {0:~ }|
- {0:~ }|
+ {0:~ }|*3
{2:-- INSERT --} |
]])
-- No line wraps, so changing 'showbreak' should lead to the same screen.
@@ -43,22 +42,75 @@ describe('breakindent', function()
screen:expect_unchanged()
-- The first line now wraps because of "eol" in 'listchars'.
command('setlocal list')
- screen:expect{grid=[[
+ screen:expect([[
{1: }xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxX|
{1: } {0:+^$} |
{1: }second line{0:$} |
- {0:~ }|
- {0:~ }|
+ {0:~ }|*2
{2:-- INSERT --} |
- ]]}
+ ]])
command('setlocal nobreakindent')
- screen:expect{grid=[[
+ screen:expect([[
{1: }xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxX|
{1: }{0:+^$} |
{1: }second line{0:$} |
+ {0:~ }|*2
+ {2:-- INSERT --} |
+ ]])
+ end)
+
+ -- oldtest: Test_visual_starts_before_skipcol()
+ it('Visual selection that starts before skipcol shows correctly', function()
+ local screen = Screen.new(75, 6)
+ exec([[
+ 1new
+ setlocal breakindent
+ call setline(1, "\t" .. join(range(100)))
+ ]])
+ screen:set_default_attr_ids({
+ [0] = { bold = true, foreground = Screen.colors.Blue }, -- NonText
+ [1] = { background = Screen.colors.LightGrey, foreground = Screen.colors.Black }, -- Visual
+ [2] = { bold = true, reverse = true }, -- StatusLine
+ [3] = { reverse = true }, -- StatusLineNC
+ [4] = { bold = true }, -- ModeMsg
+ })
+ screen:attach()
+
+ feed('v$')
+ screen:expect([[
+ {0:<<<} {1: 93 94 95 96 97 98 99}^ |
+ {2:[No Name] [+] }|
+ |
{0:~ }|
+ {3:[No Name] }|
+ {4:-- VISUAL --} |
+ ]])
+ command('setlocal showbreak=+++')
+ screen:expect([[
+ {0:+++}{1: 90 91 92 93 94 95 96 97 98 99}^ |
+ {2:[No Name] [+] }|
+ |
{0:~ }|
- {2:-- INSERT --} |
- ]]}
+ {3:[No Name] }|
+ {4:-- VISUAL --} |
+ ]])
+ command('setlocal breakindentopt+=sbr')
+ screen:expect([[
+ {0:+++} {1: 93 94 95 96 97 98 99}^ |
+ {2:[No Name] [+] }|
+ |
+ {0:~ }|
+ {3:[No Name] }|
+ {4:-- VISUAL --} |
+ ]])
+ command('setlocal nobreakindent')
+ screen:expect([[
+ {0:+++}{1: 98 99}^ |
+ {2:[No Name] [+] }|
+ |
+ {0:~ }|
+ {3:[No Name] }|
+ {4:-- VISUAL --} |
+ ]])
end)
end)