aboutsummaryrefslogtreecommitdiff
path: root/src/nvim/window.c
diff options
context:
space:
mode:
authorBjörn Linse <bjorn.linse@gmail.com>2021-06-01 10:05:58 +0200
committerGitHub <noreply@github.com>2021-06-01 10:05:58 +0200
commit2faa1c361ba54b3c1f20771397f7b48ac4386cdc (patch)
treefb9cd296624254180adff92840620fab754a28f4 /src/nvim/window.c
parent27c616d688c73c406726c949a3b664f52d4e4f04 (diff)
parentdb6523cd130e239eea4cec4d3e60f2323bffe0fc (diff)
downloadrneovim-2faa1c361ba54b3c1f20771397f7b48ac4386cdc.tar.gz
rneovim-2faa1c361ba54b3c1f20771397f7b48ac4386cdc.tar.bz2
rneovim-2faa1c361ba54b3c1f20771397f7b48ac4386cdc.zip
Merge pull request #14659 from seandewar/api-win-buf-noautocmd
api(nvim_open_win): Enable BufEnter autocmds by default like ordinary window; add "noautocmd" option to block BufEnter.
Diffstat (limited to 'src/nvim/window.c')
-rw-r--r--src/nvim/window.c39
1 files changed, 39 insertions, 0 deletions
diff --git a/src/nvim/window.c b/src/nvim/window.c
index 936bfa8c5b..cdeae2e294 100644
--- a/src/nvim/window.c
+++ b/src/nvim/window.c
@@ -570,6 +570,45 @@ static void cmd_with_count(char *cmd, char_u *bufp, size_t bufsize,
}
}
+void win_set_buf(Window window, Buffer buffer, bool noautocmd, Error *err)
+{
+ win_T *win = find_window_by_handle(window, err), *save_curwin = curwin;
+ buf_T *buf = find_buffer_by_handle(buffer, err);
+ tabpage_T *tab = win_find_tabpage(win), *save_curtab = curtab;
+
+ if (!win || !buf) {
+ return;
+ }
+
+ if (noautocmd) {
+ block_autocmds();
+ }
+ if (switch_win_noblock(&save_curwin, &save_curtab, win, tab, false) == FAIL) {
+ api_set_error(err,
+ kErrorTypeException,
+ "Failed to switch to window %d",
+ window);
+ }
+
+ try_start();
+ int result = do_buffer(DOBUF_GOTO, DOBUF_FIRST, FORWARD, buf->b_fnum, 0);
+ if (!try_end(err) && result == FAIL) {
+ api_set_error(err,
+ kErrorTypeException,
+ "Failed to set buffer %d",
+ buffer);
+ }
+
+ // If window is not current, state logic will not validate its cursor.
+ // So do it now.
+ validate_cursor();
+
+ restore_win_noblock(save_curwin, save_curtab, false);
+ if (noautocmd) {
+ unblock_autocmds();
+ }
+}
+
/// Create a new float.
///
/// if wp == NULL allocate a new window, otherwise turn existing window into a