diff src/cmdexpand.c @ 26213:ee1c116b91ea v8.2.3638

patch 8.2.3638: getcompletion() always passes zero as position Commit: https://github.com/vim/vim/commit/4785fe02bba14c4e0aede0fa425ca790a1cb98d7 Author: ii14 <ii14@users.noreply.github.com> Date: Sun Nov 21 12:13:56 2021 +0000 patch 8.2.3638: getcompletion() always passes zero as position Problem: getcompletion() always passes zero as position to custom completion function. Solution: Pass the pattern length. (closes #9173)
author Bram Moolenaar <Bram@vim.org>
date Sun, 21 Nov 2021 13:15:04 +0100
parents 162ef12a3b5f
children ef0c07cbf53f
line wrap: on
line diff
--- a/src/cmdexpand.c
+++ b/src/cmdexpand.c
@@ -2900,6 +2900,7 @@ f_getcompletion(typval_T *argvars, typva
 		|| check_for_opt_bool_arg(argvars, 2) == FAIL))
 	return;
 
+    pat = tv_get_string(&argvars[0]);
     if (argvars[1].v_type != VAR_STRING)
     {
 	semsg(_(e_invarg2), "type must be a string");
@@ -2920,12 +2921,13 @@ f_getcompletion(typval_T *argvars, typva
     ExpandInit(&xpc);
     if (STRCMP(type, "cmdline") == 0)
     {
-	set_one_cmd_context(&xpc, tv_get_string(&argvars[0]));
+	set_one_cmd_context(&xpc, pat);
 	xpc.xp_pattern_len = (int)STRLEN(xpc.xp_pattern);
+	xpc.xp_col = (int)STRLEN(pat);
     }
     else
     {
-	xpc.xp_pattern = tv_get_string(&argvars[0]);
+	xpc.xp_pattern = pat;
 	xpc.xp_pattern_len = (int)STRLEN(xpc.xp_pattern);
 
 	xpc.xp_context = cmdcomplete_str_to_type(type);