From 1a909fd6eb2f1ac5fb302c1c164e346fe9050249 Mon Sep 17 00:00:00 2001 From: James Booth <boothj5@gmail.com> Date: Wed, 21 Nov 2012 00:21:58 +0000 Subject: [PATCH] Added more colour preferences --- docs/profanity.1 | 43 ++++++----- src/preferences.c | 182 +++++++++++++++++++++++++++++++++++++--------- src/preferences.h | 23 ++++-- src/status_bar.c | 40 +++++----- src/title_bar.c | 12 +-- src/ui.h | 33 ++++++--- src/windows.c | 160 +++++++++++++++++++++------------------- 7 files changed, 323 insertions(+), 170 deletions(-) diff --git a/docs/profanity.1 b/docs/profanity.1 index fc5cd37a..552613c5 100644 --- a/docs/profanity.1 +++ b/docs/profanity.1 @@ -83,31 +83,40 @@ vercheck=true .PP [colours] .br -away=magenta +bkgnd=default .br -chat=yellow +titlebar=blue .br -xa=blue +statusbar=blue .br -online=white +titlebartext=white +.br +titlebarbrackets=cyan +.br +statusbartext=white +.br +statusbarbrackets=cyan +.br +statusbaractive=cyan +.br +statusbarnew=white +.br +maintext=white +.br +splashtext=cyan +.br +online=green +.br +away=cyan +.br +chat=green .br dnd=red .br -offline=cyan +xa=cyan .br -bkgnd=default +offline=red .br -text=white -.br -err=red -.br -inc=yellow -.br -bar=green -.br -bar_draw=black -.br -bar_text=black .PP [connections] .br diff --git a/src/preferences.c b/src/preferences.c index e5e9653e..9bfacd88 100644 --- a/src/preferences.c +++ b/src/preferences.c @@ -65,18 +65,29 @@ static struct colour_string_t colours[] = { // colour preferences static struct colours_t { NCURSES_COLOR_T bkgnd; - NCURSES_COLOR_T text; + NCURSES_COLOR_T titlebar; + NCURSES_COLOR_T statusbar; + NCURSES_COLOR_T titlebartext; + NCURSES_COLOR_T titlebarbrackets; + NCURSES_COLOR_T statusbartext; + NCURSES_COLOR_T statusbarbrackets; + NCURSES_COLOR_T statusbaractive; + NCURSES_COLOR_T statusbarnew; + NCURSES_COLOR_T maintext; + NCURSES_COLOR_T splashtext; NCURSES_COLOR_T online; NCURSES_COLOR_T away; - NCURSES_COLOR_T chat; - NCURSES_COLOR_T dnd; NCURSES_COLOR_T xa; + NCURSES_COLOR_T dnd; + NCURSES_COLOR_T chat; NCURSES_COLOR_T offline; - NCURSES_COLOR_T err; - NCURSES_COLOR_T inc; - NCURSES_COLOR_T bar; - NCURSES_COLOR_T bar_draw; - NCURSES_COLOR_T bar_text; + NCURSES_COLOR_T typing; + NCURSES_COLOR_T gone; + NCURSES_COLOR_T error; + NCURSES_COLOR_T incoming; + NCURSES_COLOR_T roominfo; + NCURSES_COLOR_T me; + NCURSES_COLOR_T them; } colour_prefs; static NCURSES_COLOR_T _lookup_colour(const char * const colour); @@ -171,41 +182,74 @@ _load_colours(void) gchar *bkgnd_val = g_key_file_get_string(prefs, "colours", "bkgnd", NULL); _set_colour(bkgnd_val, &colour_prefs.bkgnd, -1); - gchar *text_val = g_key_file_get_string(prefs, "colours", "text", NULL); - _set_colour(text_val, &colour_prefs.text, COLOR_WHITE); + gchar *titlebar_val = g_key_file_get_string(prefs, "colours", "titlebar", NULL); + _set_colour(titlebar_val, &colour_prefs.titlebar, COLOR_BLUE); + + gchar *statusbar_val = g_key_file_get_string(prefs, "colours", "statusbar", NULL); + _set_colour(statusbar_val, &colour_prefs.statusbar, COLOR_BLUE); + + gchar *titlebartext_val = g_key_file_get_string(prefs, "colours", "titlebartext", NULL); + _set_colour(titlebartext_val, &colour_prefs.titlebartext, COLOR_WHITE); + + gchar *titlebarbrackets_val = g_key_file_get_string(prefs, "colours", "titlebarbrackets", NULL); + _set_colour(titlebarbrackets_val, &colour_prefs.titlebarbrackets, COLOR_CYAN); + + gchar *statusbartext_val = g_key_file_get_string(prefs, "colours", "statusbartext", NULL); + _set_colour(statusbartext_val, &colour_prefs.statusbartext, COLOR_WHITE); + + gchar *statusbarbrackets_val = g_key_file_get_string(prefs, "colours", "statusbarbrackets", NULL); + _set_colour(statusbarbrackets_val, &colour_prefs.statusbarbrackets, COLOR_CYAN); + + gchar *statusbaractive_val = g_key_file_get_string(prefs, "colours", "statusbaractive", NULL); + _set_colour(statusbaractive_val, &colour_prefs.statusbaractive, COLOR_CYAN); + + gchar *statusbarnew_val = g_key_file_get_string(prefs, "colours", "statusbarnew", NULL); + _set_colour(statusbarnew_val, &colour_prefs.statusbarnew, COLOR_WHITE); + + gchar *maintext_val = g_key_file_get_string(prefs, "colours", "maintext", NULL); + _set_colour(maintext_val, &colour_prefs.maintext, COLOR_WHITE); + + gchar *splashtext_val = g_key_file_get_string(prefs, "colours", "splashtext", NULL); + _set_colour(splashtext_val, &colour_prefs.splashtext, COLOR_CYAN); gchar *online_val = g_key_file_get_string(prefs, "colours", "online", NULL); _set_colour(online_val, &colour_prefs.online, COLOR_GREEN); gchar *away_val = g_key_file_get_string(prefs, "colours", "away", NULL); - _set_colour(away_val, &colour_prefs.away, COLOR_GREEN); + _set_colour(away_val, &colour_prefs.away, COLOR_CYAN); gchar *chat_val = g_key_file_get_string(prefs, "colours", "chat", NULL); _set_colour(chat_val, &colour_prefs.chat, COLOR_GREEN); gchar *dnd_val = g_key_file_get_string(prefs, "colours", "dnd", NULL); - _set_colour(dnd_val, &colour_prefs.dnd, COLOR_GREEN); + _set_colour(dnd_val, &colour_prefs.dnd, COLOR_RED); gchar *xa_val = g_key_file_get_string(prefs, "colours", "xa", NULL); - _set_colour(xa_val, &colour_prefs.xa, COLOR_GREEN); + _set_colour(xa_val, &colour_prefs.xa, COLOR_CYAN); gchar *offline_val = g_key_file_get_string(prefs, "colours", "offline", NULL); - _set_colour(offline_val, &colour_prefs.offline, COLOR_CYAN); + _set_colour(offline_val, &colour_prefs.offline, COLOR_RED); - gchar *err_val = g_key_file_get_string(prefs, "colours", "err", NULL); - _set_colour(err_val, &colour_prefs.err, COLOR_RED); + gchar *typing_val = g_key_file_get_string(prefs, "colours", "typing", NULL); + _set_colour(typing_val, &colour_prefs.typing, COLOR_YELLOW); - gchar *inc_val = g_key_file_get_string(prefs, "colours", "inc", NULL); - _set_colour(inc_val, &colour_prefs.inc, COLOR_YELLOW); + gchar *gone_val = g_key_file_get_string(prefs, "colours", "gone", NULL); + _set_colour(gone_val, &colour_prefs.gone, COLOR_RED); - gchar *bar_val = g_key_file_get_string(prefs, "colours", "bar", NULL); - _set_colour(bar_val, &colour_prefs.bar, COLOR_BLUE); + gchar *error_val = g_key_file_get_string(prefs, "colours", "error", NULL); + _set_colour(error_val, &colour_prefs.error, COLOR_RED); - gchar *bar_draw_val = g_key_file_get_string(prefs, "colours", "bar_draw", NULL); - _set_colour(bar_draw_val, &colour_prefs.bar_draw, COLOR_CYAN); + gchar *incoming_val = g_key_file_get_string(prefs, "colours", "incoming", NULL); + _set_colour(incoming_val, &colour_prefs.incoming, COLOR_YELLOW); - gchar *bar_text_val = g_key_file_get_string(prefs, "colours", "bar_text", NULL); - _set_colour(bar_text_val, &colour_prefs.bar_text, COLOR_WHITE); + gchar *roominfo_val = g_key_file_get_string(prefs, "colours", "roominfo", NULL); + _set_colour(roominfo_val, &colour_prefs.roominfo, COLOR_YELLOW); + + gchar *me_val = g_key_file_get_string(prefs, "colours", "me", NULL); + _set_colour(me_val, &colour_prefs.me, COLOR_YELLOW); + + gchar *them_val = g_key_file_get_string(prefs, "colours", "them", NULL); + _set_colour(them_val, &colour_prefs.them, COLOR_GREEN); } char * @@ -475,9 +519,63 @@ prefs_get_bkgnd() } NCURSES_COLOR_T -prefs_get_text() +prefs_get_titlebar() { - return colour_prefs.text; + return colour_prefs.titlebar; +} + +NCURSES_COLOR_T +prefs_get_statusbar() +{ + return colour_prefs.statusbar; +} + +NCURSES_COLOR_T +prefs_get_titlebartext() +{ + return colour_prefs.titlebartext; +} + +NCURSES_COLOR_T +prefs_get_titlebarbrackets() +{ + return colour_prefs.titlebarbrackets; +} + +NCURSES_COLOR_T +prefs_get_statusbartext() +{ + return colour_prefs.statusbartext; +} + +NCURSES_COLOR_T +prefs_get_statusbarbrackets() +{ + return colour_prefs.statusbarbrackets; +} + +NCURSES_COLOR_T +prefs_get_statusbaractive() +{ + return colour_prefs.statusbaractive; +} + +NCURSES_COLOR_T +prefs_get_statusbarnew() +{ + return colour_prefs.statusbarnew; +} + +NCURSES_COLOR_T +prefs_get_maintext() +{ + return colour_prefs.maintext; +} + +NCURSES_COLOR_T +prefs_get_splashtext() +{ + return colour_prefs.splashtext; } NCURSES_COLOR_T @@ -517,31 +615,43 @@ prefs_get_offline() } NCURSES_COLOR_T -prefs_get_err() +prefs_get_typing() { - return colour_prefs.err; + return colour_prefs.typing; } NCURSES_COLOR_T -prefs_get_inc() +prefs_get_gone() { - return colour_prefs.inc; + return colour_prefs.gone; } NCURSES_COLOR_T -prefs_get_bar() +prefs_get_error() { - return colour_prefs.bar; + return colour_prefs.error; } NCURSES_COLOR_T -prefs_get_bar_draw() +prefs_get_incoming() { - return colour_prefs.bar_draw; + return colour_prefs.incoming; } NCURSES_COLOR_T -prefs_get_bar_text() +prefs_get_roominfo() { - return colour_prefs.bar_text; + return colour_prefs.roominfo; +} + +NCURSES_COLOR_T +prefs_get_me() +{ + return colour_prefs.me; +} + +NCURSES_COLOR_T +prefs_get_them() +{ + return colour_prefs.them; } diff --git a/src/preferences.h b/src/preferences.h index d045f517..bb45ee07 100644 --- a/src/preferences.h +++ b/src/preferences.h @@ -78,17 +78,28 @@ gint prefs_get_priority(void); void prefs_add_login(const char *jid); NCURSES_COLOR_T prefs_get_bkgnd(); -NCURSES_COLOR_T prefs_get_text(); +NCURSES_COLOR_T prefs_get_titlebar(); +NCURSES_COLOR_T prefs_get_statusbar(); +NCURSES_COLOR_T prefs_get_titlebartext(); +NCURSES_COLOR_T prefs_get_titlebarbrackets(); +NCURSES_COLOR_T prefs_get_statusbartext(); +NCURSES_COLOR_T prefs_get_statusbarbrackets(); +NCURSES_COLOR_T prefs_get_statusbaractive(); +NCURSES_COLOR_T prefs_get_statusbarnew(); +NCURSES_COLOR_T prefs_get_maintext(); +NCURSES_COLOR_T prefs_get_splashtext(); NCURSES_COLOR_T prefs_get_online(); NCURSES_COLOR_T prefs_get_away(); NCURSES_COLOR_T prefs_get_chat(); NCURSES_COLOR_T prefs_get_dnd(); NCURSES_COLOR_T prefs_get_xa(); NCURSES_COLOR_T prefs_get_offline(); -NCURSES_COLOR_T prefs_get_err(); -NCURSES_COLOR_T prefs_get_inc(); -NCURSES_COLOR_T prefs_get_bar(); -NCURSES_COLOR_T prefs_get_bar_draw(); -NCURSES_COLOR_T prefs_get_bar_text(); +NCURSES_COLOR_T prefs_get_typing(); +NCURSES_COLOR_T prefs_get_gone(); +NCURSES_COLOR_T prefs_get_error(); +NCURSES_COLOR_T prefs_get_incoming(); +NCURSES_COLOR_T prefs_get_roominfo(); +NCURSES_COLOR_T prefs_get_me(); +NCURSES_COLOR_T prefs_get_them(); #endif diff --git a/src/status_bar.c b/src/status_bar.c index ad042cd1..37a9bce4 100644 --- a/src/status_bar.c +++ b/src/status_bar.c @@ -56,10 +56,10 @@ create_status_bar(void) } status_bar = newwin(1, cols, rows-2, 0); - wbkgd(status_bar, COLOUR_BAR_DEF); - wattron(status_bar, COLOUR_BAR_DRAW); + wbkgd(status_bar, COLOUR_STATUS_TEXT); + wattron(status_bar, COLOUR_STATUS_BRACKET); mvwprintw(status_bar, 0, cols - 29, _active); - wattroff(status_bar, COLOUR_BAR_DRAW); + wattroff(status_bar, COLOUR_STATUS_BRACKET); last_time = g_date_time_new_now_local(); @@ -95,11 +95,11 @@ status_bar_resize(void) mvwin(status_bar, rows-2, 0); wresize(status_bar, 1, cols); - wbkgd(status_bar, COLOUR_BAR_DEF); + wbkgd(status_bar, COLOUR_STATUS_TEXT); wclear(status_bar); - wattron(status_bar, COLOUR_BAR_DRAW); + wattron(status_bar, COLOUR_STATUS_BRACKET); mvwprintw(status_bar, 0, cols - 29, _active); - wattroff(status_bar, COLOUR_BAR_DRAW); + wattroff(status_bar, COLOUR_STATUS_BRACKET); for(i = 0; i < 9; i++) { if (is_new[i]) @@ -142,12 +142,12 @@ status_bar_active(const int win) int cols = getmaxx(stdscr); - wattron(status_bar, COLOUR_BAR_DRAW); + wattron(status_bar, COLOUR_STATUS_ACTIVE); if (win < 9) mvwprintw(status_bar, 0, cols - 29 + active_pos, "%d", win+1); else mvwprintw(status_bar, 0, cols - 29 + active_pos, "10"); - wattroff(status_bar, COLOUR_BAR_DRAW); + wattroff(status_bar, COLOUR_STATUS_ACTIVE); dirty = TRUE; } @@ -162,13 +162,13 @@ status_bar_new(const int win) int cols = getmaxx(stdscr); - wattron(status_bar, COLOUR_BAR_TEXT); + wattron(status_bar, COLOUR_STATUS_NEW); wattron(status_bar, A_BLINK); if (win < 9) mvwprintw(status_bar, 0, cols - 29 + active_pos, "%d", win+1); else mvwprintw(status_bar, 0, cols - 29 + active_pos, "10"); - wattroff(status_bar, COLOUR_BAR_TEXT); + wattroff(status_bar, COLOUR_STATUS_NEW); wattroff(status_bar, A_BLINK); dirty = TRUE; @@ -197,9 +197,9 @@ status_bar_print_message(const char * const msg) int cols = getmaxx(stdscr); - wattron(status_bar, COLOUR_BAR_DRAW); + wattron(status_bar, COLOUR_STATUS_BRACKET); mvwprintw(status_bar, 0, cols - 29, _active); - wattroff(status_bar, COLOUR_BAR_DRAW); + wattroff(status_bar, COLOUR_STATUS_BRACKET); int i; for(i = 0; i < 9; i++) { @@ -230,9 +230,9 @@ status_bar_clear(void) int cols = getmaxx(stdscr); - wattron(status_bar, COLOUR_BAR_DRAW); + wattron(status_bar, COLOUR_STATUS_BRACKET); mvwprintw(status_bar, 0, cols - 29, _active); - wattroff(status_bar, COLOUR_BAR_DRAW); + wattroff(status_bar, COLOUR_STATUS_BRACKET); dirty = TRUE; } @@ -249,9 +249,9 @@ status_bar_clear_message(void) int cols = getmaxx(stdscr); - wattron(status_bar, COLOUR_BAR_DRAW); + wattron(status_bar, COLOUR_STATUS_BRACKET); mvwprintw(status_bar, 0, cols - 29, _active); - wattroff(status_bar, COLOUR_BAR_DRAW); + wattroff(status_bar, COLOUR_STATUS_BRACKET); int i; for(i = 0; i < 9; i++) { @@ -269,13 +269,13 @@ _status_bar_update_time(void) { gchar *date_fmt = g_date_time_format(last_time, "%H:%M"); - wattron(status_bar, COLOUR_BAR_DRAW); + wattron(status_bar, COLOUR_STATUS_BRACKET); mvwaddch(status_bar, 0, 1, '['); - wattroff(status_bar, COLOUR_BAR_DRAW); + wattroff(status_bar, COLOUR_STATUS_BRACKET); mvwprintw(status_bar, 0, 2, date_fmt); - wattron(status_bar, COLOUR_BAR_DRAW); + wattron(status_bar, COLOUR_STATUS_BRACKET); mvwaddch(status_bar, 0, 7, ']'); - wattroff(status_bar, COLOUR_BAR_DRAW); + wattroff(status_bar, COLOUR_STATUS_BRACKET); free(date_fmt); diff --git a/src/title_bar.c b/src/title_bar.c index 0bfed5ba..1ebe4f09 100644 --- a/src/title_bar.c +++ b/src/title_bar.c @@ -42,7 +42,7 @@ create_title_bar(void) int cols = getmaxx(stdscr); title_bar = newwin(1, cols, 0, 0); - wbkgd(title_bar, COLOUR_BAR_DEF); + wbkgd(title_bar, COLOUR_TITLE_TEXT); title_bar_title(); title_bar_set_status(PRESENCE_OFFLINE); dirty = TRUE; @@ -63,7 +63,7 @@ title_bar_resize(void) int cols = getmaxx(stdscr); wresize(title_bar, 1, cols); - wbkgd(title_bar, COLOUR_BAR_DEF); + wbkgd(title_bar, COLOUR_TITLE_TEXT); wclear(title_bar); _title_bar_draw_title(); _title_bar_draw_status(); @@ -173,9 +173,9 @@ _title_bar_draw_status(void) { int cols = getmaxx(stdscr); - wattron(title_bar, COLOUR_BAR_DRAW); + wattron(title_bar, COLOUR_TITLE_BRACKET); mvwaddch(title_bar, 0, cols - 14, '['); - wattroff(title_bar, COLOUR_BAR_DRAW); + wattroff(title_bar, COLOUR_TITLE_BRACKET); if (current_status == PRESENCE_ONLINE) { mvwprintw(title_bar, 0, cols - 13, " ...online "); @@ -191,9 +191,9 @@ _title_bar_draw_status(void) mvwprintw(title_bar, 0, cols - 13, " ..offline "); } - wattron(title_bar, COLOUR_BAR_DRAW); + wattron(title_bar, COLOUR_TITLE_BRACKET); mvwaddch(title_bar, 0, cols - 2, ']'); - wattroff(title_bar, COLOUR_BAR_DRAW); + wattroff(title_bar, COLOUR_TITLE_BRACKET); dirty = TRUE; } diff --git a/src/ui.h b/src/ui.h index 68ee89d2..3e30fd1a 100644 --- a/src/ui.h +++ b/src/ui.h @@ -38,18 +38,27 @@ #define INP_WIN_MAX 1000 -#define COLOUR_TEXT COLOR_PAIR(1) -#define COLOUR_ONLINE COLOR_PAIR(2) -#define COLOUR_BAR_TEXT COLOR_PAIR(3) -#define COLOUR_BAR_DRAW COLOR_PAIR(4) -#define COLOUR_OFFLINE COLOR_PAIR(5) -#define COLOUR_ERR COLOR_PAIR(6) -#define COLOUR_INC COLOR_PAIR(7) -#define COLOUR_BAR_DEF COLOR_PAIR(8) -#define COLOUR_AWAY COLOR_PAIR(9) -#define COLOUR_CHAT COLOR_PAIR(10) -#define COLOUR_DND COLOR_PAIR(11) -#define COLOUR_XA COLOR_PAIR(12) +#define COLOUR_TEXT COLOR_PAIR(1) +#define COLOUR_SPLASH COLOR_PAIR(2) +#define COLOUR_ERROR COLOR_PAIR(3) +#define COLOUR_INCOMING COLOR_PAIR(4) +#define COLOUR_TITLE_TEXT COLOR_PAIR(10) +#define COLOUR_TITLE_BRACKET COLOR_PAIR(11) +#define COLOUR_STATUS_TEXT COLOR_PAIR(20) +#define COLOUR_STATUS_BRACKET COLOR_PAIR(21) +#define COLOUR_STATUS_ACTIVE COLOR_PAIR(22) +#define COLOUR_STATUS_NEW COLOR_PAIR(23) +#define COLOUR_ME COLOR_PAIR(30) +#define COLOUR_THEM COLOR_PAIR(31) +#define COLOUR_ROOMINFO COLOR_PAIR(40) +#define COLOUR_ONLINE COLOR_PAIR(50) +#define COLOUR_OFFLINE COLOR_PAIR(51) +#define COLOUR_AWAY COLOR_PAIR(52) +#define COLOUR_CHAT COLOR_PAIR(53) +#define COLOUR_DND COLOR_PAIR(54) +#define COLOUR_XA COLOR_PAIR(55) +#define COLOUR_TYPING COLOR_PAIR(60) +#define COLOUR_GONE COLOR_PAIR(61) typedef enum { WIN_UNUSED, diff --git a/src/windows.c b/src/windows.c index 1881f23a..80adeed7 100644 --- a/src/windows.c +++ b/src/windows.c @@ -112,20 +112,40 @@ gui_init(void) use_default_colors(); start_color(); - init_pair(1, prefs_get_text(), prefs_get_bkgnd()); - init_pair(2, prefs_get_online(), prefs_get_bkgnd()); - init_pair(3, prefs_get_text(), prefs_get_bar()); - init_pair(4, prefs_get_bar_draw(), prefs_get_bar()); - init_pair(5, prefs_get_offline(), prefs_get_bkgnd()); - init_pair(6, prefs_get_err(), prefs_get_bkgnd()); - init_pair(7, prefs_get_inc(), prefs_get_bkgnd()); - init_pair(8, prefs_get_bar_text(), prefs_get_bar()); + // main text + init_pair(1, prefs_get_maintext(), prefs_get_bkgnd()); + init_pair(2, prefs_get_splashtext(), prefs_get_bkgnd()); + init_pair(3, prefs_get_error(), prefs_get_bkgnd()); + init_pair(4, prefs_get_incoming(), prefs_get_bkgnd()); - //statuses - init_pair(9, prefs_get_away(), prefs_get_bkgnd()); - init_pair(10, prefs_get_chat(), prefs_get_bkgnd()); - init_pair(11, prefs_get_dnd(), prefs_get_bkgnd()); - init_pair(12, prefs_get_xa(), prefs_get_bkgnd()); + // title bar + init_pair(10, prefs_get_titlebartext(), prefs_get_titlebar()); + init_pair(11, prefs_get_titlebarbrackets(), prefs_get_titlebar()); + + // status bar + init_pair(20, prefs_get_statusbartext(), prefs_get_statusbar()); + init_pair(21, prefs_get_statusbarbrackets(), prefs_get_statusbar()); + init_pair(22, prefs_get_statusbaractive(), prefs_get_statusbar()); + init_pair(23, prefs_get_statusbarnew(), prefs_get_statusbar()); + + // chat + init_pair(30, prefs_get_me(), prefs_get_bkgnd()); + init_pair(31, prefs_get_them(), prefs_get_bkgnd()); + + // room chat + init_pair(40, prefs_get_roominfo(), prefs_get_bkgnd()); + + // statuses + init_pair(50, prefs_get_online(), prefs_get_bkgnd()); + init_pair(51, prefs_get_offline(), prefs_get_bkgnd()); + init_pair(52, prefs_get_away(), prefs_get_bkgnd()); + init_pair(53, prefs_get_chat(), prefs_get_bkgnd()); + init_pair(54, prefs_get_dnd(), prefs_get_bkgnd()); + init_pair(55, prefs_get_xa(), prefs_get_bkgnd()); + + // states + init_pair(60, prefs_get_typing(), prefs_get_bkgnd()); + init_pair(61, prefs_get_gone(), prefs_get_bkgnd()); } refresh(); @@ -406,11 +426,11 @@ win_show_incomming_msg(const char * const from, const char * const message, } if (strncmp(message, "/me ", 4) == 0) { - wattron(win, COLOUR_ONLINE); + wattron(win, COLOUR_THEM); wprintw(win, "*%s ", from); wprintw(win, message + 4); wprintw(win, "\n"); - wattroff(win, COLOUR_ONLINE); + wattroff(win, COLOUR_THEM); } else { _win_show_user(win, from, 1); _win_show_message(win, message); @@ -443,11 +463,11 @@ win_show_incomming_msg(const char * const from, const char * const message, } if (strncmp(message, "/me ", 4) == 0) { - wattron(win, COLOUR_ONLINE); + wattron(win, COLOUR_THEM); wprintw(win, "*%s ", from); wprintw(win, message + 4); wprintw(win, "\n"); - wattroff(win, COLOUR_ONLINE); + wattroff(win, COLOUR_THEM); } else { _win_show_user(win, from, 1); _win_show_message(win, message); @@ -497,11 +517,11 @@ win_show_gone(const char * const from) if (win_index < NUM_WINS) { win = _wins[win_index].win; _win_show_time(win); - wattron(win, COLOUR_AWAY); + wattron(win, COLOUR_GONE); wprintw(win, "*%s ", from); wprintw(win, "has left the conversation."); wprintw(win, "\n"); - wattroff(win, COLOUR_AWAY); + wattroff(win, COLOUR_GONE); if (win_index == _curr_prof_win) { dirty = TRUE; } @@ -531,9 +551,7 @@ win_show_system_msg(const char * const from, const char *message) win = _wins[win_index].win; _win_show_time(win); - wattron(win, COLOUR_ONLINE); wprintw(win, "*%s %s\n", bare_jid, message); - wattroff(win, COLOUR_ONLINE); // this is the current window if (win_index == _curr_prof_win) { @@ -643,11 +661,11 @@ win_show_outgoing_msg(const char * const from, const char * const to, _win_show_time(win); if (strncmp(message, "/me ", 4) == 0) { - wattron(win, COLOUR_INC); + wattron(win, COLOUR_ME); wprintw(win, "*%s ", from); wprintw(win, message + 4); wprintw(win, "\n"); - wattroff(win, COLOUR_INC); + wattroff(win, COLOUR_ME); } else { _win_show_user(win, from, 0); _win_show_message(win, message); @@ -677,13 +695,13 @@ win_show_room_roster(const char * const room) GList *roster = room_get_roster(room); if ((roster == NULL) || (g_list_length(roster) == 0)) { - wattron(win, COLOUR_INC); + wattron(win, COLOUR_ROOMINFO); wprintw(win, "You are alone!\n"); - wattroff(win, COLOUR_INC); + wattroff(win, COLOUR_ROOMINFO); } else { - wattron(win, COLOUR_INC); + wattron(win, COLOUR_ROOMINFO); wprintw(win, "Room occupants:\n"); - wattroff(win, COLOUR_INC); + wattroff(win, COLOUR_ROOMINFO); wattron(win, COLOUR_ONLINE); while (roster != NULL) { @@ -755,9 +773,9 @@ win_show_room_member_nick_change(const char * const room, WINDOW *win = _wins[win_index].win; _win_show_time(win); - wattron(win, COLOUR_ONLINE); + wattron(win, COLOUR_THEM); wprintw(win, "** %s is now known as %s\n", old_nick, nick); - wattroff(win, COLOUR_ONLINE); + wattroff(win, COLOUR_THEM); if (win_index == _curr_prof_win) dirty = TRUE; @@ -770,9 +788,9 @@ win_show_room_nick_change(const char * const room, const char * const nick) WINDOW *win = _wins[win_index].win; _win_show_time(win); - wattron(win, COLOUR_ONLINE); + wattron(win, COLOUR_ME); wprintw(win, "** You are now known as %s\n", nick); - wattroff(win, COLOUR_ONLINE); + wattroff(win, COLOUR_ME); if (win_index == _curr_prof_win) dirty = TRUE; @@ -814,11 +832,11 @@ win_show_room_message(const char * const room_jid, const char * const nick, _win_show_time(win); if (strcmp(nick, room_get_nick_for_room(room_jid)) != 0) { if (strncmp(message, "/me ", 4) == 0) { - wattron(win, COLOUR_ONLINE); + wattron(win, COLOUR_THEM); wprintw(win, "*%s ", nick); wprintw(win, message + 4); wprintw(win, "\n"); - wattroff(win, COLOUR_ONLINE); + wattroff(win, COLOUR_THEM); } else { _win_show_user(win, nick, 1); _win_show_message(win, message); @@ -826,11 +844,11 @@ win_show_room_message(const char * const room_jid, const char * const nick, } else { if (strncmp(message, "/me ", 4) == 0) { - wattron(win, COLOUR_INC); + wattron(win, COLOUR_ME); wprintw(win, "*%s ", nick); wprintw(win, message + 4); wprintw(win, "\n"); - wattroff(win, COLOUR_INC); + wattroff(win, COLOUR_ME); } else { _win_show_user(win, nick, 0); _win_show_message(win, message); @@ -877,9 +895,9 @@ win_show_room_subject(const char * const room_jid, const char * const subject) int win_index = _find_prof_win_index(room_jid); WINDOW *win = _wins[win_index].win; - wattron(win, COLOUR_INC); + wattron(win, COLOUR_ROOMINFO); wprintw(win, "Room subject: "); - wattroff(win, COLOUR_INC); + wattroff(win, COLOUR_ROOMINFO); wprintw(win, "%s\n", subject); // currently in groupchat window @@ -899,9 +917,9 @@ win_show_room_broadcast(const char * const room_jid, const char * const message) int win_index = _find_prof_win_index(room_jid); WINDOW *win = _wins[win_index].win; - wattron(win, COLOUR_INC); + wattron(win, COLOUR_ROOMINFO); wprintw(win, "Room message: "); - wattroff(win, COLOUR_INC); + wattroff(win, COLOUR_ROOMINFO); wprintw(win, "%s\n", message); // currently in groupchat window @@ -930,9 +948,9 @@ win_bad_show(const char * const msg) { WINDOW *win = _wins[_curr_prof_win].win; _win_show_time(win); - wattron(win, COLOUR_ERR); + wattron(win, COLOUR_ERROR); wprintw(win, "%s\n", msg); - wattroff(win, COLOUR_ERR); + wattroff(win, COLOUR_ERROR); dirty = TRUE; } @@ -990,9 +1008,9 @@ win_disconnected(void) if (strcmp(_wins[i].from, "") != 0) { WINDOW *win = _wins[i].win; _win_show_time(win); - wattron(win, COLOUR_ERR); + wattron(win, COLOUR_ERROR); wprintw(win, "%s\n", "Lost connection."); - wattroff(win, COLOUR_ERR); + wattroff(win, COLOUR_ERROR); // if current win, set dirty if (i == _curr_prof_win) { @@ -1208,9 +1226,9 @@ cons_bad_show(const char * const msg, ...) GString *fmt_msg = g_string_new(NULL); g_string_vprintf(fmt_msg, msg, arg); _win_show_time(_cons_win); - wattron(_cons_win, COLOUR_ERR); + wattron(_cons_win, COLOUR_ERROR); wprintw(_cons_win, "%s\n", fmt_msg->str); - wattroff(_cons_win, COLOUR_ERR); + wattroff(_cons_win, COLOUR_ERROR); g_string_free(fmt_msg, TRUE); va_end(arg); @@ -1379,13 +1397,9 @@ cons_check_version(gboolean not_available_msg) if (relase_valid) { if (_new_release(latest_release)) { _win_show_time(_cons_win); - wattron(_cons_win, COLOUR_ONLINE); wprintw(_cons_win, "A new version of Profanity is available: %s", latest_release); - wattroff(_cons_win, COLOUR_ONLINE); _win_show_time(_cons_win); - wattron(_cons_win, COLOUR_ONLINE); wprintw(_cons_win, "Check <http://www.profanity.im> for details.\n"); - wattroff(_cons_win, COLOUR_ONLINE); free(latest_release); _win_show_time(_cons_win); wprintw(_cons_win, "\n"); @@ -1432,39 +1446,39 @@ _cons_splash_logo(void) wprintw(_cons_win, "Welcome to\n"); _win_show_time(_cons_win); - wattron(_cons_win, COLOUR_OFFLINE); + wattron(_cons_win, COLOUR_SPLASH); wprintw(_cons_win, " ___ _ \n"); - wattroff(_cons_win, COLOUR_OFFLINE); + wattroff(_cons_win, COLOUR_SPLASH); _win_show_time(_cons_win); - wattron(_cons_win, COLOUR_OFFLINE); + wattron(_cons_win, COLOUR_SPLASH); wprintw(_cons_win, " / __) (_)_ \n"); - wattroff(_cons_win, COLOUR_OFFLINE); + wattroff(_cons_win, COLOUR_SPLASH); _win_show_time(_cons_win); - wattron(_cons_win, COLOUR_OFFLINE); + wattron(_cons_win, COLOUR_SPLASH); wprintw(_cons_win, " ____ ____ ___ | |__ ____ ____ _| |_ _ _ \n"); - wattroff(_cons_win, COLOUR_OFFLINE); + wattroff(_cons_win, COLOUR_SPLASH); _win_show_time(_cons_win); - wattron(_cons_win, COLOUR_OFFLINE); + wattron(_cons_win, COLOUR_SPLASH); wprintw(_cons_win, "| _ \\ / ___) _ \\| __) _ | _ \\| | _) | | |\n"); - wattroff(_cons_win, COLOUR_OFFLINE); + wattroff(_cons_win, COLOUR_SPLASH); _win_show_time(_cons_win); - wattron(_cons_win, COLOUR_OFFLINE); + wattron(_cons_win, COLOUR_SPLASH); wprintw(_cons_win, "| | | | | | |_| | | ( ( | | | | | | |_| |_| |\n"); - wattroff(_cons_win, COLOUR_OFFLINE); + wattroff(_cons_win, COLOUR_SPLASH); _win_show_time(_cons_win); - wattron(_cons_win, COLOUR_OFFLINE); + wattron(_cons_win, COLOUR_SPLASH); wprintw(_cons_win, "| ||_/|_| \\___/|_| \\_||_|_| |_|_|\\___)__ |\n"); - wattroff(_cons_win, COLOUR_OFFLINE); + wattroff(_cons_win, COLOUR_SPLASH); _win_show_time(_cons_win); - wattron(_cons_win, COLOUR_OFFLINE); + wattron(_cons_win, COLOUR_SPLASH); wprintw(_cons_win, "|_| (____/ \n"); - wattroff(_cons_win, COLOUR_OFFLINE); + wattroff(_cons_win, COLOUR_SPLASH); _win_show_time(_cons_win); wprintw(_cons_win, "\n"); @@ -1541,14 +1555,14 @@ static void _win_show_user(WINDOW *win, const char * const user, const int colour) { if (colour) - wattron(win, COLOUR_ONLINE); + wattron(win, COLOUR_THEM); else - wattron(win, COLOUR_INC); + wattron(win, COLOUR_ME); wprintw(win, "%s: ", user); if (colour) - wattroff(win, COLOUR_ONLINE); + wattroff(win, COLOUR_THEM); else - wattroff(win, COLOUR_INC); + wattroff(win, COLOUR_ME); } static void @@ -1560,9 +1574,9 @@ _win_show_message(WINDOW *win, const char * const message) static void _win_show_error_msg(WINDOW *win, const char * const message) { - wattron(win, COLOUR_ERR); + wattron(win, COLOUR_ERROR); wprintw(win, "%s\n", message); - wattroff(win, COLOUR_ERR); + wattroff(win, COLOUR_ERROR); } static void @@ -1659,18 +1673,18 @@ static void _cons_show_typing(const char * const short_from) { _win_show_time(_cons_win); - wattron(_cons_win, COLOUR_INC); + wattron(_cons_win, COLOUR_TYPING); wprintw(_cons_win, "!! %s is typing a message...\n", short_from); - wattroff(_cons_win, COLOUR_INC); + wattroff(_cons_win, COLOUR_TYPING); } static void _cons_show_incoming_message(const char * const short_from, const int win_index) { _win_show_time(_cons_win); - wattron(_cons_win, COLOUR_INC); + wattron(_cons_win, COLOUR_INCOMING); wprintw(_cons_win, "<< incoming from %s (%d)\n", short_from, win_index + 1); - wattroff(_cons_win, COLOUR_INC); + wattroff(_cons_win, COLOUR_INCOMING); } static void