diff options
author | June McEnroe <june@causal.agency> | 2020-02-10 03:37:17 -0500 |
---|---|---|
committer | June McEnroe <june@causal.agency> | 2020-02-10 03:37:17 -0500 |
commit | 2c9ff1717b00b9373240dad8200bb8a766ac05cb (patch) | |
tree | c17f6247e1d951a5287c6764f6ea9ec918c40c6f | |
parent | Only make windows hotter (diff) | |
download | catgirl-2c9ff1717b00b9373240dad8200bb8a766ac05cb.tar.gz catgirl-2c9ff1717b00b9373240dad8200bb8a766ac05cb.zip |
Recalculate unreadLines on reflow
-rw-r--r-- | ui.c | 11 |
1 files changed, 8 insertions, 3 deletions
diff --git a/ui.c b/ui.c index 7f13e5b..666a93d 100644 --- a/ui.c +++ b/ui.c @@ -415,7 +415,7 @@ static void windowScroll(struct Window *window, int n) { static void windowScrollUnread(struct Window *window) { window->scroll = 0; - windowScroll(window, window->unreadLines - PAGE_LINES); + windowScroll(window, window->unreadLines - PAGE_LINES + 1); } static int wordWidth(const char *str) { @@ -516,13 +516,18 @@ void uiFormat( static void reflow(struct Window *window) { werase(window->pad); - wmove(window->pad, BufferCap - 1, 0); + wmove(window->pad, WindowLines - 1, 0); + window->unreadLines = 0; struct Buffer *buffer = &window->buffer; for (size_t i = 0; i < BufferCap; ++i) { char *line = buffer->lines[(buffer->len + i) % BufferCap]; if (!line) continue; waddch(window->pad, '\n'); - wordWrap(window->pad, line); + if (i >= (size_t)(BufferCap - window->unreadCount)) { + window->unreadLines += 1 + wordWrap(window->pad, line); + } else { + wordWrap(window->pad, line); + } } } |