about summary refs log tree commit diff homepage
diff options
context:
space:
mode:
authorJune McEnroe <june@causal.agency>2018-08-26 23:14:48 -0400
committerJune McEnroe <june@causal.agency>2018-08-26 23:14:48 -0400
commitc5ee7405e650fd184deaf55794b4843f733c3986 (patch)
treeba1d6f17248815297cc5ae9ffe209738e05673a8
parentUpdate help page (diff)
downloadtorus-c5ee7405e650fd184deaf55794b4843f733c3986.tar.gz
torus-c5ee7405e650fd184deaf55794b4843f733c3986.zip
Map modifyCount on log scale
-rw-r--r--client.c30
1 files changed, 21 insertions, 9 deletions
diff --git a/client.c b/client.c
index 29e1cce..1478ebe 100644
--- a/client.c
+++ b/client.c
@@ -16,6 +16,7 @@
 
 #define _XOPEN_SOURCE_EXTENDED
 
+#include <assert.h>
 #include <curses.h>
 #include <err.h>
 #include <errno.h>
@@ -45,6 +46,11 @@ enum {
 	DEL = 0x7F,
 };
 
+static uint32_t log2(uint32_t n) {
+	assert(n > 0);
+	return 32 - __builtin_clz(n) - 1;
+}
+
 static void curse(void) {
 	setlocale(LC_CTYPE, "");
 
@@ -190,15 +196,21 @@ static void serverMap(void) {
 		for (uint8_t x = 0; x < MAP_COLS; ++x) {
 			struct Meta meta = map.meta[y][x];
 
-			uint32_t count = DIV_ROUND(
-				(ARRAY_LEN(MAP_CELLS) - 1) * meta.modifyCount,
-				map.max.modifyCount
-			);
-			uint32_t time = DIV_ROUND(
-				(ARRAY_LEN(MAP_COLORS) - 1) * (meta.modifyTime - map.min.createTime),
-				map.now - map.min.createTime
-			);
-			if (!meta.modifyTime) time = 0;
+			uint32_t count = 0;
+			if (meta.modifyCount && log2(map.max.modifyCount)) {
+				count = DIV_ROUND(
+					(ARRAY_LEN(MAP_CELLS) - 1) * log2(meta.modifyCount),
+					log2(map.max.modifyCount)
+				);
+			}
+			uint32_t time = 0;
+			if (meta.modifyTime) {
+				uint32_t modify = meta.modifyTime - map.min.createTime;
+				time = DIV_ROUND(
+					(ARRAY_LEN(MAP_COLORS) - 1) * modify,
+					map.now - map.min.createTime
+				);
+			}
 
 			wchar_t cell = MAP_CELLS[count];
 			uint8_t color = MAP_COLORS[time];