patch 9.0.0788: ModeChanged autocmd not executed when Visual ends with CTRL-C
Problem:    ModeChanged autocmd not executed when Visual mode is ended with
            CTRL-C.
Solution:   Do not trigger the autocmd when got_int is set. (closes #11394)
			
			
This commit is contained in:
		| @ -330,6 +330,7 @@ get_last_leader_offset(char_u *line, char_u **flags) | ||||
|  | ||||
| /* | ||||
|  * Return the number of window lines occupied by buffer line "lnum". | ||||
|  * Includes any filler lines. | ||||
|  */ | ||||
|     int | ||||
| plines(linenr_T lnum) | ||||
| @ -349,6 +350,10 @@ plines_win( | ||||
|     return plines_win_nofill(wp, lnum, winheight) + diff_check_fill(wp, lnum); | ||||
| } | ||||
|  | ||||
| /* | ||||
|  * Return the number of window lines occupied by buffer line "lnum". | ||||
|  * Does not include filler lines. | ||||
|  */ | ||||
|     int | ||||
| plines_nofill(linenr_T lnum) | ||||
| { | ||||
| @ -2754,7 +2759,9 @@ may_trigger_modechanged() | ||||
|     char_u	    curr_mode[MODE_MAX_LENGTH]; | ||||
|     char_u	    pattern_buf[2 * MODE_MAX_LENGTH]; | ||||
|  | ||||
|     if (!has_modechanged()) | ||||
|     // Skip this when got_int is set, the autocommand will not be executed. | ||||
|     // Better trigger it next time. | ||||
|     if (!has_modechanged() || got_int) | ||||
| 	return; | ||||
|  | ||||
|     get_mode(curr_mode); | ||||
|  | ||||
| @ -3429,6 +3429,18 @@ func Test_mode_changes() | ||||
|   unlet g:n_to_c | ||||
|   unlet g:c_to_n | ||||
|  | ||||
|   let g:n_to_v = 0 | ||||
|   au ModeChanged n:v let g:n_to_v += 1 | ||||
|   let g:v_to_n = 0 | ||||
|   au ModeChanged v:n let g:v_to_n += 1 | ||||
|   let g:mode_seq += ['v', 'n'] | ||||
|   call feedkeys("v\<C-C>", 'tnix') | ||||
|   call assert_equal(len(g:mode_seq) - 1, g:index) | ||||
|   call assert_equal(1, g:n_to_v) | ||||
|   call assert_equal(1, g:v_to_n) | ||||
|   unlet g:n_to_v | ||||
|   unlet g:v_to_n | ||||
|  | ||||
|   au! ModeChanged | ||||
|   delfunc TestMode | ||||
|   unlet! g:mode_seq | ||||
|  | ||||
| @ -695,6 +695,8 @@ static char *(features[]) = | ||||
|  | ||||
| static int included_patches[] = | ||||
| {   /* Add new patch number below this line */ | ||||
| /**/ | ||||
|     788, | ||||
| /**/ | ||||
|     787, | ||||
| /**/ | ||||
|  | ||||
		Reference in New Issue
	
	Block a user