summaryrefslogtreecommitdiff
path: root/src/spellfile.c
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2017-02-26 15:27:23 +0100
committerBram Moolenaar <Bram@vim.org>2017-02-26 15:27:23 +0100
commit6d3c8586fc81b022e9f06c611b9926108fb878c7 (patch)
treef8ec58f6b4262885089d4e036eccc181bf854986 /src/spellfile.c
parent5074a0e0333eaa6a9f697eb765124ca0e244c89b (diff)
downloadvim-git-6d3c8586fc81b022e9f06c611b9926108fb878c7.tar.gz
patch 8.0.0376: size computations in spell file reading are offv8.0.0376
Problem: Size computations in spell file reading are not exactly right. Solution: Make "len" a "long" and check with LONG_MAX.
Diffstat (limited to 'src/spellfile.c')
-rw-r--r--src/spellfile.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/src/spellfile.c b/src/spellfile.c
index 8b1a3a633..00ef019a6 100644
--- a/src/spellfile.c
+++ b/src/spellfile.c
@@ -1585,7 +1585,7 @@ spell_read_tree(
int prefixtree, /* TRUE for the prefix tree */
int prefixcnt) /* when "prefixtree" is TRUE: prefix count */
{
- int len;
+ long len;
int idx;
char_u *bp;
idx_T *ip;
@@ -1595,7 +1595,7 @@ spell_read_tree(
len = get4c(fd);
if (len < 0)
return SP_TRUNCERROR;
- if (len >= 0x3ffffff)
+ if (len >= LONG_MAX / (long)sizeof(int))
/* Invalid length, multiply with sizeof(int) would overflow. */
return SP_FORMERROR;
if (len > 0)