aboutsummaryrefslogtreecommitdiff
path: root/src/nvim/eval.c
diff options
context:
space:
mode:
authorShougo Matsushita <Shougo.Matsu@gmail.com>2019-07-06 17:10:12 +0900
committerShougo Matsushita <Shougo.Matsu@gmail.com>2019-07-06 17:11:27 +0900
commit5f7e0531c1fe4eb069667e09c0e251e1c6fdee68 (patch)
tree9211c65c56af32baf7a13cfc61175dd8830644b1 /src/nvim/eval.c
parent3f6346b73265d22b2a2baeedb1e0575938fea727 (diff)
downloadrneovim-5f7e0531c1fe4eb069667e09c0e251e1c6fdee68.tar.gz
rneovim-5f7e0531c1fe4eb069667e09c0e251e1c6fdee68.tar.bz2
rneovim-5f7e0531c1fe4eb069667e09c0e251e1c6fdee68.zip
vim-patch:8.1.1611: bufadd() reuses existing buffer without a name
Problem: Bufadd() reuses existing buffer without a name. Solution: When the name is empty always create a new buffer. https://github.com/vim/vim/commit/892ae723ab95e429222e930cf41b32809567e58e
Diffstat (limited to 'src/nvim/eval.c')
-rw-r--r--src/nvim/eval.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/src/nvim/eval.c b/src/nvim/eval.c
index 659f957fd1..15202591f6 100644
--- a/src/nvim/eval.c
+++ b/src/nvim/eval.c
@@ -7292,7 +7292,9 @@ static buf_T *find_buffer(typval_T *avar)
// "bufadd(expr)" function
static void f_bufadd(typval_T *argvars, typval_T *rettv, FunPtr fptr)
{
- rettv->vval.v_number = buflist_add(tv_get_string(&argvars[0]), 0);
+ char_u *name = tv_get_string(&argvars[0]);
+
+ rettv->vval.v_number = buflist_add(*name == NUL ? NULL : name, 0);
}
/*