mirror of
https://github.com/rizinorg/cutter.git
synced 2025-01-07 04:25:25 +00:00
Get rid of stale jump arrows in disassembly widget. (#3175)
This commit clears arrows from edited instructions, in order to avoid stale arrows to remain drawn. closes #3114
This commit is contained in:
parent
3ccccae291
commit
a5fa4103b2
@ -132,7 +132,7 @@ DisassemblyWidget::DisassemblyWidget(MainWindow *main)
|
|||||||
connect(Core(), &CutterCore::functionRenamed, this, [this]() { refreshDisasm(); });
|
connect(Core(), &CutterCore::functionRenamed, this, [this]() { refreshDisasm(); });
|
||||||
connect(Core(), SIGNAL(varsChanged()), this, SLOT(refreshDisasm()));
|
connect(Core(), SIGNAL(varsChanged()), this, SLOT(refreshDisasm()));
|
||||||
connect(Core(), SIGNAL(asmOptionsChanged()), this, SLOT(refreshDisasm()));
|
connect(Core(), SIGNAL(asmOptionsChanged()), this, SLOT(refreshDisasm()));
|
||||||
connect(Core(), &CutterCore::instructionChanged, this, &DisassemblyWidget::refreshIfInRange);
|
connect(Core(), &CutterCore::instructionChanged, this, &DisassemblyWidget::instructionChanged);
|
||||||
connect(Core(), &CutterCore::breakpointsChanged, this, &DisassemblyWidget::refreshIfInRange);
|
connect(Core(), &CutterCore::breakpointsChanged, this, &DisassemblyWidget::refreshIfInRange);
|
||||||
connect(Core(), SIGNAL(refreshCodeViews()), this, SLOT(refreshDisasm()));
|
connect(Core(), SIGNAL(refreshCodeViews()), this, SLOT(refreshDisasm()));
|
||||||
|
|
||||||
@ -226,6 +226,12 @@ void DisassemblyWidget::refreshIfInRange(RVA offset)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void DisassemblyWidget::instructionChanged(RVA offset)
|
||||||
|
{
|
||||||
|
leftPanel->clearArrowFrom(offset);
|
||||||
|
refreshDisasm();
|
||||||
|
}
|
||||||
|
|
||||||
void DisassemblyWidget::refreshDisasm(RVA offset)
|
void DisassemblyWidget::refreshDisasm(RVA offset)
|
||||||
{
|
{
|
||||||
if (!disasmRefresh->attemptRefresh(offset == RVA_INVALID ? nullptr : new RVA(offset))) {
|
if (!disasmRefresh->attemptRefresh(offset == RVA_INVALID ? nullptr : new RVA(offset))) {
|
||||||
@ -1006,3 +1012,12 @@ void DisassemblyLeftPanel::paintEvent(QPaintEvent *event)
|
|||||||
|
|
||||||
lastBeginOffset = lines.first().offset;
|
lastBeginOffset = lines.first().offset;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void DisassemblyLeftPanel::clearArrowFrom(RVA offset)
|
||||||
|
{
|
||||||
|
auto it = std::find_if(arrows.begin(), arrows.end(),
|
||||||
|
[&](const Arrow &it) { return it.jmpFromOffset() == offset; });
|
||||||
|
if (it != arrows.end()) {
|
||||||
|
arrows.erase(it);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@ -53,6 +53,7 @@ public slots:
|
|||||||
protected slots:
|
protected slots:
|
||||||
void on_seekChanged(RVA offset, CutterCore::SeekHistoryType type);
|
void on_seekChanged(RVA offset, CutterCore::SeekHistoryType type);
|
||||||
void refreshIfInRange(RVA offset);
|
void refreshIfInRange(RVA offset);
|
||||||
|
void instructionChanged(RVA offset);
|
||||||
void refreshDisasm(RVA offset = RVA_INVALID);
|
void refreshDisasm(RVA offset = RVA_INVALID);
|
||||||
|
|
||||||
bool updateMaxLines();
|
bool updateMaxLines();
|
||||||
@ -156,6 +157,7 @@ public:
|
|||||||
DisassemblyLeftPanel(DisassemblyWidget *disas);
|
DisassemblyLeftPanel(DisassemblyWidget *disas);
|
||||||
void paintEvent(QPaintEvent *event) override;
|
void paintEvent(QPaintEvent *event) override;
|
||||||
void wheelEvent(QWheelEvent *event) override;
|
void wheelEvent(QWheelEvent *event) override;
|
||||||
|
void clearArrowFrom(RVA offset);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
DisassemblyWidget *disas;
|
DisassemblyWidget *disas;
|
||||||
|
Loading…
Reference in New Issue
Block a user