mirror of
				https://github.com/neovim/neovim.git
				synced 2025-11-04 01:34:25 +00:00 
			
		
		
		
	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.
This commit is contained in:
		
				
					committed by
					
						
						Justin M. Keyes
					
				
			
			
				
	
			
			
			
						parent
						
							4a5bc6275d
						
					
				
				
					commit
					abe38f7d26
				
			@@ -1991,6 +1991,14 @@ int win_close(win_T *win, int free_buf)
 | 
				
			|||||||
   * the screen space. */
 | 
					   * the screen space. */
 | 
				
			||||||
  wp = win_free_mem(win, &dir, NULL);
 | 
					  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
 | 
					  /* Make sure curwin isn't invalid.  It can cause severe trouble when
 | 
				
			||||||
   * printing an error message.  For win_equal() curbuf needs to be valid
 | 
					   * printing an error message.  For win_equal() curbuf needs to be valid
 | 
				
			||||||
   * too. */
 | 
					   * too. */
 | 
				
			||||||
@@ -5421,6 +5429,27 @@ static win_T *restore_snapshot_rec(frame_T *sn, frame_T *fr)
 | 
				
			|||||||
  return wp;
 | 
					  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.
 | 
					 * Set "win" to be the curwin and "tp" to be the current tab page.
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -31,4 +31,17 @@ describe('autocmd BufEnter', function()
 | 
				
			|||||||
    eq(1, eval("exists('g:dir_bufenter')"))  -- Did BufEnter for the directory.
 | 
					    eq(1, eval("exists('g:dir_bufenter')"))  -- Did BufEnter for the directory.
 | 
				
			||||||
    eq(2, eval("bufnr('%')"))                -- Switched to the dir buffer.
 | 
					    eq(2, eval("bufnr('%')"))                -- Switched to the dir buffer.
 | 
				
			||||||
  end)
 | 
					  end)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  it('triggered by ":split normal|:help|:bw"', function()
 | 
				
			||||||
 | 
					    command("split normal")
 | 
				
			||||||
 | 
					    command("wincmd j")
 | 
				
			||||||
 | 
					    command("helptags runtime/doc")
 | 
				
			||||||
 | 
					    command("help")
 | 
				
			||||||
 | 
					    command("wincmd L")
 | 
				
			||||||
 | 
					    command("autocmd BufEnter normal let g:bufentered = 1")
 | 
				
			||||||
 | 
					    command("bw")
 | 
				
			||||||
 | 
					    eq(1, eval('bufnr("%")')) -- The cursor is back to the bottom window
 | 
				
			||||||
 | 
					    eq(0, eval("exists('g:bufentered')")) -- The autocmd hasn't been triggered
 | 
				
			||||||
 | 
					  end)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
end)
 | 
					end)
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user