diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/fe-common/core/themes.c | 255 | ||||
-rw-r--r-- | src/fe-common/core/themes.h | 15 | ||||
-rw-r--r-- | src/fe-text/mainwindows.h | 2 | ||||
-rw-r--r-- | src/fe-text/screen.c | 10 | ||||
-rw-r--r-- | src/fe-text/statusbar-items.c | 219 | ||||
-rw-r--r-- | src/fe-text/statusbar.c | 35 | ||||
-rw-r--r-- | src/fe-text/statusbar.h | 3 |
7 files changed, 295 insertions, 244 deletions
diff --git a/src/fe-common/core/themes.c b/src/fe-common/core/themes.c index 5646b7bc..997395a3 100644 --- a/src/fe-common/core/themes.c +++ b/src/fe-common/core/themes.c @@ -94,8 +94,6 @@ void theme_destroy(THEME_REC *rec) g_hash_table_foreach(rec->modules, (GHFunc) theme_module_destroy, NULL); g_hash_table_destroy(rec->modules); - g_slist_foreach(rec->replace_keys, (GFunc) g_free, NULL); - g_slist_free(rec->replace_keys); g_slist_foreach(rec->replace_values, (GFunc) g_free, NULL); g_slist_free(rec->replace_values); @@ -104,30 +102,10 @@ void theme_destroy(THEME_REC *rec) g_free(rec); } -#define EXPAND_FLAG_ROOT 0x01 -#define EXPAND_FLAG_LASTCOLOR_ARG 0x02 -static char *theme_format_expand_data(THEME_REC *theme, - const char **format, - char default_color, - char *save_color, int flags); - -static int theme_replace_find(THEME_REC *theme, char chr) -{ - GSList *tmp; - int index = 0; - - for (tmp = theme->replace_keys; tmp != NULL; tmp = tmp->next) { - if (strchr(tmp->data, chr) != NULL) - return index; - index++; - } - - return -1; -} - static char *theme_replace_expand(THEME_REC *theme, int index, - char default_color, char *last_color, - char chr) + char default_fg, char default_bg, + char *last_fg, char *last_bg, + char chr, int flags) { GSList *rec; char *ret, *abstract, data[2]; @@ -139,16 +117,20 @@ static char *theme_replace_expand(THEME_REC *theme, int index, abstract = rec->data; abstract = theme_format_expand_data(theme, (const char **) &abstract, - default_color, last_color, 0); + default_fg, default_bg, + last_fg, last_bg, flags); ret = parse_special_string(abstract, NULL, NULL, data, NULL, 0); g_free(abstract); return ret; } -static const char *colorformats = "n01234567krgybmpcwKRGYBMPCW"; +static const char *fgcolorformats = "nkrgybmpcwKRGYBMPCW"; +static const char *bgcolorformats = "n01234567"; -#define IS_COLOR_FORMAT(c) \ - ((c) != '\0' && strchr(colorformats, c) != NULL) +#define IS_FGCOLOR_FORMAT(c) \ + ((c) != '\0' && strchr(fgcolorformats, c) != NULL) +#define IS_BGCOLOR_FORMAT(c) \ + ((c) != '\0' && strchr(bgcolorformats, c) != NULL) /* append "variable" part in $variable, ie. not the contents of the variable */ static void theme_format_append_variable(GString *str, const char **format) @@ -174,7 +156,9 @@ static void theme_format_append_variable(GString *str, const char **format) /* append next "item", either a character, $variable or %format */ static void theme_format_append_next(THEME_REC *theme, GString *str, const char **format, - char default_color, char *last_color) + char default_fg, char default_bg, + char *last_fg, char *last_bg, + int flags) { int index; char chr; @@ -200,14 +184,32 @@ static void theme_format_append_next(THEME_REC *theme, GString *str, (*format)++; if (**format != '{' && **format != '}') { chr = **format; - if (**format == 'n') - chr = default_color; - - if (IS_COLOR_FORMAT(chr)) - *last_color = chr; - - g_string_append_c(str, '%'); - g_string_append_c(str, chr); + if (**format == 'n') { + /* %n = change to default color */ + if (default_fg == 'n' || default_bg == 'n') { + if (*last_fg != 'n') + g_string_append(str, "%n"); + *last_bg = *last_fg = 'n'; + } + if (default_bg != *last_bg) { + g_string_append_c(str, '%'); + g_string_append_c(str, default_bg); + } + if (default_fg != *last_fg) { + g_string_append_c(str, '%'); + g_string_append_c(str, default_fg); + } + + *last_fg = default_fg; + *last_bg = default_bg; + } else { + if (IS_FGCOLOR_FORMAT(chr)) + *last_fg = chr; + if (IS_BGCOLOR_FORMAT(chr)) + *last_bg = chr; + g_string_append_c(str, '%'); + g_string_append_c(str, chr); + } (*format)++; return; } @@ -216,14 +218,16 @@ static void theme_format_append_next(THEME_REC *theme, GString *str, chr = **format; } - index = theme_replace_find(theme, chr); + index = (flags & EXPAND_FLAG_IGNORE_REPLACES) ? -1 : + theme->replace_keys[(int) chr]; if (index == -1) g_string_append_c(str, chr); else { char *value; - value = theme_replace_expand(theme, index, default_color, - last_color, chr); + value = theme_replace_expand(theme, index, + default_fg, default_bg, + last_fg, last_bg, chr, flags); g_string_append(str, value); g_free(value); } @@ -234,7 +238,8 @@ static void theme_format_append_next(THEME_REC *theme, GString *str, /* expand a single {abstract ...data... } */ static char *theme_format_expand_abstract(THEME_REC *theme, const char **formatp, - char default_color) + char default_fg, char default_bg, + int flags) { const char *p, *format; char *abstract, *data, *ret; @@ -252,9 +257,23 @@ static char *theme_format_expand_abstract(THEME_REC *theme, len = (int) (p-format); abstract = g_strndup(format, len); - /* skip the following space */ - if (*p == ' ') len++; - *formatp = format + len; + /* skip the following space, if there's any more spaces they're + treated as arguments */ + if (*p == ' ') { + len++; + if ((flags & EXPAND_FLAG_IGNORE_EMPTY)) { + /* if the data is empty, ignore the abstract */ + p = format+len; + while (*p == ' ') p++; + if (*p == '}') { + *formatp = p+1; + g_free(abstract); + return NULL; + } + } + + } + *formatp = format+len; /* get the abstract data */ data = g_hash_table_lookup(theme->abstracts, abstract); @@ -265,19 +284,12 @@ static char *theme_format_expand_abstract(THEME_REC *theme, } abstract = g_strdup(data); - /* abstract may itself contain abstracts or replaces :) */ - p = data = abstract; - abstract = theme_format_expand_data(theme, &p, default_color, - &default_color, - EXPAND_FLAG_LASTCOLOR_ARG); - g_free(data); - - /* now we'll need to get the data part. it may contain + /* we'll need to get the data part. it may contain more abstracts, they are automatically expanded. */ - data = theme_format_expand_data(theme, formatp, default_color, - NULL, 0); - + data = theme_format_expand_data(theme, formatp, default_fg, default_bg, + NULL, NULL, flags); len = strlen(data); + if (len > 1 && isdigit(data[len-1]) && data[len-2] == '$') { /* ends with $<digit> .. this breaks things if next character is digit or '-' */ @@ -293,23 +305,34 @@ static char *theme_format_expand_abstract(THEME_REC *theme, ret = parse_special_string(abstract, NULL, NULL, data, NULL, 0); g_free(abstract); - g_free(data); + g_free(data); + abstract = ret; + + /* abstract may itself contain abstracts or replaces */ + p = abstract; + ret = theme_format_expand_data(theme, &p, default_fg, default_bg, + &default_fg, &default_bg, + flags | EXPAND_FLAG_LASTCOLOR_ARG); + g_free(abstract); return ret; } /* expand the data part in {abstract data} */ -static char *theme_format_expand_data(THEME_REC *theme, - const char **format, - char default_color, - char *save_last_color, - int flags) +char *theme_format_expand_data(THEME_REC *theme, const char **format, + char default_fg, char default_bg, + char *save_last_fg, char *save_last_bg, + int flags) { GString *str; char *ret, *abstract; - char last_color = default_color; + char last_fg, last_bg; + int recurse_flags; - str = g_string_new(NULL); + last_fg = default_fg; + last_bg = default_bg; + recurse_flags = flags & EXPAND_FLAG_RECURSIVE_MASK; + str = g_string_new(NULL); while (**format != '\0') { if ((flags & EXPAND_FLAG_ROOT) == 0 && **format == '}') { /* ignore } if we're expanding original string */ @@ -318,17 +341,24 @@ static char *theme_format_expand_data(THEME_REC *theme, } if (**format != '{') { - if (save_last_color != NULL && - (flags & EXPAND_FLAG_LASTCOLOR_ARG) && + if ((flags & EXPAND_FLAG_LASTCOLOR_ARG) && **format == '$' && (*format)[1] == '0') { /* save the color before $0 .. this is for the %n replacing */ - *save_last_color = last_color; - save_last_color = NULL; + if (save_last_fg != NULL) { + *save_last_fg = last_fg; + save_last_fg = NULL; + } + if (save_last_bg != NULL) { + *save_last_bg = last_bg; + save_last_bg = NULL; + } } theme_format_append_next(theme, str, format, - default_color, &last_color); + default_fg, default_bg, + &last_fg, &last_bg, + recurse_flags); continue; } @@ -338,17 +368,20 @@ static char *theme_format_expand_data(THEME_REC *theme, /* get a single {...} */ abstract = theme_format_expand_abstract(theme, format, - last_color); + last_fg, last_bg, + recurse_flags); if (abstract != NULL) { g_string_append(str, abstract); g_free(abstract); } } - if (save_last_color != NULL && - (flags & EXPAND_FLAG_LASTCOLOR_ARG) == 0) { + if ((flags & EXPAND_FLAG_LASTCOLOR_ARG) == 0) { /* save the last color */ - *save_last_color = last_color; + if (save_last_fg != NULL) + *save_last_fg = last_fg; + if (save_last_bg != NULL) + *save_last_bg = last_bg; } ret = str->str; @@ -356,18 +389,23 @@ static char *theme_format_expand_data(THEME_REC *theme, return ret; } +#define IS_OLD_FORMAT(code, last_fg, last_bg) \ + (((code) == 'n' && (last_fg) == 'n' && (last_bg) == 'n') || \ + ((code) != 'n' && ((code) == (last_fg) || (code) == (last_bg)))) + static char *theme_format_compress_colors(THEME_REC *theme, const char *format) { GString *str; - char *ret, last_color = 'n'; + char *ret, last_fg, last_bg; str = g_string_new(NULL); + last_fg = last_bg = 'n'; while (*format != '\0') { if (*format == '$') { /* $variable, skrip it entirely */ theme_format_append_variable(str, &format); - last_color = '\0'; + last_fg = last_bg = '\0'; } else if (*format != '%') { /* a normal character */ g_string_append_c(str, *format); @@ -375,19 +413,24 @@ static char *theme_format_compress_colors(THEME_REC *theme, const char *format) } else { /* %format */ format++; - if (*format == last_color) { + if (IS_OLD_FORMAT(*format, last_fg, last_bg)) { /* active color set again */ - } else if (IS_COLOR_FORMAT(*format) && + } else if (IS_FGCOLOR_FORMAT(*format) && + (*format != 'n' || format[2] == 'n') && format[1] == '%' && - IS_COLOR_FORMAT(format[2])) { - /* two colors in a row */ + IS_FGCOLOR_FORMAT(format[2])) { + /* two fg colors in a row. bg colors are + so rare that we don't bother checking + them */ } else { /* some format, add it */ g_string_append_c(str, '%'); g_string_append_c(str, *format); - if (IS_COLOR_FORMAT(*format)) - last_color = *format; + if (IS_FGCOLOR_FORMAT(*format)) + last_fg = *format; + if (IS_BGCOLOR_FORMAT(*format)) + last_bg = *format; } format++; } @@ -398,16 +441,16 @@ static char *theme_format_compress_colors(THEME_REC *theme, const char *format) return ret; } -static char *theme_format_expand(THEME_REC *theme, const char *format) +char *theme_format_expand(THEME_REC *theme, const char *format) { char *data, *ret; g_return_val_if_fail(theme != NULL, NULL); g_return_val_if_fail(format != NULL, NULL); - data = theme_format_expand_data(theme, &format, 'n', NULL, + data = theme_format_expand_data(theme, &format, 'n', 'n', NULL, NULL, EXPAND_FLAG_ROOT); - ret = theme_format_compress_colors(theme, data); + ret = theme_format_compress_colors(theme, data); g_free(data); return ret; } @@ -438,20 +481,28 @@ static void theme_read_replaces(CONFIG_REC *config, THEME_REC *theme) { GSList *tmp; CONFIG_NODE *node; + const char *p; + int index; node = config_node_traverse(config, "replaces", FALSE); if (node == NULL || node->type != NODE_TYPE_BLOCK) return; + /* reset replace keys */ + for (index = 0; index < 256; index++) + theme->replace_keys[index] = -1; + index = 0; + for (tmp = node->value; tmp != NULL; tmp = tmp->next) { node = tmp->data; if (node->key != NULL && node->value != NULL) { - theme->replace_keys = - g_slist_append(theme->replace_keys, - g_strdup(node->key)); + for (p = node->key; *p != '\0'; p++) + theme->replace_keys[(int) *p] = index; + theme->replace_values = g_slist_append(theme->replace_values, g_strdup(node->value)); + index++; } } } @@ -460,6 +511,7 @@ static void theme_read_abstracts(CONFIG_REC *config, THEME_REC *theme) { GSList *tmp; CONFIG_NODE *node; + gpointer oldkey, oldvalue; node = config_node_traverse(config, "abstracts", FALSE); if (node == NULL || node->type != NODE_TYPE_BLOCK) return; @@ -467,12 +519,19 @@ static void theme_read_abstracts(CONFIG_REC *config, THEME_REC *theme) for (tmp = node->value; tmp != NULL; tmp = tmp->next) { node = tmp->data; - if (node->key != NULL && node->value != NULL && - g_hash_table_lookup(theme->abstracts, node->key) == NULL) { - g_hash_table_insert(theme->abstracts, - g_strdup(node->key), - g_strdup(node->value)); + if (node->key == NULL || node->value == NULL) + continue; + + if (g_hash_table_lookup_extended(theme->abstracts, node->key, + &oldkey, &oldvalue)) { + /* new values override old ones */ + g_hash_table_remove(theme->abstracts, oldkey); + g_free(oldkey); + g_free(oldvalue); } + + g_hash_table_insert(theme->abstracts, g_strdup(node->key), + g_strdup(node->value)); } } @@ -742,7 +801,17 @@ static int theme_read(THEME_REC *theme, const char *path, const char *data) config_get_int(config, NULL, "default_color", 0); theme->default_real_color = config_get_int(config, NULL, "default_real_color", 7); - theme_read_replaces(config, theme); + theme_read_replaces(config, theme); + + if (data == NULL) { + /* get the default abstracts from default theme. */ + CONFIG_REC *default_config; + + default_config = config_open(NULL, -1); + config_parse_data(default_config, default_theme, "internal"); + theme_read_abstracts(default_config, theme); + config_close(default_config); + } theme_read_abstracts(config, theme); rec.theme = theme; diff --git a/src/fe-common/core/themes.h b/src/fe-common/core/themes.h index d1e0283f..96f23400 100644 --- a/src/fe-common/core/themes.h +++ b/src/fe-common/core/themes.h @@ -23,7 +23,7 @@ typedef struct { wanted. default is 7 (white). */ GHashTable *modules; - GSList *replace_keys; + int replace_keys[256]; /* index to replace_values for each char */ GSList *replace_values; GHashTable *abstracts; @@ -46,6 +46,19 @@ THEME_REC *theme_load(const char *name); void theme_register_module(const char *module, FORMAT_REC *formats); void theme_unregister_module(const char *module); +#define EXPAND_FLAG_IGNORE_REPLACES 0x01 /* don't use the character replaces when expanding */ +#define EXPAND_FLAG_IGNORE_EMPTY 0x02 /* if abstract's argument is empty, don't try to expand it (ie. {xx }, but not {xx}) */ +#define EXPAND_FLAG_RECURSIVE_MASK 0x0f +/* private */ +#define EXPAND_FLAG_ROOT 0x10 +#define EXPAND_FLAG_LASTCOLOR_ARG 0x20 + +char *theme_format_expand(THEME_REC *theme, const char *format); +char *theme_format_expand_data(THEME_REC *theme, const char **format, + char default_fg, char default_bg, + char *save_last_fg, char *save_last_bg, + int flags); + void themes_init(void); void themes_deinit(void); diff --git a/src/fe-text/mainwindows.h b/src/fe-text/mainwindows.h index 7eb4875b..88ff97e0 100644 --- a/src/fe-text/mainwindows.h +++ b/src/fe-text/mainwindows.h @@ -16,7 +16,7 @@ typedef struct { int first_line, last_line, lines; int statusbar_lines; void *statusbar; - void *statusbar_channel_item; + void *statusbar_window_item; } MAIN_WINDOW_REC; extern GSList *mainwindows; diff --git a/src/fe-text/screen.c b/src/fe-text/screen.c index 65f30bf9..86681d78 100644 --- a/src/fe-text/screen.c +++ b/src/fe-text/screen.c @@ -116,7 +116,11 @@ static void read_settings(void) use_colors = settings_get_bool("colors"); read_signals(); - if (use_colors != old_colors) irssi_redraw(); + if (use_colors && !has_colors()) + use_colors = FALSE; + + if (use_colors != old_colors) + irssi_redraw(); } static int init_curses(void) @@ -151,8 +155,8 @@ static int init_curses(void) if (has_colors()) start_color(); - else - use_colors = FALSE; + else if (use_colors) + use_colors = FALSE; #ifdef HAVE_NCURSES_USE_DEFAULT_COLORS /* this lets us to use the "default" background color for colors <= 7 so diff --git a/src/fe-text/statusbar-items.c b/src/fe-text/statusbar-items.c index 2a91bb14..683ae81d 100644 --- a/src/fe-text/statusbar-items.c +++ b/src/fe-text/statusbar-items.c @@ -20,25 +20,14 @@ #include "module.h" #include "signals.h" -#include "servers.h" #include "misc.h" #include "settings.h" #include "special-vars.h" -#include "irc.h" -#include "channels.h" -#include "queries.h" -#include "irc-servers.h" -#include "nicklist.h" - -#include "fe-windows.h" #include "window-items.h" -#include "printtext.h" #include "formats.h" -#include "screen.h" #include "statusbar.h" -#include "gui-windows.h" #include "gui-printtext.h" /* how often to redraw lagging time (seconds) */ @@ -51,9 +40,6 @@ the lag */ #define MAX_LAG_UNKNOWN_TIME 30 -static int sbar_color_dim, sbar_color_normal, sbar_color_bold; -static int sbar_color_background, sbar_color_away, sbar_color_act_highlight; - static STATUSBAR_REC *mainbar; static MAIN_WINDOW_REC *mainbar_window; static int use_colors; @@ -67,7 +53,7 @@ static time_t clock_last; static SBAR_ITEM_REC *nick_item; /* channel */ -static SBAR_ITEM_REC *channel_item; +static SBAR_ITEM_REC *window_item; /* activity */ static SBAR_ITEM_REC *activity_item; @@ -92,11 +78,11 @@ static SBAR_ITEM_REC *topic_item; static STATUSBAR_REC *topic_bar; static void item_default(SBAR_ITEM_REC *item, int get_size_only, - const char *str) + const char *str, const char *data) { SERVER_REC *server; - WI_ITEM_REC *wiitem; - char *stripped, *parsed, *printstr; + WI_ITEM_REC *wiitem; + char *tmpstr, *tmpstr2; int len; if (active_win == NULL) { @@ -107,31 +93,44 @@ static void item_default(SBAR_ITEM_REC *item, int get_size_only, wiitem = active_win->active; } - parsed = parse_special_string(str, server, wiitem, "", NULL, + /* expand $variables */ + tmpstr = parse_special_string(str, server, wiitem, data, NULL, PARSE_FLAG_ESCAPE_VARS); - stripped = strip_codes(parsed); - g_free(parsed); parsed = stripped; + + /* expand templates */ + str = tmpstr; + tmpstr2 = theme_format_expand_data(current_theme, &str, + 'n', '0' + item->bar->color, + NULL, NULL, + EXPAND_FLAG_ROOT | + EXPAND_FLAG_IGNORE_REPLACES | + EXPAND_FLAG_IGNORE_EMPTY); + g_free(tmpstr); + + /* remove color codes */ + tmpstr = strip_codes(tmpstr2); + g_free(tmpstr2); if (get_size_only) { - item->min_size = item->max_size = format_get_length(parsed); + item->min_size = item->max_size = format_get_length(tmpstr); } else { if (item->size < item->min_size) { /* they're forcing us smaller than minimum size.. */ - len = format_real_length(parsed, item->size); - parsed[len] = '\0'; + len = format_real_length(tmpstr, item->size); + tmpstr[len] = '\0'; } - printstr = g_strconcat("%n%4", parsed, NULL); - gui_printtext(item->xpos, item->bar->ypos, printstr); - g_free(printstr); + tmpstr2 = g_strconcat(item->bar->color_string, tmpstr, NULL); + gui_printtext(item->xpos, item->bar->ypos, tmpstr2); + g_free(tmpstr2); } - g_free(parsed); + g_free(tmpstr); } /* redraw clock */ static void statusbar_clock(SBAR_ITEM_REC *item, int get_size_only) { - item_default(item, get_size_only, "%c[%w$Z%c]"); + item_default(item, get_size_only, "{sb $Z}", ""); } /* check if we need to redraw clock.. */ @@ -158,20 +157,8 @@ static int statusbar_clock_timeout(void) /* redraw nick */ static void statusbar_nick(SBAR_ITEM_REC *item, int get_size_only) { - IRC_SERVER_REC *server; - char *str, *usermode, *away; - - server = IRC_SERVER(active_win->active_server); - usermode = server == NULL || server->usermode == NULL || - *server->usermode == '\0' ? "" : - g_strdup_printf("(%%c+%%w%s)", server->usermode); - away = server == NULL || !server->usermode_away ? "" : - "(%GzZzZ%w)"; - - str = g_strconcat("%c[%w$P$N", usermode, away, "%c]", NULL); - item_default(item, get_size_only, str); - g_free(str); - if (*usermode != '\0') g_free(usermode); + item_default(item, get_size_only, + "{sb $P$N{sbmode $usermode}{sbaway $A}}", ""); } static void sig_statusbar_nick_redraw(void) @@ -179,52 +166,36 @@ static void sig_statusbar_nick_redraw(void) statusbar_item_redraw(nick_item); } -/* redraw channel */ -static void statusbar_channel(SBAR_ITEM_REC *item, int get_size_only) +/* redraw window */ +static void statusbar_window(SBAR_ITEM_REC *item, int get_size_only) { - SERVER_REC *server; - CHANNEL_REC *channel; - char *str, *tmp; - if (active_win->active != NULL) { - /* channel/query */ - channel = CHANNEL(active_win->active); - tmp = channel == NULL || channel->mode == NULL || - *channel->mode == '\0' ? "" : - g_strdup_printf("(%%c+%%w%s)", channel->mode); - str = g_strconcat("%c[%w$winref:$[.15]T", tmp, "%c]", NULL); + item_default(item, get_size_only, + "{sb $winref:$T{sbmode $M}}", ""); } else { - /* empty window */ - server = active_win->active_server; - tmp = server == NULL ? "" : - g_strdup_printf(":%s (change with ^X)", server->tag); - str = g_strconcat("%c[%w$winref", tmp, "%c]", NULL); + item_default(item, get_size_only, + "{sb $winref{sbservertag $tag}}", ""); } - - item_default(item, get_size_only, str); - - g_free(str); - if (*tmp != '\0') g_free(tmp); } -static void sig_statusbar_channel_redraw(void) +static void sig_statusbar_window_redraw(void) { - statusbar_item_redraw(channel_item); + statusbar_item_redraw(window_item); } -static void sig_statusbar_channel_redraw_window(WINDOW_REC *window) +static void sig_statusbar_window_redraw_window(WINDOW_REC *window) { if (is_window_visible(window)) - statusbar_item_redraw(channel_item); + statusbar_item_redraw(window_item); } -static void sig_statusbar_channel_redraw_window_item(WI_ITEM_REC *item) +static void sig_statusbar_window_redraw_window_item(WI_ITEM_REC *item) { WINDOW_REC *window; window = window_item_window(item); if (window->active == item && is_window_visible(window)) - statusbar_item_redraw(channel_item); + statusbar_item_redraw(window_item); } static char *get_activity_list(int normal, int hilight) @@ -281,8 +252,7 @@ static char *get_activity_list(int normal, int hilight) act list so that the highest priority items comes first. */ static void statusbar_activity(SBAR_ITEM_REC *item, int get_size_only) { - GString *str; - char *actlist, *detlist; + char *actlist, *detlist, *data; if (use_colors) { actlist = get_activity_list(TRUE, TRUE); @@ -298,24 +268,13 @@ static void statusbar_activity(SBAR_ITEM_REC *item, int get_size_only) return; } - str = g_string_new("%c[%w"); + data = g_strconcat("{sbact ", actlist != NULL ? actlist : "", + " ", detlist != NULL ? detlist : "", "}", NULL); + item_default(item, get_size_only, data, ""); + g_free(data); - if (actlist != NULL) { - g_string_append(str, "Act: "); - g_string_append(str, actlist); - g_free(actlist); - } - if (detlist != NULL) { - if (actlist != NULL) - g_string_append(str, " "); - g_string_append(str, "Det: "); - g_string_append(str, detlist); - g_free(detlist); - } - - g_string_append(str, "%c]"); - item_default(item, get_size_only, str->str); - g_string_free(str, TRUE); + g_free_not_null(actlist); + g_free_not_null(detlist); } static void sig_statusbar_activity_hilight(WINDOW_REC *window, gpointer oldlevel) @@ -387,7 +346,7 @@ static void sig_statusbar_activity_updated(void) /* redraw -- more -- */ static void statusbar_more(SBAR_ITEM_REC *item, int get_size_only) { - item_default(item, get_size_only, "%_-- more --%_"); + item_default(item, get_size_only, "{sbmore}", ""); } static void sig_statusbar_more_check_remove(WINDOW_REC *window) @@ -435,7 +394,7 @@ static void statusbar_lag(SBAR_ITEM_REC *item, int get_size_only) } now = time(NULL); - str = g_string_new("%c[%wLag: %_"); + str = g_string_new(NULL); /* FIXME: ugly ugly.. */ if (server->lag_sent == 0 || now-server->lag_sent < 5) { @@ -443,8 +402,7 @@ static void statusbar_lag(SBAR_ITEM_REC *item, int get_size_only) MAX_LAG_UNKNOWN_TIME+settings_get_int("lag_check_time"); if (lag_min_show < 0 || (server->lag < lag_min_show && !lag_unknown)) { - /* small, lag, don't display */ - g_string_truncate(str, 0); + /* small lag, don't display */ } else { g_string_sprintfa(str, "%d.%02d", server->lag/1000, (server->lag % 1000)/10); @@ -457,10 +415,7 @@ static void statusbar_lag(SBAR_ITEM_REC *item, int get_size_only) (long) (now-server->lag_sent)); } - if (str->len > 0) - g_string_append(str, "%c]"); - - item_default(item, get_size_only, str->str); + item_default(item, get_size_only, "{sblag $0-}", str->str); g_string_free(str, TRUE); } @@ -531,7 +486,7 @@ static int get_mail_count(void) static void statusbar_mail(SBAR_ITEM_REC *item, int get_size_only) { - char countstr[MAX_INT_STRLEN], *str; + char countstr[MAX_INT_STRLEN]; int mail_count; mail_count = settings_get_bool("mail_counter") ? get_mail_count() : 0; @@ -543,10 +498,7 @@ static void statusbar_mail(SBAR_ITEM_REC *item, int get_size_only) } ltoa(countstr, mail_count); - str = g_strconcat("%c[%wMail: %_", countstr, "%_%c]", NULL); - - item_default(item, get_size_only, str); - g_free(str); + item_default(item, get_size_only, "{sbmail $0-}", countstr); } static int statusbar_mail_timeout(void) @@ -557,7 +509,7 @@ static int statusbar_mail_timeout(void) static void statusbar_topic(SBAR_ITEM_REC *item, int get_size_only) { - item_default(item, get_size_only, "$topic"); + item_default(item, get_size_only, "$topic", ""); } static void sig_statusbar_topic_redraw(void) @@ -572,8 +524,8 @@ static void sig_sidebars_redraw(void) for (tmp = mainwindows; tmp != NULL; tmp = tmp->next) { MAIN_WINDOW_REC *rec = tmp->data; - if (rec->statusbar_channel_item != NULL) - statusbar_item_redraw(rec->statusbar_channel_item); + if (rec->statusbar_window_item != NULL) + statusbar_item_redraw(rec->statusbar_window_item); } } @@ -612,7 +564,7 @@ static void mainbar_remove_items(void) { statusbar_item_remove(clock_item); statusbar_item_remove(nick_item); - statusbar_item_remove(channel_item); + statusbar_item_remove(window_item); statusbar_item_remove(mail_item); statusbar_item_remove(lag_item); statusbar_item_remove(activity_item); @@ -625,7 +577,7 @@ static void mainbar_add_items(MAIN_WINDOW_REC *window) clock_item = statusbar_item_create(mainbar, SBAR_PRIORITY_HIGH, FALSE, statusbar_clock); nick_item = statusbar_item_create(mainbar, SBAR_PRIORITY_NORMAL, FALSE, statusbar_nick); - channel_item = statusbar_item_create(mainbar, SBAR_PRIORITY_NORMAL, FALSE, statusbar_channel); + window_item = statusbar_item_create(mainbar, SBAR_PRIORITY_NORMAL, FALSE, statusbar_window); mail_item = statusbar_item_create(mainbar, SBAR_PRIORITY_LOW, FALSE, statusbar_mail); lag_item = statusbar_item_create(mainbar, SBAR_PRIORITY_LOW, FALSE, statusbar_lag); activity_item = statusbar_item_create(mainbar, SBAR_PRIORITY_HIGH, FALSE, statusbar_activity); @@ -633,15 +585,15 @@ static void mainbar_add_items(MAIN_WINDOW_REC *window) static void sidebar_add_items(MAIN_WINDOW_REC *window) { - window->statusbar_channel_item = - statusbar_item_create(window->statusbar, SBAR_PRIORITY_NORMAL, FALSE, statusbar_channel); + window->statusbar_window_item = + statusbar_item_create(window->statusbar, SBAR_PRIORITY_NORMAL, FALSE, statusbar_window); } static void sidebar_remove_items(MAIN_WINDOW_REC *window) { - if (window->statusbar_channel_item != NULL) { - statusbar_item_remove(window->statusbar_channel_item); - window->statusbar_channel_item = NULL; + if (window->statusbar_window_item != NULL) { + statusbar_item_remove(window->statusbar_window_item); + window->statusbar_window_item = NULL; } } @@ -683,25 +635,13 @@ static void sig_main_statusbar_changed(WINDOW_REC *window) static void read_settings(void) { - use_colors = settings_get_bool("colors"); + use_colors = settings_get_bool("colors") && has_colors(); if (settings_get_bool("topicbar")) topicbar_create(); else if (!settings_get_bool("topicbar")) topicbar_destroy(); lag_min_show = settings_get_int("lag_min_show")*10; - - sbar_color_background = settings_get_int("statusbar_background") << 4; - sbar_color_dim = sbar_color_background | - settings_get_int("statusbar_dim"); - sbar_color_normal = sbar_color_background | - settings_get_int("statusbar_normal"); - sbar_color_bold = sbar_color_background | - settings_get_int("statusbar_bold"); - sbar_color_away = sbar_color_background | - settings_get_int("statusbar_away"); - sbar_color_act_highlight = sbar_color_background | - settings_get_int("statusbar_act_highlight"); statusbar_redraw(NULL); } @@ -714,13 +654,6 @@ void statusbar_items_init(void) settings_add_bool("lookandfeel", "actlist_moves", FALSE); settings_add_bool("misc", "mail_counter", TRUE); - settings_add_int("colors", "statusbar_background", 1); - settings_add_int("colors", "statusbar_dim", 3); - settings_add_int("colors", "statusbar_normal", 7); - settings_add_int("colors", "statusbar_bold", 15); - settings_add_int("colors", "statusbar_away", 10); - settings_add_int("colors", "statusbar_act_highlight", 13); - /* clock */ clock_timetag = g_timeout_add(1000, (GSourceFunc) statusbar_clock_timeout, NULL); @@ -736,11 +669,11 @@ void statusbar_items_init(void) signal_add("away mode changed", (SIGNAL_FUNC) sig_statusbar_nick_redraw); /* channel */ - signal_add("window changed", (SIGNAL_FUNC) sig_statusbar_channel_redraw); - signal_add("window item changed", (SIGNAL_FUNC) sig_statusbar_channel_redraw_window); - signal_add("channel mode changed", (SIGNAL_FUNC) sig_statusbar_channel_redraw_window_item); - signal_add("window server changed", (SIGNAL_FUNC) sig_statusbar_channel_redraw_window); - signal_add("window refnum changed", (SIGNAL_FUNC) sig_statusbar_channel_redraw_window); + signal_add("window changed", (SIGNAL_FUNC) sig_statusbar_window_redraw); + signal_add("window item changed", (SIGNAL_FUNC) sig_statusbar_window_redraw_window); + signal_add("channel mode changed", (SIGNAL_FUNC) sig_statusbar_window_redraw_window_item); + signal_add("window server changed", (SIGNAL_FUNC) sig_statusbar_window_redraw_window); + signal_add("window refnum changed", (SIGNAL_FUNC) sig_statusbar_window_redraw_window); /* activity */ activity_list = NULL; @@ -798,11 +731,11 @@ void statusbar_items_deinit(void) signal_remove("away mode changed", (SIGNAL_FUNC) sig_statusbar_nick_redraw); /* channel */ - signal_remove("window changed", (SIGNAL_FUNC) sig_statusbar_channel_redraw); - signal_remove("window item changed", (SIGNAL_FUNC) sig_statusbar_channel_redraw_window); - signal_remove("channel mode changed", (SIGNAL_FUNC) sig_statusbar_channel_redraw_window_item); - signal_remove("window server changed", (SIGNAL_FUNC) sig_statusbar_channel_redraw_window); - signal_remove("window refnum changed", (SIGNAL_FUNC) sig_statusbar_channel_redraw_window); + signal_remove("window changed", (SIGNAL_FUNC) sig_statusbar_window_redraw); + signal_remove("window item changed", (SIGNAL_FUNC) sig_statusbar_window_redraw_window); + signal_remove("channel mode changed", (SIGNAL_FUNC) sig_statusbar_window_redraw_window_item); + signal_remove("window server changed", (SIGNAL_FUNC) sig_statusbar_window_redraw_window); + signal_remove("window refnum changed", (SIGNAL_FUNC) sig_statusbar_window_redraw_window); /* activity */ signal_remove("window activity", (SIGNAL_FUNC) sig_statusbar_activity_hilight); diff --git a/src/fe-text/statusbar.c b/src/fe-text/statusbar.c index ca019e97..4299835a 100644 --- a/src/fe-text/statusbar.c +++ b/src/fe-text/statusbar.c @@ -21,14 +21,16 @@ #include "module.h" #include "signals.h" #include "servers.h" -#include "settings.h" #include "fe-windows.h" +#include "themes.h" #include "screen.h" #include "statusbar.h" #include "gui-windows.h" +static int backs[] = { 0, 4, 2, 6, 1, 5, 3, 7 }; /* FIXME: should be in some more generic place.. */ + void statusbar_items_init(void); void statusbar_items_deinit(void); @@ -190,7 +192,7 @@ void statusbar_redraw(STATUSBAR_REC *bar) return; } - set_bg(stdscr, settings_get_int("statusbar_background") << 4); + set_bg(stdscr, backs[bar->color] << 4); move(bar->ypos, 0); clrtoeol(); set_bg(stdscr, 0); @@ -212,10 +214,27 @@ void statusbar_item_redraw(SBAR_ITEM_REC *item) } } +static int get_last_bg(const char *str) +{ + int last = -1; + + while (*str != '\0') { + if (*str == '%' && str[1] != '\0') { + str++; + if (*str >= '0' && *str <= '7') + last = *str-'0'; + } + str++; + } + + return last; +} + /* ypos is used only when pos == STATUSBAR_POS_MIDDLE */ STATUSBAR_REC *statusbar_create(int pos, int ypos) { STATUSBAR_REC *rec; + char *str; rec = g_new0(STATUSBAR_REC, 1); statusbars = g_slist_append(statusbars, rec); @@ -226,6 +245,15 @@ STATUSBAR_REC *statusbar_create(int pos, int ypos) rec->ypos = pos == STATUSBAR_POS_MIDDLE ? ypos : pos == STATUSBAR_POS_UP ? rec->line : LINES-1-rec->line; + /* get background color from sb_background abstract */ + str = theme_format_expand(current_theme, "{sb_background}"); + if (str == NULL) str = g_strdup("%n%8"); + rec->color_string = g_strconcat("%n", str, NULL); + g_free(str); + + rec->color = get_last_bg(rec->color_string); + if (rec->color < 0) rec->color = current_theme->default_real_color; + if (pos == STATUSBAR_POS_UP) { if (sbars_up == 0) sbar_uppest = rec->line; sbars_up++; @@ -236,7 +264,7 @@ STATUSBAR_REC *statusbar_create(int pos, int ypos) rec->line -= sbar_lowest; } - set_bg(stdscr, settings_get_int("statusbar_background") << 4); + set_bg(stdscr, backs[rec->color] << 4); move(rec->ypos, 0); clrtoeol(); set_bg(stdscr, 0); @@ -273,6 +301,7 @@ void statusbar_destroy(STATUSBAR_REC *bar) if (bar->pos != STATUSBAR_POS_MIDDLE) statusbars_pack(bar->pos, bar->pos); + g_free(bar->color_string); g_free(bar); if (!quitting) statusbar_redraw_all(); diff --git a/src/fe-text/statusbar.h b/src/fe-text/statusbar.h index 5aa4da31..5a00eaa7 100644 --- a/src/fe-text/statusbar.h +++ b/src/fe-text/statusbar.h @@ -18,6 +18,9 @@ typedef struct { int pos; int line; + char *color_string; + int color; + int ypos; /* real position in screen at the moment */ GSList *items; } STATUSBAR_REC; |