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
|
/* See LICENSE file for copyright and license details. */
#include "common.h"
USAGE("(file columns) ...")
int
main(int argc, char *argv[])
{
struct stream stream;
size_t *cols, period = 0, parts, i;
int *fds;
UNOFLAGS(argc % 2 || !argc);
eopen_stream(&stream, NULL);
parts = (size_t)argc / 2;
cols = alloca(parts * sizeof(*cols));
fds = alloca(parts * sizeof(*fds));
for (i = 0; i < parts; i++) {
fds[i] = eopen(argv[i * 2], O_WRONLY | O_CREAT | O_TRUNC, 0666);
cols[i] = etozu_arg("columns", argv[i * 2 + 1], 1, SIZE_MAX);
}
for (i = 0; i < parts; i++) {
if (cols[i] > SIZE_MAX - period)
goto bad_col_count;
period += cols[i];
}
if (period != stream.width)
goto bad_col_count;
for (i = 0; i < parts; i++)
if (DPRINTF_HEAD(fds[i], stream.frames, cols[i], stream.height, stream.pixfmt) < 0)
eprintf("dprintf %s:", argv[i * 2]);
for (i = 0; i < parts; i++, i = i == parts ? 0 : i)
if (esend_pixels(&stream, fds[i], cols[i], argv[i * 2]) != cols[i])
break;
for (i = 0; i < parts; i++)
close(fds[i]);
return 0;
bad_col_count:
eprintf("the sum of all columns must add up to the width of the input video\n");
return 1;
}
|