diff options
author | James McCoy <jamessan@jamessan.com> | 2016-06-09 21:56:49 -0400 |
---|---|---|
committer | GitHub <noreply@github.com> | 2016-06-09 21:56:49 -0400 |
commit | b3f6b3075188860454e6000c765f8483c5ca782a (patch) | |
tree | e0bc267f245eb7e7a069e75d4521344d75eea007 /src/nvim/eval.c | |
parent | 56e9e81115f9c551c5820cb49284602224e0e84e (diff) | |
parent | 1e6fa9338e58a3ed9f014ffea4ed52df78f1258b (diff) | |
download | rneovim-b3f6b3075188860454e6000c765f8483c5ca782a.tar.gz rneovim-b3f6b3075188860454e6000c765f8483c5ca782a.tar.bz2 rneovim-b3f6b3075188860454e6000c765f8483c5ca782a.zip |
Merge pull request #4788 from brcolow/vim-7.4.1051
vim-patch:7.4.{1051,1068}
Diffstat (limited to 'src/nvim/eval.c')
-rw-r--r-- | src/nvim/eval.c | 12 |
1 files changed, 11 insertions, 1 deletions
diff --git a/src/nvim/eval.c b/src/nvim/eval.c index d8c3933ac1..d8f1ce8494 100644 --- a/src/nvim/eval.c +++ b/src/nvim/eval.c @@ -2979,11 +2979,16 @@ int do_unlet(char_u *name, int forceit) } else if (current_funccal != NULL && ht == ¤t_funccal->l_vars.dv_hashtab) { d = ¤t_funccal->l_vars; + } else if (ht == &compat_hashtab) { + d = &vimvardict; } else { di = find_var_in_ht(ht, *name, (char_u *)"", false); d = di->di_tv.vval.v_dict; } - + if (d == NULL) { + EMSG2(_(e_intern2), "do_unlet()"); + return FAIL; + } hi = hash_find(ht, varname); if (!HASHITEM_EMPTY(hi)) { di = HI2DI(hi); @@ -2992,6 +2997,11 @@ int do_unlet(char_u *name, int forceit) || tv_check_lock(d->dv_lock, name, false)) { return FAIL; } + + if (d == NULL || tv_check_lock(d->dv_lock, name, false)) { + return FAIL; + } + typval_T oldtv; bool watched = is_watched(dict); |