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:
parent
02710228dd
commit
b29763aa9b
24
copy.c
24
copy.c
@ -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));
|
||||||
|
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user