X-Git-Url: https://git.siccegge.de//index.cgi?a=blobdiff_plain;f=src%2Fgui%2Fwidgets%2FFunctionWidget.cxx;h=0d931adc202b29d049baadfbdc5e13db856be56d;hb=1975fc2d8d5f1a2a7bf71717c0ca7cef6dd57566;hp=ba96e5d4af18fe3732de18e9c9e9ef6a0f9e8b3c;hpb=cab6494b97d1626c7b9285b69df324d9c9953614;p=frida%2Ffrida.git diff --git a/src/gui/widgets/FunctionWidget.cxx b/src/gui/widgets/FunctionWidget.cxx index ba96e5d..0d931ad 100644 --- a/src/gui/widgets/FunctionWidget.cxx +++ b/src/gui/widgets/FunctionWidget.cxx @@ -18,41 +18,46 @@ namespace { FunctionWidget::FunctionWidget(Function* function, Mainwindow* mainwindow) : function(function) , mainwindow(mainwindow) + , layouted(false) , logger(log4cxx::Logger::getLogger("gui.Mainwindow")) { - // CFG - CFGScene * scene = new CFGScene; - InformationManager* manager = function->getManager(); - - BasicBlock * block = manager->getBasicBlock(function->getStartAddress()); - LOG4CXX_DEBUG(logger, "Building widget for functionction " << function->getName()); - for (auto i : function->blocks()) { - LOG4CXX_DEBUG(logger, "Functionction contains Block " << i.second->getName()); - } - - uint64_t start_address(std::numeric_limits::max()); - for (auto b : function->blocks()) { - if (b.first < start_address) - start_address = b.first; - } +} - std::map _blocks; - local__add_basic_block(block, mainwindow, - manager, _blocks, scene, start_address, 100); +void FunctionWidget::showEvent(QShowEvent* event) { + if (!layouted) { + CFGScene * scene = new CFGScene; + InformationManager* manager = function->getManager(); - QGraphicsView * view = new QGraphicsView(scene); - addTab(view, "CFG"); + BasicBlock * block = manager->getBasicBlock(function->getStartAddress()); + LOG4CXX_DEBUG(logger, "Building widget for functionction " << function->getName()); + for (auto i : function->blocks()) { + LOG4CXX_DEBUG(logger, "Functionction contains Block " << i.second->getName()); + } - // Listing - QTableWidget * t = new QTableWidget(); - t->setColumnCount(3); - t->horizontalHeader()->setSectionResizeMode(QHeaderView::ResizeToContents); + uint64_t start_address(std::numeric_limits::max()); + for (auto b : function->blocks()) { + if (b.first < start_address) + start_address = b.first; + } - addTab(t, "Listing"); -} + std::map _blocks; + BasicBlockWidget* firstblock = local__add_basic_block(block, mainwindow, + manager, _blocks, scene, 3*start_address, 100); + QGraphicsView * view = new QGraphicsView(scene); + view->setDragMode(QGraphicsView::ScrollHandDrag); + addTab(view, "CFG"); + // Listing + QTableWidget * t = new QTableWidget(); + t->setColumnCount(3); + t->horizontalHeader()->setSectionResizeMode(QHeaderView::ResizeToContents); + addTab(t, "Listing"); + view->ensureVisible(firstblock); + layouted = true; + } +} namespace { BasicBlockWidget * @@ -62,6 +67,7 @@ namespace { CFGScene * scene, uint64_t starty, uint64_t startx) { decltype(known_blocks.begin()) old; + if (!block) return NULL; if ((old = known_blocks.find(block->getStartAddress())) != known_blocks.end()) return old->second; @@ -75,19 +81,7 @@ namespace { scene->addItem(widget); widget->setFlag(QGraphicsItem::ItemIsMovable, true); - widget->moveBy(100*startx, block->getStartAddress() - starty); - - manager->getDisassembler() - ->printEachInstruction(block->getStartAddress(), - block->getEndAddress(), - [&](uint8_t* bytes, - size_t byte_count, - const std::string& line, - const std::string& ref) { - widget->addItem(bytes, byte_count, - line.c_str() + 1, // remove \t - ref.c_str()); - }); + widget->moveBy(100*startx, 3*block->getStartAddress() - starty); BasicBlockWidget *tmp, *nextl(NULL), *nextr(NULL); BasicBlock * tmpblock;