updated for version 7.4.102
Problem:    Crash when interrupting "z=".
Solution:   Add safety check for word length. (Christian Brabandt, Dominique
            Pelle)
			
			
This commit is contained in:
		| @ -13398,9 +13398,8 @@ add_sound_suggest(su, goodword, score, lp) | |||||||
|  |  | ||||||
| 	/* Lookup the word "orgnr" one of the two tries. */ | 	/* Lookup the word "orgnr" one of the two tries. */ | ||||||
| 	n = 0; | 	n = 0; | ||||||
| 	wlen = 0; |  | ||||||
| 	wordcount = 0; | 	wordcount = 0; | ||||||
| 	for (;;) | 	for (wlen = 0; wlen < MAXWLEN - 3; ++wlen) | ||||||
| 	{ | 	{ | ||||||
| 	    i = 1; | 	    i = 1; | ||||||
| 	    if (wordcount == orgnr && byts[n + 1] == NUL) | 	    if (wordcount == orgnr && byts[n + 1] == NUL) | ||||||
| @ -13414,6 +13413,7 @@ add_sound_suggest(su, goodword, score, lp) | |||||||
| 		if (i > byts[n])	/* safety check */ | 		if (i > byts[n])	/* safety check */ | ||||||
| 		{ | 		{ | ||||||
| 		    STRCPY(theword + wlen, "BAD"); | 		    STRCPY(theword + wlen, "BAD"); | ||||||
|  | 		    wlen += 3; | ||||||
| 		    goto badword; | 		    goto badword; | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| @ -13426,7 +13426,7 @@ add_sound_suggest(su, goodword, score, lp) | |||||||
| 		wordcount += wc; | 		wordcount += wc; | ||||||
| 	    } | 	    } | ||||||
|  |  | ||||||
| 	    theword[wlen++] = byts[n + i]; | 	    theword[wlen] = byts[n + i]; | ||||||
| 	    n = idxs[n + i]; | 	    n = idxs[n + i]; | ||||||
| 	} | 	} | ||||||
| badword: | badword: | ||||||
|  | |||||||
| @ -738,6 +738,8 @@ static char *(features[]) = | |||||||
|  |  | ||||||
| static int included_patches[] = | static int included_patches[] = | ||||||
| {   /* Add new patch number below this line */ | {   /* Add new patch number below this line */ | ||||||
|  | /**/ | ||||||
|  |     102, | ||||||
| /**/ | /**/ | ||||||
|     101, |     101, | ||||||
| /**/ | /**/ | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user