]> granicus.if.org Git - vim/commitdiff
patch 8.0.1488: emacs tags no longer work v8.0.1488
authorBram Moolenaar <Bram@vim.org>
Fri, 9 Feb 2018 18:25:29 +0000 (19:25 +0100)
committerBram Moolenaar <Bram@vim.org>
Fri, 9 Feb 2018 18:25:29 +0000 (19:25 +0100)
Problem:    Emacs tags no longer work. (zdohnal)
Solution:   Do not skip over end of line.

src/tag.c
src/testdir/test_tagjump.vim
src/version.c

index 3d18a41ebbd28dd767eb64fc8930f60517145a66..cdad6a348a17c07b4c29bc10e898e6dd001e1a9e 100644 (file)
--- a/src/tag.c
+++ b/src/tag.c
@@ -2958,12 +2958,9 @@ matching_line_len(char_u *lbuf)
     char_u     *p = lbuf + 1;
 
     /* does the same thing as parse_match() */
-    p += STRLEN(p) + 2;
+    p += STRLEN(p) + 1;
 #ifdef FEAT_EMACS_TAGS
-    if (*p)
-       p += STRLEN(p);
-    else
-       ++p;
+    p += STRLEN(p) + 1;
 #endif
     return (p - lbuf) + STRLEN(p);
 }
index 0e51098eb9838fc8dd05bf3cf2560afeb5e629f8..9f0accc3d89792c14859c938a92584d57498f1ea 100644 (file)
@@ -229,4 +229,32 @@ func Test_tag_file_encoding()
   call delete('Xtags1')
 endfunc
 
+func Test_tagjump_etags()
+  if !has('emacs_tags')
+    return
+  endif
+  call writefile([
+        \ "void foo() {}",
+        \ "int main(int argc, char **argv)",
+        \ "{",
+        \ "\tfoo();",
+        \ "\treturn 0;",
+        \ "}",
+        \ ], 'Xmain.c')
+
+  call writefile([
+       \ "\x0c",
+        \ "Xmain.c,64",
+        \ "void foo() {}\x7ffoo\x011,0",
+        \ "int main(int argc, char **argv)\x7fmain\x012,14",
+       \ ], 'Xtags')
+  set tags=Xtags
+  ta foo
+  call assert_equal('void foo() {}', getline('.'))
+
+  call delete('Xtags')
+  call delete('Xmain.c')
+  bwipe!
+endfunc
+
 " vim: shiftwidth=2 sts=2 expandtab
index 043cc623ff925549783050855c1386d4f724c47b..eb0c02a1e8a1c9accd2d42fe77856518a222617d 100644 (file)
@@ -771,6 +771,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    1488,
 /**/
     1487,
 /**/