aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorglacambre <me@r4>2017-11-26 13:29:32 +0100
committerJustin M. Keyes <justinkz@gmail.com>2017-12-10 14:55:59 +0100
commitabe38f7d26d68d7032ea391c039c56c8b87675a5 (patch)
tree2414fb06d52576a07206b7465910d24ba6fe5793 /src
parent4a5bc6275d09056ff0ccf5a29a878d48bbe58655 (diff)
downloadrneovim-abe38f7d26d68d7032ea391c039c56c8b87675a5.tar.gz
rneovim-abe38f7d26d68d7032ea391c039c56c8b87675a5.tar.bz2
rneovim-abe38f7d26d68d7032ea391c039c56c8b87675a5.zip
window.c: do BufEnter in correct window after closing help #7431
closes #7429 Problem: after a help window was closed, a window was selected and its autocommands triggered. After that, restore_snapshot was called and the focused window changed, confusing the user. Solution: Add function get_snapshot_focus() that returns the window that holds the cursor in a snapshot. Use this function in win_close to make sure the right window is selected before any autocommand is triggered.
Diffstat (limited to 'src')
-rw-r--r--src/nvim/window.c29
1 files changed, 29 insertions, 0 deletions
diff --git a/src/nvim/window.c b/src/nvim/window.c
index 4e4eb297aa..e39569321e 100644
--- a/src/nvim/window.c
+++ b/src/nvim/window.c
@@ -1991,6 +1991,14 @@ int win_close(win_T *win, int free_buf)
* the screen space. */
wp = win_free_mem(win, &dir, NULL);
+ if (help_window) {
+ // Closing the help window moves the cursor back to the original window.
+ win_T *tmpwp = get_snapshot_focus(SNAP_HELP_IDX);
+ if (tmpwp != NULL) {
+ wp = tmpwp;
+ }
+ }
+
/* Make sure curwin isn't invalid. It can cause severe trouble when
* printing an error message. For win_equal() curbuf needs to be valid
* too. */
@@ -5421,6 +5429,27 @@ static win_T *restore_snapshot_rec(frame_T *sn, frame_T *fr)
return wp;
}
+/// Gets the focused window (the one holding the cursor) of the snapshot.
+static win_T *get_snapshot_focus(int idx)
+{
+ if (curtab->tp_snapshot[idx] == NULL) {
+ return NULL;
+ }
+
+ frame_T *sn = curtab->tp_snapshot[idx];
+ // This should be equivalent to the recursive algorithm found in
+ // restore_snapshot as far as traveling nodes go.
+ while (sn->fr_child != NULL || sn->fr_next != NULL) {
+ while (sn->fr_child != NULL) {
+ sn = sn->fr_child;
+ }
+ if (sn->fr_next != NULL) {
+ sn = sn->fr_next;
+ }
+ }
+
+ return sn->fr_win;
+}
/*
* Set "win" to be the curwin and "tp" to be the current tab page.