about summary refs log tree commit diff
diff options
context:
space:
mode:
authorJune McEnroe <june@causal.agency>2021-01-21 11:39:23 -0500
committerJune McEnroe <june@causal.agency>2021-01-21 11:57:23 -0500
commit6ee0aea9e55cd72102a7abee26481179311273f2 (patch)
tree151df7435dcc16f94be0b2a5ea6de4ccb24339f6
parentDocument that M-l shows timestamps (diff)
downloadcatgirl-6ee0aea9e55cd72102a7abee26481179311273f2.tar.gz
catgirl-6ee0aea9e55cd72102a7abee26481179311273f2.zip
Simplify windowUpdate loops and factor out windowTop
No idea why I made that more complicated than it had to be looping
backwards.
-rw-r--r--ui.c38
1 files changed, 17 insertions, 21 deletions
diff --git a/ui.c b/ui.c
index 090a247..ed0cb6a 100644
--- a/ui.c
+++ b/ui.c
@@ -463,33 +463,31 @@ static void mainAdd(int y, const char *str) {
 	(void)nx;
 }
 
+static size_t windowTop(const struct Window *window) {
+	size_t top = BufferCap - MAIN_LINES - window->scroll;
+	if (window->scroll) top += MarkerLines;
+	return top;
+}
+
 static void windowUpdate(void) {
 	struct Window *window = windows.ptrs[windows.show];
 
-	int y = MAIN_LINES - 1;
-	size_t bottom = BufferCap - 1 - window->scroll + !!window->scroll;
-	for (size_t i = bottom; i < BufferCap; --i) {
+	int y = 0;
+	int marker = MAIN_LINES - SplitLines - MarkerLines;
+	for (size_t i = windowTop(window); i < BufferCap; ++i) {
 		const struct Line *line = bufferHard(window->buffer, i);
-		if (!line) break;
-		mainAdd(y, line->str);
-		if (!y--) break;
-	}
-
-	while (y >= 0) {
-		wmove(main, y--, 0);
-		wclrtoeol(main);
+		mainAdd(y++, (line ? line->str : ""));
+		if (window->scroll && y == marker) break;
 	}
 	if (!window->scroll) return;
 
-	y = MAIN_LINES - 1;
-	for (size_t i = BufferCap - 1; i < BufferCap; --i) {
+	y = MAIN_LINES - SplitLines;
+	for (size_t i = BufferCap - SplitLines; i < BufferCap; ++i) {
 		const struct Line *line = bufferHard(window->buffer, i);
-		if (!line) break;
-		mainAdd(y, line->str);
-		if (--y < MAIN_LINES - SplitLines) break;
+		mainAdd(y++, (line ? line->str : ""));
 	}
 	wattr_set(main, A_NORMAL, 0, NULL);
-	mvwhline(main, y, 0, ACS_BULLET, COLS);
+	mvwhline(main, marker, 0, ACS_BULLET, COLS);
 }
 
 static void windowScroll(struct Window *window, int n) {
@@ -513,8 +511,7 @@ static void windowScrollTo(struct Window *window, int top) {
 }
 
 static void windowScrollHot(struct Window *window, int dir) {
-	size_t from = BufferCap - window->scroll - MAIN_LINES + MarkerLines + dir;
-	for (size_t i = from; i < BufferCap; i += dir) {
+	for (size_t i = windowTop(window) + dir; i < BufferCap; i += dir) {
 		const struct Line *line = bufferHard(window->buffer, i);
 		const struct Line *prev = bufferHard(window->buffer, i - 1);
 		if (!line || line->heat < Hot) continue;
@@ -526,8 +523,7 @@ static void windowScrollHot(struct Window *window, int dir) {
 
 static void
 windowScrollSearch(struct Window *window, const char *str, int dir) {
-	size_t from = BufferCap - window->scroll - MAIN_LINES + MarkerLines + dir;
-	for (size_t i = from; i < BufferCap; i += dir) {
+	for (size_t i = windowTop(window) + dir; i < BufferCap; i += dir) {
 		const struct Line *line = bufferHard(window->buffer, i);
 		if (!line || !strcasestr(line->str, str)) continue;
 		windowScrollTo(window, BufferCap - i);
ght'> 2022-09-18Make copyrights and AUTHORS consistentJune McEnroe 2022-07-27Update to FreeBSD 13.1 2062.83June McEnroe 2022-07-27openbsd: Include man pages from baseXX.tgzKeith Whitney A number of OpenBSD man pages are currently missing in exman, since they reside in OpenBSD's baseXX.tgz [1]: - help(1) - man(1) - pkg_add(1) - OpenBSD::BaseState(3p) - packages(7) - adduser(8) - afterboot(8) - user(8) - useradd(8) - userdel(8) - userinfo(8) - usermod(8) This patch adds baseXX.tgz to the OpenBSD distfiles, which begrudgingly adds ~330 MiB to the install. I figure this might acceptable since base.txz is similarly fetched for FreeBSD. Since this isn't ideal, I'll look into whether these man pages are intended to be in baseXX.tgz or not. If not, I'll see about changing this upstream, and this patch can be reverted. [1] Lines 2876-2931: https://cvsweb.openbsd.org/cgi-bin/cvsweb/src/distrib/sets/lists/base/mi?annotate=1.1065 2022-05-08Update to OpenBSD 7.1 2062.73June McEnroe 2021-10-15Update to OpenBSD 7.0 2062.63June McEnroe 2021-08-29Update to Linux man-pages 5.13 2062.53Štěpán Němec 2021-08-26Update to NetBSD 9.2 2062.52June McEnroe 2021-08-26Support DESTDIR in install/uninstallJune McEnroe 2021-08-26Add version number generatorJune McEnroe 2021-08-22Add ISC license headerJune McEnroe 2021-08-22Update to Linux man-pages 5.12Štěpán Němec 2021-06-21Add manuals for macOS 11.3June McEnroe 2021-05-08Update to OpenBSD 6.9June McEnroe 2021-04-26Update to Linux man-pages 5.11June McEnroe 2021-04-26Update to FreeBSD 13.0June McEnroe 2021-01-27Completely rewrite how manuals are fetched and installedJune McEnroe Also add section 6 manuals from NetBSD and OpenBSD! 2020-12-14Update to man-pages-posix 2017-aJune McEnroe 2020-12-14Update to OpenBSD 6.8June McEnroe 2020-12-14Update to NetBSD 9.1June McEnroe 2020-12-14Update to man-pages 5.09June McEnroe 2020-12-14Update to FreeBSD 12.2June McEnroe 2020-06-08Update to OpenBSD 6.7June McEnroe 2020-05-04Add hack for macOS to search extra man sectionsJune McEnroe 2020-05-04Don't clear MANSECTJune McEnroe