summaryrefslogtreecommitdiff
path: root/src/spell.c
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2013-11-21 17:42:31 +0100
committerBram Moolenaar <Bram@vim.org>2013-11-21 17:42:31 +0100
commitace8d8ee2f5d6ddd6d47272609c75155ce533f97 (patch)
tree2d7927db652b4fe25f64a84cb01dd08cfd208edb /src/spell.c
parent438ee5bf603f3cee2c8ec924d081885c0086ba19 (diff)
downloadvim-ace8d8ee2f5d6ddd6d47272609c75155ce533f97.zip
updated for version 7.4.102
Problem: Crash when interrupting "z=". Solution: Add safety check for word length. (Christian Brabandt, Dominique Pelle)
Diffstat (limited to 'src/spell.c')
-rw-r--r--src/spell.c6
1 files changed, 3 insertions, 3 deletions
diff --git a/src/spell.c b/src/spell.c
index 6e0d986d7..18a39570d 100644
--- a/src/spell.c
+++ b/src/spell.c
@@ -13398,9 +13398,8 @@ add_sound_suggest(su, goodword, score, lp)
/* Lookup the word "orgnr" one of the two tries. */
n = 0;
- wlen = 0;
wordcount = 0;
- for (;;)
+ for (wlen = 0; wlen < MAXWLEN - 3; ++wlen)
{
i = 1;
if (wordcount == orgnr && byts[n + 1] == NUL)
@@ -13414,6 +13413,7 @@ add_sound_suggest(su, goodword, score, lp)
if (i > byts[n]) /* safety check */
{
STRCPY(theword + wlen, "BAD");
+ wlen += 3;
goto badword;
}
@@ -13426,7 +13426,7 @@ add_sound_suggest(su, goodword, score, lp)
wordcount += wc;
}
- theword[wlen++] = byts[n + i];
+ theword[wlen] = byts[n + i];
n = idxs[n + i];
}
badword: