patch 8.2.1783: try-catch test fails
Problem: Try-catch test fails. Solution: Don't call win_enter(), only call enterering_window().
This commit is contained in:
		| @ -1533,18 +1533,22 @@ win_found: | ||||
| 	unblock_autocmds(); | ||||
|  | ||||
| 	if (win_valid(aco->save_curwin)) | ||||
| 	    win_enter(aco->save_curwin, TRUE); | ||||
| 	    curwin = aco->save_curwin; | ||||
| 	else | ||||
| 	    // Hmm, original window disappeared.  Just use the first one. | ||||
| 	    curwin = firstwin; | ||||
| 	curbuf = curwin->w_buffer; | ||||
| #ifdef FEAT_JOB_CHANNEL | ||||
| 	// May need to restore insert mode for a prompt buffer. | ||||
| 	entering_window(curwin); | ||||
| #endif | ||||
|  | ||||
| 	if (win_valid(aco->save_prevwin)) | ||||
| 	    prevwin = aco->save_prevwin; | ||||
| #ifdef FEAT_EVAL | ||||
| 	vars_clear(&aucmd_win->w_vars->dv_hashtab);  // free all w: variables | ||||
| 	hash_init(&aucmd_win->w_vars->dv_hashtab);   // re-use the hashtab | ||||
| #endif | ||||
| 	curbuf = curwin->w_buffer; | ||||
|  | ||||
| 	vim_free(globaldir); | ||||
| 	globaldir = aco->globaldir; | ||||
|  | ||||
|  | ||||
| @ -10,6 +10,7 @@ int win_count(void); | ||||
| int make_windows(int count, int vertical); | ||||
| void win_move_after(win_T *win1, win_T *win2); | ||||
| void win_equal(win_T *next_curwin, int current, int dir); | ||||
| void entering_window(win_T *win); | ||||
| void close_windows(buf_T *buf, int keep_curwin); | ||||
| int one_window(void); | ||||
| int win_close(win_T *win, int free_buf); | ||||
|  | ||||
| @ -227,7 +227,12 @@ func RunTheTest(test) | ||||
|  | ||||
|   " Close any extra tab pages and windows and make the current one not modified. | ||||
|   while tabpagenr('$') > 1 | ||||
|     let winid = win_getid() | ||||
|     quit! | ||||
|     if winid == win_getid() | ||||
|       echoerr 'Could not quit window' | ||||
|       break | ||||
|     endif | ||||
|   endwhile | ||||
|  | ||||
|   while 1 | ||||
|  | ||||
| @ -750,6 +750,8 @@ static char *(features[]) = | ||||
|  | ||||
| static int included_patches[] = | ||||
| {   /* Add new patch number below this line */ | ||||
| /**/ | ||||
|     1783, | ||||
| /**/ | ||||
|     1782, | ||||
| /**/ | ||||
|  | ||||
| @ -2227,7 +2227,7 @@ leaving_window(win_T *win) | ||||
|     } | ||||
| } | ||||
|  | ||||
|     static void | ||||
|     void | ||||
| entering_window(win_T *win) | ||||
| { | ||||
|     // Only matters for a prompt window. | ||||
|  | ||||
		Reference in New Issue
	
	Block a user