assert everything, with everyone

master
denes 8 years ago
parent 9b5f74da21
commit ad5e9aa91d
Signed by: denes
GPG Key ID: A7D50EAD42F9FC9F

@ -54,15 +54,14 @@ namespace {
void GraphBrowser::init() void GraphBrowser::init()
{ {
initscr(); assert(initscr());
cbreak(); assert(cbreak() == OK);
noecho(); assert(noecho() == OK);
keypad(stdscr, TRUE); assert(keypad(stdscr, TRUE) == OK);
//Needed to have immediate ESC-Key behavior: //Needed to have immediate ESC-Key behavior:
if (getenv ("ESCDELAY") == NULL) { if (getenv ("ESCDELAY") == NULL)
set_escdelay(25); assert(set_escdelay(25) == OK);
}
} }
void GraphBrowser::destroy() void GraphBrowser::destroy()
@ -75,7 +74,8 @@ void GraphBrowser::destroy()
GraphBrowser::GraphBrowser(Graph<std::string>& g) GraphBrowser::GraphBrowser(Graph<std::string>& g)
: menu_(0) : menu_(0)
, current_win_(0) , current_win_(0)
, n_win(0) , menu_subwindow_(0)
, n_win_(0)
, n_of_n_win_(0) , n_of_n_win_(0)
, graph_(g) , graph_(g)
, history_() , history_()
@ -88,52 +88,71 @@ void GraphBrowser::initLayout()
{ {
// window of the current node // window of the current node
menu_ = new_menu((ITEM **)0); menu_ = new_menu((ITEM **)0);
assert(menu_);
current_win_ = newwin(window_height, current_window_width, 1, 0); current_win_ = newwin(window_height, current_window_width, 1, 0);
keypad(current_win_, TRUE); assert(current_win_);
assert(keypad(current_win_, TRUE) == OK);
set_menu_win(menu_, current_win_);
set_menu_sub(menu_, derwin(current_win_, window_height-2, current_window_width-2, 1, 1)); assert(set_menu_win(menu_, current_win_) == E_OK);
set_menu_format(menu_, window_height-2, 1); menu_subwindow_ = derwin(current_win_, window_height-2, current_window_width-2, 1, 1);
assert(menu_subwindow_);
set_menu_mark(menu_, " "); assert(set_menu_sub(menu_, menu_subwindow_) == E_OK);
const int r = set_menu_format(menu_, window_height-2, 1);
wborder(current_win_, ACS_VLINE, ACS_VLINE, ACS_HLINE, ACS_HLINE, assert(set_menu_mark(menu_, " ") == E_OK);
ACS_ULCORNER, ACS_TTEE, ACS_LLCORNER, ACS_BTEE);
post_menu(menu_); assert(wborder(current_win_,
refresh(); ACS_VLINE, ACS_VLINE, ACS_HLINE, ACS_HLINE,
wrefresh(current_win_); ACS_ULCORNER, ACS_TTEE, ACS_LLCORNER, ACS_BTEE) == OK);
assert(refresh() == OK);
assert(wrefresh(current_win_) == OK);
n_win = newwin(window_height, n_window_width, 1, current_window_width); n_win_ = newwin(window_height, n_window_width, 1, current_window_width);
wborder(n_win, ' ', ' ', ACS_HLINE, ACS_HLINE, assert(n_win_);
ACS_HLINE, ACS_HLINE, ACS_HLINE, ACS_HLINE); assert(wborder(n_win_,
refresh(); ' ', ' ', ACS_HLINE, ACS_HLINE,
wrefresh(n_win); ACS_HLINE, ACS_HLINE, ACS_HLINE, ACS_HLINE) == OK);
assert(refresh() == OK);
assert(wrefresh(n_win_) == OK);
// window of the neighbours'neighbours of the current vertex // 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, n_of_n_win_ = newwin(window_height, term_max_x_-current_window_width-n_window_width,
1, n_window_width+current_window_width); 1, n_window_width+current_window_width);
wborder(n_of_n_win_, ACS_VLINE, ACS_VLINE, ACS_HLINE, ACS_HLINE, assert(n_of_n_win_);
ACS_TTEE, ACS_URCORNER, ACS_BTEE, ACS_LRCORNER); assert(wborder(n_of_n_win_,
refresh(); ACS_VLINE, ACS_VLINE, ACS_HLINE, ACS_HLINE,
wrefresh(n_of_n_win_); ACS_TTEE, ACS_URCORNER, ACS_BTEE, ACS_LRCORNER) == OK);
assert(refresh() == OK);
assert(wrefresh(n_of_n_win_) == OK);
// bottom text // 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"); mvprintw(term_max_y_-1, 0, "ESC:exit, cursors:navigate, d/i:del/ins edge, D/I:del/ins node");
refresh(); assert(refresh() == OK);
} }
void GraphBrowser::cleanUp()
GraphBrowser::~GraphBrowser()
{ {
unpost_menu(menu_); assert(endwin() == OK);
free_menu(menu_); assert(refresh() == OK);
const int number_of_items = item_count(menu_); assert(clear() == OK);
ITEM** old_items = menu_items(menu_); ITEM** old_items = menu_items(menu_);
for(int i = 0; i < number_of_items; ++i) const int old_items_count = item_count(menu_);
free_item(old_items[i]); 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);
}
/// @todo delete windows and windows' subwindows GraphBrowser::~GraphBrowser()
{
cleanUp();
} }
void GraphBrowser::mainLoop() void GraphBrowser::mainLoop()
@ -236,19 +255,19 @@ void GraphBrowser::deleteElement(bool delete_node)
void GraphBrowser::setStartVertex(const std::string& s) void GraphBrowser::setStartVertex(const std::string& s)
{ {
history_.push_back(s); history_.push_back(s);
updateCurrent(s); updateCurrent(s, true);
updateNeighbours(); updateNeighbours();
} }
void GraphBrowser::updateCurrent(const std::string& s) void GraphBrowser::updateCurrent(const std::string& s, bool first_run)
{ {
const std::vector<std::string>& n = graph_.neighboursOf(s); const std::vector<std::string>& n = graph_.neighboursOf(s);
addItems(n); addItems(n, first_run);
updateNeighbours(); updateNeighbours();
mvprintw(0, 0, "%s",std::string(term_max_x_,' ').c_str()); assert(mvprintw(0, 0, "%s",std::string(term_max_x_,' ').c_str()) == OK);
mvprintw(0, 0, historyToString(history_, term_max_x_).c_str()); assert(mvprintw(0, 0, historyToString(history_, term_max_x_).c_str()) == OK);
refresh(); refresh();
} }
@ -258,8 +277,8 @@ void GraphBrowser::updateNeighbours()
const size_t n_width = n_window_width-1; 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; 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) { for (int i = 1; i < window_height-1; ++i) {
mvwprintw(n_win, i, 1, "%s", std::string(n_width,' ').c_str()); assert(mvwprintw(n_win_, i, 1, "%s", std::string(n_width,' ').c_str()) == OK);
mvwprintw(n_of_n_win_, i, 1, "%s", std::string(n_of_n_width,' ').c_str()); assert(mvwprintw(n_of_n_win_, i, 1, "%s", std::string(n_of_n_width,' ').c_str()) == OK);
} }
ITEM* c_item = current_item(menu_); ITEM* c_item = current_item(menu_);
@ -268,28 +287,28 @@ void GraphBrowser::updateNeighbours()
const std::vector<std::string>& n = graph_.neighboursOf(current); const std::vector<std::string>& n = graph_.neighboursOf(current);
for (size_t i = 0; i < n.size() && i < window_height-2; ++i) { 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); const size_t n_win_w = std::min(n[i].length(), n_width);
mvwprintw(n_win, i+1, 1, std::string(n[i], 0, n_win_w).c_str()); assert(mvwprintw(n_win_, i+1, 1, std::string(n[i], 0, n_win_w).c_str()) == OK);
const std::vector<std::string>& n_of_n = graph_.neighboursOf(n[i]); const std::vector<std::string>& 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);
const size_t n_of_n_win__w = std::min(n_of_n_string.length(), n_of_n_width-1); const size_t n_of_n_win__w = std::min(n_of_n_string.length(), n_of_n_width-1);
mvwprintw(n_of_n_win_, i+1, 2, assert(mvwprintw(n_of_n_win_, i+1, 2,
std::string(n_of_n_string, 0, n_of_n_win__w).c_str()); std::string(n_of_n_string, 0, n_of_n_win__w).c_str()) == OK);
} }
} }
assert(wrefresh(n_win) == E_OK); assert(wrefresh(n_win_) == E_OK);
assert(wrefresh(n_of_n_win_) == E_OK); assert(wrefresh(n_of_n_win_) == E_OK);
} }
void GraphBrowser::addItems(const std::vector<std::string>& stringVector) void GraphBrowser::addItems(const std::vector<std::string>& stringVector, bool first_run)
{ {
// keep pointed to deallocate old items // keep pointed to deallocate old items
ITEM** old_items = menu_items(menu_); ITEM** old_items = menu_items(menu_);
const int old_items_count = item_count(menu_); const int old_items_count = item_count(menu_);
const int u = unpost_menu(menu_); const int u = unpost_menu(menu_);
assert (u == E_OK || u == E_NOT_POSTED); assert (u == E_OK || first_run && u == E_NOT_POSTED);
const int number_of_new_items = stringVector.size(); const int number_of_new_items = stringVector.size();
ITEM** new_items = 0; ITEM** new_items = 0;
@ -325,16 +344,8 @@ void GraphBrowser::updateDimensions()
void GraphBrowser::terminalResizedEvent(int) void GraphBrowser::terminalResizedEvent(int)
{ {
endwin(); cleanUp();
refresh();
clear();
free_menu(menu_);
delwin(current_win_);
delwin(n_win);
delwin(n_of_n_win_);
updateDimensions(); updateDimensions();
initLayout(); initLayout();
updateCurrent(history_.back()); updateCurrent(history_.back(), true);
} }

@ -37,15 +37,15 @@ public:
private: private:
void initLayout(); void initLayout();
void updateCurrent(const std::string& s); void cleanUp();
void updateCurrent(const std::string& s, bool first_run = false);
void updateNeighbours(); void updateNeighbours();
void addItems(const std::vector<std::string>& stringVector); void addItems(const std::vector<std::string>& stringVector, bool first_run);
void deleteElement(bool delete_node); void deleteElement(bool delete_node);
void updateDimensions(); void updateDimensions();
MENU *menu_; MENU *menu_;
WINDOW *current_win_, *n_win, * n_of_n_win_; WINDOW *current_win_, *menu_subwindow_, *n_win_, * n_of_n_win_;
// ITEM **items_;
Graph<std::string>& graph_; Graph<std::string>& graph_;
std::deque<std::string> history_; std::deque<std::string> history_;

@ -7,8 +7,6 @@
#include "graph_browser.hpp" #include "graph_browser.hpp"
using namespace std::placeholders;
std::string generateRandomString(size_t length) std::string generateRandomString(size_t length)
{ {
const char charset[] = const char charset[] =
@ -55,11 +53,11 @@ Graph<std::string> generateRandomGraph(size_t number_of_vertices,
return graph; return graph;
} }
std::function<void(int)> callback_function; std::function<void(int)> callback_wrapper;
void CallCb( int value ) void callback_function( int value )
{ {
callback_function(value); callback_wrapper(value);
} }
int main(int argc, char* argv[]) int main(int argc, char* argv[])
@ -67,17 +65,19 @@ int main(int argc, char* argv[])
Graph<std::string> g = generateRandomGraph(10, 200, 5, 20); Graph<std::string> g = generateRandomGraph(10, 200, 5, 20);
GraphBrowser::init(); GraphBrowser::init();
{
GraphBrowser gb(g); GraphBrowser gb(g);
gb.setStartVertex(*g.begin()); gb.setStartVertex(*g.begin());
callback_function = std::bind1st(std::mem_fun(&GraphBrowser::terminalResizedEvent), &gb); callback_wrapper = std::bind(&GraphBrowser::terminalResizedEvent,
&gb,
struct sigaction act; std::placeholders::_1);
act.sa_handler = CallCb; struct sigaction act;
sigaction(SIGWINCH, &act, NULL); act.sa_handler = callback_function;
sigaction(SIGWINCH, &act, NULL);
gb.mainLoop();
gb.mainLoop();
}
GraphBrowser::destroy(); GraphBrowser::destroy();
return EXIT_SUCCESS; return EXIT_SUCCESS;

Loading…
Cancel
Save