aboutsummaryrefslogtreecommitdiff
path: root/src/nvim/eval.c
diff options
context:
space:
mode:
authorBjörn Linse <bjorn.linse@gmail.com>2016-04-21 20:11:27 +0200
committerBjörn Linse <bjorn.linse@gmail.com>2016-04-21 20:11:27 +0200
commitcef624ee9e14bf15598219d96f65a6e4932eb935 (patch)
tree24afb43c916063c690d7a8f5fb319cac407aeb01 /src/nvim/eval.c
parenta7a0bf54e3f339f7bf1f97dee44546cdcd926b1d (diff)
parentce17d031805ab548f26f5b2d519fb8e3bf1bbff1 (diff)
downloadrneovim-cef624ee9e14bf15598219d96f65a6e4932eb935.tar.gz
rneovim-cef624ee9e14bf15598219d96f65a6e4932eb935.tar.bz2
rneovim-cef624ee9e14bf15598219d96f65a6e4932eb935.zip
Merge pull request #4618 from bfredl/regcrash
eval: make sure getreg() returns a valid list for an unset register (vim-patch:7.4.1755)
Diffstat (limited to 'src/nvim/eval.c')
-rw-r--r--src/nvim/eval.c5
1 files changed, 3 insertions, 2 deletions
diff --git a/src/nvim/eval.c b/src/nvim/eval.c
index e9b1df6367..b51480afc6 100644
--- a/src/nvim/eval.c
+++ b/src/nvim/eval.c
@@ -10096,9 +10096,10 @@ static void f_getreg(typval_T *argvars, typval_T *rettv)
rettv->v_type = VAR_LIST;
rettv->vval.v_list =
get_reg_contents(regname, (arg2 ? kGRegExprSrc : 0) | kGRegList);
- if (rettv->vval.v_list != NULL) {
- rettv->vval.v_list->lv_refcount++;
+ if (rettv->vval.v_list == NULL) {
+ rettv->vval.v_list = list_alloc();
}
+ rettv->vval.v_list->lv_refcount++;
} else {
rettv->v_type = VAR_STRING;
rettv->vval.v_string = get_reg_contents(regname, arg2 ? kGRegExprSrc : 0);