" Tests for put commands, e.g. ":put", "p", "gp", "P", "gP", etc. source check.vim source screendump.vim func Test_put_block() new call feedkeys("i\u2500\x\", 'x') call feedkeys("\y", 'x') call feedkeys("gg0p", 'x') call assert_equal("\u2500x", getline(1)) bwipe! endfunc func Test_put_char_block() new call setline(1, ['Line 1', 'Line 2']) f Xfile_put " visually select both lines and put the cursor at the top of the visual " selection and then put the buffer name over it exe "norm! G0\ke\"%p" call assert_equal(['Xfile_put 1', 'Xfile_put 2'], getline(1,2)) bw! endfunc func Test_put_char_block2() new call setreg('a', ' one ', 'v') call setline(1, ['Line 1', '', 'Line 3', '']) " visually select the first 3 lines and put register a over it exe "norm! ggl\2j2l\"ap" call assert_equal(['L one 1', '', 'L one 3', ''], getline(1, 4)) " clean up bw! endfunc func Test_put_lines() new let a = [ getreg('a'), getregtype('a') ] call setline(1, ['Line 1', 'Line2', 'Line 3', '']) exe 'norm! gg"add"AddG""p' call assert_equal(['Line 3', '', 'Line 1', 'Line2'], getline(1, '$')) " clean up bw! eval a[0]->setreg('a', a[1]) endfunc func Test_put_expr() new call setline(1, repeat(['A'], 6)) exec "1norm! \"=line('.')\p" norm! j0. norm! j0. exec "4norm! \"=\P" norm! j0. norm! j0. call assert_equal(['A1','A2','A3','4A','5A','6A'], getline(1, '$')) bw! endfunc func Test_put_fails_when_nomodifiable() new setlocal nomodifiable normal! yy call assert_fails(':put', 'E21') call assert_fails(':put!', 'E21') call assert_fails(':normal! p', 'E21') call assert_fails(':normal! gp', 'E21') call assert_fails(':normal! P', 'E21') call assert_fails(':normal! gP', 'E21') if has('mouse') set mouse=n call assert_fails('execute "normal! \"', 'E21') set mouse& endif bwipeout! endfunc " A bug was discovered where the Normal mode put commands (e.g., "p") would " output duplicate error messages when invoked in a non-modifiable buffer. func Test_put_p_errmsg_nodup() new setlocal nomodifiable normal! yy func Capture_p_error() redir => s:p_err normal! p redir END endfunc silent! call Capture_p_error() " Error message output within a function should be three lines (the function " name, the line number, and the error message). call assert_equal(3, count(s:p_err, "\n")) delfunction Capture_p_error bwipeout! endfunc func Test_put_p_indent_visual() new call setline(1, ['select this text', 'select that text']) " yank "that" from the second line normal 2Gwvey " select "this" in the first line and put normal k0wve[p call assert_equal('select that text', getline(1)) call assert_equal('select that text', getline(2)) bwipe! endfunc " Test for deleting all the contents of a buffer with a put func Test_put_visual_delete_all_lines() new call setline(1, ['one', 'two', 'three']) let @r = '' normal! VG"rgp call assert_equal(1, line('$')) close! endfunc func Test_gp_with_count_leaves_cursor_at_end() new call setline(1, '<---->') call setreg('@', "foo\nbar", 'c') normal 1G3|3gp call assert_equal([0, 4, 4, 0], getpos(".")) call assert_equal(['<--foo', 'barfoo', 'barfoo', 'bar-->'], getline(1, '$')) call assert_equal([0, 4, 3, 0], getpos("']")) bwipe! endfunc func Test_p_with_count_leaves_mark_at_end() new call setline(1, '<---->') call setreg('@', "start\nend", 'c') normal 1G3|3p call assert_equal([0, 1, 4, 0], getpos(".")) call assert_equal(['<--start', 'endstart', 'endstart', 'end-->'], getline(1, '$')) call assert_equal([0, 4, 3, 0], getpos("']")) bwipe! endfunc func Test_very_large_count() new " total put-length (21474837 * 100) brings 32 bit int overflow let @" = repeat('x', 100) call assert_fails('norm 21474837p', 'E1240:') bwipe! endfunc func Test_very_large_count_64bit() throw 'Skipped: v:sizeoflong is N/A' " use legacy/put_spec.lua instead if v:sizeoflong < 8 throw 'Skipped: only works with 64 bit long ints' endif new let @" = repeat('x', 100) call assert_fails('norm 999999999p', 'E1240:') bwipe! endfunc func Test_very_large_count_block() new " total put-length (21474837 * 100) brings 32 bit int overflow call setline(1, repeat('x', 100)) exe "norm \99ly" call assert_fails('norm 21474837p', 'E1240:') bwipe! endfunc func Test_very_large_count_block_64bit() throw 'Skipped: v:sizeoflong is N/A' " use legacy/put_spec.lua instead if v:sizeoflong < 8 throw 'Skipped: only works with 64 bit long ints' endif new call setline(1, repeat('x', 100)) exe "norm \$y" call assert_fails('norm 999999999p', 'E1240:') bwipe! endfunc func Test_put_above_first_line() new let @" = 'text' silent! normal 0o00 0put call assert_equal('text', getline(1)) bwipe! endfunc func Test_multibyte_op_end_mark() new call setline(1, 'ั‚ะตัั‚') normal viwdp call assert_equal([0, 1, 7, 0], getpos("'>")) call assert_equal([0, 1, 7, 0], getpos("']")) normal Vyp call assert_equal([0, 1, v:maxcol, 0], getpos("'>")) call assert_equal([0, 2, 7, 0], getpos("']")) bwipe! endfunc " this was putting a mark before the start of a line func Test_put_empty_register() new norm yy norm [Pi00ggv)s0 sil! norm [P bwipe! endfunc " this was putting the end mark after the end of the line func Test_put_visual_mode() edit! SomeNewBuffer set selection=exclusive exe "norm o\t" m0 sil! norm  p p bwipe! set selection& endfunc func Test_put_visual_block_mode() enew exe "norm 0R\\V" sil exe "norm \c \" set ve=all sil norm vz=p bwipe! set ve= endfunc func Test_put_other_window() CheckRunVimInTerminal let lines =<< trim END 40vsplit 0put ='some text at the top' put =' one more text' put =' two more text' put =' three more text' put =' four more text' END call writefile(lines, 'Xtest_put_other', 'D') let buf = RunVimInTerminal('-S Xtest_put_other', #{rows: 10}) call VerifyScreenDump(buf, 'Test_put_other_window_1', {}) call StopVimInTerminal(buf) endfunc " vim: shiftwidth=2 sts=2 expandtab