mirror of
https://github.com/neovim/neovim.git
synced 2025-09-14 07:18:17 +00:00
vim-patch:7.4.1839
Problem: Cannot get the items stored in a partial.
Solution: Support using get() on a partial.
2bbf8eff6f
This commit is contained in:

committed by
James McCoy

parent
c82dc7a6fd
commit
02c58d8a07
@@ -3586,6 +3586,12 @@ get({dict}, {key} [, {default}])
|
|||||||
Get item with key {key} from |Dictionary| {dict}. When this
|
Get item with key {key} from |Dictionary| {dict}. When this
|
||||||
item is not available return {default}. Return zero when
|
item is not available return {default}. Return zero when
|
||||||
{default} is omitted.
|
{default} is omitted.
|
||||||
|
get({partial}, {what})
|
||||||
|
Get an item with from Funcref {partial}. Possible values for
|
||||||
|
{what} are:
|
||||||
|
'func' The function
|
||||||
|
'dict' The dictionary
|
||||||
|
'args' The list with arguments
|
||||||
|
|
||||||
*getbufline()*
|
*getbufline()*
|
||||||
getbufline({expr}, {lnum} [, {end}])
|
getbufline({expr}, {lnum} [, {end}])
|
||||||
|
@@ -9706,8 +9706,40 @@ static void f_get(typval_T *argvars, typval_T *rettv, FunPtr fptr)
|
|||||||
if (di != NULL)
|
if (di != NULL)
|
||||||
tv = &di->di_tv;
|
tv = &di->di_tv;
|
||||||
}
|
}
|
||||||
} else
|
} else if (argvars[0].v_type == VAR_PARTIAL) {
|
||||||
|
partial_T *pt = argvars[0].vval.v_partial;
|
||||||
|
|
||||||
|
if (pt != NULL) {
|
||||||
|
char_u *what = get_tv_string(&argvars[1]);
|
||||||
|
|
||||||
|
if (STRCMP(what, "func") == 0) {
|
||||||
|
rettv->v_type = VAR_STRING;
|
||||||
|
if (pt->pt_name != NULL) {
|
||||||
|
rettv->vval.v_string = vim_strsave(pt->pt_name);
|
||||||
|
}
|
||||||
|
} else if (STRCMP(what, "dict") == 0) {
|
||||||
|
rettv->v_type = VAR_DICT;
|
||||||
|
rettv->vval.v_dict = pt->pt_dict;
|
||||||
|
if (pt->pt_dict != NULL) {
|
||||||
|
(pt->pt_dict->dv_refcount)++;
|
||||||
|
}
|
||||||
|
} else if (STRCMP(what, "args") == 0) {
|
||||||
|
rettv->v_type = VAR_LIST;
|
||||||
|
if (rettv_list_alloc(rettv) != NULL) {
|
||||||
|
int i;
|
||||||
|
|
||||||
|
for (i = 0; i < pt->pt_argc; i++) {
|
||||||
|
list_append_tv(rettv->vval.v_list, &pt->pt_argv[i]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
EMSG2(_(e_invarg2), what);
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
EMSG2(_(e_listdictarg), "get()");
|
EMSG2(_(e_listdictarg), "get()");
|
||||||
|
}
|
||||||
|
|
||||||
if (tv == NULL) {
|
if (tv == NULL) {
|
||||||
if (argvars[2].v_type != VAR_UNKNOWN)
|
if (argvars[2].v_type != VAR_UNKNOWN)
|
||||||
@@ -18430,7 +18462,7 @@ handle_subscript (
|
|||||||
// Turn "dict.Func" into a partial for "Func" bound to "dict".
|
// Turn "dict.Func" into a partial for "Func" bound to "dict".
|
||||||
// Don't do this when "Func" is already a partial that was bound
|
// Don't do this when "Func" is already a partial that was bound
|
||||||
// explicitly (pt_auto is false).
|
// explicitly (pt_auto is false).
|
||||||
if (self != NULL
|
if (selfdict != NULL
|
||||||
&& (rettv->v_type == VAR_FUNC
|
&& (rettv->v_type == VAR_FUNC
|
||||||
|| (rettv->v_type == VAR_PARTIAL
|
|| (rettv->v_type == VAR_PARTIAL
|
||||||
&& (rettv->vval.v_partial->pt_auto
|
&& (rettv->vval.v_partial->pt_auto
|
||||||
|
Reference in New Issue
Block a user