blob: e85d38acd1b834f24fa6d5d9d7df4d8f8b13a696 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
|
#include "shgetc.h"
void __shlim(FILE *f, off_t lim)
{
f->shlim = lim;
f->shcnt = f->rend - f->rpos;
if (lim && f->rend - f->rpos > lim)
f->shend = f->rpos + lim;
else
f->shend = f->rend;
}
int __shgetc(FILE *f)
{
int c;
if (f->shlim && f->shcnt >= f->shlim) {
f->shend = 0;
return EOF;
}
c = __uflow(f);
if (f->shlim && f->rend - f->rpos > f->shlim - f->shcnt - 1)
f->shend = f->rpos + (f->shlim - f->shcnt - 1);
else
f->shend = f->rend;
if (f->rend) f->shcnt += f->rend - f->buf;
return c;
}
|