# HG changeset patch # User Bram Moolenaar # Date 1639169102 -3600 # Node ID 3af0359e8a420674a77ef8b11d200a7935e5142f # Parent fc828c5248497fbbb48324e89ab802c048011334 patch 8.2.3777: spell file write error not checked Commit: https://github.com/vim/vim/commit/1daedc838126bf6fe30221192cfe36aa1b56b454 Author: =?UTF-8?q?Bj=C3=B6rn=20Linse?= Date: Fri Dec 10 20:39:17 2021 +0000 patch 8.2.3777: spell file write error not checked Problem: Spell file write error not checked. Solution: Check writing the prefix conditions. (Bjorn Linse, closes https://github.com/vim/vim/issues/9323) diff --git a/src/spellfile.c b/src/spellfile.c --- a/src/spellfile.c +++ b/src/spellfile.c @@ -303,7 +303,7 @@ for ((np) = (node); (np) != NULL; (np) = (np)->wn_sibling) static int set_spell_finish(spelltab_T *new_st); -static int write_spell_prefcond(FILE *fd, garray_T *gap); +static int write_spell_prefcond(FILE *fd, garray_T *gap, size_t *fwv); static int read_region_section(FILE *fd, slang_T *slang, int len); static int read_charflags_section(FILE *fd); static int read_prefcond_section(FILE *fd, slang_T *lp); @@ -4977,10 +4977,10 @@ write_vim_spell(spellinfo_T *spin, char_ putc(SN_PREFCOND, fd); // putc(SNF_REQUIRED, fd); // - l = write_spell_prefcond(NULL, &spin->si_prefcond); + l = write_spell_prefcond(NULL, &spin->si_prefcond, &fwv); put_bytes(fd, (long_u)l, 4); // - write_spell_prefcond(fd, &spin->si_prefcond); + write_spell_prefcond(fd, &spin->si_prefcond, &fwv); } // SN_REP: ... @@ -6567,16 +6567,15 @@ set_spell_finish(spelltab_T *new_st) /* * Write the table with prefix conditions to the .spl file. - * When "fd" is NULL only count the length of what is written. + * When "fd" is NULL only count the length of what is written and return it. */ static int -write_spell_prefcond(FILE *fd, garray_T *gap) +write_spell_prefcond(FILE *fd, garray_T *gap, size_t *fwv) { int i; char_u *p; int len; int totlen; - size_t x UNUSED = 1; // collect return value of fwrite() if (fd != NULL) put_bytes(fd, (long_u)gap->ga_len, 2); // @@ -6593,7 +6592,7 @@ write_spell_prefcond(FILE *fd, garray_T if (fd != NULL) { fputc(len, fd); - x &= fwrite(p, (size_t)len, (size_t)1, fd); + *fwv &= fwrite(p, (size_t)len, (size_t)1, fd); } totlen += len; } @@ -6604,7 +6603,6 @@ write_spell_prefcond(FILE *fd, garray_T return totlen; } - /* * Use map string "map" for languages "lp". */ diff --git a/src/version.c b/src/version.c --- a/src/version.c +++ b/src/version.c @@ -754,6 +754,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ /**/ + 3777, +/**/ 3776, /**/ 3775,