about summary refs log tree commit diff
path: root/ui.c
diff options
context:
space:
mode:
authorJune McEnroe <june@causal.agency>2020-09-03 15:50:39 -0400
committerJune McEnroe <june@causal.agency>2020-09-03 15:50:39 -0400
commitdbc0c3ef4028ae4af2cb2d0a2088ba1e5cc2cd13 (patch)
tree1c690bfc514ccce03b9d21009daa10ecf92ee239 /ui.c
parentRecalculate unreadHard on reflow (diff)
downloadcatgirl-dbc0c3ef4028ae4af2cb2d0a2088ba1e5cc2cd13.tar.gz
catgirl-dbc0c3ef4028ae4af2cb2d0a2088ba1e5cc2cd13.zip
Fix M-u behaviour difference before and after reflow
Diffstat (limited to 'ui.c')
-rw-r--r--ui.c9
1 files changed, 4 insertions, 5 deletions
diff --git a/ui.c b/ui.c
index 333ef53..1e1f361 100644
--- a/ui.c
+++ b/ui.c
@@ -501,7 +501,7 @@ static void windowScrollPage(struct Window *window, int n) {
 
 static void windowScrollUnread(struct Window *window) {
 	window->scroll = 0;
-	windowScroll(window, window->unreadHard - MAIN_LINES);
+	windowScroll(window, window->unreadHard - MAIN_LINES + MarkerLines);
 }
 
 struct Util uiNotifyUtil;
@@ -536,19 +536,18 @@ void uiWrite(uint id, enum Heat heat, const time_t *src, const char *str) {
 	struct Window *window = windows.ptrs[windowFor(id)];
 	time_t ts = (src ? *src : time(NULL));
 
-	int lines = 0;
 	if (heat > Ice || !window->ignore) {
 		if (!window->unreadSoft++) window->unreadHard = 0;
 	}
 	if (window->mark && heat > Cold) {
 		if (!window->unreadWarm++) {
-			window->unreadSoft++;
-			lines += bufferPush(window->buffer, COLS, false, Cold, ts, "");
+			int lines = bufferPush(window->buffer, COLS, false, Cold, ts, "");
+			if (window->scroll) windowScroll(window, lines);
 		}
 		if (heat > window->heat) window->heat = heat;
 		statusUpdate();
 	}
-	lines += bufferPush(window->buffer, COLS, window->ignore, heat, ts, str);
+	int lines = bufferPush(window->buffer, COLS, window->ignore, heat, ts, str);
 	window->unreadHard += lines;
 	if (window->scroll) windowScroll(window, lines);
 	if (window == windows.ptrs[windows.show]) windowUpdate();