diff --git a/graph_browser.cpp b/graph_browser.cpp index cf1482a..36cb846 100644 --- a/graph_browser.cpp +++ b/graph_browser.cpp @@ -1,16 +1,6 @@ #include - - -// every day is assert day -#ifndef NDEBUG - #include -#else - #define NDEBUG - #include - #undef NDEBUG -#endif - #include +#include #include "graph_browser.hpp" @@ -29,10 +19,13 @@ namespace { return s; } - std::string toCommaSeparatedList(const std::vector& v) + std::string toCommaSeparatedList(const std::vector& v, const std::string& skip) { std::string s; for (size_t i = 0; i < v.size()-1; ++i) { + if (v[i] == skip) + continue; + s += v[i]; s += ","; } @@ -64,14 +57,23 @@ namespace { void GraphBrowser::init() { - assert(initscr()); - assert(cbreak() == OK); - assert(noecho() == OK); - assert(keypad(stdscr, TRUE) == OK); + int r = 0; + WINDOW* w; + + w = initscr(); + assert(w); + r = cbreak(); + assert(r == OK); + r = noecho(); + assert(r == OK); + r = keypad(stdscr, TRUE); + assert(r == OK); //Needed to have ‘immediate’ ESC-Key behavior: - if (getenv ("ESCDELAY") == NULL) - assert(set_escdelay(25) == OK); + if (getenv ("ESCDELAY") == NULL) { + r = set_escdelay(25); + assert(r == OK); + } } void GraphBrowser::destroy() @@ -96,69 +98,99 @@ GraphBrowser::GraphBrowser(Graph& g) void GraphBrowser::initLayout() { - // window of the current node - menu_ = new_menu((ITEM **)0); - assert(menu_); + int r; current_win_ = newwin(window_height, current_window_width, 1, 0); assert(current_win_); - assert(keypad(current_win_, TRUE) == OK); + r = keypad(current_win_, TRUE); + assert(r == OK); - assert(set_menu_win(menu_, current_win_) == E_OK); + menu_ = new_menu((ITEM **)0); + assert(menu_); + + r = set_menu_win(menu_, current_win_); + assert(r == E_OK); menu_subwindow_ = derwin(current_win_, window_height-2, current_window_width-2, 1, 1); assert(menu_subwindow_); - assert(set_menu_sub(menu_, menu_subwindow_) == E_OK); - const int r = set_menu_format(menu_, window_height-2, 1); - assert(set_menu_mark(menu_, " ") == E_OK); - - assert(wborder(current_win_, - ACS_VLINE, ACS_VLINE, ACS_HLINE, ACS_HLINE, - ACS_ULCORNER, ACS_TTEE, ACS_LLCORNER, ACS_BTEE) == OK); - assert(refresh() == OK); - assert(wrefresh(current_win_) == OK); + r = set_menu_sub(menu_, menu_subwindow_); + assert(r == E_OK); + r = set_menu_format(menu_, window_height-2, 1); + assert(r == E_OK); // @bug NOT connected + r = set_menu_mark(menu_, " "); + assert(r == E_OK); + + r = wborder(current_win_, + ACS_VLINE, ACS_VLINE, ACS_HLINE, ACS_HLINE, + ACS_ULCORNER, ACS_TTEE, ACS_LLCORNER, ACS_BTEE); + assert(r == OK); + r = refresh(); + assert(r == OK); + r = wrefresh(current_win_); + assert(r == OK); n_win_ = newwin(window_height, n_window_width, 1, current_window_width); assert(n_win_); - assert(wborder(n_win_, - ' ', ' ', ACS_HLINE, ACS_HLINE, - ACS_HLINE, ACS_HLINE, ACS_HLINE, ACS_HLINE) == OK); - assert(refresh() == OK); - assert(wrefresh(n_win_) == OK); + r = wborder(n_win_, + ' ', ' ', ACS_HLINE, ACS_HLINE, + ACS_HLINE, ACS_HLINE, ACS_HLINE, ACS_HLINE); + assert(r == OK); + r = refresh(); + assert(r == OK); + r = wrefresh(n_win_); + assert(r == OK); // window of the neighbours'neighbours of the current vertex n_of_n_win_ = newwin(window_height, term_max_x_-current_window_width-n_window_width, 1, n_window_width+current_window_width); assert(n_of_n_win_); - assert(wborder(n_of_n_win_, - ACS_VLINE, ACS_VLINE, ACS_HLINE, ACS_HLINE, - ACS_TTEE, ACS_URCORNER, ACS_BTEE, ACS_LRCORNER) == OK); - assert(refresh() == OK); - assert(wrefresh(n_of_n_win_) == OK); + r = wborder(n_of_n_win_, + ACS_VLINE, ACS_VLINE, ACS_HLINE, ACS_HLINE, + ACS_TTEE, ACS_URCORNER, ACS_BTEE, ACS_LRCORNER); + assert(r == OK); + r = refresh(); + assert(r == OK); + r = wrefresh(n_of_n_win_); + assert(r == OK); // bottom text /// @note should we assert as a minimum width? mvprintw(term_max_y_-1, 0, "ESC:exit, cursors:navigate, d/i:del/ins edge, D/I:del/ins node"); - assert(refresh() == OK); + r = refresh(); + assert(r == OK); } void GraphBrowser::cleanUp() { - assert(endwin() == OK); - assert(refresh() == OK); - assert(clear() == OK); + int r; + + r = endwin(); + assert(r == OK); + r = refresh(); + assert(r == OK); + r = clear(); + assert(r == OK); ITEM** old_items = menu_items(menu_); const int old_items_count = item_count(menu_); - if (old_items_count > 0) - assert(unpost_menu(menu_) == E_OK); - assert(free_menu(menu_) == E_OK); - for (int i = 0; i < old_items_count; ++i) - assert(free_item(old_items[i]) == E_OK); - - assert(delwin(menu_subwindow_) == OK); - assert(delwin(current_win_) == OK); - assert(delwin(n_win_) == OK); - assert(delwin(n_of_n_win_) == OK); + if (old_items_count > 0) { + r = unpost_menu(menu_); + assert(r == E_OK); + } + r = free_menu(menu_); + assert(r == E_OK); + for (int i = 0; i < old_items_count; ++i) { + r = free_item(old_items[i]); + assert(r == E_OK); + } + + r = delwin(menu_subwindow_); + assert(r == OK); + r = delwin(current_win_); + assert(r == OK); + r = delwin(n_win_); + assert(r == OK); + r = delwin(n_of_n_win_); + assert(r == OK); } GraphBrowser::~GraphBrowser() @@ -277,19 +309,26 @@ void GraphBrowser::updateCurrent(const std::string& s, bool first_run) addItems(n, first_run); updateNeighbours(); - assert(mvprintw(0, 0, "%s",std::string(term_max_x_,' ').c_str()) == OK); - assert(mvprintw(0, 0, historyToString(history_, term_max_x_).c_str()) == OK); - refresh(); + int r; + r = mvprintw(0, 0, "%s",std::string(term_max_x_,' ').c_str()); + assert(r == OK); + r = mvprintw(0, 0, historyToString(history_, term_max_x_).c_str()); + assert(r == OK); + + r = refresh(); + assert(r == OK); } void GraphBrowser::updateNeighbours() { - + int r; const size_t n_width = n_window_width-1; const size_t n_of_n_width = term_max_x_-current_window_width-n_window_width-2; for (int i = 1; i < window_height-1; ++i) { - assert(mvwprintw(n_win_, i, 1, "%s", std::string(n_width,' ').c_str()) == OK); - assert(mvwprintw(n_of_n_win_, i, 1, "%s", std::string(n_of_n_width,' ').c_str()) == OK); + r = mvwprintw(n_win_, i, 1, "%s", std::string(n_width,' ').c_str()); + assert(r == OK); + r = mvwprintw(n_of_n_win_, i, 1, "%s", std::string(n_of_n_width,' ').c_str()); + assert(r == OK); } ITEM* c_item = current_item(menu_); @@ -298,29 +337,35 @@ void GraphBrowser::updateNeighbours() const std::vector& n = graph_.neighboursOf(current); for (size_t i = 0; i < n.size() && i < window_height-2; ++i) { const size_t n_win_w = std::min(n[i].length(), n_width); - assert(mvwprintw(n_win_, i+1, 1, std::string(n[i], 0, n_win_w).c_str()) == OK); + r = mvwprintw(n_win_, i+1, 1, std::string(n[i], 0, n_win_w).c_str()); + assert(r == OK); const std::vector& n_of_n = graph_.neighboursOf(n[i]); - const std::string n_of_n_string = toCommaSeparatedList(n_of_n); + const std::string n_of_n_string = toCommaSeparatedList(n_of_n, current); const size_t n_of_n_win__w = std::min(n_of_n_string.length(), n_of_n_width-1); - assert(mvwprintw(n_of_n_win_, i+1, 2, - std::string(n_of_n_string, 0, n_of_n_win__w).c_str()) == OK); + r = mvwprintw(n_of_n_win_, i+1, 2, + std::string(n_of_n_string, 0, n_of_n_win__w).c_str()); + assert(r == OK); } } - assert(wrefresh(n_win_) == E_OK); - assert(wrefresh(n_of_n_win_) == E_OK); + r = wrefresh(n_win_); + assert(r == E_OK); + r = wrefresh(n_of_n_win_); + assert(r == E_OK); } void GraphBrowser::addItems(const std::vector& stringVector, bool first_run) { + int r; + // keep pointed to deallocate old items ITEM** old_items = menu_items(menu_); const int old_items_count = item_count(menu_); if (old_items_count > 0) { - const int u = unpost_menu(menu_); - assert (u == E_OK || first_run && u == E_NOT_POSTED); + r = unpost_menu(menu_); + assert (r == E_OK || first_run && r == E_NOT_POSTED); } const int number_of_new_items = stringVector.size(); @@ -333,17 +378,23 @@ void GraphBrowser::addItems(const std::vector& stringVector, bool f } new_items[number_of_new_items] = 0; // terminating empty item } - assert(set_menu_items(menu_, new_items) == E_OK); + r = set_menu_items(menu_, new_items); + assert(r == E_OK); if (number_of_new_items > 0) { - assert(set_menu_format(menu_, window_height-2, 1) == E_OK); - assert(post_menu(menu_) == E_OK); + r = set_menu_format(menu_, window_height-2, 1); + assert(r == E_OK); + r = post_menu(menu_); + assert(r == E_OK); } - assert(wrefresh(current_win_) == OK); + r = wrefresh(current_win_); + assert(r == OK); // deallocate old items - for (int i = 0; i < old_items_count; ++i) - assert(free_item(old_items[i]) == E_OK); + for (int i = 0; i < old_items_count; ++i) { + r = free_item(old_items[i]); + assert(r == E_OK); + } } void GraphBrowser::updateDimensions()