diff options
author | Junio C Hamano <junkio@cox.net> | 2005-05-18 23:34:03 -0700 |
---|---|---|
committer | Linus Torvalds <torvalds@ppc970.osdl.org> | 2005-05-19 07:31:23 -0700 |
commit | 9dc527adbc013b67cd85cce67bdccc3c10ed4792 (patch) | |
tree | 7ec4c720ba190e5082ac7f1c809f24bedc0fd3c0 | |
parent | 9b632be30c72f25ac180fa2bf7286505c87e46d2 (diff) | |
download | git-9dc527adbc013b67cd85cce67bdccc3c10ed4792.tar.gz |
[PATCH] fix strbuf take #2
I just remembered why I placed that bogus "sb->len ==0 implies
sb->eof" condition there. We need at least something like this
to catch the normal EOF (that is, line termination immediately
followed by EOF) case. "if (feof(fp))" fires when we have
already read the eof, not when we are about read it.
Signed-off-by: Junio C Hamano <junkio@cox.net>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
-rw-r--r-- | strbuf.c | 2 |
1 files changed, 2 insertions, 0 deletions
@@ -37,6 +37,8 @@ void read_line(struct strbuf *sb, FILE *fp, int term) { break; strbuf_add(sb, ch); } + if (ch == EOF && sb->len == 0) + sb->eof = 1; strbuf_end(sb); } |