Mercurial > vim
view src/testdir/test_goto.vim @ 17922:4d63d47d87ef v8.1.1957
patch 8.1.1957: more code can be moved to evalvars.c
Commit: https://github.com/vim/vim/commit/da6c03342117fb7f4a8110bd9e8627b612a05a64
Author: Bram Moolenaar <Bram@vim.org>
Date: Sun Sep 1 16:01:30 2019 +0200
patch 8.1.1957: more code can be moved to evalvars.c
Problem: More code can be moved to evalvars.c.
Solution: Move code to where it fits better. (Yegappan Lakshmanan,
closes #4883)
author | Bram Moolenaar <Bram@vim.org> |
---|---|
date | Sun, 01 Sep 2019 16:15:03 +0200 |
parents | 6990c1160ea5 |
children | a4bd28e2cf1d |
line wrap: on
line source
" Test commands that jump somewhere. " Create a new buffer using "lines" and place the cursor on the word after the " first occurrence of return and invoke "cmd". The cursor should now be " positioned at the given line and col. func XTest_goto_decl(cmd, lines, line, col) new call setline(1, a:lines) /return/ normal! W execute 'norm! ' . a:cmd call assert_equal(a:line, line('.')) call assert_equal(a:col, col('.')) quit! endfunc func Test_gD() let lines =<< trim [CODE] int x; int func(void) { return x; } [CODE] call XTest_goto_decl('gD', lines, 1, 5) endfunc func Test_gD_too() let lines =<< trim [CODE] Filename x; int Filename int func() { Filename x; return x; [CODE] call XTest_goto_decl('gD', lines, 1, 10) endfunc func Test_gD_comment() let lines =<< trim [CODE] /* int x; */ int x; int func(void) { return x; } [CODE] call XTest_goto_decl('gD', lines, 2, 5) endfunc func Test_gD_inline_comment() let lines =<< trim [CODE] int y /* , x */; int x; int func(void) { return x; } [CODE] call XTest_goto_decl('gD', lines, 2, 5) endfunc func Test_gD_string() let lines =<< trim [CODE] char *s[] = "x"; int x = 1; int func(void) { return x; } [CODE] call XTest_goto_decl('gD', lines, 2, 5) endfunc func Test_gD_string_same_line() let lines =<< trim [CODE] char *s[] = "x", int x = 1; int func(void) { return x; } [CODE] call XTest_goto_decl('gD', lines, 1, 22) endfunc func Test_gD_char() let lines =<< trim [CODE] char c = 'x'; int x = 1; int func(void) { return x; } [CODE] call XTest_goto_decl('gD', lines, 2, 5) endfunc func Test_gd() let lines =<< trim [CODE] int x; int func(int x) { return x; } [CODE] call XTest_goto_decl('gd', lines, 3, 14) endfunc func Test_gd_not_local() let lines =<< trim [CODE] int func1(void) { return x; } int func2(int x) { return x; } [CODE] call XTest_goto_decl('gd', lines, 3, 10) endfunc func Test_gd_kr_style() let lines =<< trim [CODE] int func(x) int x; { return x; } [CODE] call XTest_goto_decl('gd', lines, 2, 7) endfunc func Test_gd_missing_braces() let lines =<< trim [CODE] def func1(a) a + 1 end a = 1 def func2() return a end [CODE] call XTest_goto_decl('gd', lines, 1, 11) endfunc func Test_gd_comment() let lines =<< trim [CODE] int func(void) { /* int x; */ int x; return x; } [CODE] call XTest_goto_decl('gd', lines, 4, 7) endfunc func Test_gd_comment_in_string() let lines =<< trim [CODE] int func(void) { char *s ="//"; int x; int x; return x; } [CODE] call XTest_goto_decl('gd', lines, 3, 22) endfunc func Test_gd_string_in_comment() set comments= let lines =<< trim [CODE] int func(void) { /* " */ int x; int x; return x; } [CODE] call XTest_goto_decl('gd', lines, 3, 15) set comments& endfunc func Test_gd_inline_comment() let lines =<< trim [CODE] int func(/* x is an int */ int x) { return x; } [CODE] call XTest_goto_decl('gd', lines, 1, 32) endfunc func Test_gd_inline_comment_only() let lines =<< trim [CODE] int func(void) /* one lonely x */ { return x; } [CODE] call XTest_goto_decl('gd', lines, 3, 10) endfunc func Test_gd_inline_comment_body() let lines =<< trim [CODE] int func(void) { int y /* , x */; for (/* int x = 0 */; y < 2; y++); int x = 0; return x; } [CODE] call XTest_goto_decl('gd', lines, 7, 7) endfunc func Test_gd_trailing_multiline_comment() let lines =<< trim [CODE] int func(int x) /* x is an int */ { return x; } [CODE] call XTest_goto_decl('gd', lines, 1, 14) endfunc func Test_gd_trailing_comment() let lines =<< trim [CODE] int func(int x) // x is an int { return x; } [CODE] call XTest_goto_decl('gd', lines, 1, 14) endfunc func Test_gd_string() let lines =<< trim [CODE] int func(void) { char *s = "x"; int x = 1; return x; } [CODE] call XTest_goto_decl('gd', lines, 4, 7) endfunc func Test_gd_string_only() let lines =<< trim [CODE] int func(void) { char *s = "x"; return x; } [CODE] call XTest_goto_decl('gd', lines, 5, 10) endfunc " Check that setting 'cursorline' does not change curswant func Test_cursorline_keep_col() new call setline(1, ['long long long line', 'short line']) normal ggfi let pos = getcurpos() normal j set cursorline normal k call assert_equal(pos, getcurpos()) bwipe! set nocursorline endfunc func Test_gd_local_block() let lines =<< trim [CODE] int main() { char *a = "NOT NULL"; if(a) { char *b = a; printf("%s\n", b); } else { char *b = "NULL"; return b; } return 0; } [CODE] call XTest_goto_decl('1gd', lines, 11, 11) endfunc func Test_motion_if_elif_else_endif() new a /* Test pressing % on #if, #else #elsif and #endif, * with nested #if */ #if FOO /* ... */ # if BAR /* ... */ # endif #elif BAR /* ... */ #else /* ... */ #endif . /#if FOO norm % call assert_equal([9, 1], getpos('.')[1:2]) norm % call assert_equal([11, 1], getpos('.')[1:2]) norm % call assert_equal([13, 1], getpos('.')[1:2]) norm % call assert_equal([4, 1], getpos('.')[1:2]) /# if BAR norm $% call assert_equal([8, 1], getpos('.')[1:2]) norm $% call assert_equal([6, 1], getpos('.')[1:2]) bw! endfunc func Test_motion_c_comment() new a /* * Test pressing % on beginning/end * of C comments. */ /* Another comment */ . norm gg0% call assert_equal([4, 3], getpos('.')[1:2]) norm % call assert_equal([1, 1], getpos('.')[1:2]) norm gg0l% call assert_equal([4, 3], getpos('.')[1:2]) norm h% call assert_equal([1, 1], getpos('.')[1:2]) norm G^ norm % call assert_equal([5, 21], getpos('.')[1:2]) norm % call assert_equal([5, 1], getpos('.')[1:2]) bw! endfunc