]> git.siccegge.de Git - frida/frida.git/blobdiff - src/gui/Mainwindow.cxx
Renaming functions
[frida/frida.git] / src / gui / Mainwindow.cxx
index 0f2486ddc13e2ed82227107d0f791368f82bb8b6..611f3da62822307dc1043944f944f6a079a60ed0 100644 (file)
@@ -4,6 +4,7 @@
 
 #include "widgets/CFGScene.hxx"
 #include "dialogs/NewFunctionDialog.hxx"
+#include "dialogs/RenameFunctionDialog.hxx"
 
 #include <sstream>
 
@@ -99,15 +100,15 @@ void Mainwindow::switchMainPlane(int index) {
 
 void Mainwindow::showListContextMenu(const QPoint& point) {
        QListWidgetItem * item = listWidget->itemAt(point);
+       QMenu menu(this);
        if (item) {
-               LOG4CXX_DEBUG(logger, "WOHO " << item->text().toStdString());
+               QAction * act = menu.addAction("Rename Function");
+               connect(act, &QAction::triggered, [=]() {this->renameFunction(item);});
        } else {
-               QMenu menu(this);
                QAction * act = menu.addAction("AddFunction");
                connect(act, SIGNAL(triggered()), this, SLOT(requestNewFunction()));
-
-               menu.exec(listWidget->mapToGlobal(point));
        }
+       menu.exec(listWidget->mapToGlobal(point));
 }
 
 void Mainwindow::requestNewFunction() {
@@ -121,6 +122,18 @@ void Mainwindow::requestNewFunction() {
        }
 }
 
+void Mainwindow::renameFunction(QListWidgetItem * item) {
+       RenameFunctionDialog dialog;
+       int result = dialog.exec();
+       if (QDialog::Accepted == result) {
+               LOG4CXX_DEBUG(logger, "renaming Function" << item->text().toStdString()
+                             << " to " << dialog.result().toStdString());
+               item->setText(dialog.result());
+       } else {
+               LOG4CXX_DEBUG(logger, "renameFunction aborted");
+       }
+}
+
 void Mainwindow::addFunction(Function* fun) {
        if (functions.find(fun) != functions.end())
                return;