aboutsummaryrefslogtreecommitdiffstats
path: root/src/vu-set-alpha.c
diff options
context:
space:
mode:
authorMattias Andrée <maandree@kth.se>2017-01-11 09:30:33 +0100
committerMattias Andrée <maandree@kth.se>2017-01-11 09:30:33 +0100
commita21ebe8bea569e7d8961b9711d430d21c92f769b (patch)
treedda3810db2e7ad3683bdfc6f68538da144c2a0c8 /src/vu-set-alpha.c
parentClean up code (diff)
downloadblind-a21ebe8bea569e7d8961b9711d430d21c92f769b.tar.gz
blind-a21ebe8bea569e7d8961b9711d430d21c92f769b.tar.bz2
blind-a21ebe8bea569e7d8961b9711d430d21c92f769b.tar.xz
Reuse code
Signed-off-by: Mattias Andrée <maandree@kth.se>
Diffstat (limited to 'src/vu-set-alpha.c')
-rw-r--r--src/vu-set-alpha.c47
1 files changed, 1 insertions, 46 deletions
diff --git a/src/vu-set-alpha.c b/src/vu-set-alpha.c
index 3288126..2e80154 100644
--- a/src/vu-set-alpha.c
+++ b/src/vu-set-alpha.c
@@ -38,7 +38,6 @@ main(int argc, char *argv[])
{
int invert = 0;
struct stream colour, alpha;
- size_t n;
void (*process)(struct stream *colour, struct stream *alpha, size_t n) = NULL;
ARGBEGIN {
@@ -60,55 +59,11 @@ main(int argc, char *argv[])
alpha.fd = eopen(alpha.file, O_RDONLY);
einit_stream(&alpha);
- echeck_compat(&colour, &alpha);
-
if (!strcmp(colour.pixfmt, "xyza"))
process = invert ? process_xyza_i : process_xyza;
else
eprintf("pixel format %s is not supported, try xyza\n", colour.pixfmt);
- for (;;) {
- if (colour.ptr < sizeof(colour.buf) && !eread_stream(&colour, SIZE_MAX)) {
- close(colour.fd);
- colour.fd = -1;
- break;
- }
- if (alpha.ptr < sizeof(alpha.buf) && !eread_stream(&alpha, SIZE_MAX)) {
- close(alpha.fd);
- alpha.fd = -1;
- break;
- }
-
- n = colour.ptr < alpha.ptr ? colour.ptr : alpha.ptr;
- n -= n % colour.pixel_size;
- colour.ptr -= n;
- alpha.ptr -= n;
-
- process(&colour, &alpha, n);
-
- ewriteall(STDOUT_FILENO, colour.buf, n, "<stdout>");
- if ((n & 3) || colour.ptr != alpha.ptr) {
- memmove(colour.buf, colour.buf + n, colour.ptr);
- memmove(alpha.buf, alpha.buf + n, alpha.ptr);
- }
- }
-
- if (alpha.fd >= 0)
- close(alpha.fd);
-
- ewriteall(STDOUT_FILENO, colour.buf, colour.ptr, "<stdout>");
-
- if (colour.fd >= 0) {
- for (;;) {
- colour.ptr = 0;
- if (!eread_stream(&colour, SIZE_MAX)) {
- close(colour.fd);
- colour.fd = -1;
- break;
- }
- ewriteall(STDOUT_FILENO, colour.buf, colour.ptr, "<stdout>");
- }
- }
-
+ process_two_streams(&colour, &alpha, STDOUT_FILENO, "<stdout>", process);
return 0;
}