patch 9.0.0063: too many type casts for dict_get functions

Problem:    Too many type casts for dict_get functions.
Solution:   Change the key argument from "char_u *" to "char *".
This commit is contained in:
Bram Moolenaar
2022-07-23 09:52:04 +01:00
parent 5ac50de83f
commit d61efa50f8
24 changed files with 193 additions and 202 deletions

View File

@ -2833,7 +2833,7 @@ autocmd_add_or_delete(typval_T *argvars, typval_T *rettv, int delete)
} }
} }
group_name = dict_get_string(event_dict, (char_u *)"group", TRUE); group_name = dict_get_string(event_dict, "group", TRUE);
if (group_name == NULL || *group_name == NUL) if (group_name == NULL || *group_name == NUL)
// if the autocmd group name is not specified, then use the current // if the autocmd group name is not specified, then use the current
// autocmd group // autocmd group
@ -2868,7 +2868,7 @@ autocmd_add_or_delete(typval_T *argvars, typval_T *rettv, int delete)
{ {
varnumber_T bnum; varnumber_T bnum;
bnum = dict_get_number_def(event_dict, (char_u *)"bufnr", -1); bnum = dict_get_number_def(event_dict, "bufnr", -1);
if (bnum == -1) if (bnum == -1)
continue; continue;
@ -2908,13 +2908,13 @@ autocmd_add_or_delete(typval_T *argvars, typval_T *rettv, int delete)
pat = (char_u *)""; pat = (char_u *)"";
} }
once = dict_get_bool(event_dict, (char_u *)"once", FALSE); once = dict_get_bool(event_dict, "once", FALSE);
nested = dict_get_bool(event_dict, (char_u *)"nested", FALSE); nested = dict_get_bool(event_dict, "nested", FALSE);
// if 'replace' is true, then remove all the commands associated with // if 'replace' is true, then remove all the commands associated with
// this autocmd event/group and add the new command. // this autocmd event/group and add the new command.
replace = dict_get_bool(event_dict, (char_u *)"replace", FALSE); replace = dict_get_bool(event_dict, "replace", FALSE);
cmd = dict_get_string(event_dict, (char_u *)"cmd", TRUE); cmd = dict_get_string(event_dict, "cmd", TRUE);
if (cmd == NULL) if (cmd == NULL)
{ {
if (delete) if (delete)
@ -3076,8 +3076,7 @@ f_autocmd_get(typval_T *argvars, typval_T *rettv)
// return only the autocmds in the specified group // return only the autocmds in the specified group
if (dict_has_key(argvars[0].vval.v_dict, "group")) if (dict_has_key(argvars[0].vval.v_dict, "group"))
{ {
name = dict_get_string(argvars[0].vval.v_dict, name = dict_get_string(argvars[0].vval.v_dict, "group", TRUE);
(char_u *)"group", TRUE);
if (name == NULL) if (name == NULL)
return; return;
@ -3101,8 +3100,7 @@ f_autocmd_get(typval_T *argvars, typval_T *rettv)
{ {
int i; int i;
name = dict_get_string(argvars[0].vval.v_dict, name = dict_get_string(argvars[0].vval.v_dict, "event", TRUE);
(char_u *)"event", TRUE);
if (name == NULL) if (name == NULL)
return; return;
@ -3127,8 +3125,7 @@ f_autocmd_get(typval_T *argvars, typval_T *rettv)
// return only the autocmds for the specified pattern // return only the autocmds for the specified pattern
if (dict_has_key(argvars[0].vval.v_dict, "pattern")) if (dict_has_key(argvars[0].vval.v_dict, "pattern"))
{ {
pat = dict_get_string(argvars[0].vval.v_dict, pat = dict_get_string(argvars[0].vval.v_dict, "pattern", TRUE);
(char_u *)"pattern", TRUE);
if (pat == NULL) if (pat == NULL)
return; return;
} }

View File

@ -172,9 +172,9 @@ check_recorded_changes(
FOR_ALL_LIST_ITEMS(buf->b_recorded_changes, li) FOR_ALL_LIST_ITEMS(buf->b_recorded_changes, li)
{ {
prev_lnum = (linenr_T)dict_get_number( prev_lnum = (linenr_T)dict_get_number(
li->li_tv.vval.v_dict, (char_u *)"lnum"); li->li_tv.vval.v_dict, "lnum");
prev_lnume = (linenr_T)dict_get_number( prev_lnume = (linenr_T)dict_get_number(
li->li_tv.vval.v_dict, (char_u *)"end"); li->li_tv.vval.v_dict, "end");
if (prev_lnum >= lnum || prev_lnum > lnume || prev_lnume >= lnum) if (prev_lnum >= lnum || prev_lnum > lnume || prev_lnume >= lnum)
{ {
// the current change is going to make the line number in // the current change is going to make the line number in
@ -384,13 +384,13 @@ invoke_listeners(buf_T *buf)
{ {
varnumber_T lnum; varnumber_T lnum;
lnum = dict_get_number(li->li_tv.vval.v_dict, (char_u *)"lnum"); lnum = dict_get_number(li->li_tv.vval.v_dict, "lnum");
if (start > lnum) if (start > lnum)
start = lnum; start = lnum;
lnum = dict_get_number(li->li_tv.vval.v_dict, (char_u *)"end"); lnum = dict_get_number(li->li_tv.vval.v_dict, "end");
if (end < lnum) if (end < lnum)
end = lnum; end = lnum;
added += dict_get_number(li->li_tv.vval.v_dict, (char_u *)"added"); added += dict_get_number(li->li_tv.vval.v_dict, "added");
} }
argv[1].v_type = VAR_NUMBER; argv[1].v_type = VAR_NUMBER;
argv[1].vval.v_number = start; argv[1].vval.v_number = start;

View File

@ -662,11 +662,11 @@ dict_has_key(dict_T *d, char *key)
* Returns FAIL if the entry doesn't exist or out of memory. * Returns FAIL if the entry doesn't exist or out of memory.
*/ */
int int
dict_get_tv(dict_T *d, char_u *key, typval_T *rettv) dict_get_tv(dict_T *d, char *key, typval_T *rettv)
{ {
dictitem_T *di; dictitem_T *di;
di = dict_find(d, key, -1); di = dict_find(d, (char_u *)key, -1);
if (di == NULL) if (di == NULL)
return FAIL; return FAIL;
copy_tv(&di->di_tv, rettv); copy_tv(&di->di_tv, rettv);
@ -680,12 +680,12 @@ dict_get_tv(dict_T *d, char_u *key, typval_T *rettv)
* Returns NULL if the entry doesn't exist or out of memory. * Returns NULL if the entry doesn't exist or out of memory.
*/ */
char_u * char_u *
dict_get_string(dict_T *d, char_u *key, int save) dict_get_string(dict_T *d, char *key, int save)
{ {
dictitem_T *di; dictitem_T *di;
char_u *s; char_u *s;
di = dict_find(d, key, -1); di = dict_find(d, (char_u *)key, -1);
if (di == NULL) if (di == NULL)
return NULL; return NULL;
s = tv_get_string(&di->di_tv); s = tv_get_string(&di->di_tv);
@ -699,7 +699,7 @@ dict_get_string(dict_T *d, char_u *key, int save)
* Returns 0 if the entry doesn't exist. * Returns 0 if the entry doesn't exist.
*/ */
varnumber_T varnumber_T
dict_get_number(dict_T *d, char_u *key) dict_get_number(dict_T *d, char *key)
{ {
return dict_get_number_def(d, key, 0); return dict_get_number_def(d, key, 0);
} }
@ -709,11 +709,11 @@ dict_get_number(dict_T *d, char_u *key)
* Returns "def" if the entry doesn't exist. * Returns "def" if the entry doesn't exist.
*/ */
varnumber_T varnumber_T
dict_get_number_def(dict_T *d, char_u *key, int def) dict_get_number_def(dict_T *d, char *key, int def)
{ {
dictitem_T *di; dictitem_T *di;
di = dict_find(d, key, -1); di = dict_find(d, (char_u *)key, -1);
if (di == NULL) if (di == NULL)
return def; return def;
return tv_get_number(&di->di_tv); return tv_get_number(&di->di_tv);
@ -745,11 +745,11 @@ dict_get_number_check(dict_T *d, char_u *key)
* Returns "def" if the entry doesn't exist. * Returns "def" if the entry doesn't exist.
*/ */
varnumber_T varnumber_T
dict_get_bool(dict_T *d, char_u *key, int def) dict_get_bool(dict_T *d, char *key, int def)
{ {
dictitem_T *di; dictitem_T *di;
di = dict_find(d, key, -1); di = dict_find(d, (char_u *)key, -1);
if (di == NULL) if (di == NULL)
return def; return def;
return tv_get_bool(&di->di_tv); return tv_get_bool(&di->di_tv);

View File

@ -695,9 +695,9 @@ f_getbufinfo(typval_T *argvars, typval_T *rettv)
if (sel_d != NULL) if (sel_d != NULL)
{ {
filtered = TRUE; filtered = TRUE;
sel_buflisted = dict_get_bool(sel_d, (char_u *)"buflisted", FALSE); sel_buflisted = dict_get_bool(sel_d, "buflisted", FALSE);
sel_bufloaded = dict_get_bool(sel_d, (char_u *)"bufloaded", FALSE); sel_bufloaded = dict_get_bool(sel_d, "bufloaded", FALSE);
sel_bufmodified = dict_get_bool(sel_d, (char_u *)"bufmodified", sel_bufmodified = dict_get_bool(sel_d, "bufmodified",
FALSE); FALSE);
} }
} }

View File

@ -4217,8 +4217,7 @@ f_expandcmd(typval_T *argvars, typval_T *rettv)
return; return;
if (argvars[1].v_type == VAR_DICT if (argvars[1].v_type == VAR_DICT
&& dict_get_bool(argvars[1].vval.v_dict, (char_u *)"errmsg", && dict_get_bool(argvars[1].vval.v_dict, "errmsg", VVAL_FALSE))
VVAL_FALSE))
emsgoff = FALSE; emsgoff = FALSE;
rettv->v_type = VAR_STRING; rettv->v_type = VAR_STRING;
@ -9172,7 +9171,7 @@ f_setcharsearch(typval_T *argvars, typval_T *rettv UNUSED)
if ((d = argvars[0].vval.v_dict) != NULL) if ((d = argvars[0].vval.v_dict) != NULL)
{ {
csearch = dict_get_string(d, (char_u *)"char", FALSE); csearch = dict_get_string(d, "char", FALSE);
if (csearch != NULL) if (csearch != NULL)
{ {
if (enc_utf8) if (enc_utf8)
@ -9368,7 +9367,7 @@ f_setreg(typval_T *argvars, typval_T *rettv)
if (di != NULL) if (di != NULL)
regcontents = &di->di_tv; regcontents = &di->di_tv;
stropt = dict_get_string(d, (char_u *)"regtype", FALSE); stropt = dict_get_string(d, "regtype", FALSE);
if (stropt != NULL) if (stropt != NULL)
{ {
int ret = get_yank_type(&stropt, &yank_type, &block_len); int ret = get_yank_type(&stropt, &yank_type, &block_len);
@ -9382,14 +9381,14 @@ f_setreg(typval_T *argvars, typval_T *rettv)
if (regname == '"') if (regname == '"')
{ {
stropt = dict_get_string(d, (char_u *)"points_to", FALSE); stropt = dict_get_string(d, "points_to", FALSE);
if (stropt != NULL) if (stropt != NULL)
{ {
pointreg = *stropt; pointreg = *stropt;
regname = pointreg; regname = pointreg;
} }
} }
else if (dict_get_bool(d, (char_u *)"isunnamed", -1) > 0) else if (dict_get_bool(d, "isunnamed", -1) > 0)
pointreg = regname; pointreg = regname;
} }
else else

View File

@ -1016,11 +1016,11 @@ f_win_splitmove(typval_T *argvars, typval_T *rettv)
} }
d = argvars[2].vval.v_dict; d = argvars[2].vval.v_dict;
if (dict_get_bool(d, (char_u *)"vertical", FALSE)) if (dict_get_bool(d, "vertical", FALSE))
flags |= WSP_VERT; flags |= WSP_VERT;
if ((di = dict_find(d, (char_u *)"rightbelow", -1)) != NULL) if ((di = dict_find(d, (char_u *)"rightbelow", -1)) != NULL)
flags |= tv_get_bool(&di->di_tv) ? WSP_BELOW : WSP_ABOVE; flags |= tv_get_bool(&di->di_tv) ? WSP_BELOW : WSP_ABOVE;
size = (int)dict_get_number(d, (char_u *)"size"); size = (int)dict_get_number(d, "size");
} }
win_move_into_split(wp, targetwin, size, flags); win_move_into_split(wp, targetwin, size, flags);
@ -1236,27 +1236,27 @@ f_winrestview(typval_T *argvars, typval_T *rettv UNUSED)
else else
{ {
if (dict_has_key(dict, "lnum")) if (dict_has_key(dict, "lnum"))
curwin->w_cursor.lnum = (linenr_T)dict_get_number(dict, (char_u *)"lnum"); curwin->w_cursor.lnum = (linenr_T)dict_get_number(dict, "lnum");
if (dict_has_key(dict, "col")) if (dict_has_key(dict, "col"))
curwin->w_cursor.col = (colnr_T)dict_get_number(dict, (char_u *)"col"); curwin->w_cursor.col = (colnr_T)dict_get_number(dict, "col");
if (dict_has_key(dict, "coladd")) if (dict_has_key(dict, "coladd"))
curwin->w_cursor.coladd = (colnr_T)dict_get_number(dict, (char_u *)"coladd"); curwin->w_cursor.coladd = (colnr_T)dict_get_number(dict, "coladd");
if (dict_has_key(dict, "curswant")) if (dict_has_key(dict, "curswant"))
{ {
curwin->w_curswant = (colnr_T)dict_get_number(dict, (char_u *)"curswant"); curwin->w_curswant = (colnr_T)dict_get_number(dict, "curswant");
curwin->w_set_curswant = FALSE; curwin->w_set_curswant = FALSE;
} }
if (dict_has_key(dict, "topline")) if (dict_has_key(dict, "topline"))
set_topline(curwin, (linenr_T)dict_get_number(dict, (char_u *)"topline")); set_topline(curwin, (linenr_T)dict_get_number(dict, "topline"));
#ifdef FEAT_DIFF #ifdef FEAT_DIFF
if (dict_has_key(dict, "topfill")) if (dict_has_key(dict, "topfill"))
curwin->w_topfill = (int)dict_get_number(dict, (char_u *)"topfill"); curwin->w_topfill = (int)dict_get_number(dict, "topfill");
#endif #endif
if (dict_has_key(dict, "leftcol")) if (dict_has_key(dict, "leftcol"))
curwin->w_leftcol = (colnr_T)dict_get_number(dict, (char_u *)"leftcol"); curwin->w_leftcol = (colnr_T)dict_get_number(dict, "leftcol");
if (dict_has_key(dict, "skipcol")) if (dict_has_key(dict, "skipcol"))
curwin->w_skipcol = (colnr_T)dict_get_number(dict, (char_u *)"skipcol"); curwin->w_skipcol = (colnr_T)dict_get_number(dict, "skipcol");
check_cursor(); check_cursor();
win_new_height(curwin, curwin->w_height); win_new_height(curwin, curwin->w_height);

View File

@ -4746,8 +4746,8 @@ compare_readdirex_item(const void *p1, const void *p2)
{ {
char_u *name1, *name2; char_u *name1, *name2;
name1 = dict_get_string(*(dict_T**)p1, (char_u*)"name", FALSE); name1 = dict_get_string(*(dict_T**)p1, "name", FALSE);
name2 = dict_get_string(*(dict_T**)p2, (char_u*)"name", FALSE); name2 = dict_get_string(*(dict_T**)p2, "name", FALSE);
if (readdirex_sort == READDIR_SORT_BYTE) if (readdirex_sort == READDIR_SORT_BYTE)
return STRCMP(name1, name2); return STRCMP(name1, name2);
else if (readdirex_sort == READDIR_SORT_IC) else if (readdirex_sort == READDIR_SORT_IC)

View File

@ -1619,7 +1619,7 @@ readdirex_dict_arg(typval_T *tv, int *cmp)
} }
if (dict_has_key(tv->vval.v_dict, "sort")) if (dict_has_key(tv->vval.v_dict, "sort"))
compare = dict_get_string(tv->vval.v_dict, (char_u *)"sort", FALSE); compare = dict_get_string(tv->vval.v_dict, "sort", FALSE);
else else
{ {
semsg(_(e_dictionary_key_str_required), "sort"); semsg(_(e_dictionary_key_str_required), "sort");

View File

@ -8549,7 +8549,7 @@ test_gui_w32_sendevent(dict_T *args)
char_u *event; char_u *event;
INPUT inputs[1]; INPUT inputs[1];
event = dict_get_string(args, (char_u *)"event", TRUE); event = dict_get_string(args, "event", TRUE);
if (event == NULL) if (event == NULL)
return FALSE; return FALSE;
@ -8559,7 +8559,7 @@ test_gui_w32_sendevent(dict_T *args)
{ {
WORD vkCode; WORD vkCode;
vkCode = dict_get_number_def(args, (char_u *)"keycode", 0); vkCode = dict_get_number_def(args, "keycode", 0);
if (vkCode <= 0 || vkCode >= 0xFF) if (vkCode <= 0 || vkCode >= 0xFF)
{ {
semsg(_(e_invalid_argument_nr), (long)vkCode); semsg(_(e_invalid_argument_nr), (long)vkCode);

View File

@ -4317,8 +4317,7 @@ hldict_attr_to_str(
p = attr_str; p = attr_str;
for (i = 0; i < (int)ARRAY_LENGTH(hl_name_table); i++) for (i = 0; i < (int)ARRAY_LENGTH(hl_name_table); i++)
{ {
if (dict_get_bool(attrdict, (char_u *)hl_name_table[i], if (dict_get_bool(attrdict, hl_name_table[i], VVAL_FALSE) == VVAL_TRUE)
VVAL_FALSE) == VVAL_TRUE)
{ {
if (p != attr_str && (size_t)(p - attr_str + 2) < len) if (p != attr_str && (size_t)(p - attr_str + 2) < len)
STRCPY(p, (char_u *)","); STRCPY(p, (char_u *)",");
@ -4398,10 +4397,10 @@ hlg_add_or_update(dict_T *dict)
if (name == NULL || *name == NUL || error) if (name == NULL || *name == NUL || error)
return FALSE; return FALSE;
if (dict_get_bool(dict, (char_u *)"force", VVAL_FALSE) == VVAL_TRUE) if (dict_get_bool(dict, "force", VVAL_FALSE) == VVAL_TRUE)
forceit = TRUE; forceit = TRUE;
if (dict_get_bool(dict, (char_u *)"default", VVAL_FALSE) == VVAL_TRUE) if (dict_get_bool(dict, "default", VVAL_FALSE) == VVAL_TRUE)
dodefault = TRUE; dodefault = TRUE;
if (dict_has_key(dict, "cleared")) if (dict_has_key(dict, "cleared"))
@ -4409,7 +4408,7 @@ hlg_add_or_update(dict_T *dict)
varnumber_T cleared; varnumber_T cleared;
// clear a highlight group // clear a highlight group
cleared = dict_get_bool(dict, (char_u *)"cleared", FALSE); cleared = dict_get_bool(dict, "cleared", FALSE);
if (cleared == TRUE) if (cleared == TRUE)
{ {
vim_snprintf((char *)hlsetBuf, HLSETBUFSZ, "clear %s", name); vim_snprintf((char *)hlsetBuf, HLSETBUFSZ, "clear %s", name);

View File

@ -2767,25 +2767,21 @@ ins_compl_add_tv(typval_T *tv, int dir, int fast)
user_data.v_type = VAR_UNKNOWN; user_data.v_type = VAR_UNKNOWN;
if (tv->v_type == VAR_DICT && tv->vval.v_dict != NULL) if (tv->v_type == VAR_DICT && tv->vval.v_dict != NULL)
{ {
word = dict_get_string(tv->vval.v_dict, (char_u *)"word", FALSE); word = dict_get_string(tv->vval.v_dict, "word", FALSE);
cptext[CPT_ABBR] = dict_get_string(tv->vval.v_dict, cptext[CPT_ABBR] = dict_get_string(tv->vval.v_dict, "abbr", FALSE);
(char_u *)"abbr", FALSE); cptext[CPT_MENU] = dict_get_string(tv->vval.v_dict, "menu", FALSE);
cptext[CPT_MENU] = dict_get_string(tv->vval.v_dict, cptext[CPT_KIND] = dict_get_string(tv->vval.v_dict, "kind", FALSE);
(char_u *)"menu", FALSE); cptext[CPT_INFO] = dict_get_string(tv->vval.v_dict, "info", FALSE);
cptext[CPT_KIND] = dict_get_string(tv->vval.v_dict, dict_get_tv(tv->vval.v_dict, "user_data", &user_data);
(char_u *)"kind", FALSE); if (dict_get_string(tv->vval.v_dict, "icase", FALSE) != NULL
cptext[CPT_INFO] = dict_get_string(tv->vval.v_dict, && dict_get_number(tv->vval.v_dict, "icase"))
(char_u *)"info", FALSE);
dict_get_tv(tv->vval.v_dict, (char_u *)"user_data", &user_data);
if (dict_get_string(tv->vval.v_dict, (char_u *)"icase", FALSE) != NULL
&& dict_get_number(tv->vval.v_dict, (char_u *)"icase"))
flags |= CP_ICASE; flags |= CP_ICASE;
if (dict_get_string(tv->vval.v_dict, (char_u *)"dup", FALSE) != NULL) if (dict_get_string(tv->vval.v_dict, "dup", FALSE) != NULL)
dup = dict_get_number(tv->vval.v_dict, (char_u *)"dup"); dup = dict_get_number(tv->vval.v_dict, "dup");
if (dict_get_string(tv->vval.v_dict, (char_u *)"empty", FALSE) != NULL) if (dict_get_string(tv->vval.v_dict, "empty", FALSE) != NULL)
empty = dict_get_number(tv->vval.v_dict, (char_u *)"empty"); empty = dict_get_number(tv->vval.v_dict, "empty");
if (dict_get_string(tv->vval.v_dict, (char_u *)"equal", FALSE) != NULL if (dict_get_string(tv->vval.v_dict, "equal", FALSE) != NULL
&& dict_get_number(tv->vval.v_dict, (char_u *)"equal")) && dict_get_number(tv->vval.v_dict, "equal"))
flags |= CP_EQUAL; flags |= CP_EQUAL;
} }
else else

View File

@ -2621,8 +2621,8 @@ f_mapset(typval_T *argvars, typval_T *rettv UNUSED)
if (dict_only) if (dict_only)
{ {
d = argvars[0].vval.v_dict; d = argvars[0].vval.v_dict;
which = dict_get_string(d, (char_u *)"mode", FALSE); which = dict_get_string(d, "mode", FALSE);
is_abbr = dict_get_bool(d, (char_u *)"abbr", -1); is_abbr = dict_get_bool(d, "abbr", -1);
if (which == NULL || is_abbr < 0) if (which == NULL || is_abbr < 0)
{ {
emsg(_(e_entries_missing_in_mapset_dict_argument)); emsg(_(e_entries_missing_in_mapset_dict_argument));
@ -2652,10 +2652,10 @@ f_mapset(typval_T *argvars, typval_T *rettv UNUSED)
// Get the values in the same order as above in get_maparg(). // Get the values in the same order as above in get_maparg().
lhs = dict_get_string(d, (char_u *)"lhs", FALSE); lhs = dict_get_string(d, "lhs", FALSE);
lhsraw = dict_get_string(d, (char_u *)"lhsraw", FALSE); lhsraw = dict_get_string(d, "lhsraw", FALSE);
lhsrawalt = dict_get_string(d, (char_u *)"lhsrawalt", FALSE); lhsrawalt = dict_get_string(d, "lhsrawalt", FALSE);
rhs = dict_get_string(d, (char_u *)"rhs", FALSE); rhs = dict_get_string(d, "rhs", FALSE);
if (lhs == NULL || lhsraw == NULL || rhs == NULL) if (lhs == NULL || lhsraw == NULL || rhs == NULL)
{ {
emsg(_(e_entries_missing_in_mapset_dict_argument)); emsg(_(e_entries_missing_in_mapset_dict_argument));
@ -2665,16 +2665,16 @@ f_mapset(typval_T *argvars, typval_T *rettv UNUSED)
rhs = replace_termcodes(rhs, &arg_buf, rhs = replace_termcodes(rhs, &arg_buf,
REPTERM_DO_LT | REPTERM_SPECIAL, NULL); REPTERM_DO_LT | REPTERM_SPECIAL, NULL);
noremap = dict_get_number(d, (char_u *)"noremap") ? REMAP_NONE: 0; noremap = dict_get_number(d, "noremap") ? REMAP_NONE: 0;
if (dict_get_number(d, (char_u *)"script") != 0) if (dict_get_number(d, "script") != 0)
noremap = REMAP_SCRIPT; noremap = REMAP_SCRIPT;
expr = dict_get_number(d, (char_u *)"expr") != 0; expr = dict_get_number(d, "expr") != 0;
silent = dict_get_number(d, (char_u *)"silent") != 0; silent = dict_get_number(d, "silent") != 0;
sid = dict_get_number(d, (char_u *)"sid"); sid = dict_get_number(d, "sid");
scriptversion = dict_get_number(d, (char_u *)"scriptversion"); scriptversion = dict_get_number(d, "scriptversion");
lnum = dict_get_number(d, (char_u *)"lnum"); lnum = dict_get_number(d, "lnum");
buffer = dict_get_number(d, (char_u *)"buffer"); buffer = dict_get_number(d, "buffer");
nowait = dict_get_number(d, (char_u *)"nowait") != 0; nowait = dict_get_number(d, "nowait") != 0;
// mode from the dict is not used // mode from the dict is not used
if (buffer) if (buffer)

View File

@ -961,8 +961,7 @@ matchadd_dict_arg(typval_T *tv, char_u **conceal_char, win_T **win)
} }
if (dict_has_key(tv->vval.v_dict, "conceal")) if (dict_has_key(tv->vval.v_dict, "conceal"))
*conceal_char = dict_get_string(tv->vval.v_dict, *conceal_char = dict_get_string(tv->vval.v_dict, "conceal", FALSE);
(char_u *)"conceal", FALSE);
if ((di = dict_find(tv->vval.v_dict, (char_u *)"window", -1)) != NULL) if ((di = dict_find(tv->vval.v_dict, (char_u *)"window", -1)) != NULL)
{ {
@ -1161,16 +1160,16 @@ f_setmatches(typval_T *argvars UNUSED, typval_T *rettv UNUSED)
} }
} }
group = dict_get_string(d, (char_u *)"group", TRUE); group = dict_get_string(d, "group", TRUE);
priority = (int)dict_get_number(d, (char_u *)"priority"); priority = (int)dict_get_number(d, "priority");
id = (int)dict_get_number(d, (char_u *)"id"); id = (int)dict_get_number(d, "id");
conceal = dict_has_key(d, "conceal") conceal = dict_has_key(d, "conceal")
? dict_get_string(d, (char_u *)"conceal", TRUE) ? dict_get_string(d, "conceal", TRUE)
: NULL; : NULL;
if (i == 0) if (i == 0)
{ {
match_add(win, group, match_add(win, group,
dict_get_string(d, (char_u *)"pattern", FALSE), dict_get_string(d, "pattern", FALSE),
priority, id, NULL, conceal); priority, id, NULL, conceal);
} }
else else

View File

@ -433,7 +433,7 @@ popup_add_timeout(win_T *wp, int time)
static poppos_T static poppos_T
get_pos_entry(dict_T *d, int give_error) get_pos_entry(dict_T *d, int give_error)
{ {
char_u *str = dict_get_string(d, (char_u *)"pos", FALSE); char_u *str = dict_get_string(d, "pos", FALSE);
int nr; int nr;
if (str == NULL) if (str == NULL)
@ -458,13 +458,13 @@ apply_move_options(win_T *wp, dict_T *d)
char_u *str; char_u *str;
dictitem_T *di; dictitem_T *di;
if ((nr = dict_get_number_def(d, (char_u *)"minwidth", -1)) >= 0) if ((nr = dict_get_number_def(d, "minwidth", -1)) >= 0)
wp->w_minwidth = nr; wp->w_minwidth = nr;
if ((nr = dict_get_number_def(d, (char_u *)"minheight", -1)) >= 0) if ((nr = dict_get_number_def(d, "minheight", -1)) >= 0)
wp->w_minheight = nr; wp->w_minheight = nr;
if ((nr = dict_get_number_def(d, (char_u *)"maxwidth", -1)) >= 0) if ((nr = dict_get_number_def(d, "maxwidth", -1)) >= 0)
wp->w_maxwidth = nr; wp->w_maxwidth = nr;
if ((nr = dict_get_number_def(d, (char_u *)"maxheight", -1)) >= 0) if ((nr = dict_get_number_def(d, "maxheight", -1)) >= 0)
wp->w_maxheight = nr; wp->w_maxheight = nr;
nr = popup_options_one(d, (char_u *)"line"); nr = popup_options_one(d, (char_u *)"line");
@ -475,7 +475,7 @@ apply_move_options(win_T *wp, dict_T *d)
wp->w_wantcol = nr; wp->w_wantcol = nr;
nr = dict_get_bool(d, (char_u *)"fixed", -1); nr = dict_get_bool(d, "fixed", -1);
if (nr != -1) if (nr != -1)
wp->w_popup_fixed = nr != 0; wp->w_popup_fixed = nr != 0;
@ -486,7 +486,7 @@ apply_move_options(win_T *wp, dict_T *d)
wp->w_popup_pos = ppt; wp->w_popup_pos = ppt;
} }
str = dict_get_string(d, (char_u *)"textprop", FALSE); str = dict_get_string(d, "textprop", FALSE);
if (str != NULL) if (str != NULL)
{ {
wp->w_popup_prop_type = 0; wp->w_popup_prop_type = 0;
@ -513,7 +513,7 @@ apply_move_options(win_T *wp, dict_T *d)
di = dict_find(d, (char_u *)"textpropid", -1); di = dict_find(d, (char_u *)"textpropid", -1);
if (di != NULL) if (di != NULL)
wp->w_popup_prop_id = dict_get_number(d, (char_u *)"textpropid"); wp->w_popup_prop_id = dict_get_number(d, "textpropid");
} }
/* /*
@ -696,27 +696,27 @@ apply_general_options(win_T *wp, dict_T *dict)
di = dict_find(dict, (char_u *)"firstline", -1); di = dict_find(dict, (char_u *)"firstline", -1);
if (di != NULL) if (di != NULL)
{ {
wp->w_firstline = dict_get_number(dict, (char_u *)"firstline"); wp->w_firstline = dict_get_number(dict, "firstline");
if (wp->w_firstline < 0) if (wp->w_firstline < 0)
wp->w_firstline = -1; wp->w_firstline = -1;
} }
nr = dict_get_bool(dict, (char_u *)"scrollbar", -1); nr = dict_get_bool(dict, "scrollbar", -1);
if (nr != -1) if (nr != -1)
wp->w_want_scrollbar = nr; wp->w_want_scrollbar = nr;
str = dict_get_string(dict, (char_u *)"title", FALSE); str = dict_get_string(dict, "title", FALSE);
if (str != NULL) if (str != NULL)
{ {
vim_free(wp->w_popup_title); vim_free(wp->w_popup_title);
wp->w_popup_title = vim_strsave(str); wp->w_popup_title = vim_strsave(str);
} }
nr = dict_get_bool(dict, (char_u *)"wrap", -1); nr = dict_get_bool(dict, "wrap", -1);
if (nr != -1) if (nr != -1)
wp->w_p_wrap = nr != 0; wp->w_p_wrap = nr != 0;
nr = dict_get_bool(dict, (char_u *)"drag", -1); nr = dict_get_bool(dict, "drag", -1);
if (nr != -1) if (nr != -1)
{ {
if (nr) if (nr)
@ -724,7 +724,7 @@ apply_general_options(win_T *wp, dict_T *dict)
else else
wp->w_popup_flags &= ~POPF_DRAG; wp->w_popup_flags &= ~POPF_DRAG;
} }
nr = dict_get_bool(dict, (char_u *)"dragall", -1); nr = dict_get_bool(dict, "dragall", -1);
if (nr != -1) if (nr != -1)
{ {
if (nr) if (nr)
@ -733,7 +733,7 @@ apply_general_options(win_T *wp, dict_T *dict)
wp->w_popup_flags &= ~POPF_DRAGALL; wp->w_popup_flags &= ~POPF_DRAGALL;
} }
nr = dict_get_bool(dict, (char_u *)"posinvert", -1); nr = dict_get_bool(dict, "posinvert", -1);
if (nr != -1) if (nr != -1)
{ {
if (nr) if (nr)
@ -742,7 +742,7 @@ apply_general_options(win_T *wp, dict_T *dict)
wp->w_popup_flags &= ~POPF_POSINVERT; wp->w_popup_flags &= ~POPF_POSINVERT;
} }
nr = dict_get_bool(dict, (char_u *)"resize", -1); nr = dict_get_bool(dict, "resize", -1);
if (nr != -1) if (nr != -1)
{ {
if (nr) if (nr)
@ -775,7 +775,7 @@ apply_general_options(win_T *wp, dict_T *dict)
semsg(_(e_invalid_value_for_argument_str_str), "close", tv_get_string(&di->di_tv)); semsg(_(e_invalid_value_for_argument_str_str), "close", tv_get_string(&di->di_tv));
} }
str = dict_get_string(dict, (char_u *)"highlight", FALSE); str = dict_get_string(dict, "highlight", FALSE);
if (str != NULL) if (str != NULL)
{ {
set_string_option_direct_in_win(wp, (char_u *)"wincolor", -1, set_string_option_direct_in_win(wp, (char_u *)"wincolor", -1,
@ -861,7 +861,7 @@ apply_general_options(win_T *wp, dict_T *dict)
di = dict_find(dict, (char_u *)"zindex", -1); di = dict_find(dict, (char_u *)"zindex", -1);
if (di != NULL) if (di != NULL)
{ {
wp->w_zindex = dict_get_number(dict, (char_u *)"zindex"); wp->w_zindex = dict_get_number(dict, "zindex");
if (wp->w_zindex < 1) if (wp->w_zindex < 1)
wp->w_zindex = POPUPWIN_DEFAULT_ZINDEX; wp->w_zindex = POPUPWIN_DEFAULT_ZINDEX;
if (wp->w_zindex > 32000) if (wp->w_zindex > 32000)
@ -903,7 +903,7 @@ apply_general_options(win_T *wp, dict_T *dict)
#if defined(FEAT_TIMERS) #if defined(FEAT_TIMERS)
// Add timer to close the popup after some time. // Add timer to close the popup after some time.
nr = dict_get_number(dict, (char_u *)"time"); nr = dict_get_number(dict, "time");
if (nr > 0) if (nr > 0)
popup_add_timeout(wp, nr); popup_add_timeout(wp, nr);
#endif #endif
@ -922,7 +922,7 @@ apply_general_options(win_T *wp, dict_T *dict)
handle_moved_argument(wp, di, TRUE); handle_moved_argument(wp, di, TRUE);
} }
nr = dict_get_bool(dict, (char_u *)"cursorline", -1); nr = dict_get_bool(dict, "cursorline", -1);
if (nr != -1) if (nr != -1)
{ {
if (nr != 0) if (nr != 0)
@ -942,7 +942,7 @@ apply_general_options(win_T *wp, dict_T *dict)
set_callback(&wp->w_filter_cb, &callback); set_callback(&wp->w_filter_cb, &callback);
} }
} }
nr = dict_get_bool(dict, (char_u *)"mapping", -1); nr = dict_get_bool(dict, "mapping", -1);
if (nr != -1) if (nr != -1)
{ {
if (nr) if (nr)
@ -951,7 +951,7 @@ apply_general_options(win_T *wp, dict_T *dict)
wp->w_popup_flags &= ~POPF_MAPPING; wp->w_popup_flags &= ~POPF_MAPPING;
} }
str = dict_get_string(dict, (char_u *)"filtermode", FALSE); str = dict_get_string(dict, "filtermode", FALSE);
if (str != NULL) if (str != NULL)
{ {
if (STRCMP(str, "a") == 0) if (STRCMP(str, "a") == 0)
@ -990,7 +990,7 @@ apply_options(win_T *wp, dict_T *dict, int create)
apply_general_options(wp, dict); apply_general_options(wp, dict);
nr = dict_get_bool(dict, (char_u *)"hidden", FALSE); nr = dict_get_bool(dict, "hidden", FALSE);
if (nr > 0) if (nr > 0)
wp->w_popup_flags |= POPF_HIDDEN | POPF_HIDDEN_FORCE; wp->w_popup_flags |= POPF_HIDDEN | POPF_HIDDEN_FORCE;
@ -1051,8 +1051,7 @@ add_popup_dicts(buf_T *buf, list_T *l)
return; return;
} }
dict = li->li_tv.vval.v_dict; dict = li->li_tv.vval.v_dict;
p = dict == NULL ? NULL p = dict == NULL ? NULL : dict_get_string(dict, "text", FALSE);
: dict_get_string(dict, (char_u *)"text", FALSE);
ml_append_buf(buf, lnum++, ml_append_buf(buf, lnum++,
p == NULL ? (char_u *)"" : p, (colnr_T)0, TRUE); p == NULL ? (char_u *)"" : p, (colnr_T)0, TRUE);
} }
@ -1086,7 +1085,7 @@ add_popup_dicts(buf_T *buf, list_T *l)
dict = pli->li_tv.vval.v_dict; dict = pli->li_tv.vval.v_dict;
if (dict != NULL) if (dict != NULL)
{ {
int col = dict_get_number(dict, (char_u *)"col"); int col = dict_get_number(dict, "col");
prop_add_common( lnum, col, dict, buf, NULL); prop_add_common( lnum, col, dict, buf, NULL);
} }
@ -1975,7 +1974,7 @@ popup_create(typval_T *argvars, typval_T *rettv, create_type_T type)
if (d != NULL) if (d != NULL)
{ {
if (dict_has_key(d, "tabpage")) if (dict_has_key(d, "tabpage"))
tabnr = (int)dict_get_number(d, (char_u *)"tabpage"); tabnr = (int)dict_get_number(d, "tabpage");
else if (type == TYPE_NOTIFICATION) else if (type == TYPE_NOTIFICATION)
tabnr = -1; // notifications are global by default tabnr = -1; // notifications are global by default
else else

View File

@ -28,12 +28,12 @@ int dict_add_dict(dict_T *d, char *key, dict_T *dict);
long dict_len(dict_T *d); long dict_len(dict_T *d);
dictitem_T *dict_find(dict_T *d, char_u *key, int len); dictitem_T *dict_find(dict_T *d, char_u *key, int len);
int dict_has_key(dict_T *d, char *key); int dict_has_key(dict_T *d, char *key);
int dict_get_tv(dict_T *d, char_u *key, typval_T *rettv); int dict_get_tv(dict_T *d, char *key, typval_T *rettv);
char_u *dict_get_string(dict_T *d, char_u *key, int save); char_u *dict_get_string(dict_T *d, char *key, int save);
varnumber_T dict_get_number(dict_T *d, char_u *key); varnumber_T dict_get_number(dict_T *d, char *key);
varnumber_T dict_get_number_def(dict_T *d, char_u *key, int def); varnumber_T dict_get_number_def(dict_T *d, char *key, int def);
varnumber_T dict_get_number_check(dict_T *d, char_u *key); varnumber_T dict_get_number_check(dict_T *d, char_u *key);
varnumber_T dict_get_bool(dict_T *d, char_u *key, int def); varnumber_T dict_get_bool(dict_T *d, char *key, int def);
char_u *dict2string(typval_T *tv, int copyID, int restore_copyID); char_u *dict2string(typval_T *tv, int copyID, int restore_copyID);
char_u *get_literal_key(char_u **arg); char_u *get_literal_key(char_u **arg);
int eval_dict(char_u **arg, typval_T *rettv, evalarg_T *evalarg, int literal); int eval_dict(char_u **arg, typval_T *rettv, evalarg_T *evalarg, int literal);

View File

@ -7209,18 +7209,18 @@ qf_add_entry_from_dict(
if (first_entry) if (first_entry)
did_bufnr_emsg = FALSE; did_bufnr_emsg = FALSE;
filename = dict_get_string(d, (char_u *)"filename", TRUE); filename = dict_get_string(d, "filename", TRUE);
module = dict_get_string(d, (char_u *)"module", TRUE); module = dict_get_string(d, "module", TRUE);
bufnum = (int)dict_get_number(d, (char_u *)"bufnr"); bufnum = (int)dict_get_number(d, "bufnr");
lnum = (int)dict_get_number(d, (char_u *)"lnum"); lnum = (int)dict_get_number(d, "lnum");
end_lnum = (int)dict_get_number(d, (char_u *)"end_lnum"); end_lnum = (int)dict_get_number(d, "end_lnum");
col = (int)dict_get_number(d, (char_u *)"col"); col = (int)dict_get_number(d, "col");
end_col = (int)dict_get_number(d, (char_u *)"end_col"); end_col = (int)dict_get_number(d, "end_col");
vcol = (int)dict_get_number(d, (char_u *)"vcol"); vcol = (int)dict_get_number(d, "vcol");
nr = (int)dict_get_number(d, (char_u *)"nr"); nr = (int)dict_get_number(d, "nr");
type = dict_get_string(d, (char_u *)"type", TRUE); type = dict_get_string(d, "type", TRUE);
pattern = dict_get_string(d, (char_u *)"pattern", TRUE); pattern = dict_get_string(d, "pattern", TRUE);
text = dict_get_string(d, (char_u *)"text", TRUE); text = dict_get_string(d, "text", TRUE);
if (text == NULL) if (text == NULL)
text = vim_strsave((char_u *)""); text = vim_strsave((char_u *)"");
@ -7243,7 +7243,7 @@ qf_add_entry_from_dict(
// If the 'valid' field is present it overrules the detected value. // If the 'valid' field is present it overrules the detected value.
if (dict_has_key(d, "valid")) if (dict_has_key(d, "valid"))
valid = (int)dict_get_bool(d, (char_u *)"valid", FALSE); valid = (int)dict_get_bool(d, "valid", FALSE);
status = qf_add_entry(qfl, status = qf_add_entry(qfl,
NULL, // dir NULL, // dir
@ -7419,7 +7419,7 @@ qf_setprop_title(qf_info_T *qi, int qf_idx, dict_T *what, dictitem_T *di)
return FAIL; return FAIL;
vim_free(qfl->qf_title); vim_free(qfl->qf_title);
qfl->qf_title = dict_get_string(what, (char_u *)"title", TRUE); qfl->qf_title = dict_get_string(what, "title", TRUE);
if (qf_idx == qi->qf_curlist) if (qf_idx == qi->qf_curlist)
qf_update_win_titlevar(qi); qf_update_win_titlevar(qi);

View File

@ -4115,7 +4115,7 @@ f_searchcount(typval_T *argvars, typval_T *rettv)
if (error) if (error)
return; return;
} }
recompute = dict_get_bool(dict, (char_u *)"recompute", recompute); recompute = dict_get_bool(dict, "recompute", recompute);
di = dict_find(dict, (char_u *)"pattern", -1); di = dict_find(dict, (char_u *)"pattern", -1);
if (di != NULL) if (di != NULL)
{ {
@ -4645,7 +4645,8 @@ fuzzy_match_in_list(
// For a dict, either use the specified key to lookup the string or // For a dict, either use the specified key to lookup the string or
// use the specified callback function to get the string. // use the specified callback function to get the string.
if (key != NULL) if (key != NULL)
itemstr = dict_get_string(li->li_tv.vval.v_dict, key, FALSE); itemstr = dict_get_string(li->li_tv.vval.v_dict,
(char *)key, FALSE);
else else
{ {
typval_T argv[2]; typval_T argv[2];

View File

@ -2267,7 +2267,7 @@ sign_define_from_dict(char_u *name_arg, dict_T *dict)
{ {
if (dict == NULL) if (dict == NULL)
return -1; return -1;
name = dict_get_string(dict, (char_u *)"name", TRUE); name = dict_get_string(dict, "name", TRUE);
} }
else else
name = vim_strsave(name_arg); name = vim_strsave(name_arg);
@ -2275,12 +2275,12 @@ sign_define_from_dict(char_u *name_arg, dict_T *dict)
goto cleanup; goto cleanup;
if (dict != NULL) if (dict != NULL)
{ {
icon = dict_get_string(dict, (char_u *)"icon", TRUE); icon = dict_get_string(dict, "icon", TRUE);
linehl = dict_get_string(dict, (char_u *)"linehl", TRUE); linehl = dict_get_string(dict, "linehl", TRUE);
text = dict_get_string(dict, (char_u *)"text", TRUE); text = dict_get_string(dict, "text", TRUE);
texthl = dict_get_string(dict, (char_u *)"texthl", TRUE); texthl = dict_get_string(dict, "texthl", TRUE);
culhl = dict_get_string(dict, (char_u *)"culhl", TRUE); culhl = dict_get_string(dict, "culhl", TRUE);
numhl = dict_get_string(dict, (char_u *)"numhl", TRUE); numhl = dict_get_string(dict, "numhl", TRUE);
} }
if (sign_define_by_name(name, icon, linehl, text, texthl, culhl, numhl) == OK) if (sign_define_by_name(name, icon, linehl, text, texthl, culhl, numhl) == OK)
@ -2765,7 +2765,7 @@ sign_unplace_from_dict(typval_T *group_tv, dict_T *dict)
if (group_tv != NULL) if (group_tv != NULL)
group = tv_get_string(group_tv); group = tv_get_string(group_tv);
else else
group = dict_get_string(dict, (char_u *)"group", FALSE); group = dict_get_string(dict, "group", FALSE);
if (group != NULL) if (group != NULL)
{ {
if (group[0] == '\0') // global sign group if (group[0] == '\0') // global sign group
@ -2788,7 +2788,7 @@ sign_unplace_from_dict(typval_T *group_tv, dict_T *dict)
} }
if (dict_has_key(dict, "id")) if (dict_has_key(dict, "id"))
{ {
sign_id = dict_get_number(dict, (char_u *)"id"); sign_id = dict_get_number(dict, "id");
if (sign_id <= 0) if (sign_id <= 0)
{ {
emsg(_(e_invalid_argument)); emsg(_(e_invalid_argument));

View File

@ -4589,17 +4589,16 @@ tagstack_push_items(win_T *wp, list_T *l)
continue; continue;
if (list2fpos(&di->di_tv, &mark, &fnum, NULL, FALSE) != OK) if (list2fpos(&di->di_tv, &mark, &fnum, NULL, FALSE) != OK)
continue; continue;
if ((tagname = if ((tagname = dict_get_string(itemdict, "tagname", TRUE)) == NULL)
dict_get_string(itemdict, (char_u *)"tagname", TRUE)) == NULL)
continue; continue;
if (mark.col > 0) if (mark.col > 0)
mark.col--; mark.col--;
tagstack_push_item(wp, tagname, tagstack_push_item(wp, tagname,
(int)dict_get_number(itemdict, (char_u *)"bufnr"), (int)dict_get_number(itemdict, "bufnr"),
(int)dict_get_number(itemdict, (char_u *)"matchnr") - 1, (int)dict_get_number(itemdict, "matchnr") - 1,
mark, fnum, mark, fnum,
dict_get_string(itemdict, (char_u *)"user_data", TRUE)); dict_get_string(itemdict, "user_data", TRUE));
} }
} }

View File

@ -4338,9 +4338,9 @@ handle_drop_command(listitem_T *item)
dict_T *dict = opt_item->li_tv.vval.v_dict; dict_T *dict = opt_item->li_tv.vval.v_dict;
char_u *p; char_u *p;
p = dict_get_string(dict, (char_u *)"ff", FALSE); p = dict_get_string(dict, "ff", FALSE);
if (p == NULL) if (p == NULL)
p = dict_get_string(dict, (char_u *)"fileformat", FALSE); p = dict_get_string(dict, "fileformat", FALSE);
if (p != NULL) if (p != NULL)
{ {
if (check_ff_value(p) == FAIL) if (check_ff_value(p) == FAIL)
@ -4348,9 +4348,9 @@ handle_drop_command(listitem_T *item)
else else
ea.force_ff = *p; ea.force_ff = *p;
} }
p = dict_get_string(dict, (char_u *)"enc", FALSE); p = dict_get_string(dict, "enc", FALSE);
if (p == NULL) if (p == NULL)
p = dict_get_string(dict, (char_u *)"encoding", FALSE); p = dict_get_string(dict, "encoding", FALSE);
if (p != NULL) if (p != NULL)
{ {
ea.cmd = alloc(STRLEN(p) + 12); ea.cmd = alloc(STRLEN(p) + 12);
@ -4362,7 +4362,7 @@ handle_drop_command(listitem_T *item)
} }
} }
p = dict_get_string(dict, (char_u *)"bad", FALSE); p = dict_get_string(dict, "bad", FALSE);
if (p != NULL) if (p != NULL)
get_bad_opt(p, &ea); get_bad_opt(p, &ea);
@ -4995,8 +4995,8 @@ f_term_dumpwrite(typval_T *argvars, typval_T *rettv UNUSED)
d = argvars[2].vval.v_dict; d = argvars[2].vval.v_dict;
if (d != NULL) if (d != NULL)
{ {
max_height = dict_get_number(d, (char_u *)"rows"); max_height = dict_get_number(d, "rows");
max_width = dict_get_number(d, (char_u *)"columns"); max_width = dict_get_number(d, "columns");
} }
} }

View File

@ -1295,10 +1295,10 @@ test_gui_drop_files(dict_T *args UNUSED)
|| !dict_has_key(args, "modifiers")) || !dict_has_key(args, "modifiers"))
return FALSE; return FALSE;
(void)dict_get_tv(args, (char_u *)"files", &t); (void)dict_get_tv(args, "files", &t);
row = (int)dict_get_number(args, (char_u *)"row"); row = (int)dict_get_number(args, "row");
col = (int)dict_get_number(args, (char_u *)"col"); col = (int)dict_get_number(args, "col");
mods = (int)dict_get_number(args, (char_u *)"modifiers"); mods = (int)dict_get_number(args, "modifiers");
if (t.v_type != VAR_LIST || list_len(t.vval.v_list) == 0) if (t.v_type != VAR_LIST || list_len(t.vval.v_list) == 0)
return FALSE; return FALSE;
@ -1351,10 +1351,10 @@ test_gui_find_repl(dict_T *args)
|| !dict_has_key(args, "forward")) || !dict_has_key(args, "forward"))
return FALSE; return FALSE;
find_text = dict_get_string(args, (char_u *)"find_text", TRUE); find_text = dict_get_string(args, "find_text", TRUE);
repl_text = dict_get_string(args, (char_u *)"repl_text", TRUE); repl_text = dict_get_string(args, "repl_text", TRUE);
flags = (int)dict_get_number(args, (char_u *)"flags"); flags = (int)dict_get_number(args, "flags");
forward = (int)dict_get_number(args, (char_u *)"forward"); forward = (int)dict_get_number(args, "forward");
retval = gui_do_findrepl(flags, find_text, repl_text, forward); retval = gui_do_findrepl(flags, find_text, repl_text, forward);
vim_free(find_text); vim_free(find_text);
@ -1379,19 +1379,19 @@ test_gui_mouse_event(dict_T *args)
return FALSE; return FALSE;
// Note: "move" is optional, requires fewer arguments // Note: "move" is optional, requires fewer arguments
move = (int)dict_get_bool(args, (char_u *)"move", FALSE); move = (int)dict_get_bool(args, "move", FALSE);
if (!move && (!dict_has_key(args, "button") if (!move && (!dict_has_key(args, "button")
|| !dict_has_key(args, "multiclick") || !dict_has_key(args, "multiclick")
|| !dict_has_key(args, "modifiers"))) || !dict_has_key(args, "modifiers")))
return FALSE; return FALSE;
row = (int)dict_get_number(args, (char_u *)"row"); row = (int)dict_get_number(args, "row");
col = (int)dict_get_number(args, (char_u *)"col"); col = (int)dict_get_number(args, "col");
if (move) if (move)
{ {
if (dict_get_bool(args, (char_u *)"cell", FALSE)) if (dict_get_bool(args, "cell", FALSE))
{ {
// click in the middle of the character cell // click in the middle of the character cell
row = row * gui.char_height + gui.char_height / 2; row = row * gui.char_height + gui.char_height / 2;
@ -1401,9 +1401,9 @@ test_gui_mouse_event(dict_T *args)
} }
else else
{ {
button = (int)dict_get_number(args, (char_u *)"button"); button = (int)dict_get_number(args, "button");
repeated_click = (int)dict_get_number(args, (char_u *)"multiclick"); repeated_click = (int)dict_get_number(args, "multiclick");
mods = (int)dict_get_number(args, (char_u *)"modifiers"); mods = (int)dict_get_number(args, "modifiers");
// Reset the scroll values to known values. // Reset the scroll values to known values.
// XXX: Remove this when/if the scroll step is made configurable. // XXX: Remove this when/if the scroll step is made configurable.
@ -1430,9 +1430,9 @@ test_gui_scrollbar(dict_T *args)
|| !dict_has_key(args, "dragging")) || !dict_has_key(args, "dragging"))
return FALSE; return FALSE;
which = dict_get_string(args, (char_u *)"which", FALSE); which = dict_get_string(args, "which", FALSE);
value = (long)dict_get_number(args, (char_u *)"value"); value = (long)dict_get_number(args, "value");
dragging = (int)dict_get_number(args, (char_u *)"dragging"); dragging = (int)dict_get_number(args, "dragging");
if (STRCMP(which, "left") == 0) if (STRCMP(which, "left") == 0)
sb = &curwin->w_scrollbars[SBAR_LEFT]; sb = &curwin->w_scrollbars[SBAR_LEFT];
@ -1463,7 +1463,7 @@ test_gui_tabline_event(dict_T *args UNUSED)
if (!dict_has_key(args, "tabnr")) if (!dict_has_key(args, "tabnr"))
return FALSE; return FALSE;
tabnr = (int)dict_get_number(args, (char_u *)"tabnr"); tabnr = (int)dict_get_number(args, "tabnr");
return send_tabline_event(tabnr); return send_tabline_event(tabnr);
# else # else
@ -1482,8 +1482,8 @@ test_gui_tabmenu_event(dict_T *args UNUSED)
|| !dict_has_key(args, "item")) || !dict_has_key(args, "item"))
return FALSE; return FALSE;
tabnr = (int)dict_get_number(args, (char_u *)"tabnr"); tabnr = (int)dict_get_number(args, "tabnr");
item = (int)dict_get_number(args, (char_u *)"item"); item = (int)dict_get_number(args, "item");
send_tabline_menu_event(tabnr, item); send_tabline_menu_event(tabnr, item);
# endif # endif

View File

@ -336,10 +336,10 @@ f_prop_add_list(typval_T *argvars, typval_T *rettv UNUSED)
emsg(_(e_missing_property_type_name)); emsg(_(e_missing_property_type_name));
return; return;
} }
type_name = dict_get_string(dict, (char_u *)"type", FALSE); type_name = dict_get_string(dict, "type", FALSE);
if (dict_has_key(dict, "id")) if (dict_has_key(dict, "id"))
id = dict_get_number(dict, (char_u *)"id"); id = dict_get_number(dict, "id");
if (get_bufnr_from_arg(&argvars[0], &buf) == FAIL) if (get_bufnr_from_arg(&argvars[0], &buf) == FAIL)
return; return;
@ -399,11 +399,11 @@ prop_add_common(
emsg(_(e_missing_property_type_name)); emsg(_(e_missing_property_type_name));
return; return;
} }
type_name = dict_get_string(dict, (char_u *)"type", FALSE); type_name = dict_get_string(dict, "type", FALSE);
if (dict_has_key(dict, "end_lnum")) if (dict_has_key(dict, "end_lnum"))
{ {
end_lnum = dict_get_number(dict, (char_u *)"end_lnum"); end_lnum = dict_get_number(dict, "end_lnum");
if (end_lnum < start_lnum) if (end_lnum < start_lnum)
{ {
semsg(_(e_invalid_value_for_argument_str), "end_lnum"); semsg(_(e_invalid_value_for_argument_str), "end_lnum");
@ -415,7 +415,7 @@ prop_add_common(
if (dict_has_key(dict, "length")) if (dict_has_key(dict, "length"))
{ {
long length = dict_get_number(dict, (char_u *)"length"); long length = dict_get_number(dict, "length");
if (length < 0 || end_lnum > start_lnum) if (length < 0 || end_lnum > start_lnum)
{ {
@ -426,7 +426,7 @@ prop_add_common(
} }
else if (dict_has_key(dict, "end_col")) else if (dict_has_key(dict, "end_col"))
{ {
end_col = dict_get_number(dict, (char_u *)"end_col"); end_col = dict_get_number(dict, "end_col");
if (end_col <= 0) if (end_col <= 0)
{ {
semsg(_(e_invalid_value_for_argument_str), "end_col"); semsg(_(e_invalid_value_for_argument_str), "end_col");
@ -439,7 +439,7 @@ prop_add_common(
end_col = 1; end_col = 1;
if (dict_has_key(dict, "id")) if (dict_has_key(dict, "id"))
id = dict_get_number(dict, (char_u *)"id"); id = dict_get_number(dict, "id");
if (dict_arg != NULL && get_bufnr_from_arg(dict_arg, &buf) == FAIL) if (dict_arg != NULL && get_bufnr_from_arg(dict_arg, &buf) == FAIL)
return; return;
@ -784,23 +784,23 @@ f_prop_find(typval_T *argvars, typval_T *rettv)
return; return;
} }
skipstart = dict_get_bool(dict, (char_u *)"skipstart", 0); skipstart = dict_get_bool(dict, "skipstart", 0);
if (dict_has_key(dict, "id")) if (dict_has_key(dict, "id"))
{ {
id = dict_get_number(dict, (char_u *)"id"); id = dict_get_number(dict, "id");
id_found = TRUE; id_found = TRUE;
} }
if (dict_has_key(dict, "type")) if (dict_has_key(dict, "type"))
{ {
char_u *name = dict_get_string(dict, (char_u *)"type", FALSE); char_u *name = dict_get_string(dict, "type", FALSE);
proptype_T *type = lookup_prop_type(name, buf); proptype_T *type = lookup_prop_type(name, buf);
if (type == NULL) if (type == NULL)
return; return;
type_id = type->pt_id; type_id = type->pt_id;
} }
both = dict_get_bool(dict, (char_u *)"both", FALSE); both = dict_get_bool(dict, "both", FALSE);
if (!id_found && type_id == -1) if (!id_found && type_id == -1)
{ {
emsg(_(e_need_at_least_one_of_id_or_type)); emsg(_(e_need_at_least_one_of_id_or_type));
@ -1213,20 +1213,20 @@ f_prop_remove(typval_T *argvars, typval_T *rettv)
if (buf->b_ml.ml_mfp == NULL) if (buf->b_ml.ml_mfp == NULL)
return; return;
do_all = dict_get_bool(dict, (char_u *)"all", FALSE); do_all = dict_get_bool(dict, "all", FALSE);
if (dict_has_key(dict, "id")) if (dict_has_key(dict, "id"))
id = dict_get_number(dict, (char_u *)"id"); id = dict_get_number(dict, "id");
if (dict_has_key(dict, "type")) if (dict_has_key(dict, "type"))
{ {
char_u *name = dict_get_string(dict, (char_u *)"type", FALSE); char_u *name = dict_get_string(dict, "type", FALSE);
proptype_T *type = lookup_prop_type(name, buf); proptype_T *type = lookup_prop_type(name, buf);
if (type == NULL) if (type == NULL)
return; return;
type_id = type->pt_id; type_id = type->pt_id;
} }
both = dict_get_bool(dict, (char_u *)"both", FALSE); both = dict_get_bool(dict, "both", FALSE);
if (id == -1 && type_id == -1) if (id == -1 && type_id == -1)
{ {
@ -1383,7 +1383,7 @@ prop_type_set(typval_T *argvars, int add)
char_u *highlight; char_u *highlight;
int hl_id = 0; int hl_id = 0;
highlight = dict_get_string(dict, (char_u *)"highlight", FALSE); highlight = dict_get_string(dict, "highlight", FALSE);
if (highlight != NULL && *highlight != NUL) if (highlight != NULL && *highlight != NUL)
hl_id = syn_name2id(highlight); hl_id = syn_name2id(highlight);
if (hl_id <= 0) if (hl_id <= 0)

View File

@ -863,7 +863,7 @@ f_timer_start(typval_T *argvars, typval_T *rettv)
return; return;
} }
if (dict_has_key(dict, "repeat")) if (dict_has_key(dict, "repeat"))
repeat = dict_get_number(dict, (char_u *)"repeat"); repeat = dict_get_number(dict, "repeat");
} }
callback = get_callback(&argvars[1]); callback = get_callback(&argvars[1]);

View File

@ -735,6 +735,8 @@ static char *(features[]) =
static int included_patches[] = static int included_patches[] =
{ /* Add new patch number below this line */ { /* Add new patch number below this line */
/**/
63,
/**/ /**/
62, 62,
/**/ /**/