diff options
author | Bram Moolenaar <Bram@vim.org> | 2019-03-30 19:12:02 +0100 |
---|---|---|
committer | Bram Moolenaar <Bram@vim.org> | 2019-03-30 19:12:02 +0100 |
commit | 7559dcef6cfd0ba13271088fff51b8979fee950b (patch) | |
tree | c9ff3c5edf111e39156179015d0c8c028f5c0cd1 | |
parent | abab0b0fdd6535969447b03a4fffc1947918cf6c (diff) | |
download | vim-git-7559dcef6cfd0ba13271088fff51b8979fee950b.tar.gz |
patch 8.1.1087: tag stack is incorrect after CTRL-T and then :tagv8.1.1087
Problem: tag stack is incorrect after CTRL-T and then :tag
Solution: Handle DT_TAG differently. (test by Andy Massimino, closes #3944,
closes #4177)
-rw-r--r-- | src/tag.c | 9 | ||||
-rw-r--r-- | src/testdir/test_tagjump.vim | 73 | ||||
-rw-r--r-- | src/version.c | 2 |
3 files changed, 81 insertions, 3 deletions
@@ -504,13 +504,16 @@ do_tag( tagmatchname = vim_strsave(name); } - if (type == DT_TAG || type == DT_SELECT || type == DT_JUMP + if (type == DT_SELECT || type == DT_JUMP #if defined(FEAT_QUICKFIX) || type == DT_LTAG #endif ) cur_match = MAXCOL - 1; - max_num_matches = cur_match + 1; + if (type == DT_TAG) + max_num_matches = MAXCOL; + else + max_num_matches = cur_match + 1; /* when the argument starts with '/', use it as a regexp */ if (!no_regexp && *name == '/') @@ -583,7 +586,7 @@ do_tag( } else #endif - if (type == DT_TAG) + if (type == DT_TAG && *tag != NUL) /* * If a count is supplied to the ":tag <name>" command, then * jump to count'th matching tag. diff --git a/src/testdir/test_tagjump.vim b/src/testdir/test_tagjump.vim index ae47a69c3..4ce9ece87 100644 --- a/src/testdir/test_tagjump.vim +++ b/src/testdir/test_tagjump.vim @@ -366,4 +366,77 @@ func Test_getsettagstack() set tags& endfunc +func Test_tag_with_count() + call writefile([ + \ 'test Xtest.h /^void test();$/;" p typeref:typename:void signature:()', + \ ], 'Xtags') + call writefile([ + \ 'main Xtest.c /^int main()$/;" f typeref:typename:int signature:()', + \ 'test Xtest.c /^void test()$/;" f typeref:typename:void signature:()', + \ ], 'Ytags') + cal writefile([ + \ 'int main()', + \ 'void test()', + \ ], 'Xtest.c') + cal writefile([ + \ 'void test();', + \ ], 'Xtest.h') + set tags=Xtags,Ytags + + new Xtest.c + let tl = taglist('test', 'Xtest.c') + call assert_equal(tl[0].filename, 'Xtest.c') + call assert_equal(tl[1].filename, 'Xtest.h') + + tag test + call assert_equal(bufname('%'), 'Xtest.c') + 1tag test + call assert_equal(bufname('%'), 'Xtest.c') + 2tag test + call assert_equal(bufname('%'), 'Xtest.h') + + set tags& + call delete('Xtags') + call delete('Ytags') + bwipe Xtest.h + bwipe Xtest.c + call delete('Xtest.h') + call delete('Xtest.c') +endfunc + +func Test_tagnr_recall() + call writefile([ + \ 'test Xtest.h /^void test();$/;" p', + \ 'main Xtest.c /^int main()$/;" f', + \ 'test Xtest.c /^void test()$/;" f', + \ ], 'Xtags') + cal writefile([ + \ 'int main()', + \ 'void test()', + \ ], 'Xtest.c') + cal writefile([ + \ 'void test();', + \ ], 'Xtest.h') + set tags=Xtags + + new Xtest.c + let tl = taglist('test', 'Xtest.c') + call assert_equal(tl[0].filename, 'Xtest.c') + call assert_equal(tl[1].filename, 'Xtest.h') + + 2tag test + call assert_equal(bufname('%'), 'Xtest.h') + pop + call assert_equal(bufname('%'), 'Xtest.c') + tag + call assert_equal(bufname('%'), 'Xtest.h') + + set tag& + call delete('Xtags') + bwipe Xtest.h + bwipe Xtest.c + call delete('Xtest.h') + call delete('Xtest.c') +endfunc + " vim: shiftwidth=2 sts=2 expandtab diff --git a/src/version.c b/src/version.c index 063dea0a5..6d1df32f7 100644 --- a/src/version.c +++ b/src/version.c @@ -776,6 +776,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ /**/ + 1087, +/**/ 1086, /**/ 1085, |