X-Git-Url: https://git.siccegge.de//index.cgi?p=frida%2Ffrida.git;a=blobdiff_plain;f=src%2Fgui%2FMainwindow.cxx;h=1add669e55c6f32c3174f74e45123f71e746aa4c;hp=adadc0686a9a600d70f99b2e85dc9aae523a2499;hb=f9d8bd4a0312a92a1ec3493e83996c0a99d8d1bf;hpb=1b43b26ba9b23cb5f3004db7b9b00f6b08227563 diff --git a/src/gui/Mainwindow.cxx b/src/gui/Mainwindow.cxx index adadc06..1add669 100644 --- a/src/gui/Mainwindow.cxx +++ b/src/gui/Mainwindow.cxx @@ -87,19 +87,16 @@ Mainwindow::Mainwindow(InformationManager* mgr) setWindowTitle(tr("FRIDA")); - QTreeWidgetItem * external = new QTreeWidgetItem(listWidget, QStringList("External Functions")); + external = new QTreeWidgetItem(listWidget, QStringList("External Functions")); external->setChildIndicatorPolicy(QTreeWidgetItem::ShowIndicator); external->setBackground(0, QBrush(QColor(0xff, 0xdd, 0xdd))); - connect(mgr, &InformationManager::newFunctionEvent, - [=] (NewFunctionEvent* event) { - std::string name = event->function->getName(); - if (event->function->isDynamic()) { - auto item = new QTreeWidgetItem(external, QStringList(name.c_str())); - item->setBackground(0, QBrush(QColor(0xff, 0xdd, 0xdd))); - } else { - addFunction(event->function); - } + connect(mgr, &InformationManager::resetEvent, + [this,mgr]() { + connect(this, SIGNAL(requestNewFunctionByAddress(uint64_t)), + mgr->getDisassembler(), SLOT(disassembleFunctionAt(uint64_t))); }); + connect(mgr, &InformationManager::newFunctionEvent, + this, &Mainwindow::handleNewFunctionEvent); connect(mgr, &InformationManager::renameFunctionEvent, [&](RenameFunctionEvent* event) { if (objects_list_by_address.find(event->address) == objects_list_by_address.end()) @@ -121,6 +118,16 @@ void Mainwindow::setGlobalHotkeys() { }); } +void Mainwindow::handleNewFunctionEvent(NewFunctionEvent event) { + std::string name = event.function->getName(); + if (event.function->isDynamic()) { + auto item = new QTreeWidgetItem(external, QStringList(name.c_str())); + item->setBackground(0, QBrush(QColor(0xff, 0xdd, 0xdd))); + } else { + addFunction(event.function); + } +} + void Mainwindow::quit() { QMessageBox messageBox; @@ -220,7 +227,7 @@ void Mainwindow::requestNewFunction() { NewFunctionDialog dialog; int result = dialog.exec(); if (QDialog::Accepted == result) { - requestNewFunctionByAddress(dialog.result()); + emit requestNewFunctionByAddress(dialog.result()); } else { LOG4CXX_DEBUG(logger, "requestNewFunction aborted"); } @@ -238,12 +245,6 @@ void Mainwindow::requestNewGroup() { } } -void Mainwindow::requestNewFunctionByAddress(uint64_t address) { - LOG4CXX_DEBUG(logger, "requesting Function at " << std::hex << address); - manager->getDisassembler()->disassembleFunctionAt(address); - switchMainPlaneToAddress(address); -} - void Mainwindow::renameFunction(Function* function) { SimpleStringDialog dialog("New name"); int result = dialog.exec();