diff options
| author | June McEnroe <june@causal.agency> | 2020-09-03 15:50:39 -0400 | 
|---|---|---|
| committer | June McEnroe <june@causal.agency> | 2020-09-03 15:50:39 -0400 | 
| commit | dbc0c3ef4028ae4af2cb2d0a2088ba1e5cc2cd13 (patch) | |
| tree | 1c690bfc514ccce03b9d21009daa10ecf92ee239 | |
| parent | Recalculate unreadHard on reflow (diff) | |
| download | catgirl-dbc0c3ef4028ae4af2cb2d0a2088ba1e5cc2cd13.tar.gz catgirl-dbc0c3ef4028ae4af2cb2d0a2088ba1e5cc2cd13.zip | |
Fix M-u behaviour difference before and after reflow
| -rw-r--r-- | ui.c | 9 | 
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(); |