summary refs log tree commit diff
path: root/bin/gfx
diff options
context:
space:
mode:
authorJune McEnroe <june@causal.agency>2018-02-14 15:24:53 -0500
committerJune McEnroe <june@causal.agency>2018-02-14 15:26:22 -0500
commit1e262a8cc1cf97459682cfb0dfeacdda532ec585 (patch)
treed6930d5dea70fbe82184767443bdec186c32267b /bin/gfx
parentReplace pngChunk with glorious C metaprogramming (diff)
downloadsrc-1e262a8cc1cf97459682cfb0dfeacdda532ec585.tar.gz
src-1e262a8cc1cf97459682cfb0dfeacdda532ec585.zip
Add gfxx DUMP_ALL
Diffstat (limited to '')
-rw-r--r--bin/gfxx.c11
1 files changed, 8 insertions, 3 deletions
diff --git a/bin/gfxx.c b/bin/gfxx.c
index c52c5f0d..6ccb17cb 100644
--- a/bin/gfxx.c
+++ b/bin/gfxx.c
@@ -362,7 +362,11 @@ static void pngDump(uint32_t *src, size_t srcWidth, size_t srcHeight) {
     if (error) err(EX_IOERR, "%s", pngPath);
 }
 
-static bool dump;
+static enum {
+    DUMP_NONE,
+    DUMP_ONE,
+    DUMP_ALL,
+} dump;
 
 void draw(uint32_t *buf, size_t bufWidth, size_t bufHeight) {
     memset(buf, 0, 4 * bufWidth * bufHeight);
@@ -373,7 +377,7 @@ void draw(uint32_t *buf, size_t bufWidth, size_t bufHeight) {
         drawBits(&it);
     }
     if (dump) pngDump(buf, bufWidth, bufHeight);
-    dump = false;
+    if (dump == DUMP_ONE) dump = DUMP_NONE;
 }
 
 static void palSample(void) {
@@ -420,7 +424,8 @@ bool input(char in) {
     size_t row = width * pixel;
     switch (in) {
         case 'q': return false;
-        break; case 'x': dump = true;
+        break; case 'x': dump = DUMP_ONE;
+        break; case 'X': dump ^= DUMP_ALL;
         break; case 'o': formatOptions(); printf("%s\n", options);
         break; case '[': if (!space--) space = COLOR__MAX - 1;
         break; case ']': if (++space == COLOR__MAX) space = 0;