forked from aniani/vim
		
	patch 8.2.1095: may use pointer after freeing it
Problem: May use pointer after freeing it when text properties are used. Solution: Update redo buffer before calling ml_replace().
This commit is contained in:
		| @@ -676,8 +676,6 @@ spell_suggest(int count) | ||||
| 	    mch_memmove(p, line, c); | ||||
| 	    STRCPY(p + c, stp->st_word); | ||||
| 	    STRCAT(p, sug.su_badptr + stp->st_orglen); | ||||
| 	    ml_replace(curwin->w_cursor.lnum, p, FALSE); | ||||
| 	    curwin->w_cursor.col = c; | ||||
|  | ||||
| 	    // For redo we use a change-word command. | ||||
| 	    ResetRedobuff(); | ||||
| @@ -686,7 +684,10 @@ spell_suggest(int count) | ||||
| 			    stp->st_wordlen + sug.su_badlen - stp->st_orglen); | ||||
| 	    AppendCharToRedobuff(ESC); | ||||
|  | ||||
| 	    // After this "p" may be invalid. | ||||
| 	    // "p" may be freed here | ||||
| 	    ml_replace(curwin->w_cursor.lnum, p, FALSE); | ||||
| 	    curwin->w_cursor.col = c; | ||||
|  | ||||
| 	    changed_bytes(curwin->w_cursor.lnum, c); | ||||
| 	} | ||||
|     } | ||||
|   | ||||
| @@ -754,6 +754,8 @@ static char *(features[]) = | ||||
|  | ||||
| static int included_patches[] = | ||||
| {   /* Add new patch number below this line */ | ||||
| /**/ | ||||
|     1095, | ||||
| /**/ | ||||
|     1094, | ||||
| /**/ | ||||
|   | ||||
		Reference in New Issue
	
	Block a user