summary refs log tree commit diff
diff options
context:
space:
mode:
-rw-r--r--ui.c29
1 files changed, 23 insertions, 6 deletions
diff --git a/ui.c b/ui.c
index 18af635..df51a3d 100644
--- a/ui.c
+++ b/ui.c
@@ -447,19 +447,24 @@ void uiHide(void) {
 	endwin();
 }
 
+static void mainAdd(int y, const char *str) {
+	int ny, nx;
+	wmove(main, y, 0);
+	styleAdd(main, str);
+	getyx(main, ny, nx);
+	if (ny == y) wclrtoeol(main);
+}
+
 static void windowUpdate(void) {
 	struct Window *window = windows.ptrs[windows.show];
 
 	int y = MAIN_LINES - 1;
-	for (size_t i = BufferCap - 1 - window->scroll; i < BufferCap; --i) {
+	size_t bottom = BufferCap - 1 - window->scroll + !!window->scroll;
+	for (size_t i = bottom; i < BufferCap; --i) {
 		const struct Line *line = bufferHard(window->buffer, i);
 		if (!line) continue;
 		if (line->heat < Cold && window->ignore) continue;
-		wmove(main, y, 0);
-		styleAdd(main, line->str);
-		int ny, nx;
-		getyx(main, ny, nx);
-		if (ny == y) wclrtoeol(main);
+		mainAdd(y, line->str);
 		if (!y--) break;
 	}
 
@@ -467,6 +472,18 @@ static void windowUpdate(void) {
 		wmove(main, y--, 0);
 		wclrtoeol(main);
 	}
+	if (!window->scroll) return;
+
+	y = MAIN_LINES - 1;
+	for (size_t i = BufferCap - 1; i < BufferCap; --i) {
+		const struct Line *line = bufferHard(window->buffer, i);
+		if (!line) continue;
+		if (line->heat < Cold && window->ignore) continue;
+		mainAdd(y, line->str);
+		if (--y < MAIN_LINES - SplitLines) break;
+	}
+	wattr_set(main, A_NORMAL, 0, NULL);
+	mvwhline(main, y, 0, ACS_BULLET, COLS);
 }
 
 static void windowScroll(struct Window *window, int n) {
pan>snapshot: use cgit_print_error_page() instead of html_status()John Keeping 2015-08-14plain: use cgit_print_error_page() instead of html_status()John Keeping 2015-08-14clone: use cgit_print_error_page() instead of html_status()John Keeping 2015-08-14cgit: use cgit_print_error_page() where appropriateJohn Keeping 2015-08-14ui-shared: add cgit_print_error_page() functionJohn Keeping 2015-08-14ui-patch: make sure to send http headersChristian Hesse 2015-08-13Makefile: make "git/config.mak.uname" inclusion optionalJohn Keeping 2015-08-13ui-shared: show full date in tooltip if longer ago than max_relativeJohn Keeping 2015-08-13ui-shared: use common function in print_rel_date()John Keeping 2015-08-13ui-shared: extract date formatting to a functionJohn Keeping 2015-08-13filter: don't use dlsym unnecessarilyJohn Keeping 2015-08-13ui-tree: use "sane" isgraph()John Keeping 2015-08-13cgit.h: move stdbool.h from ui-shared.hJohn Keeping 2015-08-13cache.c: fix header orderJohn Keeping 2015-08-13configfile.c: don't include system headers directlyJohn Keeping 2015-08-13Remove redundant includesJohn Keeping 2015-08-13Makefile: include Git's config.mak.unameJohn Keeping 2015-08-13tests: allow shell to be overriddenJohn Keeping 2015-08-13redirect: cleanlinessJason A. Donenfeld 2015-08-13redirect: be more careful for different cgi setupsJason A. Donenfeld 2015-08-12ui-log: fix double countingJohn Keeping 2015-08-12log: allow users to follow a fileJohn Keeping 2015-08-12shared: make cgit_diff_tree_cb publicJohn Keeping 2015-08-12t0110: Chain together using &&Jason A. Donenfeld 2015-08-12about: always ensure page has a trailing slashJason A. Donenfeld 2015-08-12filters: apply HTML escapingLazaros Koromilas 2015-08-12git: update to v2.5.0Christian Hesse 2015-08-12Fix processing of repo.hide and repo.ignoreDaniel Reichelt