Merge branch 'jh/strbuf-read-use-read-in-full'
strbuf_read() used to have one extra iteration (and an unnecessary strbuf_grow() of 8kB), which was eliminated. * jh/strbuf-read-use-read-in-full: strbuf_read(): skip unnecessary strbuf_grow() at eof
This commit is contained in:
commit
3b281d1281
10
strbuf.c
10
strbuf.c
@ -364,19 +364,19 @@ ssize_t strbuf_read(struct strbuf *sb, int fd, size_t hint)
|
|||||||
|
|
||||||
strbuf_grow(sb, hint ? hint : 8192);
|
strbuf_grow(sb, hint ? hint : 8192);
|
||||||
for (;;) {
|
for (;;) {
|
||||||
ssize_t cnt;
|
ssize_t want = sb->alloc - sb->len - 1;
|
||||||
|
ssize_t got = read_in_full(fd, sb->buf + sb->len, want);
|
||||||
|
|
||||||
cnt = xread(fd, sb->buf + sb->len, sb->alloc - sb->len - 1);
|
if (got < 0) {
|
||||||
if (cnt < 0) {
|
|
||||||
if (oldalloc == 0)
|
if (oldalloc == 0)
|
||||||
strbuf_release(sb);
|
strbuf_release(sb);
|
||||||
else
|
else
|
||||||
strbuf_setlen(sb, oldlen);
|
strbuf_setlen(sb, oldlen);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
if (!cnt)
|
sb->len += got;
|
||||||
|
if (got < want)
|
||||||
break;
|
break;
|
||||||
sb->len += cnt;
|
|
||||||
strbuf_grow(sb, 8192);
|
strbuf_grow(sb, 8192);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user