summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2013-06-29 12:58:33 +0200
committerBram Moolenaar <Bram@vim.org>2013-06-29 12:58:33 +0200
commitb751546636c71f206733af1bc30415aaab9a0b42 (patch)
treecb96a703d4c93ebc41b5454b7db16c3e90dd1293 /src
parent560c52d32b3e509710e5e7fd620feb751e97689b (diff)
downloadvim-git-b751546636c71f206733af1bc30415aaab9a0b42.tar.gz
updated for version 7.3.1260v7.3.1260
Problem: User completion does not get the whole command line in the command line window. Solution: Pass on the whole command line. (Daniel Thau)
Diffstat (limited to 'src')
-rw-r--r--src/ex_getln.c23
-rw-r--r--src/structs.h2
-rw-r--r--src/version.c2
3 files changed, 15 insertions, 12 deletions
diff --git a/src/ex_getln.c b/src/ex_getln.c
index ec64619e4..18a708bf9 100644
--- a/src/ex_getln.c
+++ b/src/ex_getln.c
@@ -3729,6 +3729,7 @@ ExpandInit(xp)
#if defined(FEAT_USR_CMDS) && defined(FEAT_EVAL) && defined(FEAT_CMDL_COMPL)
xp->xp_arg = NULL;
#endif
+ xp->xp_line = NULL;
}
/*
@@ -4378,6 +4379,11 @@ set_cmd_context(xp, str, len, col)
int old_char = NUL;
char_u *nextcomm;
+ /* Store the string here so that call_user_expand_func() can get to them
+ * easily. */
+ xp->xp_line = str;
+ xp->xp_col = col;
+
/*
* Avoid a UMR warning from Purify, only save the character if it has been
* written before.
@@ -4952,27 +4958,20 @@ call_user_expand_func(user_expand_func, xp, num_file, file)
void *ret;
struct cmdline_info save_ccline;
- if (xp->xp_arg == NULL || xp->xp_arg[0] == '\0')
+ if (xp->xp_arg == NULL || xp->xp_arg[0] == '\0' || xp->xp_line == NULL)
return NULL;
*num_file = 0;
*file = NULL;
- if (ccline.cmdbuff == NULL)
- {
- /* Completion from Insert mode, pass fake arguments. */
- keep = 0;
- sprintf((char *)num, "%d", (int)STRLEN(xp->xp_pattern));
- args[1] = xp->xp_pattern;
- }
- else
+ if (ccline.cmdbuff != NULL)
{
- /* Completion on the command line, pass real arguments. */
keep = ccline.cmdbuff[ccline.cmdlen];
ccline.cmdbuff[ccline.cmdlen] = 0;
- sprintf((char *)num, "%d", ccline.cmdpos);
- args[1] = ccline.cmdbuff;
}
+
args[0] = vim_strnsave(xp->xp_pattern, xp->xp_pattern_len);
+ args[1] = xp->xp_line;
+ sprintf((char *)num, "%d", xp->xp_col);
args[2] = num;
/* Save the cmdline, we don't know what the function may do. */
diff --git a/src/structs.h b/src/structs.h
index bfe1919b6..96435eda7 100644
--- a/src/structs.h
+++ b/src/structs.h
@@ -493,6 +493,8 @@ typedef struct expand
int xp_numfiles; /* number of files found by
file name completion */
char_u **xp_files; /* list of files */
+ char_u *xp_line; /* text being completed */
+ int xp_col; /* cursor position in line */
} expand_T;
/* values for xp_backslash */
diff --git a/src/version.c b/src/version.c
index d9e62dd48..60d0d10da 100644
--- a/src/version.c
+++ b/src/version.c
@@ -729,6 +729,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 1260,
+/**/
1259,
/**/
1258,