Am 01.11.2017 um 12:10 schrieb Simon Ruderich:
> On Tue, Oct 31, 2017 at 10:54:21AM +0100, René Scharfe wrote:
>> +static int rewrite_file(const char *path, const char *buf, size_t len)
>> +{
>> +    int rc = 0;
>> +    int fd = open(path, O_WRONLY);
>> +    if (fd < 0)
>> +            return error_errno(_("could not open '%s' for writing"), path);
>> +    if (write_in_full(fd, buf, len) < 0)
>> +            rc = error_errno(_("could not write to '%s'"), path);
>> +    if (!rc && ftruncate(fd, len) < 0)
>> +            rc = error_errno(_("could not truncate '%s'"), path);
>> +    close(fd);
> 
> We might want to check the return value of close() as some file
> systems report write errors only on close. But I'm not sure how
> the rest of Git's code-base handles this.

Most calls are not checked, but that doesn't necessarily mean they need
to (or should) stay that way.  The Linux man-page of close(2) spends
multiple paragraphs recommending to check its return value..  Care to
send a follow-up patch?

René

Reply via email to