make sure buffer_get tries to get all the bytes it was asked for

This commit is contained in:
leitner 2005-08-09 11:04:44 +00:00
parent f141d3e24f
commit 636cfb70b0

View File

@ -2,11 +2,18 @@
#include "buffer.h"
int buffer_get(buffer* b,char* x,unsigned long int len) {
unsigned long done;
int blen;
if ((blen=buffer_feed(b))<0) return blen;
if ((unsigned long int) blen>=len)
blen=len;
byte_copy(x,blen,b->x+b->p);
b->p+=blen;
return blen;
done=0;
while (len) {
if ((blen=buffer_feed(b))<=0) return blen;
if ((unsigned long int) blen>=len)
blen=len;
byte_copy(x,blen,b->x+b->p);
b->p+=blen;
len-=blen;
x+=blen;
done+=blen;
}
return done;
}