mirror of
https://github.com/rizinorg/cutter.git
synced 2024-12-20 20:06:12 +00:00
Adapt MainWindow to refactored widgets
- Use new DockWidget interface as much as possible - Remove unused/unneeded code - Make more members private
This commit is contained in:
parent
6f2607fc3c
commit
9931d6f484
@ -30,6 +30,36 @@
|
|||||||
#include <QMessageBox>
|
#include <QMessageBox>
|
||||||
#include <QStyleFactory>
|
#include <QStyleFactory>
|
||||||
|
|
||||||
|
#include <QLabel>
|
||||||
|
#include <QComboBox>
|
||||||
|
#include <QTreeWidgetItem>
|
||||||
|
#include <QDockWidget>
|
||||||
|
#include <QLineEdit>
|
||||||
|
#include <QSettings>
|
||||||
|
#include <QList>
|
||||||
|
|
||||||
|
#include "highlighter.h"
|
||||||
|
#include "hexascii_highlighter.h"
|
||||||
|
#include "newfiledialog.h"
|
||||||
|
#include "helpers.h"
|
||||||
|
|
||||||
|
#include "widgets/memorywidget.h"
|
||||||
|
#include "widgets/functionswidget.h"
|
||||||
|
#include "widgets/sectionswidget.h"
|
||||||
|
#include "widgets/commentswidget.h"
|
||||||
|
#include "widgets/importswidget.h"
|
||||||
|
#include "widgets/symbolswidget.h"
|
||||||
|
#include "widgets/stringswidget.h"
|
||||||
|
#include "widgets/sectionsdock.h"
|
||||||
|
#include "widgets/relocswidget.h"
|
||||||
|
#include "widgets/flagswidget.h"
|
||||||
|
#include "widgets/codegraphic.h"
|
||||||
|
#include "widgets/dashboard.h"
|
||||||
|
#include "widgets/notepad.h"
|
||||||
|
#include "widgets/sidebar.h"
|
||||||
|
#include "widgets/sdbdock.h"
|
||||||
|
#include "widgets/omnibar.h"
|
||||||
|
|
||||||
// graphics
|
// graphics
|
||||||
#include <QGraphicsEllipseItem>
|
#include <QGraphicsEllipseItem>
|
||||||
#include <QGraphicsScene>
|
#include <QGraphicsScene>
|
||||||
@ -52,11 +82,11 @@ static void registerCustomFonts()
|
|||||||
MainWindow::MainWindow(QWidget *parent, QRCore *kore) :
|
MainWindow::MainWindow(QWidget *parent, QRCore *kore) :
|
||||||
QMainWindow(parent),
|
QMainWindow(parent),
|
||||||
core(kore),
|
core(kore),
|
||||||
|
memoryDock(nullptr),
|
||||||
|
notepadDock(nullptr),
|
||||||
asmDock(nullptr),
|
asmDock(nullptr),
|
||||||
calcDock(nullptr),
|
calcDock(nullptr),
|
||||||
omnibar(nullptr),
|
omnibar(nullptr),
|
||||||
memoryDock(nullptr),
|
|
||||||
notepadDock(nullptr),
|
|
||||||
sideBar(nullptr),
|
sideBar(nullptr),
|
||||||
ui(new Ui::MainWindow),
|
ui(new Ui::MainWindow),
|
||||||
highlighter(nullptr),
|
highlighter(nullptr),
|
||||||
@ -153,42 +183,55 @@ MainWindow::MainWindow(QWidget *parent, QRCore *kore) :
|
|||||||
* Dock Widgets
|
* Dock Widgets
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
dockWidgets.reserve(11);
|
||||||
|
|
||||||
// Add Memory DockWidget
|
// Add Memory DockWidget
|
||||||
this->memoryDock = new MemoryWidget(this);
|
this->memoryDock = new MemoryWidget(this);
|
||||||
this->dockList << this->memoryDock;
|
dockWidgets.push_back(memoryDock);
|
||||||
// To use in the future when we handle more than one memory views
|
// To use in the future when we handle more than one memory views
|
||||||
// this->memoryDock->setAttribute(Qt::WA_DeleteOnClose);
|
// this->memoryDock->setAttribute(Qt::WA_DeleteOnClose);
|
||||||
// this->add_debug_output( QString::number(this->dockList.length()) );
|
// this->add_debug_output( QString::number(this->dockList.length()) );
|
||||||
|
|
||||||
// Add Sections dock panel
|
// Add Sections dock panel
|
||||||
this->sectionsDock = new SectionsDock(this);
|
this->sectionsDock = new SectionsDock(this);
|
||||||
|
dockWidgets.push_back(sectionsDock);
|
||||||
|
|
||||||
// Add functions DockWidget
|
// Add functions DockWidget
|
||||||
this->functionsDock = new FunctionsWidget(this);
|
this->functionsDock = new FunctionsWidget(this);
|
||||||
|
dockWidgets.push_back(functionsDock);
|
||||||
|
|
||||||
// Add imports DockWidget
|
// Add imports DockWidget
|
||||||
this->importsDock = new ImportsWidget(this);
|
this->importsDock = new ImportsWidget(this);
|
||||||
|
dockWidgets.push_back(importsDock);
|
||||||
|
|
||||||
// Add symbols DockWidget
|
// Add symbols DockWidget
|
||||||
this->symbolsDock = new SymbolsWidget(this);
|
this->symbolsDock = new SymbolsWidget(this);
|
||||||
|
dockWidgets.push_back(symbolsDock);
|
||||||
|
|
||||||
// Add relocs DockWidget
|
// Add relocs DockWidget
|
||||||
this->relocsDock = new RelocsWidget(this);
|
this->relocsDock = new RelocsWidget(this);
|
||||||
|
dockWidgets.push_back(relocsDock);
|
||||||
|
|
||||||
// Add comments DockWidget
|
// Add comments DockWidget
|
||||||
this->commentsDock = new CommentsWidget(this);
|
this->commentsDock = new CommentsWidget(this);
|
||||||
|
dockWidgets.push_back(commentsDock);
|
||||||
|
|
||||||
// Add strings DockWidget
|
// Add strings DockWidget
|
||||||
this->stringsDock = new StringsWidget(this);
|
this->stringsDock = new StringsWidget(this);
|
||||||
|
dockWidgets.push_back(stringsDock);
|
||||||
|
|
||||||
// Add flags DockWidget
|
// Add flags DockWidget
|
||||||
this->flagsDock = new FlagsWidget(this);
|
this->flagsDock = new FlagsWidget(this);
|
||||||
|
dockWidgets.push_back(flagsDock);
|
||||||
|
|
||||||
// Add Notepad Dock panel
|
// Add Notepad Dock panel
|
||||||
this->notepadDock = new Notepad(this);
|
this->notepadDock = new Notepad(this);
|
||||||
|
dockWidgets.push_back(notepadDock);
|
||||||
|
connect(memoryDock, SIGNAL(fontChanged(QFont)), notepadDock, SLOT(setFonts(QFont)));
|
||||||
|
|
||||||
//Add Dashboard Dock panel
|
//Add Dashboard Dock panel
|
||||||
this->dashboardDock = new Dashboard(this);
|
this->dashboardDock = new Dashboard(this);
|
||||||
|
dockWidgets.push_back(dashboardDock);
|
||||||
|
|
||||||
// Set up dock widgets default layout
|
// Set up dock widgets default layout
|
||||||
restoreDocks();
|
restoreDocks();
|
||||||
@ -204,8 +247,6 @@ MainWindow::MainWindow(QWidget *parent, QRCore *kore) :
|
|||||||
setCorner(Qt::BottomLeftCorner, Qt::LeftDockWidgetArea);
|
setCorner(Qt::BottomLeftCorner, Qt::LeftDockWidgetArea);
|
||||||
//setCorner( Qt::BottomRightCorner, Qt::RightDockWidgetArea );
|
//setCorner( Qt::BottomRightCorner, Qt::RightDockWidgetArea );
|
||||||
|
|
||||||
this->flagsDock->flagsTreeWidget->clear();
|
|
||||||
|
|
||||||
// Set omnibar completer for flags
|
// Set omnibar completer for flags
|
||||||
this->omnibar->setupCompleter();
|
this->omnibar->setupCompleter();
|
||||||
|
|
||||||
@ -214,9 +255,6 @@ MainWindow::MainWindow(QWidget *parent, QRCore *kore) :
|
|||||||
connect(ui->consoleOutputTextEdit, SIGNAL(customContextMenuRequested(const QPoint &)),
|
connect(ui->consoleOutputTextEdit, SIGNAL(customContextMenuRequested(const QPoint &)),
|
||||||
this, SLOT(showConsoleContextMenu(const QPoint &)));
|
this, SLOT(showConsoleContextMenu(const QPoint &)));
|
||||||
|
|
||||||
// Hide dummy columns so we can reorder the rest
|
|
||||||
hideDummyColumns();
|
|
||||||
|
|
||||||
// Setup and hide sidebar by default
|
// Setup and hide sidebar by default
|
||||||
this->sideBar = new SideBar(this);
|
this->sideBar = new SideBar(this);
|
||||||
this->sidebar_action = ui->sideToolBar->addWidget(this->sideBar);
|
this->sidebar_action = ui->sideToolBar->addWidget(this->sideBar);
|
||||||
@ -271,34 +309,6 @@ void MainWindow::webserverThreadFinished()
|
|||||||
//}
|
//}
|
||||||
}
|
}
|
||||||
|
|
||||||
void MainWindow::adjustColumns(QTreeWidget *tw)
|
|
||||||
{
|
|
||||||
int count = tw->columnCount();
|
|
||||||
for (int i = 0; i != count; ++i)
|
|
||||||
{
|
|
||||||
tw->resizeColumnToContents(i);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void MainWindow::appendRow(QTreeWidget *tw, const QString &str, const QString &str2,
|
|
||||||
const QString &str3, const QString &str4, const QString &str5)
|
|
||||||
{
|
|
||||||
QTreeWidgetItem *tempItem = new QTreeWidgetItem();
|
|
||||||
// Fill dummy hidden column
|
|
||||||
tempItem->setText(0, "0");
|
|
||||||
tempItem->setText(1, str);
|
|
||||||
if (!str2.isNull())
|
|
||||||
tempItem->setText(2, str2);
|
|
||||||
if (!str3.isNull())
|
|
||||||
tempItem->setText(3, str3);
|
|
||||||
if (!str4.isNull())
|
|
||||||
tempItem->setText(4, str4);
|
|
||||||
if (!str5.isNull())
|
|
||||||
tempItem->setText(5, str5);
|
|
||||||
|
|
||||||
tw->insertTopLevelItem(0, tempItem);
|
|
||||||
}
|
|
||||||
|
|
||||||
void MainWindow::setWebServerState(bool start)
|
void MainWindow::setWebServerState(bool start)
|
||||||
{
|
{
|
||||||
if (start)
|
if (start)
|
||||||
@ -316,21 +326,18 @@ void MainWindow::setWebServerState(bool start)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void MainWindow::hideDummyColumns()
|
void MainWindow::raiseMemoryDock()
|
||||||
{
|
{
|
||||||
// UGLY, should be a loop over all treewidgets...
|
memoryDock->raise();
|
||||||
this->functionsDock->functionsTreeWidget->setColumnHidden(0, true);
|
}
|
||||||
this->importsDock->importsTreeWidget->setColumnHidden(0, true);
|
|
||||||
this->symbolsDock->symbolsTreeWidget->setColumnHidden(0, true);
|
void MainWindow::toggleSideBarTheme()
|
||||||
this->relocsDock->relocsTreeWidget->setColumnHidden(0, true);
|
{
|
||||||
this->stringsDock->stringsTreeWidget->setColumnHidden(0, true);
|
sideBar->themesButtonToggle();
|
||||||
this->flagsDock->flagsTreeWidget->setColumnHidden(0, true);
|
|
||||||
this->commentsDock->commentsTreeWidget->setColumnHidden(0, true);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void MainWindow::setFilename(QString fn)
|
void MainWindow::setFilename(QString fn)
|
||||||
{
|
{
|
||||||
|
|
||||||
// Add file name to window title
|
// Add file name to window title
|
||||||
this->filename = fn;
|
this->filename = fn;
|
||||||
this->setWindowTitle("Iaito - " + fn);
|
this->setWindowTitle("Iaito - " + fn);
|
||||||
@ -364,7 +371,7 @@ void MainWindow::closeEvent(QCloseEvent *event)
|
|||||||
settings.setValue("pos", pos());
|
settings.setValue("pos", pos());
|
||||||
settings.setValue("state", saveState());
|
settings.setValue("state", saveState());
|
||||||
core->cmd("Ps " + qhelpers::uniqueProjectName(filename));
|
core->cmd("Ps " + qhelpers::uniqueProjectName(filename));
|
||||||
QString notes = this->notepadDock->notesTextEdit->toPlainText().toUtf8().toBase64();
|
QString notes = this->notepadDock->textToBase64();
|
||||||
//this->add_debug_output(notes);
|
//this->add_debug_output(notes);
|
||||||
this->core->cmd("Pnj " + notes);
|
this->core->cmd("Pnj " + notes);
|
||||||
QMainWindow::closeEvent(event);
|
QMainWindow::closeEvent(event);
|
||||||
@ -419,55 +426,12 @@ void MainWindow::def_theme()
|
|||||||
|
|
||||||
void MainWindow::refreshFunctions()
|
void MainWindow::refreshFunctions()
|
||||||
{
|
{
|
||||||
this->functionsDock->refreshTree();
|
functionsDock->refresh();
|
||||||
}
|
}
|
||||||
|
|
||||||
void MainWindow::refreshComments()
|
void MainWindow::refreshComments()
|
||||||
{
|
{
|
||||||
this->commentsDock->refreshTree();
|
commentsDock->refresh();
|
||||||
}
|
|
||||||
|
|
||||||
void MainWindow::refreshFlagspaces()
|
|
||||||
{
|
|
||||||
int cur_idx = this->flagsDock->flagspaceCombo->currentIndex();
|
|
||||||
if (cur_idx < 0)cur_idx = 0;
|
|
||||||
this->flagsDock->flagspaceCombo->clear();
|
|
||||||
this->flagsDock->flagspaceCombo->addItem("(all)");
|
|
||||||
for (auto i : core->getList("flagspaces"))
|
|
||||||
{
|
|
||||||
this->flagsDock->flagspaceCombo->addItem(i);
|
|
||||||
}
|
|
||||||
if (cur_idx > 0)
|
|
||||||
this->flagsDock->flagspaceCombo->setCurrentIndex(cur_idx);
|
|
||||||
refreshFlags();
|
|
||||||
}
|
|
||||||
|
|
||||||
void MainWindow::refreshFlags()
|
|
||||||
{
|
|
||||||
QString flagspace = this->flagsDock->flagspaceCombo->currentText();
|
|
||||||
this->omnibar->clearFlags();
|
|
||||||
if (flagspace == "(all)")
|
|
||||||
flagspace = "";
|
|
||||||
|
|
||||||
this->flagsDock->flagsTreeWidget->clear();
|
|
||||||
|
|
||||||
for (auto i : core->getList("flags", flagspace))
|
|
||||||
{
|
|
||||||
QStringList a = i.split(",");
|
|
||||||
if (a.length() > 3)
|
|
||||||
{
|
|
||||||
appendRow(this->flagsDock->flagsTreeWidget, a[1], a[2], a[0], a[3]);
|
|
||||||
this->omnibar->fillFlags(a[0]);
|
|
||||||
}
|
|
||||||
else if (a.length() > 2)
|
|
||||||
{
|
|
||||||
appendRow(this->flagsDock->flagsTreeWidget, a[1], a[2], a[0], "");
|
|
||||||
this->omnibar->fillFlags(a[0]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
adjustColumns(this->flagsDock->flagsTreeWidget);
|
|
||||||
// Set omnibar completer for flags and commands
|
|
||||||
this->omnibar->setupCompleter();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void MainWindow::updateFrames()
|
void MainWindow::updateFrames()
|
||||||
@ -476,167 +440,27 @@ void MainWindow::updateFrames()
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
static bool first_time = true;
|
static bool first_time = true;
|
||||||
|
|
||||||
if (first_time)
|
if (first_time)
|
||||||
{
|
{
|
||||||
setup_mem();
|
for (auto w : dockWidgets)
|
||||||
this->add_output(" > Adding binary information to notepad");
|
|
||||||
notepadDock->setText("# Binary information\n\n" + core->cmd("i") +
|
|
||||||
"\n" + core->cmd("ie") + "\n" + core->cmd("iM") + "\n");
|
|
||||||
//first_time = false;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
refreshMem();
|
|
||||||
}
|
|
||||||
|
|
||||||
refreshFlagspaces();
|
|
||||||
|
|
||||||
auto spi = QAbstractItemView::ScrollPerItem;
|
|
||||||
auto spp = QAbstractItemView::ScrollPerPixel;
|
|
||||||
|
|
||||||
// TODO: make this configurable by the user?
|
|
||||||
const bool use_scrollperpixel = true;
|
|
||||||
if (use_scrollperpixel)
|
|
||||||
{
|
|
||||||
this->flagsDock->flagsTreeWidget->setVerticalScrollMode(spp);
|
|
||||||
this->symbolsDock->symbolsTreeWidget->setVerticalScrollMode(spp);
|
|
||||||
this->importsDock->importsTreeWidget->setVerticalScrollMode(spp);
|
|
||||||
this->functionsDock->functionsTreeWidget->setVerticalScrollMode(spp);
|
|
||||||
this->stringsDock->stringsTreeWidget->setVerticalScrollMode(spp);
|
|
||||||
this->relocsDock->relocsTreeWidget->setVerticalScrollMode(spp);
|
|
||||||
this->memoryDock->xreFromTreeWidget_2->setVerticalScrollMode(spp);
|
|
||||||
this->memoryDock->xrefToTreeWidget_2->setVerticalScrollMode(spp);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
this->flagsDock->flagsTreeWidget->setVerticalScrollMode(spi);
|
|
||||||
this->symbolsDock->symbolsTreeWidget->setVerticalScrollMode(spi);
|
|
||||||
this->importsDock->importsTreeWidget->setVerticalScrollMode(spi);
|
|
||||||
this->functionsDock->functionsTreeWidget->setVerticalScrollMode(spi);
|
|
||||||
this->stringsDock->stringsTreeWidget->setVerticalScrollMode(spi);
|
|
||||||
this->relocsDock->relocsTreeWidget->setVerticalScrollMode(spi);
|
|
||||||
this->memoryDock->xreFromTreeWidget_2->setVerticalScrollMode(spi);
|
|
||||||
this->memoryDock->xrefToTreeWidget_2->setVerticalScrollMode(spi);
|
|
||||||
}
|
|
||||||
|
|
||||||
this->functionsDock->fillFunctions();
|
|
||||||
|
|
||||||
this->importsDock->fillImports();
|
|
||||||
|
|
||||||
// FIXME, doesn't work bc it sorts strings, not numbers... sigh
|
|
||||||
/*
|
|
||||||
Use QListWidgetItem::setData() not the constructor to set your value. Then all will work like you expect it to work.
|
|
||||||
|
|
||||||
int yourIntValue = 123456;
|
|
||||||
QListWidgetItem *item = new QListWidgetItem;
|
|
||||||
item->setData(Qt::DisplayRole, yourIntValue);
|
|
||||||
*/
|
|
||||||
//this->importsDock->importsTreeWidget->sortByColumn(1, Qt::DescendingOrder);
|
|
||||||
|
|
||||||
adjustColumns(this->importsDock->importsTreeWidget);
|
|
||||||
|
|
||||||
this->relocsDock->relocsTreeWidget->clear();
|
|
||||||
for (auto i : core->getList("bin", "relocs"))
|
|
||||||
{
|
|
||||||
QStringList pieces = i.split(",");
|
|
||||||
if (pieces.length() == 3)
|
|
||||||
appendRow(this->relocsDock->relocsTreeWidget, pieces[0], pieces[1], pieces[2]);
|
|
||||||
}
|
|
||||||
adjustColumns(this->relocsDock->relocsTreeWidget);
|
|
||||||
|
|
||||||
this->symbolsDock->fillSymbols();
|
|
||||||
|
|
||||||
this->stringsDock->stringsTreeWidget->clear();
|
|
||||||
for (auto i : core->getList("bin", "strings"))
|
|
||||||
{
|
|
||||||
QStringList pieces = i.split(",");
|
|
||||||
if (pieces.length() == 2)
|
|
||||||
appendRow(this->stringsDock->stringsTreeWidget, pieces[0], pieces[1]);
|
|
||||||
}
|
|
||||||
adjustColumns(this->stringsDock->stringsTreeWidget);
|
|
||||||
|
|
||||||
this->commentsDock->commentsTreeWidget->clear();
|
|
||||||
QList<QList<QString>> comments = this->core->getComments();
|
|
||||||
for (QList<QString> comment : comments)
|
|
||||||
{
|
|
||||||
/*
|
|
||||||
QString name;
|
|
||||||
//this->add_debug_output("Comment: " + comment[1] + ": " + comment[0]);
|
|
||||||
RAnalFunction *fcn = this->core->functionAt(comment[1].toLongLong(0, 16));
|
|
||||||
if (fcn != NULL) {
|
|
||||||
name = fcn->name;
|
|
||||||
} else {
|
|
||||||
name = "";
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
QString fcn_name = this->core->cmdFunctionAt(comment[1]);
|
|
||||||
appendRow(this->commentsDock->commentsTreeWidget, comment[1], fcn_name, comment[0].remove('"'));
|
|
||||||
}
|
|
||||||
adjustColumns(this->commentsDock->commentsTreeWidget);
|
|
||||||
|
|
||||||
// Add nested comments
|
|
||||||
QMap<QString, QList<QList<QString>>> cmts = this->core->getNestedComments();
|
|
||||||
for (auto cmt : cmts.keys())
|
|
||||||
{
|
|
||||||
QTreeWidgetItem *item = new QTreeWidgetItem(this->commentsDock->nestedCommentsTreeWidget);
|
|
||||||
item->setText(0, cmt);
|
|
||||||
QList<QList<QString>> meow = cmts.value(cmt);
|
|
||||||
for (int i = 0; i < meow.size(); ++i)
|
|
||||||
{
|
{
|
||||||
QList<QString> tmp = meow.at(i);
|
w->setup();
|
||||||
QTreeWidgetItem *it = new QTreeWidgetItem();
|
|
||||||
it->setText(0, tmp[1]);
|
|
||||||
it->setText(1, tmp[0].remove('"'));
|
|
||||||
item->addChild(it);
|
|
||||||
}
|
}
|
||||||
this->commentsDock->nestedCommentsTreeWidget->addTopLevelItem(item);
|
|
||||||
}
|
|
||||||
adjustColumns(this->commentsDock->nestedCommentsTreeWidget);
|
|
||||||
|
|
||||||
// TODO: FIXME: Remove the check for first_time;
|
|
||||||
if (first_time)
|
|
||||||
{
|
|
||||||
this->sectionsDock->sectionsWidget->tree->clear();
|
|
||||||
int row = 0;
|
|
||||||
for (auto i : core->getList("bin", "sections"))
|
|
||||||
{
|
|
||||||
QStringList a = i.split(",");
|
|
||||||
if (a.length() > 2)
|
|
||||||
{
|
|
||||||
// Fix to work with ARM bins
|
|
||||||
//if (a[4].startsWith(".")) {
|
|
||||||
if (a[4].contains("."))
|
|
||||||
{
|
|
||||||
QString addr = a[1];
|
|
||||||
QString addr_end = "0x0" + core->itoa(core->math(a[1] + "+" + a[2]));
|
|
||||||
QString size = QString::number(core->math(a[2]));
|
|
||||||
QString name = a[4];
|
|
||||||
this->sectionsDock->sectionsWidget->fillSections(row, name, size, addr, addr_end);
|
|
||||||
|
|
||||||
// Used to select a color for the sections graph
|
|
||||||
if (row == 10)
|
|
||||||
{
|
|
||||||
row = 0;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
row++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
//adjustColumns(sectionsWidget->tree);
|
|
||||||
this->sectionsDock->sectionsWidget->adjustColumns();
|
|
||||||
|
|
||||||
first_time = false;
|
first_time = false;
|
||||||
|
|
||||||
this->dashboardDock->updateContents();
|
|
||||||
}
|
}
|
||||||
}
|
else
|
||||||
|
{
|
||||||
|
for (auto w : dockWidgets)
|
||||||
|
{
|
||||||
|
w->refresh();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
// graphicsBar->refreshColorBar();
|
||||||
* End of refresh widget functions
|
graphicsBar->fillData();
|
||||||
*/
|
}
|
||||||
|
|
||||||
void MainWindow::on_actionLock_triggered()
|
void MainWindow::on_actionLock_triggered()
|
||||||
{
|
{
|
||||||
@ -717,7 +541,7 @@ void MainWindow::on_actionMem_triggered()
|
|||||||
//this->memoryDock->show();
|
//this->memoryDock->show();
|
||||||
//this->memoryDock->raise();
|
//this->memoryDock->raise();
|
||||||
MemoryWidget *newMemDock = new MemoryWidget(this);
|
MemoryWidget *newMemDock = new MemoryWidget(this);
|
||||||
this->dockList << newMemDock;
|
this->dockWidgets << newMemDock;
|
||||||
newMemDock->setAttribute(Qt::WA_DeleteOnClose);
|
newMemDock->setAttribute(Qt::WA_DeleteOnClose);
|
||||||
this->tabifyDockWidget(this->memoryDock, newMemDock);
|
this->tabifyDockWidget(this->memoryDock, newMemDock);
|
||||||
newMemDock->refreshDisasm();
|
newMemDock->refreshDisasm();
|
||||||
@ -911,18 +735,6 @@ void MainWindow::seek(const QString &offset, const QString &name)
|
|||||||
this->memoryDock->disasTextEdit->setFocus();
|
this->memoryDock->disasTextEdit->setFocus();
|
||||||
}
|
}
|
||||||
|
|
||||||
void MainWindow::setup_mem()
|
|
||||||
{
|
|
||||||
QString off = this->core->cmd("afo entry0").trimmed();
|
|
||||||
//graphicsBar->refreshColorBar();
|
|
||||||
graphicsBar->fillData();
|
|
||||||
this->memoryDock->refreshDisasm(off);
|
|
||||||
this->memoryDock->refreshHexdump(off);
|
|
||||||
this->memoryDock->create_graph(off);
|
|
||||||
this->memoryDock->get_refs_data(off);
|
|
||||||
this->memoryDock->setFcnName(off);
|
|
||||||
}
|
|
||||||
|
|
||||||
void MainWindow::refreshMem(const QString &offset)
|
void MainWindow::refreshMem(const QString &offset)
|
||||||
{
|
{
|
||||||
//add_debug_output("Refreshing to: " + off);
|
//add_debug_output("Refreshing to: " + off);
|
||||||
@ -1026,30 +838,31 @@ void MainWindow::on_actionDefaut_triggered()
|
|||||||
|
|
||||||
void MainWindow::hideAllDocks()
|
void MainWindow::hideAllDocks()
|
||||||
{
|
{
|
||||||
sectionsDock->hide();
|
for (auto w : dockWidgets)
|
||||||
this->functionsDock->hide();
|
{
|
||||||
this->memoryDock->hide();
|
w->hide();
|
||||||
this->commentsDock->hide();
|
}
|
||||||
this->flagsDock->hide();
|
|
||||||
this->stringsDock->hide();
|
|
||||||
this->relocsDock->hide();
|
|
||||||
this->importsDock->hide();
|
|
||||||
this->symbolsDock->hide();
|
|
||||||
this->notepadDock->hide();
|
|
||||||
this->dashboardDock->hide();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void MainWindow::showDefaultDocks()
|
void MainWindow::showDefaultDocks()
|
||||||
{
|
{
|
||||||
sectionsDock->show();
|
const QList<DockWidget*> defaultDocks = { sectionsDock,
|
||||||
this->functionsDock->show();
|
functionsDock,
|
||||||
this->memoryDock->show();
|
memoryDock,
|
||||||
this->commentsDock->show();
|
commentsDock,
|
||||||
this->stringsDock->show();
|
stringsDock,
|
||||||
this->importsDock->show();
|
importsDock,
|
||||||
this->symbolsDock->show();
|
symbolsDock,
|
||||||
this->notepadDock->show();
|
notepadDock,
|
||||||
this->dashboardDock->show();
|
dashboardDock};
|
||||||
|
|
||||||
|
for (auto w : dockWidgets)
|
||||||
|
{
|
||||||
|
if (defaultDocks.contains(w))
|
||||||
|
{
|
||||||
|
w->show();
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void MainWindow::on_actionhide_bottomPannel_triggered()
|
void MainWindow::on_actionhide_bottomPannel_triggered()
|
||||||
@ -1066,7 +879,7 @@ void MainWindow::on_actionhide_bottomPannel_triggered()
|
|||||||
|
|
||||||
void MainWindow::send_to_notepad(QString txt)
|
void MainWindow::send_to_notepad(QString txt)
|
||||||
{
|
{
|
||||||
this->notepadDock->notesTextEdit->appendPlainText("```\n" + txt + "\n```");
|
this->notepadDock->appendPlainText("```\n" + txt + "\n```");
|
||||||
}
|
}
|
||||||
|
|
||||||
void MainWindow::on_actionFunctionsRename_triggered()
|
void MainWindow::on_actionFunctionsRename_triggered()
|
||||||
@ -1103,7 +916,7 @@ void MainWindow::on_actionNew_triggered()
|
|||||||
void MainWindow::on_actionSave_triggered()
|
void MainWindow::on_actionSave_triggered()
|
||||||
{
|
{
|
||||||
core->cmd("Ps " + qhelpers::uniqueProjectName(filename));
|
core->cmd("Ps " + qhelpers::uniqueProjectName(filename));
|
||||||
QString notes = this->notepadDock->notesTextEdit->toPlainText().toUtf8().toBase64();
|
QString notes = this->notepadDock->textToBase64();
|
||||||
//this->add_debug_output(notes);
|
//this->add_debug_output(notes);
|
||||||
this->core->cmd("Pnj " + notes);
|
this->core->cmd("Pnj " + notes);
|
||||||
this->add_output("Project saved");
|
this->add_output("Project saved");
|
||||||
@ -1226,20 +1039,11 @@ void MainWindow::refreshVisibleDockWidgets()
|
|||||||
return pWidget != nullptr && !pWidget->visibleRegion().isEmpty();
|
return pWidget != nullptr && !pWidget->visibleRegion().isEmpty();
|
||||||
};
|
};
|
||||||
|
|
||||||
//TODO: not used/set atm
|
for (auto w : dockWidgets)
|
||||||
// if (isDockVisible(asmDock)) { asmDock->update(); }
|
{
|
||||||
// if (isDockVisible(calcDock)) { calcDock->update(); }
|
if (isDockVisible(w))
|
||||||
|
{
|
||||||
if (isDockVisible(memoryDock)) { memoryDock->updateViews(); }
|
w->refresh();
|
||||||
// TODO: if (isDockVisible(notepadDock)) { eprint("notepadDock visible"); }
|
}
|
||||||
if (isDockVisible(functionsDock)) { functionsDock->refreshTree(); }
|
}
|
||||||
if (isDockVisible(importsDock)) { importsDock->fillImports(); }
|
|
||||||
if (isDockVisible(symbolsDock)) { symbolsDock->fillSymbols(); }
|
|
||||||
// TODO: update/refresh function if (isDockVisible(relocsDock)) { eprint("relocsDock visible"); }
|
|
||||||
if (isDockVisible(commentsDock)) { commentsDock->refreshTree(); }
|
|
||||||
// TODO: update/refresh function if (isDockVisible(stringsDock)) { eprint("stringsDock visible"); }
|
|
||||||
// TODO: update/refresh function if (isDockVisible(flagsDock)) { eprint("flagsDock visible"); }
|
|
||||||
if (isDockVisible(dashboardDock)) { dashboardDock->updateContents(); }
|
|
||||||
// TODO: update/refresh function if (isDockVisible(sdbDock)) { eprint("sdbDock visible"); }
|
|
||||||
// TODO: update/refresh function if (isDockVisible(sectionsDock)) { eprint("sectionsDock visible"); }
|
|
||||||
}
|
}
|
||||||
|
@ -1,40 +1,35 @@
|
|||||||
#ifndef MAINWINDOW_H
|
#ifndef MAINWINDOW_H
|
||||||
#define MAINWINDOW_H
|
#define MAINWINDOW_H
|
||||||
|
|
||||||
|
#include "webserverthread.h"
|
||||||
|
#include "qrcore.h" // only needed for ut64
|
||||||
|
|
||||||
#include <QMainWindow>
|
#include <QMainWindow>
|
||||||
#include <QLabel>
|
|
||||||
#include <QComboBox>
|
|
||||||
#include <QTreeWidgetItem>
|
|
||||||
#include <QDockWidget>
|
|
||||||
#include <QLineEdit>
|
|
||||||
#include <QSettings>
|
|
||||||
#include <QList>
|
#include <QList>
|
||||||
|
|
||||||
#include "highlighter.h"
|
class QRCore;
|
||||||
#include "hexascii_highlighter.h"
|
class DockWidget;
|
||||||
#include "helpers.h"
|
class Omnibar;
|
||||||
#include "qrcore.h"
|
class MemoryWidget;
|
||||||
|
class Notepad;
|
||||||
|
class SideBar;
|
||||||
|
class Highlighter;
|
||||||
|
class AsciiHighlighter;
|
||||||
|
class GraphicsBar;
|
||||||
|
class FunctionsWidget;
|
||||||
|
class ImportsWidget;
|
||||||
|
class SymbolsWidget;
|
||||||
|
class RelocsWidget;
|
||||||
|
class CommentsWidget;
|
||||||
|
class StringsWidget;
|
||||||
|
class FlagsWidget;
|
||||||
|
class Dashboard;
|
||||||
|
class QLineEdit;
|
||||||
|
class SdbDock;
|
||||||
|
class QAction;
|
||||||
|
class SectionsDock;
|
||||||
|
|
||||||
#include "widgets/memorywidget.h"
|
class QDockWidget;
|
||||||
#include "widgets/functionswidget.h"
|
|
||||||
#include "widgets/sectionswidget.h"
|
|
||||||
#include "widgets/commentswidget.h"
|
|
||||||
#include "widgets/importswidget.h"
|
|
||||||
#include "widgets/symbolswidget.h"
|
|
||||||
#include "widgets/stringswidget.h"
|
|
||||||
#include "widgets/sectionsdock.h"
|
|
||||||
#include "widgets/relocswidget.h"
|
|
||||||
#include "widgets/flagswidget.h"
|
|
||||||
#include "widgets/codegraphic.h"
|
|
||||||
#include "widgets/dashboard.h"
|
|
||||||
#include "widgets/notepad.h"
|
|
||||||
#include "widgets/sidebar.h"
|
|
||||||
#include "widgets/sdbdock.h"
|
|
||||||
#include "widgets/omnibar.h"
|
|
||||||
|
|
||||||
#include "webserverthread.h"
|
|
||||||
#include "newfiledialog.h"
|
|
||||||
#include "helpers.h"
|
|
||||||
|
|
||||||
namespace Ui
|
namespace Ui
|
||||||
{
|
{
|
||||||
@ -48,12 +43,8 @@ class MainWindow : public QMainWindow
|
|||||||
|
|
||||||
public:
|
public:
|
||||||
QRCore *core;
|
QRCore *core;
|
||||||
QDockWidget *asmDock;
|
MemoryWidget *memoryDock;
|
||||||
QDockWidget *calcDock;
|
Notepad *notepadDock;
|
||||||
Omnibar *omnibar;
|
|
||||||
MemoryWidget *memoryDock;
|
|
||||||
Notepad *notepadDock;
|
|
||||||
SideBar *sideBar;
|
|
||||||
|
|
||||||
bool responsive;
|
bool responsive;
|
||||||
QString current_address;
|
QString current_address;
|
||||||
@ -70,16 +61,13 @@ public:
|
|||||||
void updateFrames();
|
void updateFrames();
|
||||||
void refreshFunctions();
|
void refreshFunctions();
|
||||||
void refreshComments();
|
void refreshComments();
|
||||||
void refreshFlags();
|
|
||||||
void get_refs(const QString &offset);
|
void get_refs(const QString &offset);
|
||||||
void add_output(QString msg);
|
void add_output(QString msg);
|
||||||
void add_debug_output(QString msg);
|
void add_debug_output(QString msg);
|
||||||
void send_to_notepad(QString txt);
|
void send_to_notepad(QString txt);
|
||||||
void adjustColumns(QTreeWidget *tw);
|
|
||||||
void appendRow(QTreeWidget *tw, const QString &str, const QString &str2 = QString(),
|
|
||||||
const QString &str3 = QString(), const QString &str4 = QString(), const QString &str5 = QString());
|
|
||||||
|
|
||||||
void setWebServerState(bool start);
|
void setWebServerState(bool start);
|
||||||
|
void raiseMemoryDock();
|
||||||
|
void toggleSideBarTheme();
|
||||||
|
|
||||||
public slots:
|
public slots:
|
||||||
|
|
||||||
@ -141,8 +129,6 @@ private slots:
|
|||||||
|
|
||||||
void on_actionRefresh_Panels_triggered();
|
void on_actionRefresh_Panels_triggered();
|
||||||
|
|
||||||
void hideDummyColumns();
|
|
||||||
|
|
||||||
void on_actionCalculator_triggered();
|
void on_actionCalculator_triggered();
|
||||||
|
|
||||||
void on_actionCreate_File_triggered();
|
void on_actionCreate_File_triggered();
|
||||||
@ -192,14 +178,17 @@ private slots:
|
|||||||
void refreshVisibleDockWidgets();
|
void refreshVisibleDockWidgets();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void refreshFlagspaces();
|
QDockWidget *asmDock;
|
||||||
|
QDockWidget *calcDock;
|
||||||
|
Omnibar *omnibar;
|
||||||
|
SideBar *sideBar;
|
||||||
|
|
||||||
bool doLock;
|
bool doLock;
|
||||||
void refreshMem(const QString &offset = QString());
|
void refreshMem(const QString &offset = QString());
|
||||||
void setup_mem();
|
|
||||||
ut64 hexdumpTopOffset;
|
ut64 hexdumpTopOffset;
|
||||||
ut64 hexdumpBottomOffset;
|
ut64 hexdumpBottomOffset;
|
||||||
QString filename;
|
QString filename;
|
||||||
QList<QDockWidget *> dockList;
|
QList<DockWidget *> dockWidgets;
|
||||||
Ui::MainWindow *ui;
|
Ui::MainWindow *ui;
|
||||||
Highlighter *highlighter;
|
Highlighter *highlighter;
|
||||||
AsciiHighlighter *hex_highlighter;
|
AsciiHighlighter *hex_highlighter;
|
||||||
|
Loading…
Reference in New Issue
Block a user