fix debugger o.O (#2903)

* fix debugger o.O

* minor simplification

* how did I not see this the first time
This commit is contained in:
Megamouse 2017-06-23 14:08:38 +02:00 committed by Ivan
parent 51ce8f6c20
commit 4ce8e9ba16

View File

@ -88,9 +88,6 @@ debugger_frame::debugger_frame(QWidget *parent) : QDockWidget(tr("Debugger"), pa
}); });
connect(m_choice_units, static_cast<void (QComboBox::*)(int)>(&QComboBox::activated), this, &debugger_frame::UpdateUI); connect(m_choice_units, static_cast<void (QComboBox::*)(int)>(&QComboBox::activated), this, &debugger_frame::UpdateUI);
connect(m_choice_units, static_cast<void (QComboBox::*)(int)>(&QComboBox::currentIndexChanged), this, &debugger_frame::OnSelectUnit); connect(m_choice_units, static_cast<void (QComboBox::*)(int)>(&QComboBox::currentIndexChanged), this, &debugger_frame::OnSelectUnit);
connect(m_choice_units, static_cast<void (QComboBox::*)(int)>(&QComboBox::currentIndexChanged), m_list, [=](int index) {
m_list->m_noThreadSelected = m_choice_units->itemText(index) == NoThread ? true : false;
});
connect(this, &QDockWidget::visibilityChanged, this, &debugger_frame::EnableUpdateTimer); connect(this, &QDockWidget::visibilityChanged, this, &debugger_frame::EnableUpdateTimer);
m_list->ShowAddr(CentrePc(m_list->m_pc)); m_list->ShowAddr(CentrePc(m_list->m_pc));
@ -103,7 +100,6 @@ void debugger_frame::closeEvent(QCloseEvent *event)
emit DebugFrameClosed(); emit DebugFrameClosed();
} }
//static const int show_lines = 30;
#include <map> #include <map>
std::map<u32, bool> g_breakpoints; std::map<u32, bool> g_breakpoints;
@ -137,6 +133,8 @@ void debugger_frame::UpdateUI()
{ {
UpdateUnitList(); UpdateUnitList();
if (m_noThreadSelected) return;
const auto cpu = this->cpu.lock(); const auto cpu = this->cpu.lock();
if (!cpu) if (!cpu)
@ -228,12 +226,17 @@ void debugger_frame::UpdateUnitList()
void debugger_frame::OnSelectUnit() void debugger_frame::OnSelectUnit()
{ {
if (m_choice_units->count() < 1 || m_current_choice == m_choice_units->currentText() || m_choice_units->currentText() == NoThread) return; if (m_choice_units->count() < 1 || m_current_choice == m_choice_units->currentText()) return;
m_current_choice = m_choice_units->currentText(); m_current_choice = m_choice_units->currentText();
m_noThreadSelected = m_current_choice == NoThread;
m_list->m_noThreadSelected = m_noThreadSelected;
m_disasm.reset(); m_disasm.reset();
cpu.reset();
if (!m_noThreadSelected)
{
const auto on_select = [&](u32, cpu_thread& cpu) const auto on_select = [&](u32, cpu_thread& cpu)
{ {
cpu_thread* data = (cpu_thread *)m_choice_units->currentData().value<void *>(); cpu_thread* data = (cpu_thread *)m_choice_units->currentData().value<void *>();
@ -260,6 +263,7 @@ void debugger_frame::OnSelectUnit()
m_disasm = std::make_unique<ARMv7DisAsm>(CPUDisAsm_InterpreterMode); m_disasm = std::make_unique<ARMv7DisAsm>(CPUDisAsm_InterpreterMode);
cpu = arm.ptr; cpu = arm.ptr;
} }
}
DoUpdate(); DoUpdate();
} }
@ -373,7 +377,7 @@ void debugger_frame::Show_Val()
void debugger_frame::Show_PC() void debugger_frame::Show_PC()
{ {
if (const auto cpu = this->cpu.lock()) m_list->ShowAddr(CentrePc(GetPc())); m_list->ShowAddr(CentrePc(GetPc()));
} }
void debugger_frame::DoStep() void debugger_frame::DoStep()