Merge pull request #445 from TingPing/ulistcolors

Add option to color nicknames in the userlist to match the chat
This commit is contained in:
TingPing 2013-03-24 01:53:37 -07:00
commit a5994cf647
6 changed files with 21 additions and 16 deletions

View File

@ -465,6 +465,7 @@ const struct prefs vars[] =
{"gui_tray_minimize", P_OFFINT (hex_gui_tray_minimize), TYPE_BOOL}, {"gui_tray_minimize", P_OFFINT (hex_gui_tray_minimize), TYPE_BOOL},
{"gui_tray_quiet", P_OFFINT (hex_gui_tray_quiet), TYPE_BOOL}, {"gui_tray_quiet", P_OFFINT (hex_gui_tray_quiet), TYPE_BOOL},
{"gui_ulist_buttons", P_OFFINT (hex_gui_ulist_buttons), TYPE_BOOL}, {"gui_ulist_buttons", P_OFFINT (hex_gui_ulist_buttons), TYPE_BOOL},
{"gui_ulist_color", P_OFFINT (hex_gui_ulist_color), TYPE_BOOL},
{"gui_ulist_count", P_OFFINT (hex_gui_ulist_count), TYPE_BOOL}, {"gui_ulist_count", P_OFFINT (hex_gui_ulist_count), TYPE_BOOL},
{"gui_ulist_doubleclick", P_OFFSET (hex_gui_ulist_doubleclick), TYPE_STR}, {"gui_ulist_doubleclick", P_OFFSET (hex_gui_ulist_doubleclick), TYPE_STR},
{"gui_ulist_hide", P_OFFINT (hex_gui_ulist_hide), TYPE_BOOL}, {"gui_ulist_hide", P_OFFINT (hex_gui_ulist_hide), TYPE_BOOL},

View File

@ -157,6 +157,7 @@ struct hexchatprefs
unsigned int hex_gui_tray_minimize; unsigned int hex_gui_tray_minimize;
unsigned int hex_gui_tray_quiet; unsigned int hex_gui_tray_quiet;
unsigned int hex_gui_ulist_buttons; unsigned int hex_gui_ulist_buttons;
unsigned int hex_gui_ulist_color;
unsigned int hex_gui_ulist_count; unsigned int hex_gui_ulist_count;
unsigned int hex_gui_ulist_hide; unsigned int hex_gui_ulist_hide;
unsigned int hex_gui_ulist_icons; unsigned int hex_gui_ulist_icons;

View File

