diff options
| author | ZyX <kp-pav@yandex.ru> | 2017-01-11 23:20:03 +0300 | 
|---|---|---|
| committer | ZyX <kp-pav@yandex.ru> | 2017-03-29 10:07:43 +0300 | 
| commit | 210342d795a13e88579d3e55ae931463d16f241d (patch) | |
| tree | 573a9b67eb7ed9142c75560aa1b38a37f7a5dc03 /src/nvim/eval/typval.c | |
| parent | 983a5532ca17060508ea308a9b7069dae4facb59 (diff) | |
| download | rneovim-210342d795a13e88579d3e55ae931463d16f241d.tar.gz rneovim-210342d795a13e88579d3e55ae931463d16f241d.tar.bz2 rneovim-210342d795a13e88579d3e55ae931463d16f241d.zip | |
eval: Move dict_add_list and dict_add_dict to typval.c
Diffstat (limited to 'src/nvim/eval/typval.c')
| -rw-r--r-- | src/nvim/eval/typval.c | 52 | 
1 files changed, 52 insertions, 0 deletions
| diff --git a/src/nvim/eval/typval.c b/src/nvim/eval/typval.c index 0df818040b..f9885926c7 100644 --- a/src/nvim/eval/typval.c +++ b/src/nvim/eval/typval.c @@ -1166,6 +1166,58 @@ bool tv_dict_get_callback(dict_T *const d,    return res;  } +//{{{2 dict_add* + +/// Add a list entry to dictionary +/// +/// @param[out]  d  Dictionary to add entry to. +/// @param[in]  key  Key to add. +/// @param[in]  key_len  Key length. +/// @param  list  List to add. Will have reference count incremented. +/// +/// @return OK in case of success, FAIL when key already exists. +int tv_dict_add_list(dict_T *const d, const char *const key, +                     const size_t key_len, list_T *const list) +  FUNC_ATTR_NONNULL_ALL +{ +  dictitem_T *item = tv_dict_item_alloc_len(key, key_len); + +  item->di_tv.v_lock = VAR_UNLOCKED; +  item->di_tv.v_type = VAR_LIST; +  item->di_tv.vval.v_list = list; +  if (tv_dict_add(d, item) == FAIL) { +    tv_dict_item_free(item); +    return FAIL; +  } +  list->lv_refcount++; +  return OK; +} + +/// Add a dictionary entry to dictionary +/// +/// @param[out]  d  Dictionary to add entry to. +/// @param[in]  key  Key to add. +/// @param[in]  key_len  Key length. +/// @param  dict  Dictionary to add. Will have reference count incremented. +/// +/// @return OK in case of success, FAIL when key already exists. +int tv_dict_add_dict(dict_T *const d, const char *const key, +                     const size_t key_len, dict_T *const dict) +    FUNC_ATTR_NONNULL_ALL +{ +  dictitem_T *const item = tv_dict_item_alloc(key); + +  item->di_tv.v_lock = VAR_UNLOCKED; +  item->di_tv.v_type = VAR_DICT; +  item->di_tv.vval.v_dict = dict; +  if (tv_dict_add(d, item) == FAIL) { +    tv_dict_item_free(item); +    return FAIL; +  } +  dict->dv_refcount++; +  return OK; +} +  //{{{2 Operations on the whole dict  /// Clear all the keys of a Dictionary. "d" remains a valid empty Dictionary. | 
