let s:suite = themis#suite('visual_behaviors') let s:assert = themis#helper('assert') " Helper: function! s:add_line(str) put! =a:str endfunction function! s:add_lines(lines) for line in reverse(a:lines) put! =line endfor endfunction function! s:get_pos_char() return getline('.')[col('.')-1] endfunction function! s:reset_buffer() :1,$ delete call s:add_lines(copy(s:line_texts)) normal! Gddgg0zt endfunction function! s:suite.before() map / (incsearch-forward) map ? (incsearch-backward) map g/ (incsearch-stay) let s:line_texts = [ \ '1pattern 2pattern' \ , '3pattern 4pattern' \ ] call s:reset_buffer() endfunction function! s:suite.before_each() :1 call setreg(v:register, '') endfunction function! s:suite.after() unmap / unmap ? unmap g/ :1,$ delete endfunction function! s:suite.forward() call s:assert.equals(s:get_pos_char(), '1') exec "normal" "v/2pattern\" | normal! y call s:assert.equals(getreg(), "1pattern 2") normal! gg0 exec "normal" "V/2pattern\" | normal! y call s:assert.equals(getreg(), "1pattern 2pattern\n") normal! gg0 exec "normal" "\/4pattern\" | normal! y call s:assert.equals(getreg(), "1pattern 2\n3pattern 4") normal! gg0 exec "normal" "v/2pattern/e\" | normal! y call s:assert.equals(getreg(), "1pattern 2pattern") endfunction function! s:suite.backward() normal! G$ exec "normal" "v?3pattern?e\" | normal! y call s:assert.equals(getreg(), 'n 4pattern') normal! G$ exec "normal" "V?3pattern?e\" | normal! y call s:assert.equals(getreg(), "3pattern 4pattern\n") normal! G$ exec "normal" "\?2pattern\" | normal! y call s:assert.equals(getreg(), "2pattern\n4pattern") endfunction function! s:suite.stay() call s:assert.equals(getreg(), '') call s:assert.equals(s:get_pos_char(), '1') exec "normal" "vg/2pattern\" | normal! y call s:assert.equals(getreg(), '1') normal! gg0 exec "normal" "vg/2pattern\\" | normal! y call s:assert.equals(getreg(), '1pattern 2') normal! gg0 exec "normal" "veg/3pattern\" | normal! y call s:assert.equals(getreg(), '1pattern') normal! gg0 exec "normal" "Vg/2pattern\" | normal! y call s:assert.equals(getreg(), "1pattern 2pattern\n") normal! gg0 exec "normal" "\g/3pattern/e\\" | normal! y call s:assert.equals(getreg(), "1pattern\n3pattern") endfunction