From: Bram Moolenaar Date: Wed, 13 Jan 2021 18:48:46 +0000 (+0100) Subject: patch 8.2.2341: expresison command line completion incomplete after "g:" X-Git-Tag: v8.2.2341 X-Git-Url: http://git.ipfire.org/gitweb/gitweb.cgi?a=commitdiff_plain;h=1bb4de5302ba038b9c59e845b6d735e87d5681d0;p=thirdparty%2Fvim.git patch 8.2.2341: expresison command line completion incomplete after "g:" Problem: Expresison command line completion shows variables but not functions after "g:". (Gary Johnson) Solution: Prefix "g:" when needed to a global function. --- diff --git a/src/evalfunc.c b/src/evalfunc.c index 0e6d759c66..d3ef15e0b9 100644 --- a/src/evalfunc.c +++ b/src/evalfunc.c @@ -1822,7 +1822,11 @@ get_function_name(expand_T *xp, int idx) { name = get_user_func_name(xp, idx); if (name != NULL) + { + if (*name != '<' && STRNCMP("g:", xp->xp_pattern, 2) == 0) + return cat_prefix_varname('g', name); return name; + } } if (++intidx < (int)(sizeof(global_functions) / sizeof(funcentry_T))) { diff --git a/src/evalvars.c b/src/evalvars.c index 644190fbe1..155f603b50 100644 --- a/src/evalvars.c +++ b/src/evalvars.c @@ -1952,7 +1952,7 @@ static int varnamebuflen = 0; /* * Function to concatenate a prefix and a variable name. */ - static char_u * + char_u * cat_prefix_varname(int prefix, char_u *name) { int len; diff --git a/src/proto/evalvars.pro b/src/proto/evalvars.pro index c597ca3720..0861a8866a 100644 --- a/src/proto/evalvars.pro +++ b/src/proto/evalvars.pro @@ -26,6 +26,7 @@ void ex_unletlock(exarg_T *eap, char_u *argstart, int deep, int glv_flags, int ( int do_unlet(char_u *name, int forceit); void item_lock(typval_T *tv, int deep, int lock, int check_refcount); void del_menutrans_vars(void); +char_u *cat_prefix_varname(int prefix, char_u *name); char_u *get_user_var_name(expand_T *xp, int idx); char *get_var_special_name(int nr); dict_T *get_globvar_dict(void); diff --git a/src/testdir/test_cmdline.vim b/src/testdir/test_cmdline.vim index 2a6db7de4f..cb16de1246 100644 --- a/src/testdir/test_cmdline.vim +++ b/src/testdir/test_cmdline.vim @@ -619,6 +619,10 @@ func Test_cmdline_complete_user_func() call assert_match('"func Test_cmdline_complete_user', @:) call feedkeys(":func s:ScriptL\\\"\", 'tx') call assert_match('"func \d\+_ScriptLocalFunction', @:) + + " g: prefix also works + call feedkeys(":echo g:Test_cmdline_complete_user_f\\\"\", 'tx') + call assert_match('"echo g:Test_cmdline_complete_user_func', @:) endfunc func Test_cmdline_complete_user_names() diff --git a/src/version.c b/src/version.c index 24462a0e67..78b805f024 100644 --- a/src/version.c +++ b/src/version.c @@ -750,6 +750,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ +/**/ + 2341, /**/ 2340, /**/