X-Git-Url: http://mj.ucw.cz/gitweb/?a=blobdiff_plain;ds=sidebyside;f=lib%2Ffastbuf.c;h=00fa51bcccd902538514cbbb069598008094b06f;hb=91373ee6489fbe08db12bef2cf6df704b31e1378;hp=5b394cf1c867c2f755b07db788a562ad3e3fb84c;hpb=417d2511bb77568e041fef8ea14406b265124066;p=libucw.git diff --git a/lib/fastbuf.c b/lib/fastbuf.c index 5b394cf1..00fa51bc 100644 --- a/lib/fastbuf.c +++ b/lib/fastbuf.c @@ -187,7 +187,7 @@ void bput5_slow(struct fastbuf *f, u64 o) #endif } -uns bread_slow(struct fastbuf *f, void *b, uns l) +uns bread_slow(struct fastbuf *f, void *b, uns l, uns check) { uns total = 0; while (l) @@ -209,6 +209,8 @@ uns bread_slow(struct fastbuf *f, void *b, uns l) l -= k; total += k; } + if (check && total && l) + die("breadb: short read"); return total; } @@ -254,6 +256,28 @@ bgets(struct fastbuf *f, byte *b, uns l) die("%s: Line too long", f->name); } +byte * +bgets0(struct fastbuf *f, byte *b, uns l) +{ + byte *e = b + l - 1; + int k; + + k = bgetc(f); + if (k == EOF) + return NULL; + while (b < e) + { + if (!k || k == EOF) + { + *b = 0; + return b; + } + *b++ = k; + k = bgetc(f); + } + die("%s: Line too long", f->name); +} + int bdirect_read(struct fastbuf *f, byte **buf) {