changeset 25648:46e2b5f66800 v8.2.3360

patch 8.2.3360: user function completion fails with dict function Commit: https://github.com/vim/vim/commit/5aec755b678cfd434b8ea2158d06992f33e1ff80 Author: naohiro ono <obcat@icloud.com> Date: Thu Aug 19 21:20:41 2021 +0200 patch 8.2.3360: user function completion fails with dict function Problem: User function completion fails with dict function. Solution: Do not stop sequencing through the list if user functions when encountering an empty name. (Naohiro Ono, closes #8765, closes #8774)
author Bram Moolenaar <Bram@vim.org>
date Thu, 19 Aug 2021 21:30:04 +0200
parents b6be34f354e6
children cc4bdae84522
files src/evalfunc.c src/testdir/test_cmdline.vim src/version.c
diffstat 3 files changed, 15 insertions(+), 4 deletions(-) [+]
line wrap: on
line diff
--- a/src/evalfunc.c
+++ b/src/evalfunc.c
@@ -2307,9 +2307,10 @@ get_function_name(expand_T *xp, int idx)
     if (intidx < 0)
     {
 	name = get_user_func_name(xp, idx);
-	if (name != NULL && *name != NUL)
-	{
-	    if (*name != '<' && STRNCMP("g:", xp->xp_pattern, 2) == 0)
+	if (name != NULL)
+	{
+	    if (*name != NUL && *name != '<'
+				      && STRNCMP("g:", xp->xp_pattern, 2) == 0)
 		return cat_prefix_varname('g', name);
 	    return name;
 	}
--- a/src/testdir/test_cmdline.vim
+++ b/src/testdir/test_cmdline.vim
@@ -650,7 +650,7 @@ endfunc
 
 func Test_cmdline_complete_user_func()
   call feedkeys(":func Test_cmdline_complete_user\<Tab>\<Home>\"\<cr>", 'tx')
-  call assert_match('"func Test_cmdline_complete_user', @:)
+  call assert_match('"func Test_cmdline_complete_user_', @:)
   call feedkeys(":func s:ScriptL\<Tab>\<Home>\"\<cr>", 'tx')
   call assert_match('"func <SNR>\d\+_ScriptLocalFunction', @:)
 
@@ -662,6 +662,14 @@ func Test_cmdline_complete_user_func()
   let Fx = { a ->  a }
   call feedkeys(":echo g:\<Tab>\<Home>\"\<cr>", 'tx')
   call assert_match('"echo g:[A-Z]', @:)
+
+  " existence of script-local dict function does not break user function name
+  " completion
+  function s:a_dict_func() dict
+  endfunction
+  call feedkeys(":call Test_cmdline_complete_user\<Tab>\<Home>\"\<cr>", 'tx')
+  call assert_match('"call Test_cmdline_complete_user_', @:)
+  delfunction s:a_dict_func
 endfunc
 
 func Test_cmdline_complete_user_names()
--- a/src/version.c
+++ b/src/version.c
@@ -756,6 +756,8 @@ static char *(features[]) =
 static int included_patches[] =
 {   /* Add new patch number below this line */
 /**/
+    3360,
+/**/
     3359,
 /**/
     3358,