locking: avoid crashing when there is a problem writing the lock file
The call of ferror() as parameter of a %s specifier was a mistake --
it returns a number, not a string. Avoid the problem by combining
two error checks.
The man page of fwrite() does not say anything about errno, but I guess
that the function calls write() and that the possible error numbers of
that function apply.
In theory it is now possible that fclose() fails and returns an error
that then masks an earlier error of fwrite(). But I can't be bothered:
lock files are not essential, and any errors that might occur are most
likely overlooked anyway because they are not displayed in red.
This fixes https://savannah.gnu.org/bugs/?57724.
Bug existed since lock files were introduced, in version 2.3.2,
commit bf88d27a
.
master
parent
3f5ba950d6
commit
74f4c37d5f
|
@ -246,14 +246,7 @@ int write_lockfile(const char *lockfilename, const char *origfilename, bool modi
|
||||||
|
|
||||||
wroteamt = fwrite(lockdata, sizeof(char), LOCKSIZE, filestream);
|
wroteamt = fwrite(lockdata, sizeof(char), LOCKSIZE, filestream);
|
||||||
|
|
||||||
if (wroteamt < LOCKSIZE) {
|
if (fclose(filestream) == EOF || wroteamt < LOCKSIZE) {
|
||||||
statusline(MILD, _("Error writing lock file %s: %s"),
|
|
||||||
lockfilename, ferror(filestream));
|
|
||||||
fclose(filestream);
|
|
||||||
goto free_the_data;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (fclose(filestream) == EOF) {
|
|
||||||
statusline(MILD, _("Error writing lock file %s: %s"),
|
statusline(MILD, _("Error writing lock file %s: %s"),
|
||||||
lockfilename, strerror(errno));
|
lockfilename, strerror(errno));
|
||||||
goto free_the_data;
|
goto free_the_data;
|
||||||
|
|
Loading…
Reference in New Issue