From 875130e7e8e32ffbc3166388cfc81893ff6584d1 Mon Sep 17 00:00:00 2001 From: darkraven Date: Fri, 27 Jul 2012 02:53:32 +0800 Subject: [PATCH] Automatically hide i3bar when it's unneeded. When a workspace marked 'urgent', i3bar unhide itself. if I want to hide it again, I must press the modifier.This sometimes annoys me. In this patch I change the above behavior to this: If a urgent workspace occurs, i3bar will unhide itself; and when you navigates away from the last urgent workspace and there is no more urgent workspace, i3bar will hide itself. --- i3bar/src/xcb.c | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/i3bar/src/xcb.c b/i3bar/src/xcb.c index 289d7d9e..419a4723 100644 --- a/i3bar/src/xcb.c +++ b/i3bar/src/xcb.c @@ -1464,6 +1464,9 @@ void draw_bars() { } i3_ws *ws_walk; + static char *last_urgent_ws = NULL; + bool has_urgent = false, walks_away = true; + TAILQ_FOREACH(ws_walk, outputs_walk->workspaces, tailq) { DLOG("Drawing Button for WS %s at x = %d, len = %d\n", ws_walk->name, i, ws_walk->name_width); uint32_t fg_color = colors.inactive_ws_fg; @@ -1478,6 +1481,8 @@ void draw_bars() { fg_color = colors.focus_ws_fg; bg_color = colors.focus_ws_bg; border_color = colors.focus_ws_border; + if (last_urgent_ws && strcmp(ws_walk->name, last_urgent_ws) == 0) + walks_away = false; } } if (ws_walk->urgent) { @@ -1485,6 +1490,11 @@ void draw_bars() { fg_color = colors.urgent_ws_fg; bg_color = colors.urgent_ws_bg; border_color = colors.urgent_ws_border; + has_urgent = true; + if (!ws_walk->focused) { + FREE(last_urgent_ws); + last_urgent_ws = sstrdup(ws_walk->name); + } /* The urgent-hint should get noticed, so we unhide the bars shortly */ unhide_bars(); } @@ -1517,6 +1527,11 @@ void draw_bars() { i += 10 + ws_walk->name_width + 1; } + if (!has_urgent && !mod_pressed && walks_away) { + FREE(last_urgent_ws); + hide_bars(); + } + i = 0; }