diff options
author | Phillip Wood <phillip.wood@dunelm.org.uk> | 2017-11-15 13:40:43 +0100 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2017-11-16 02:36:16 +0100 |
commit | c5e3bc6ec46071397b40582157214d374d1b4fab (patch) | |
tree | a698b2329a07becd0211adb62f8cb76066c9947c /config.c | |
parent | branch: fix "copy" to never touch HEAD (diff) | |
download | git-c5e3bc6ec46071397b40582157214d374d1b4fab.tar.xz git-c5e3bc6ec46071397b40582157214d374d1b4fab.zip |
config: avoid "write_in_full(fd, buf, len) != len" pattern
As explained in commit 06f46f237 (avoid "write_in_full(fd, buf, len)
!= len" pattern, 2017–09–13) the return value of write_in_full() is
either -1 or the requested number of bytes. As such comparing the
return value to an unsigned value such as strbuf.len will fail to
catch errors. Change the code to use the preferred '< 0' check.
Signed-off-by: Phillip Wood <phillip.wood@dunelm.org.uk>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to '')
-rw-r--r-- | config.c | 4 |
1 files changed, 2 insertions, 2 deletions
@@ -2700,7 +2700,7 @@ static int git_config_copy_or_rename_section_in_file(const char *config_filename * multiple [branch "$name"] sections. */ if (copystr.len > 0) { - if (write_in_full(out_fd, copystr.buf, copystr.len) != copystr.len) { + if (write_in_full(out_fd, copystr.buf, copystr.len) < 0) { ret = write_error(get_lock_file_path(lock)); goto out; } @@ -2763,7 +2763,7 @@ static int git_config_copy_or_rename_section_in_file(const char *config_filename * logic in the loop above. */ if (copystr.len > 0) { - if (write_in_full(out_fd, copystr.buf, copystr.len) != copystr.len) { + if (write_in_full(out_fd, copystr.buf, copystr.len) < 0) { ret = write_error(get_lock_file_path(lock)); goto out; } |