@ -2006,8 +2006,8 @@ pevt_build_string (const char *input, char **output, int *max_arg)
static char rcolors[] = { 19, 20, 22, 24, 25, 26, 27, 28, 29 }; static char rcolors[] = { 19, 20, 22, 24, 25, 26, 27, 28, 29 };
static int int
color_of (char *name) text_color_of (char *name)
{ {
int i = 0, sum = 0; int i = 0, sum = 0;
@ -2030,7 +2030,7 @@ text_emit (int index, session *sess, char *a, char *b, char *c, char *d)
if (prefs.hex_text_color_nicks && (index == XP_TE_CHANACTION || index == XP_TE_CHANMSG)) if (prefs.hex_text_color_nicks && (index == XP_TE_CHANACTION || index == XP_TE_CHANMSG))
{ {
snprintf (tbuf, sizeof (tbuf), "\003%d%s", color_of (a), a); snprintf (tbuf, sizeof (tbuf), "\003%d%s", text_color_of (a), a);
a = tbuf; a = tbuf;
stripcolor_args &= ~ARG_FLAG(1); /* don't strip color from this argument */ stripcolor_args &= ~ARG_FLAG(1); /* don't strip color from this argument */
} }

View File

@ -26,6 +26,7 @@ void pevent_save (char *fn);
int pevt_build_string (const char *input, char **output, int *max_arg); int pevt_build_string (const char *input, char **output, int *max_arg);
int pevent_load (char *filename); int pevent_load (char *filename);
void pevent_make_pntevts (void); void pevent_make_pntevts (void);
int text_color_of (char *name);
void text_emit (int index, session *sess, char *a, char *b, char *c, char *d); void text_emit (int index, session *sess, char *a, char *b, char *c, char *d);
int text_emit_by_name (char *name, session *sess, char *a, char *b, char *c, char *d); int text_emit_by_name (char *name, session *sess, char *a, char *b, char *c, char *d);
char *text_validate (char **text, int *len); char *text_validate (char **text, int *len);

View File

@ -287,6 +287,7 @@ static const setting userlist_settings[] =
{ST_TOGGLE, N_("Show hostnames in user list"), P_OFFINTNL(hex_gui_ulist_show_hosts), 0, 0, 0}, {ST_TOGGLE, N_("Show hostnames in user list"), P_OFFINTNL(hex_gui_ulist_show_hosts), 0, 0, 0},
{ST_TOGGLE, N_("Use the Text box font and colors"), P_OFFINTNL(hex_gui_ulist_style),0,0,0}, {ST_TOGGLE, N_("Use the Text box font and colors"), P_OFFINTNL(hex_gui_ulist_style),0,0,0},
{ST_TOGGLE, N_("Show icons for user modes"), P_OFFINTNL(hex_gui_ulist_icons), N_("Use graphical icons instead of text symbols in the user list."), 0, 0}, {ST_TOGGLE, N_("Show icons for user modes"), P_OFFINTNL(hex_gui_ulist_icons), N_("Use graphical icons instead of text symbols in the user list."), 0, 0},
{ST_TOGGLE, N_("Color nicknames in userlist"), P_OFFINTNL(hex_gui_ulist_color), N_("Will color nicknames the same as in chat."), 0, 0},
{ST_TOGGLE, N_("Show user count in channels"), P_OFFINTNL(hex_gui_ulist_count), 0, 0, 0}, {ST_TOGGLE, N_("Show user count in channels"), P_OFFINTNL(hex_gui_ulist_count), 0, 0, 0},
/* {ST_TOGGLE, N_("Resizable user list"), P_OFFINTNL(hex_gui_ulist_resizable),0,0,0},*/ /* {ST_TOGGLE, N_("Resizable user list"), P_OFFINTNL(hex_gui_ulist_resizable),0,0,0},*/
{ST_MENU, N_("User list sorted by:"), P_OFFINTNL(hex_gui_ulist_sort), 0, ulmenutext, 0}, {ST_MENU, N_("User list sorted by:"), P_OFFINTNL(hex_gui_ulist_sort), 0, ulmenutext, 0},
@ -2262,7 +2263,7 @@ setup_apply (struct hexchatprefs *pr)
if (DIFF (hex_gui_tab_layout)) if (DIFF (hex_gui_tab_layout))
do_layout = TRUE; do_layout = TRUE;
if (color_change || (DIFF (hex_away_size_max)) || (DIFF (hex_away_track))) if (color_change || (DIFF (hex_gui_ulist_color)) || (DIFF (hex_away_size_max)) || (DIFF (hex_away_track)))
do_ulist = TRUE; do_ulist = TRUE;
if ((pr->hex_gui_tab_pos == 5 || pr->hex_gui_tab_pos == 6) && if ((pr->hex_gui_tab_pos == 5 || pr->hex_gui_tab_pos == 6) &&

View File

@ -38,6 +38,7 @@
#include "../common/util.h" #include "../common/util.h"
#include "../common/userlist.h" #include "../common/userlist.h"
#include "../common/modes.h" #include "../common/modes.h"
#include "../common/text.h"
#include "../common/notify.h" #include "../common/notify.h"
#include "../common/hexchatc.h" #include "../common/hexchatc.h"
#include "../common/fe.h" #include "../common/fe.h"
@ -327,21 +328,21 @@ fe_userlist_rehash (session *sess, struct User *user)
{ {
GtkTreeIter *iter; GtkTreeIter *iter;
int sel; int sel;
int do_away = TRUE; int nick_color = NULL;
iter = find_row (GTK_TREE_VIEW (sess->gui->user_tree), iter = find_row (GTK_TREE_VIEW (sess->gui->user_tree),
sess->res->user_model, user, &sel); sess->res->user_model, user, &sel);
if (!iter) if (!iter)
return; return;
if (prefs.hex_away_size_max < 1 || !prefs.hex_away_track) if (prefs.hex_away_track && prefs.hex_away_size_max && user->away)
do_away = FALSE; nick_color = COL_AWAY;
else if (prefs.hex_gui_ulist_color)
nick_color = text_color_of(user->nick);
gtk_list_store_set (GTK_LIST_STORE (sess->res->user_model), iter, gtk_list_store_set (GTK_LIST_STORE (sess->res->user_model), iter,
COL_HOST, user->hostname, COL_HOST, user->hostname,
COL_GDKCOLOR, (do_away) COL_GDKCOLOR, nick_color ? &colors[nick_color] : NULL,
? (user->away ? &colors[COL_AWAY] : NULL)
: (NULL),
-1); -1);
} }
@ -351,11 +352,13 @@ fe_userlist_insert (session *sess, struct User *newuser, int row, int sel)
GtkTreeModel *model = sess->res->user_model; GtkTreeModel *model = sess->res->user_model;
GdkPixbuf *pix = get_user_icon (sess->server, newuser); GdkPixbuf *pix = get_user_icon (sess->server, newuser);
GtkTreeIter iter; GtkTreeIter iter;
int do_away = TRUE;
char *nick; char *nick;
int nick_color = NULL;
if (prefs.hex_away_size_max < 1 || !prefs.hex_away_track) if (prefs.hex_away_track && prefs.hex_away_size_max && newuser->away)
do_away = FALSE; nick_color = COL_AWAY;
else if (prefs.hex_gui_ulist_color)
nick_color = text_color_of(newuser->nick);
nick = newuser->nick; nick = newuser->nick;
if (!prefs.hex_gui_ulist_icons) if (!prefs.hex_gui_ulist_icons)
@ -374,9 +377,7 @@ fe_userlist_insert (session *sess, struct User *newuser, int row, int sel)
COL_NICK, nick, COL_NICK, nick,
COL_HOST, newuser->hostname, COL_HOST, newuser->hostname,
COL_USER, newuser, COL_USER, newuser,
COL_GDKCOLOR, (do_away) COL_GDKCOLOR, nick_color ? &colors[nick_color] : NULL,
? (newuser->away ? &colors[COL_AWAY] : NULL)
: (NULL),
-1); -1);
if (!prefs.hex_gui_ulist_icons) if (!prefs.hex_gui_ulist_icons)