patch 8.2.1770: invalid memory use when using SpellFileMissing autocmd
Problem: Invalid memory use when using SpellFileMissing autocmd. Solution: Add test case. (Dominique Pellé, closes #7036) Fix using a window that was closed.
This commit is contained in:
		| @ -2280,11 +2280,11 @@ did_set_spelllang(win_T *wp) | ||||
| 		} | ||||
| 	    } | ||||
|     } | ||||
|     redraw_win_later(wp, NOT_VALID); | ||||
|  | ||||
| theend: | ||||
|     vim_free(spl_copy); | ||||
|     recursive = FALSE; | ||||
|     redraw_win_later(wp, NOT_VALID); | ||||
|     return ret_msg; | ||||
| } | ||||
|  | ||||
|  | ||||
| @ -120,6 +120,29 @@ foobar/? | ||||
|   set spell& | ||||
| endfunc | ||||
|  | ||||
| func Test_spell_file_missing() | ||||
|   let s:spell_file_missing = 0 | ||||
|   augroup TestSpellFileMissing | ||||
|     autocmd! SpellFileMissing * let s:spell_file_missing += 1 | ||||
|   augroup END | ||||
|  | ||||
|   set spell spelllang=ab_cd | ||||
|   let messages = GetMessages() | ||||
|   call assert_equal('Warning: Cannot find word list "ab.utf-8.spl" or "ab.ascii.spl"', messages[-1]) | ||||
|   call assert_equal(1, s:spell_file_missing) | ||||
|  | ||||
|   new XTestSpellFileMissing | ||||
|   augroup TestSpellFileMissing | ||||
|     autocmd! SpellFileMissing * bwipe | ||||
|   augroup END | ||||
|   call assert_fails('set spell spelllang=ab_cd', 'E797:') | ||||
|  | ||||
|   augroup! TestSpellFileMissing | ||||
|   unlet s:spell_file_missing | ||||
|   set spell& spelllang& | ||||
|   %bwipe! | ||||
| endfunc | ||||
|  | ||||
| func Test_spelllang_inv_region() | ||||
|   set spell spelllang=en_xx | ||||
|   let messages = GetMessages() | ||||
|  | ||||
| @ -750,6 +750,8 @@ static char *(features[]) = | ||||
|  | ||||
| static int included_patches[] = | ||||
| {   /* Add new patch number below this line */ | ||||
| /**/ | ||||
|     1770, | ||||
| /**/ | ||||
|     1769, | ||||
| /**/ | ||||
|  | ||||
		Reference in New Issue
	
	Block a user