summary refs log tree commit diff
path: root/bin/gfxx.c
diff options
context:
space:
mode:
authorJune McEnroe <programble@gmail.com>2018-02-14 15:24:53 -0500
committerJune McEnroe <programble@gmail.com>2018-02-14 15:26:22 -0500
commit4414a56f40246282ee9f62766db37a8eeb4df353 (patch)
tree6746391e1cbdb9591fc73f29334b6bb3779eb34e /bin/gfxx.c
parentReplace pngChunk with glorious C metaprogramming (diff)
downloadsrc-4414a56f40246282ee9f62766db37a8eeb4df353.tar.gz
src-4414a56f40246282ee9f62766db37a8eeb4df353.zip
Add gfxx DUMP_ALL
Diffstat (limited to 'bin/gfxx.c')
-rw-r--r--bin/gfxx.c11
1 files changed, 8 insertions, 3 deletions
diff --git a/bin/gfxx.c b/bin/gfxx.c
index 4674c82f..d3d9aa99 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;