summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--default.theme15
-rw-r--r--src/fe-text/statusbar-items.c45
2 files changed, 47 insertions, 13 deletions
diff --git a/default.theme b/default.theme
index e55549af..3b457830 100644
--- a/default.theme
+++ b/default.theme
@@ -262,10 +262,23 @@ abstracts = {
# used for anything.
sbend = " ";
+ prompt = "[$*] ";
+
sb = " %c[%n$*%c]%n";
sbmode = "(%c+%n$*)";
sbaway = " (%GzZzZ%n)";
sbservertag = ":$0 (change with ^X)";
- prompt = "[$*] ";
+ # activity in statusbar
+
+ # ',' separator
+ sb_act_sep = "%c$*";
+ # normal text
+ sb_act_text = "%c$*";
+ # public message
+ sb_act_msg = "%W$*";
+ # hilight
+ sb_act_hilight = "%M$*";
+ # hilight with specified color, $0 = color, $1 = text
+ sb_act_hilight_color = "$0$1-%n";
};
diff --git a/src/fe-text/statusbar-items.c b/src/fe-text/statusbar-items.c
index 55f26253..53d386d0 100644
--- a/src/fe-text/statusbar-items.c
+++ b/src/fe-text/statusbar-items.c
@@ -22,6 +22,7 @@
#include "signals.h"
#include "settings.h"
+#include "themes.h"
#include "statusbar.h"
#include "gui-entry.h"
@@ -118,15 +119,20 @@ static void item_lag(SBAR_ITEM_REC *item, int get_size_only)
g_string_free(str, TRUE);
}
-static char *get_activity_list(int normal, int hilight)
+static char *get_activity_list(MAIN_WINDOW_REC *window, int normal, int hilight)
{
+ THEME_REC *theme;
GString *str;
GList *tmp;
- char *ret;
+ char *ret, *name, *format, *value;
int is_det;
str = g_string_new(NULL);
+ theme = window != NULL && window->active != NULL &&
+ window->active->theme != NULL ?
+ window->active->theme : current_theme;
+
for (tmp = activity_list; tmp != NULL; tmp = tmp->next) {
WINDOW_REC *window = tmp->data;
@@ -134,26 +140,41 @@ static char *get_activity_list(int normal, int hilight)
if ((!is_det && !normal) || (is_det && !hilight))
continue;
- g_string_append(str, "%c");
- if (str->len > 2)
- g_string_append_c(str, ',');
+ /* comma separator */
+ if (str->len > 0) {
+ value = theme_format_expand(theme, "{sb_act_sep ,}");
+ g_string_append(str, value);
+ g_free(value);
+ }
switch (window->data_level) {
case DATA_LEVEL_NONE:
case DATA_LEVEL_TEXT:
+ name = "{sb_act_text %d}";
break;
case DATA_LEVEL_MSG:
- g_string_append(str, "%W");
+ name = "{sb_act_msg %d}";
break;
default:
- g_string_append(str, window->hilight_color == NULL ?
- "%M" : window->hilight_color);
+ if (window->hilight_color == NULL)
+ name = "{sb_act_hilight %d}";
+ else
+ name = NULL;
break;
}
- g_string_sprintfa(str, "%d", window->refnum);
- /* make sure the background is returned to default */
- g_string_append(str, "%n");
+ if (name != NULL)
+ format = g_strdup_printf(name, window->refnum);
+ else
+ format = g_strdup_printf("{sb_act_hilight_color %s %d}",
+ window->hilight_color,
+ window->refnum);
+
+ value = theme_format_expand(theme, format);
+ g_string_append(str, value);
+ g_free(value);
+
+ g_free(format);
}
ret = str->len == 0 ? NULL : str->str;
@@ -168,7 +189,7 @@ static void item_act(SBAR_ITEM_REC *item, int get_size_only)
{
char *actlist;
- actlist = get_activity_list(TRUE, TRUE);
+ actlist = get_activity_list(item->bar->parent_window, TRUE, TRUE);
if (actlist == NULL) {
if (get_size_only)
item->min_size = item->max_size = 0;