aboutsummaryrefslogtreecommitdiffstats
path: root/src/vu-dissolve.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/vu-dissolve.c')
-rw-r--r--src/vu-dissolve.c46
1 files changed, 12 insertions, 34 deletions
diff --git a/src/vu-dissolve.c b/src/vu-dissolve.c
index 0bf5311..04d107c 100644
--- a/src/vu-dissolve.c
+++ b/src/vu-dissolve.c
@@ -1,37 +1,35 @@
/* See LICENSE file for copyright and license details. */
-#include "arg.h"
#include "stream.h"
#include "util.h"
#include <string.h>
#include <unistd.h>
-static void
-usage(void)
-{
- eprintf("usage: %s [-r]\n", argv0);
-}
+USAGE("[-r]")
+
+static size_t fm;
+static double fmd;
static void
-process_xyza(struct stream *stream, size_t n, size_t f, size_t fm)
+process_xyza(struct stream *stream, size_t n, size_t f)
{
size_t i;
double a;
for (i = 0; i < n; i += stream->pixel_size) {
a = ((double *)(stream->buf + i))[3];
- a = a * (double)f / fm;
+ a = a * (double)f / fmd;
((double *)(stream->buf + i))[3] = a;
}
}
static void
-process_xyza_r(struct stream *stream, size_t n, size_t f, size_t fm)
+process_xyza_r(struct stream *stream, size_t n, size_t f)
{
size_t i;
double a;
for (i = 0; i < n; i += stream->pixel_size) {
a = ((double *)(stream->buf + i))[3];
- a = a * (double)(fm - f) / fm;
+ a = a * (double)(fm - f) / fmd;
((double *)(stream->buf + i))[3] = a;
}
}
@@ -41,10 +39,7 @@ main(int argc, char *argv[])
{
struct stream stream;
int reverse = 0;
- size_t f, h, w;
- size_t n, i, fm;
- ssize_t r;
- void (*process)(struct stream *stream, size_t n, size_t f, size_t fm) = NULL;
+ void (*process)(struct stream *stream, size_t n, size_t f) = NULL;
ARGBEGIN {
case 'r':
@@ -61,32 +56,15 @@ main(int argc, char *argv[])
stream.file = "<stdin>";
einit_stream(&stream);
fprint_stream_head(stdout, &stream);
- fflush(stdout);
- if (ferror(stdout))
- eprintf("<stdout>:");
+ efflush(stdout, "<stdout>");
if (!strcmp(stream.pixfmt, "xyza"))
process = reverse ? process_xyza_r : process_xyza;
else
eprintf("pixel format %s is not supported, try xyza\n", stream.pixfmt);
- fm = stream.frames - 1;
- for (f = 0; f < stream.frames; f++) {
- for (h = stream.height; h--;) {
- for (w = stream.width * stream.pixel_size; w; w -= n) {
- if (!eread_stream(&stream, w))
- eprintf("<stdin>: file is shorter than expected\n");
- n = stream.ptr - (stream.ptr % stream.pixel_size);
- process(&stream, n, f, fm);
- for (i = 0; i < n; i += (size_t)r) {
- r = write(STDOUT_FILENO, stream.buf + i, n - i);
- if (r < 0)
- eprintf("write <stdout>:");
- }
- memmove(stream.buf, stream.buf + n, stream.ptr -= n);
- }
- }
- }
+ fmd = fm = stream.frames - 1;
+ EACH_FRAME_SEGMENTED(&stream, process);
return 0;
}