Cleanup xread() loops to use read_in_full()
Signed-off-by: Heikki Orsila <heikki.orsila@iki.fi> Signed-off-by: Junio C Hamano <gitster@pobox.com>maint
parent
471793f91e
commit
c697ad143b
|
@ -701,7 +701,7 @@ static void show_patch_diff(struct combine_diff_path *elem, int num_parent,
|
||||||
else if (0 <= (fd = open(elem->path, O_RDONLY)) &&
|
else if (0 <= (fd = open(elem->path, O_RDONLY)) &&
|
||||||
!fstat(fd, &st)) {
|
!fstat(fd, &st)) {
|
||||||
size_t len = xsize_t(st.st_size);
|
size_t len = xsize_t(st.st_size);
|
||||||
size_t sz = 0;
|
ssize_t done;
|
||||||
int is_file, i;
|
int is_file, i;
|
||||||
|
|
||||||
elem->mode = canon_mode(st.st_mode);
|
elem->mode = canon_mode(st.st_mode);
|
||||||
|
@ -716,14 +716,13 @@ static void show_patch_diff(struct combine_diff_path *elem, int num_parent,
|
||||||
|
|
||||||
result_size = len;
|
result_size = len;
|
||||||
result = xmalloc(len + 1);
|
result = xmalloc(len + 1);
|
||||||
while (sz < len) {
|
|
||||||
ssize_t done = xread(fd, result+sz, len-sz);
|
done = read_in_full(fd, result, len);
|
||||||
if (done == 0 && sz != len)
|
if (done < 0)
|
||||||
die("early EOF '%s'", elem->path);
|
die("read error '%s'", elem->path);
|
||||||
else if (done < 0)
|
else if (done < len)
|
||||||
die("read error '%s'", elem->path);
|
die("early EOF '%s'", elem->path);
|
||||||
sz += done;
|
|
||||||
}
|
|
||||||
result[len] = 0;
|
result[len] = 0;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
|
|
@ -183,7 +183,6 @@ void fixup_pack_header_footer(int pack_fd,
|
||||||
|
|
||||||
char *index_pack_lockfile(int ip_out)
|
char *index_pack_lockfile(int ip_out)
|
||||||
{
|
{
|
||||||
int len, s;
|
|
||||||
char packname[46];
|
char packname[46];
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -193,11 +192,8 @@ char *index_pack_lockfile(int ip_out)
|
||||||
* case, we need it to remove the corresponding .keep file
|
* case, we need it to remove the corresponding .keep file
|
||||||
* later on. If we don't get that then tough luck with it.
|
* later on. If we don't get that then tough luck with it.
|
||||||
*/
|
*/
|
||||||
for (len = 0;
|
if (read_in_full(ip_out, packname, 46) == 46 && packname[45] == '\n' &&
|
||||||
len < 46 && (s = xread(ip_out, packname+len, 46-len)) > 0;
|
memcmp(packname, "keep\t", 5) == 0) {
|
||||||
len += s);
|
|
||||||
if (len == 46 && packname[45] == '\n' &&
|
|
||||||
memcmp(packname, "keep\t", 5) == 0) {
|
|
||||||
char path[PATH_MAX];
|
char path[PATH_MAX];
|
||||||
packname[45] = 0;
|
packname[45] = 0;
|
||||||
snprintf(path, sizeof(path), "%s/pack/pack-%s.keep",
|
snprintf(path, sizeof(path), "%s/pack/pack-%s.keep",
|
||||||
|
|
15
pkt-line.c
15
pkt-line.c
|
@ -65,16 +65,11 @@ void packet_write(int fd, const char *fmt, ...)
|
||||||
|
|
||||||
static void safe_read(int fd, void *buffer, unsigned size)
|
static void safe_read(int fd, void *buffer, unsigned size)
|
||||||
{
|
{
|
||||||
size_t n = 0;
|
ssize_t ret = read_in_full(fd, buffer, size);
|
||||||
|
if (ret < 0)
|
||||||
while (n < size) {
|
die("read error (%s)", strerror(errno));
|
||||||
ssize_t ret = xread(fd, (char *) buffer + n, size - n);
|
else if (ret < size)
|
||||||
if (ret < 0)
|
die("The remote end hung up unexpectedly");
|
||||||
die("read error (%s)", strerror(errno));
|
|
||||||
if (!ret)
|
|
||||||
die("The remote end hung up unexpectedly");
|
|
||||||
n += ret;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int packet_read_line(int fd, char *buffer, unsigned size)
|
int packet_read_line(int fd, char *buffer, unsigned size)
|
||||||
|
|
14
sha1_file.c
14
sha1_file.c
|
@ -2466,16 +2466,10 @@ int index_path(unsigned char *sha1, const char *path, struct stat *st, int write
|
||||||
|
|
||||||
int read_pack_header(int fd, struct pack_header *header)
|
int read_pack_header(int fd, struct pack_header *header)
|
||||||
{
|
{
|
||||||
char *c = (char*)header;
|
if (read_in_full(fd, header, sizeof(*header)) < sizeof(*header))
|
||||||
ssize_t remaining = sizeof(struct pack_header);
|
/* "eof before pack header was fully read" */
|
||||||
do {
|
return PH_ERROR_EOF;
|
||||||
ssize_t r = xread(fd, c, remaining);
|
|
||||||
if (r <= 0)
|
|
||||||
/* "eof before pack header was fully read" */
|
|
||||||
return PH_ERROR_EOF;
|
|
||||||
remaining -= r;
|
|
||||||
c += r;
|
|
||||||
} while (remaining > 0);
|
|
||||||
if (header->hdr_signature != htonl(PACK_SIGNATURE))
|
if (header->hdr_signature != htonl(PACK_SIGNATURE))
|
||||||
/* "protocol error (pack signature mismatch detected)" */
|
/* "protocol error (pack signature mismatch detected)" */
|
||||||
return PH_ERROR_PACK_SIGNATURE;
|
return PH_ERROR_PACK_SIGNATURE;
|
||||||
|
|
Loading…
Reference in New Issue