summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2019-04-02 21:26:07 +0200
committerBram Moolenaar <Bram@vim.org>2019-04-02 21:26:07 +0200
commitfd700393becfc35b6fad305221265b87a8564ddb (patch)
tree145f16c8b2de1a0680ed5352fbd2fc5103fc6f62
parentb4a6020ac6a0638167013f1e45ff440ddc8a1671 (diff)
downloadvim-git-fd700393becfc35b6fad305221265b87a8564ddb.tar.gz
patch 8.1.1100: tag file without trailing newline no longer worksv8.1.1100
Problem: Tag file without trailing newline no longer works. (Marco Hinz) Solution: Don't expect a newline at the end of the file. (closes #4200)
-rw-r--r--src/tag.c8
-rw-r--r--src/testdir/test_taglist.vim13
-rw-r--r--src/version.c2
3 files changed, 20 insertions, 3 deletions
diff --git a/src/tag.c b/src/tag.c
index 10039b787..6a85e747a 100644
--- a/src/tag.c
+++ b/src/tag.c
@@ -1943,14 +1943,16 @@ line_read_in:
}
parse_line:
- if (vim_strchr(lbuf, NL) == NULL
+ // When the line is too long the NUL will not be in the
+ // last-but-one byte (see vim_fgets()).
+ // Has been reported for Mozilla JS with extremely long names.
+ // In that case we can't parse it and we ignore the line.
+ if (lbuf[LSIZE - 2] != NUL
#ifdef FEAT_CSCOPE
&& !use_cscope
#endif
)
{
- // Truncated line, ignore it. Has been reported for
- // Mozilla JS with extremely long names.
if (p_verbose >= 5)
{
verbose_enter();
diff --git a/src/testdir/test_taglist.vim b/src/testdir/test_taglist.vim
index de9ca0c80..6506c3f1d 100644
--- a/src/testdir/test_taglist.vim
+++ b/src/testdir/test_taglist.vim
@@ -98,3 +98,16 @@ func Test_tagfiles()
call delete('Xtags2')
bd
endfunc
+
+" For historical reasons we support a tags file where the last line is missing
+" the newline.
+func Test_tagsfile_without_trailing_newline()
+ call writefile(["Foo\tfoo\t1"], 'Xtags', 'b')
+ set tags=Xtags
+
+ let tl = taglist('.*')
+ call assert_equal(1, len(tl))
+ call assert_equal('Foo', tl[0].name)
+
+ call delete('Xtags')
+endfunc
diff --git a/src/version.c b/src/version.c
index 1b38d299a..bb112db46 100644
--- a/src/version.c
+++ b/src/version.c
@@ -772,6 +772,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 1100,
+/**/
1099,
/**/
1098,