copy_fd(): do not close the input file descriptor

The caller, not this function, opened the file descriptor; it is
selfish for the callee to close it when it is done reading from it.
The caller may want an option to rewind and re-read the contents
after it returns.

Simplify the loop to copy the input in full to the output; its
body essentially is what a call to write_in_full() helper does.

Signed-off-by: Steffen Prohaska <prohaska@zib.de>
Helped-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Steffen Prohaska 2014-08-26 17:23:24 +02:00 committed by Junio C Hamano
parent 02710228dd
commit b29763aa9b
2 changed files with 8 additions and 21 deletions

24
copy.c
View File

@ -4,34 +4,17 @@ int copy_fd(int ifd, int ofd)
{ {
while (1) { while (1) {
char buffer[8192]; char buffer[8192];
char *buf = buffer;
ssize_t len = xread(ifd, buffer, sizeof(buffer)); ssize_t len = xread(ifd, buffer, sizeof(buffer));
if (!len) if (!len)
break; break;
if (len < 0) { if (len < 0) {
int read_error = errno;
close(ifd);
return error("copy-fd: read returned %s", return error("copy-fd: read returned %s",
strerror(read_error)); strerror(errno));
} }
while (len) { if (write_in_full(ofd, buffer, len) < 0)
int written = xwrite(ofd, buf, len);
if (written > 0) {
buf += written;
len -= written;
}
else if (!written) {
close(ifd);
return error("copy-fd: write returned 0");
} else {
int write_error = errno;
close(ifd);
return error("copy-fd: write returned %s", return error("copy-fd: write returned %s",
strerror(write_error)); strerror(errno));
} }
}
}
close(ifd);
return 0; return 0;
} }
@ -60,6 +43,7 @@ int copy_file(const char *dst, const char *src, int mode)
return fdo; return fdo;
} }
status = copy_fd(fdi, fdo); status = copy_fd(fdi, fdo);
close(fdi);
if (close(fdo) != 0) if (close(fdo) != 0)
return error("%s: close error: %s", dst, strerror(errno)); return error("%s: close error: %s", dst, strerror(errno));

View File

@ -224,8 +224,11 @@ int hold_lock_file_for_append(struct lock_file *lk, const char *path, int flags)
} else if (copy_fd(orig_fd, fd)) { } else if (copy_fd(orig_fd, fd)) {
if (flags & LOCK_DIE_ON_ERROR) if (flags & LOCK_DIE_ON_ERROR)
exit(128); exit(128);
close(orig_fd);
close(fd); close(fd);
return -1; return -1;
} else {
close(orig_fd);
} }
return fd; return fd;
} }