about summary refs log tree commit diff
path: root/ui.c
diff options
context:
space:
mode:
authorJune McEnroe <june@causal.agency>2020-02-10 21:24:30 -0500
committerJune McEnroe <june@causal.agency>2020-02-10 21:24:30 -0500
commit90eff04eda86e0a75b0e81960e2166193c366be7 (patch)
treeb35bfb3fb04aaacea8c897a36f9a0d8e3a48dfce /ui.c
parentManually raise SIGINT from C-c (diff)
downloadcatgirl-90eff04eda86e0a75b0e81960e2166193c366be7.tar.gz
catgirl-90eff04eda86e0a75b0e81960e2166193c366be7.zip
Only write out title on uiDraw
Diffstat (limited to 'ui.c')
-rw-r--r--ui.c22
1 files changed, 15 insertions, 7 deletions
diff --git a/ui.c b/ui.c
index 903c4af..297fd7b 100644
--- a/ui.c
+++ b/ui.c
@@ -268,6 +268,8 @@ void uiInit(void) {
 	uiShow();
 }
 
+static char title[256];
+
 void uiDraw(void) {
 	if (hidden) return;
 	wnoutrefresh(status);
@@ -291,6 +293,12 @@ void uiDraw(void) {
 		BOTTOM, RIGHT
 	);
 	doupdate();
+
+	if (!to_status_line) return;
+	putp(to_status_line);
+	putp(title);
+	putp(from_status_line);
+	fflush(stdout);
 }
 
 struct Style {
@@ -396,21 +404,21 @@ static void statusUpdate(void) {
 		statusAdd(buf);
 	}
 	wclrtoeol(status);
-	if (!to_status_line) return;
 
 	window = windows.active;
-	putp(to_status_line);
-	printf("%s %s", self.network, idNames[window->id]);
+	snprintf(title, sizeof(title), "%s %s", self.network, idNames[window->id]);
 	if (window->mark && window->unreadCount) {
-		printf(
+		snprintf(
+			&title[strlen(title)], sizeof(title) - strlen(title),
 			" (%d%s)", window->unreadCount, (window->heat > Warm ? "!" : "")
 		);
 	}
 	if (otherUnread) {
-		printf(" (+%d%s)", otherUnread, (otherHeat > Warm ? "!" : ""));
+		snprintf(
+			&title[strlen(title)], sizeof(title) - strlen(title),
+			" (+%d%s)", otherUnread, (otherHeat > Warm ? "!" : "")
+		);
 	}
-	putp(from_status_line);
-	fflush(stdout);
 }
 
 static void mark(struct Window *window) {