about summary refs log tree commit diff
path: root/buffer.c
diff options
context:
space:
mode:
authorJune McEnroe <june@causal.agency>2021-01-16 12:58:16 -0500
committerJune McEnroe <june@causal.agency>2021-01-16 12:58:16 -0500
commitd05872303e2313d28f45569851ddeb238fc4d5ea (patch)
treea746980ed4377ab1625affdd75ebb817aec898b2 /buffer.c
parentSave and load the URL ring in the save file (diff)
downloadcatgirl-d05872303e2313d28f45569851ddeb238fc4d5ea.tar.gz
catgirl-d05872303e2313d28f45569851ddeb238fc4d5ea.zip
Generalize ignore toggling to visibility threshold
Diffstat (limited to 'buffer.c')
-rw-r--r--buffer.c9
1 files changed, 5 insertions, 4 deletions
diff --git a/buffer.c b/buffer.c
index bdf9e3a..ef175b8 100644
--- a/buffer.c
+++ b/buffer.c
@@ -199,7 +199,7 @@ static int flow(struct Lines *hard, int cols, const struct Line *soft) {
 }
 
 int bufferPush(
-	struct Buffer *buffer, int cols, bool ignore,
+	struct Buffer *buffer, int cols, enum Heat thresh,
 	enum Heat heat, time_t time, const char *str
 ) {
 	struct Line *soft = linesNext(&buffer->soft);
@@ -207,11 +207,12 @@ int bufferPush(
 	soft->time = time;
 	soft->str = strdup(str);
 	if (!soft->str) err(EX_OSERR, "strdup");
-	if (heat < Cold && ignore) return 0;
+	if (heat < thresh) return 0;
 	return flow(&buffer->hard, cols, soft);
 }
 
-int bufferReflow(struct Buffer *buffer, int cols, bool ignore, size_t tail) {
+int
+bufferReflow(struct Buffer *buffer, int cols, enum Heat thresh, size_t tail) {
 	buffer->hard.len = 0;
 	for (size_t i = 0; i < BufferCap; ++i) {
 		free(buffer->hard.lines[i].str);
@@ -221,7 +222,7 @@ int bufferReflow(struct Buffer *buffer, int cols, bool ignore, size_t tail) {
 	for (size_t i = 0; i < BufferCap; ++i) {
 		const struct Line *soft = bufferSoft(buffer, i);
 		if (!soft) continue;
-		if (soft->heat < Cold && ignore) continue;
+		if (soft->heat < thresh) continue;
 		int n = flow(&buffer->hard, cols, soft);
 		if (i >= BufferCap - tail) flowed += n;
 	}