blind

suckless command-line video editing utility
git clone git://git.suckless.org/blind
Log | Files | Refs | README | LICENSE

commit a1e6eee26bd30a1b02d7bb002ae8605d317b05cd
parent 8c0c4c709b86c3ae75752e2ca761354fadc837f1
Author: Mattias Andrée <maandree@kth.se>
Date:   Mon,  9 Jan 2017 05:30:51 +0100

Add vu-flip

Signed-off-by: Mattias Andrée <maandree@kth.se>

Diffstat:
Asrc/vu-flip.c | 81+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
1 file changed, 81 insertions(+), 0 deletions(-)

diff --git a/src/vu-flip.c b/src/vu-flip.c @@ -0,0 +1,81 @@ +/* See LICENSE file for copyright and license details. */ +#include "arg.h" +#include "stream.h" +#include "util.h" + +#include <fcntl.h> +#include <inttypes.h> +#include <string.h> +#include <unistd.h> + +static void +usage(void) +{ + eprintf("usage: %s\n", argv0); +} + +int +main(int argc, char *argv[]) +{ + struct stream stream; + char *buf, *row; + size_t ptr, n, i, j, hm, row_size; + ssize_t r; + + ARGBEGIN { + default: + usage(); + } ARGEND; + + if (argc) + usage(); + + stream.file = "<stdin>"; + stream.fd = STDIN_FILENO; + einit_stream(&stream); + fprint_stream_head(stdout, &stream); + fflush(stdout); + if (ferror(stdout)) + eprintf("<stdin>:"); + + if (stream.width > SIZE_MAX / stream.pixel_size) + eprintf("<stdin>: video is too wide\n"); + row_size = stream.width * stream.pixel_size; + if (!(row = malloc(row_size))) + eprintf("malloc:"); + if (row_size > SIZE_MAX / stream.height) + eprintf("<stdin>: video frame is too large\n"); + n = row_size * stream.height; + if (!(buf = malloc(n))) + eprintf("malloc:"); + + hm = stream.height - 1; + memcpy(buf, stream.buf, ptr = stream.ptr); + for (;;) { + for (; ptr < n; ptr += (size_t)r) { + r = read(stream.fd, buf + ptr, n - ptr); + if (r < 0) { + eprintf("read %s:", stream.file); + } else if (r == 0) { + if (!ptr) + break; + eprintf("%s: incomplete frame", stream.file); + } + } + if (!ptr) + break; + for (i = 0; i < stream.height >> 1; i++) { + j = hm - i; + memcpy(row, buf + i * row_size, row_size); + memcpy(buf + i * row_size, buf + j * row_size, row_size); + memcpy(buf + j * row_size, row, row_size); + } + for (ptr = 0; ptr < n; ptr += (size_t)r) { + r = write(STDOUT_FILENO, buf + ptr, n - ptr); + if (r < 0) + eprintf("write <stdout>"); + } + } + + return 0; +}