Mercurial > vim
changeset 26494:3af0359e8a42 v8.2.3777
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?= <bjorn.linse@gmail.com>
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)
author | Bram Moolenaar <Bram@vim.org> |
---|---|
date | Fri, 10 Dec 2021 21:45:02 +0100 |
parents | fc828c524849 |
children | 8043606c524a |
files | src/spellfile.c src/version.c |
diffstat | 2 files changed, 8 insertions(+), 8 deletions(-) [+] |
line wrap: on
line diff
--- 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); // <sectionID> putc(SNF_REQUIRED, fd); // <sectionflags> - l = write_spell_prefcond(NULL, &spin->si_prefcond); + l = write_spell_prefcond(NULL, &spin->si_prefcond, &fwv); put_bytes(fd, (long_u)l, 4); // <sectionlen> - write_spell_prefcond(fd, &spin->si_prefcond); + write_spell_prefcond(fd, &spin->si_prefcond, &fwv); } // SN_REP: <repcount> <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); // <prefcondcnt> @@ -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". */