mirror of
https://github.com/neovim/neovim.git
synced 2025-09-16 16:28:17 +00:00
@@ -1897,7 +1897,8 @@ getcmdline() String return the current command-line
|
|||||||
getcmdpos() Number return cursor position in command-line
|
getcmdpos() Number return cursor position in command-line
|
||||||
getcmdtype() String return current command-line type
|
getcmdtype() String return current command-line type
|
||||||
getcmdwintype() String return current command-line window type
|
getcmdwintype() String return current command-line window type
|
||||||
getcompletion({pat}, {type}) List list of cmdline completion matches
|
getcompletion({pat}, {type} [, {filtered}])
|
||||||
|
List list of cmdline completion matches
|
||||||
getcurpos() List position of the cursor
|
getcurpos() List position of the cursor
|
||||||
getcwd([{winnr} [, {tabnr}]]) String the current working directory
|
getcwd([{winnr} [, {tabnr}]]) String the current working directory
|
||||||
getfontname([{name}]) String name of font being used
|
getfontname([{name}]) String name of font being used
|
||||||
@@ -3651,7 +3652,7 @@ getcmdwintype() *getcmdwintype()*
|
|||||||
values are the same as |getcmdtype()|. Returns an empty string
|
values are the same as |getcmdtype()|. Returns an empty string
|
||||||
when not in the command-line window.
|
when not in the command-line window.
|
||||||
|
|
||||||
getcompletion({pat}, {type}) *getcompletion()*
|
getcompletion({pat}, {type} [, {filtered}]) *getcompletion()*
|
||||||
Return a list of command-line completion matches. {type}
|
Return a list of command-line completion matches. {type}
|
||||||
specifies what for. The following completion types are
|
specifies what for. The following completion types are
|
||||||
supported:
|
supported:
|
||||||
@@ -3691,6 +3692,10 @@ getcompletion({pat}, {type}) *getcompletion()*
|
|||||||
Otherwise only items matching {pat} are returned. See
|
Otherwise only items matching {pat} are returned. See
|
||||||
|wildcards| for the use of special characters in {pat}.
|
|wildcards| for the use of special characters in {pat}.
|
||||||
|
|
||||||
|
If the optional {filtered} flag is set to 1, then 'wildignore'
|
||||||
|
is applied to filter the results. Otherwise all the matches
|
||||||
|
are returned. The 'wildignorecase' option always applies.
|
||||||
|
|
||||||
If there are no matches, an empty list is returned. An
|
If there are no matches, an empty list is returned. An
|
||||||
invalid value for {type} produces an error.
|
invalid value for {type} produces an error.
|
||||||
|
|
||||||
|
@@ -9648,13 +9648,23 @@ static void f_getcompletion(typval_T *argvars, typval_T *rettv, FunPtr fptr)
|
|||||||
{
|
{
|
||||||
char_u *pat;
|
char_u *pat;
|
||||||
expand_T xpc;
|
expand_T xpc;
|
||||||
|
bool filtered = false;
|
||||||
int options = WILD_SILENT | WILD_USE_NL | WILD_ADD_SLASH
|
int options = WILD_SILENT | WILD_USE_NL | WILD_ADD_SLASH
|
||||||
| WILD_NO_BEEP;
|
| WILD_NO_BEEP;
|
||||||
|
|
||||||
|
if (argvars[2].v_type != VAR_UNKNOWN) {
|
||||||
|
filtered = get_tv_number_chk(&argvars[2], NULL);
|
||||||
|
}
|
||||||
|
|
||||||
if (p_wic) {
|
if (p_wic) {
|
||||||
options |= WILD_ICASE;
|
options |= WILD_ICASE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// For filtered results, 'wildignore' is used
|
||||||
|
if (!filtered) {
|
||||||
|
options |= WILD_KEEP_ALL;
|
||||||
|
}
|
||||||
|
|
||||||
ExpandInit(&xpc);
|
ExpandInit(&xpc);
|
||||||
xpc.xp_pattern = get_tv_string(&argvars[0]);
|
xpc.xp_pattern = get_tv_string(&argvars[0]);
|
||||||
xpc.xp_pattern_len = STRLEN(xpc.xp_pattern);
|
xpc.xp_pattern_len = STRLEN(xpc.xp_pattern);
|
||||||
@@ -9673,6 +9683,16 @@ static void f_getcompletion(typval_T *argvars, typval_T *rettv, FunPtr fptr)
|
|||||||
xpc.xp_pattern_len = STRLEN(xpc.xp_pattern);
|
xpc.xp_pattern_len = STRLEN(xpc.xp_pattern);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (xpc.xp_context == EXPAND_CSCOPE) {
|
||||||
|
set_context_in_cscope_cmd(&xpc, xpc.xp_pattern, CMD_cscope);
|
||||||
|
xpc.xp_pattern_len = STRLEN(xpc.xp_pattern);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (xpc.xp_context == EXPAND_SIGN) {
|
||||||
|
set_context_in_sign_cmd(&xpc, xpc.xp_pattern);
|
||||||
|
xpc.xp_pattern_len = STRLEN(xpc.xp_pattern);
|
||||||
|
}
|
||||||
|
|
||||||
pat = addstar(xpc.xp_pattern, xpc.xp_pattern_len, xpc.xp_context);
|
pat = addstar(xpc.xp_pattern, xpc.xp_pattern_len, xpc.xp_context);
|
||||||
rettv_list_alloc(rettv);
|
rettv_list_alloc(rettv);
|
||||||
if (pat != NULL) {
|
if (pat != NULL) {
|
||||||
|
@@ -114,7 +114,7 @@ return {
|
|||||||
getcmdpos={},
|
getcmdpos={},
|
||||||
getcmdtype={},
|
getcmdtype={},
|
||||||
getcmdwintype={},
|
getcmdwintype={},
|
||||||
getcompletion={args=2},
|
getcompletion={args={2, 3}},
|
||||||
getcurpos={},
|
getcurpos={},
|
||||||
getcwd={args={0,2}},
|
getcwd={args={0,2}},
|
||||||
getfontname={args={0, 1}},
|
getfontname={args={0, 1}},
|
||||||
|
@@ -89,6 +89,10 @@ func Test_getcompletion()
|
|||||||
call assert_true(index(l, 'runtest.vim') >= 0)
|
call assert_true(index(l, 'runtest.vim') >= 0)
|
||||||
let l = getcompletion('walk', 'file')
|
let l = getcompletion('walk', 'file')
|
||||||
call assert_equal([], l)
|
call assert_equal([], l)
|
||||||
|
set wildignore=*.vim
|
||||||
|
let l = getcompletion('run', 'file', 1)
|
||||||
|
call assert_true(index(l, 'runtest.vim') < 0)
|
||||||
|
set wildignore&
|
||||||
|
|
||||||
let l = getcompletion('ha', 'filetype')
|
let l = getcompletion('ha', 'filetype')
|
||||||
call assert_true(index(l, 'hamster') >= 0)
|
call assert_true(index(l, 'hamster') >= 0)
|
||||||
@@ -121,12 +125,35 @@ func Test_getcompletion()
|
|||||||
let l = getcompletion('dark', 'highlight')
|
let l = getcompletion('dark', 'highlight')
|
||||||
call assert_equal([], l)
|
call assert_equal([], l)
|
||||||
|
|
||||||
|
if has('cscope')
|
||||||
|
let l = getcompletion('', 'cscope')
|
||||||
|
let cmds = ['add', 'find', 'help', 'kill', 'reset', 'show']
|
||||||
|
call assert_equal(cmds, l)
|
||||||
|
" using cmdline completion must not change the result
|
||||||
|
call feedkeys(":cscope find \<c-d>\<c-c>", 'xt')
|
||||||
|
let l = getcompletion('', 'cscope')
|
||||||
|
call assert_equal(cmds, l)
|
||||||
|
let keys = ['a', 'c', 'd', 'e', 'f', 'g', 'i', 's', 't']
|
||||||
|
let l = getcompletion('find ', 'cscope')
|
||||||
|
call assert_equal(keys, l)
|
||||||
|
endif
|
||||||
|
|
||||||
|
if has('signs')
|
||||||
|
sign define Testing linehl=Comment
|
||||||
|
let l = getcompletion('', 'sign')
|
||||||
|
let cmds = ['define', 'jump', 'list', 'place', 'undefine', 'unplace']
|
||||||
|
call assert_equal(cmds, l)
|
||||||
|
" using cmdline completion must not change the result
|
||||||
|
call feedkeys(":sign list \<c-d>\<c-c>", 'xt')
|
||||||
|
let l = getcompletion('', 'sign')
|
||||||
|
call assert_equal(cmds, l)
|
||||||
|
let l = getcompletion('list ', 'sign')
|
||||||
|
call assert_equal(['Testing'], l)
|
||||||
|
endif
|
||||||
|
|
||||||
" For others test if the name is recognized.
|
" For others test if the name is recognized.
|
||||||
let names = ['buffer', 'environment', 'file_in_path',
|
let names = ['buffer', 'environment', 'file_in_path',
|
||||||
\ 'mapping', 'shellcmd', 'tag', 'tag_listfiles', 'user']
|
\ 'mapping', 'shellcmd', 'tag', 'tag_listfiles', 'user']
|
||||||
if has('cscope')
|
|
||||||
call add(names, 'cscope')
|
|
||||||
endif
|
|
||||||
if has('cmdline_hist')
|
if has('cmdline_hist')
|
||||||
call add(names, 'history')
|
call add(names, 'history')
|
||||||
endif
|
endif
|
||||||
@@ -136,9 +163,6 @@ func Test_getcompletion()
|
|||||||
if has('profile')
|
if has('profile')
|
||||||
call add(names, 'syntime')
|
call add(names, 'syntime')
|
||||||
endif
|
endif
|
||||||
if has('signs')
|
|
||||||
call add(names, 'sign')
|
|
||||||
endif
|
|
||||||
|
|
||||||
set tags=Xtags
|
set tags=Xtags
|
||||||
call writefile(["!_TAG_FILE_ENCODING\tutf-8\t//", "word\tfile\tcmd"], 'Xtags')
|
call writefile(["!_TAG_FILE_ENCODING\tutf-8\t//", "word\tfile\tcmd"], 'Xtags')
|
||||||
|
@@ -236,7 +236,7 @@ static int included_patches[] = {
|
|||||||
// 2208,
|
// 2208,
|
||||||
// 2207 NA
|
// 2207 NA
|
||||||
// 2206 NA
|
// 2206 NA
|
||||||
// 2205,
|
2205,
|
||||||
// 2204,
|
// 2204,
|
||||||
// 2203 NA
|
// 2203 NA
|
||||||
// 2202 NA
|
// 2202 NA
|
||||||
@@ -279,11 +279,11 @@ static int included_patches[] = {
|
|||||||
// 2165,
|
// 2165,
|
||||||
// 2164,
|
// 2164,
|
||||||
// 2163,
|
// 2163,
|
||||||
// 2162,
|
2162,
|
||||||
// 2161,
|
// 2161,
|
||||||
// 2160,
|
// 2160,
|
||||||
// 2159,
|
// 2159,
|
||||||
// 2158,
|
2158,
|
||||||
// 2157 NA
|
// 2157 NA
|
||||||
// 2156 NA
|
// 2156 NA
|
||||||
// 2155 NA
|
// 2155 NA
|
||||||
|
Reference in New Issue
Block a user