blob: ca78546392f958229adf4108efb8ad219793816b (
plain)
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
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
|
/* ISC license. */
#include <errno.h>
#include <skalibs/allreadwrite.h>
#include <skalibs/iobuffer.h>
#include <skalibs/djbunix.h>
unsigned int fd_catn (int from, int to, unsigned int n)
{
unsigned int w = 0 ;
if (n >= IOBUFFER_SIZE)
{
iobuffer b ;
if (!iobuffer_init(&b, from, to)) return 0 ;
while (n >= IOBUFFER_SIZE)
{
register int r = iobuffer_fill(&b) ;
if (r <= 0)
{
iobuffer_finish(&b) ;
if (!r) errno = EPIPE ;
return w ;
}
if (!iobuffer_flush(&b))
{
iobuffer_finish(&b) ;
return w ;
}
n -= r ; w += r ;
}
iobuffer_finish(&b) ;
}
{
char buf[n] ;
unsigned int r = allread(from, buf, n) ;
unsigned int v = 0 ;
if (r) v = allwrite(to, buf, r) ;
w += v ;
}
return w ;
}
|