diff options
author | Bram Moolenaar <Bram@vim.org> | 2013-06-29 12:58:33 +0200 |
---|---|---|
committer | Bram Moolenaar <Bram@vim.org> | 2013-06-29 12:58:33 +0200 |
commit | b751546636c71f206733af1bc30415aaab9a0b42 (patch) | |
tree | cb96a703d4c93ebc41b5454b7db16c3e90dd1293 /src | |
parent | 560c52d32b3e509710e5e7fd620feb751e97689b (diff) | |
download | vim-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.c | 23 | ||||
-rw-r--r-- | src/structs.h | 2 | ||||
-rw-r--r-- | src/version.c | 2 |
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, |