aboutsummaryrefslogtreecommitdiff
path: root/src/nvim/eval.c
diff options
context:
space:
mode:
authorJustin M. Keyes <justinkz@gmail.com>2019-07-13 12:36:32 +0200
committerGitHub <noreply@github.com>2019-07-13 12:36:32 +0200
commite1fae8f1fe940db6a0ecddfcf88afeaacf6bb9d4 (patch)
tree0a8853953c37a87fa6326b805015ba455fbfec58 /src/nvim/eval.c
parent06826139e121fb4e003ac409bd17ebb7428d19fd (diff)
parentb9474b0641d0a91a639a77876edd2f5c918f9a70 (diff)
downloadrneovim-e1fae8f1fe940db6a0ecddfcf88afeaacf6bb9d4.tar.gz
rneovim-e1fae8f1fe940db6a0ecddfcf88afeaacf6bb9d4.tar.bz2
rneovim-e1fae8f1fe940db6a0ecddfcf88afeaacf6bb9d4.zip
Merge #10435 from Shougo/vim-8.1.1610
Diffstat (limited to 'src/nvim/eval.c')
-rw-r--r--src/nvim/eval.c23
1 files changed, 23 insertions, 0 deletions
diff --git a/src/nvim/eval.c b/src/nvim/eval.c
index a1cb79d77d..418725fa44 100644
--- a/src/nvim/eval.c
+++ b/src/nvim/eval.c
@@ -7294,6 +7294,14 @@ static buf_T *find_buffer(typval_T *avar)
return buf;
}
+// "bufadd(expr)" function
+static void f_bufadd(typval_T *argvars, typval_T *rettv, FunPtr fptr)
+{
+ char_u *name = (char_u *)tv_get_string(&argvars[0]);
+
+ rettv->vval.v_number = buflist_add(*name == NUL ? NULL : name, 0);
+}
+
/*
* "bufexists(expr)" function
*/
@@ -7313,6 +7321,21 @@ static void f_buflisted(typval_T *argvars, typval_T *rettv, FunPtr fptr)
rettv->vval.v_number = (buf != NULL && buf->b_p_bl);
}
+// "bufload(expr)" function
+static void f_bufload(typval_T *argvars, typval_T *unused, FunPtr fptr)
+{
+ buf_T *buf = get_buf_arg(&argvars[0]);
+
+ if (buf != NULL && buf->b_ml.ml_mfp == NULL) {
+ aco_save_T aco;
+
+ aucmd_prepbuf(&aco, buf);
+ swap_exists_action = SEA_NONE;
+ open_buffer(false, NULL, 0);
+ aucmd_restbuf(&aco);
+ }
+}
+
/*
* "bufloaded(expr)" function
*/