From 5c4df507c4286b48f0c6811c849b2fc40b3ac117 Mon Sep 17 00:00:00 2001 From: Maxime Coste Date: Wed, 5 Sep 2012 00:49:59 +0200 Subject: [PATCH] ncurses: colorize the menu --- src/ncurses.cc | 93 +++++++++++++++++++++++++++----------------------- src/ncurses.hh | 3 ++ 2 files changed, 54 insertions(+), 42 deletions(-) diff --git a/src/ncurses.cc b/src/ncurses.cc index b1e29891..bc60b350 100644 --- a/src/ncurses.cc +++ b/src/ncurses.cc @@ -10,27 +10,6 @@ namespace Kakoune { -NCursesClient::NCursesClient() - : m_menu(nullptr) -{ - // setlocale(LC_ALL, ""); - initscr(); - cbreak(); - noecho(); - nonl(); - intrflush(stdscr, false); - keypad(stdscr, true); - curs_set(0); - start_color(); - use_default_colors(); - ESCDELAY=25; -} - -NCursesClient::~NCursesClient() -{ - endwin(); -} - static void set_attribute(int attribute, bool on) { if (on) @@ -58,35 +37,63 @@ static int nc_color(Color color) } } -static void set_color(Color fg_color, Color bg_color) +static int get_color_pair(Color fg_color, Color bg_color) { static std::map, int> colorpairs; - static int current_pair = -1; static int next_pair = 1; - if (current_pair != -1) - attroff(COLOR_PAIR(current_pair)); - - if (fg_color == Color::Default and bg_color == Color::Default) - return; - std::pair colorpair(fg_color, bg_color); + auto it = colorpairs.find(colorpair); - if (it != colorpairs.end()) - { - current_pair = it->second; - attron(COLOR_PAIR(it->second)); - } + if (it != colorpairs.end()) + return it->second; else { init_pair(next_pair, nc_color(fg_color), nc_color(bg_color)); colorpairs[colorpair] = next_pair; - current_pair = next_pair; - attron(COLOR_PAIR(next_pair)); - ++next_pair; + return next_pair++; } } +static void set_color(Color fg_color, Color bg_color) +{ + static int current_pair = -1; + + if (current_pair != -1) + attroff(COLOR_PAIR(current_pair)); + + if (fg_color != Color::Default or bg_color != Color::Default) + { + current_pair = get_color_pair(fg_color, bg_color); + attron(COLOR_PAIR(current_pair)); + } +} + + +NCursesClient::NCursesClient() + : m_menu(nullptr) +{ + // setlocale(LC_ALL, ""); + initscr(); + cbreak(); + noecho(); + nonl(); + intrflush(stdscr, false); + keypad(stdscr, true); + curs_set(0); + start_color(); + use_default_colors(); + ESCDELAY=25; + + m_menu_fg = get_color_pair(Color::Blue, Color::Cyan); + m_menu_bg = get_color_pair(Color::Cyan, Color::Blue); +} + +NCursesClient::~NCursesClient() +{ + endwin(); +} + void NCursesClient::draw_window(Window& window) { int max_x,max_y; @@ -231,6 +238,8 @@ void NCursesClient::show_menu(const memoryview& choices) set_menu_sub(m_menu, derwin(stdscr, max_y - pos_y - 1, max_x, pos_y, 0)); set_menu_format(m_menu, lines, columns); set_menu_mark(m_menu, nullptr); + set_menu_fore(m_menu, COLOR_PAIR(m_menu_fg)); + set_menu_back(m_menu, COLOR_PAIR(m_menu_bg)); post_menu(m_menu); refresh(); } @@ -240,23 +249,23 @@ void NCursesClient::menu_ctrl(MenuCommand command) switch(command) { case MenuCommand::SelectFirst: - set_menu_fore(m_menu, A_STANDOUT); + set_menu_fore(m_menu, COLOR_PAIR(m_menu_fg)); menu_driver(m_menu, REQ_FIRST_ITEM); break; case MenuCommand::SelectLast: - set_menu_fore(m_menu, A_STANDOUT); + set_menu_fore(m_menu, COLOR_PAIR(m_menu_fg)); menu_driver(m_menu, REQ_LAST_ITEM); break; case MenuCommand::SelectNext: - set_menu_fore(m_menu, A_STANDOUT); + set_menu_fore(m_menu, COLOR_PAIR(m_menu_fg)); menu_driver(m_menu, REQ_NEXT_ITEM); break; case MenuCommand::SelectPrev: - set_menu_fore(m_menu, A_STANDOUT); + set_menu_fore(m_menu, COLOR_PAIR(m_menu_fg)); menu_driver(m_menu, REQ_PREV_ITEM); break; case MenuCommand::SelectNone: - set_menu_fore(m_menu, A_NORMAL); + set_menu_fore(m_menu, COLOR_PAIR(m_menu_bg)); break; case MenuCommand::Close: { diff --git a/src/ncurses.hh b/src/ncurses.hh index 69ddd30a..a9bb91fe 100644 --- a/src/ncurses.hh +++ b/src/ncurses.hh @@ -30,6 +30,9 @@ private: std::vector m_items; std::vector m_counts; std::vector m_choices; + + int m_menu_fg; + int m_menu_bg; }; }