diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/nvim/ex_cmds.c | 29 | ||||
| -rw-r--r-- | src/nvim/testdir/Makefile | 3 | ||||
| -rw-r--r-- | src/nvim/testdir/test_help_tagjump.vim | 40 | ||||
| -rw-r--r-- | src/nvim/version.c | 5 | 
4 files changed, 64 insertions, 13 deletions
| diff --git a/src/nvim/ex_cmds.c b/src/nvim/ex_cmds.c index e8314e02e0..415d6ee460 100644 --- a/src/nvim/ex_cmds.c +++ b/src/nvim/ex_cmds.c @@ -4413,17 +4413,20 @@ int find_help_tags(char_u *arg, int *num_matches, char_u ***matches, int keep_la            || (arg[0] == '\\' && arg[1] == '{'))          *d++ = '\\'; -      for (s = arg; *s; ++s) { -        /* -         * Replace "|" with "bar" and '"' with "quote" to match the name of -         * the tags for these commands. -         * Replace "*" with ".*" and "?" with "." to match command line -         * completion. -         * Insert a backslash before '~', '$' and '.' to avoid their -         * special meaning. -         */ -        if (d - IObuff > IOSIZE - 10)           /* getting too long!? */ +      // If tag starts with "('", skip the "(". Fixes CTRL-] on ('option'. +      if (*arg == '(' && arg[1] == '\'') { +          arg++; +      } +      for (s = arg; *s; s++) { +        // Replace "|" with "bar" and '"' with "quote" to match the name of +        // the tags for these commands. +        // Replace "*" with ".*" and "?" with "." to match command line +        // completion. +        // Insert a backslash before '~', '$' and '.' to avoid their +        // special meaning. +        if (d - IObuff > IOSIZE - 10) {           // getting too long!?            break; +        }          switch (*s) {          case '|':   STRCPY(d, "bar");            d += 3; @@ -4484,6 +4487,12 @@ int find_help_tags(char_u *arg, int *num_matches, char_u ***matches, int keep_la          *d++ = *s; +        // If tag contains "({" or "([", tag terminates at the "(". +        // This is for help on functions, e.g.: abs({expr}). +        if (*s == '(' && (s[1] == '{' || s[1] =='[')) { +          break; +        } +          /*           * If tag starts with ', toss everything after a second '. Fixes           * CTRL-] on 'option'. (would include the trailing '.'). diff --git a/src/nvim/testdir/Makefile b/src/nvim/testdir/Makefile index b763a67347..7195c7e632 100644 --- a/src/nvim/testdir/Makefile +++ b/src/nvim/testdir/Makefile @@ -39,8 +39,9 @@ SCRIPTS := \  # Tests using runtest.vim.vim.  # Keep test_alot*.res as the last one, sort the others.  NEW_TESTS = \ -	    test_viml.res \  	    test_cursor_func.res \ +	    test_help_tagjump.res \ +	    test_viml.res \  	    test_alot.res  SCRIPTS_GUI := test16.out diff --git a/src/nvim/testdir/test_help_tagjump.vim b/src/nvim/testdir/test_help_tagjump.vim new file mode 100644 index 0000000000..9f9207d27d --- /dev/null +++ b/src/nvim/testdir/test_help_tagjump.vim @@ -0,0 +1,40 @@ +" Tests for :help! {subject} + +func SetUp() +  " v:progpath is …/build/bin/nvim and we need …/build/runtime +  " to be added to &rtp +  let builddir = fnamemodify(exepath(v:progpath), ':h:h') +  let s:rtp = &rtp +  let &rtp .= printf(',%s/runtime', builddir) +endfunc + +func TearDown() +  let &rtp = s:rtp +endfunc + +func Test_help_tagjump() +  help +  call assert_equal("help", &filetype) +  call assert_true(getline('.') =~ '\*help.txt\*') +  helpclose + +  exec "help! ('textwidth'" +  call assert_equal("help", &filetype) +  call assert_true(getline('.') =~ "\\*'textwidth'\\*") +  helpclose + +  exec "help! ('buflisted')," +  call assert_equal("help", &filetype) +  call assert_true(getline('.') =~ "\\*'buflisted'\\*") +  helpclose + +  exec "help! abs({expr})" +  call assert_equal("help", &filetype) +  call assert_true(getline('.') =~ '\*abs()\*') +  helpclose + +  exec "help! arglistid([{winnr})" +  call assert_equal("help", &filetype) +  call assert_true(getline('.') =~ '\*arglistid()\*') +  helpclose +endfunc diff --git a/src/nvim/version.c b/src/nvim/version.c index 7ee3b596de..7f646b760d 100644 --- a/src/nvim/version.c +++ b/src/nvim/version.c @@ -76,6 +76,7 @@ static int included_patches[] = {    1757,    1755,    1753, +  1728,    1654,    1652,    1643, @@ -111,10 +112,10 @@ static int included_patches[] = {    1574,    // 1573,    // 1572 NA -  // 1571, +  1571,    1570,    1569, -  // 1568, +  1568,    // 1567,    // 1566 NA    // 1565, | 
