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
43
44
45
46
47
48
|
/* See LICENSE file for copyright and license details. */
#include "common.h"
USAGE("(file frames) ...")
int
main(int argc, char *argv[])
{
struct stream stream;
size_t *frames, *framecount, period = 0, parts, i, n;
int *fds;
UNOFLAGS(argc % 2 || !argc);
eopen_stream(&stream, NULL);
parts = (size_t)argc / 2;
frames = alloca(parts * sizeof(*frames));
framecount = alloca(parts * sizeof(*framecount));
fds = alloca(parts * sizeof(*fds));
for (i = 0; i < parts; i++) {
fds[i] = eopen(argv[i * 2], O_WRONLY | O_CREAT | O_TRUNC, 0666);
frames[i] = etozu_arg("frames", argv[i * 2 + 1], 1, SIZE_MAX);
}
for (i = 0; i < parts; i++) {
if (frames[i] > SIZE_MAX - period)
eprintf("the sum of selected frame intervals exceeds %zu\n", SIZE_MAX);
period += frames[i];
}
for (n = stream.frames / period, i = 0; i < parts; i++)
framecount[i] = n * frames[i];
for (n = stream.frames % period, i = 0; i < parts; i++) {
framecount[i] += MIN(n, frames[i]);
n -= MIN(n, frames[i]);
}
for (i = 0; i < parts; i++)
if (DPRINTF_HEAD(fds[i], framecount[i], stream.width, stream.height, stream.pixfmt) < 0)
eprintf("dprintf %s:", argv[i * 2]);
for (i = 0; i < parts; i++, i = i == parts ? 0 : i)
if (esend_frames(&stream, fds[i], frames[i], argv[i * 2]) != frames[i])
break;
for (i = 0; i < parts; i++)
close(fds[i]);
return 0;
}
|