X-Git-Url: http://git.ipfire.org/?a=blobdiff_plain;f=strbuf.c;h=a6153dca278abe957254fa091fdcd8eb13b90b25;hb=b1b952043f8f909649fdf053c371109c84f9cf56;hp=f03d11702b3f6212ca7305df60f2f9ea6ca49e35;hpb=9e4a90ba19033d25dca1eea495b0a8c5f06efbc6;p=thirdparty%2Fgit.git diff --git a/strbuf.c b/strbuf.c index f03d11702b..a6153dca27 100644 --- a/strbuf.c +++ b/strbuf.c @@ -322,7 +322,7 @@ int strbuf_readlink(struct strbuf *sb, const char *path, size_t hint) return -1; } -int strbuf_getline(struct strbuf *sb, FILE *fp, int term) +int strbuf_getwholeline(struct strbuf *sb, FILE *fp, int term) { int ch; @@ -332,10 +332,10 @@ int strbuf_getline(struct strbuf *sb, FILE *fp, int term) strbuf_reset(sb); while ((ch = fgetc(fp)) != EOF) { - if (ch == term) - break; strbuf_grow(sb, 1); sb->buf[sb->len++] = ch; + if (ch == term) + break; } if (ch == EOF && sb->len == 0) return EOF; @@ -344,6 +344,15 @@ int strbuf_getline(struct strbuf *sb, FILE *fp, int term) return 0; } +int strbuf_getline(struct strbuf *sb, FILE *fp, int term) +{ + if (strbuf_getwholeline(sb, fp, term)) + return EOF; + if (sb->buf[sb->len-1] == term) + strbuf_setlen(sb, sb->len-1); + return 0; +} + int strbuf_read_file(struct strbuf *sb, const char *path, size_t hint) { int fd, len;