mirror of
https://github.com/RPCS3/rpcs3.git
synced 2024-11-22 10:42:36 +01:00
Debugger: Fix instruction selection
This commit is contained in:
parent
8cc6a30557
commit
c14e79f8df
@ -35,7 +35,12 @@ debugger_list::debugger_list(QWidget* parent, std::shared_ptr<gui_settings> gui_
|
||||
|
||||
void debugger_list::UpdateCPUData(cpu_thread* cpu, CPUDisAsm* disasm)
|
||||
{
|
||||
m_cpu = cpu;
|
||||
if (m_cpu != cpu)
|
||||
{
|
||||
m_cpu = cpu;
|
||||
m_selected_instruction = -1;
|
||||
}
|
||||
|
||||
m_disasm = disasm;
|
||||
}
|
||||
|
||||
@ -77,6 +82,19 @@ void debugger_list::ShowAddress(u32 addr, bool select_addr, bool force)
|
||||
const auto& default_foreground = palette().color(foregroundRole());
|
||||
const auto& default_background = palette().color(backgroundRole());
|
||||
|
||||
if (select_addr)
|
||||
{
|
||||
m_selected_instruction = addr;
|
||||
}
|
||||
|
||||
for (uint i = 0; i < m_item_count; ++i)
|
||||
{
|
||||
if (auto list_item = item(i); list_item->isSelected())
|
||||
{
|
||||
list_item->setSelected(false);
|
||||
}
|
||||
}
|
||||
|
||||
if (!m_cpu || !m_disasm || +m_cpu->state + cpu_flag::exit + cpu_flag::wait == +m_cpu->state)
|
||||
{
|
||||
for (uint i = 0; i < m_item_count; ++i)
|
||||
@ -103,9 +121,13 @@ void debugger_list::ShowAddress(u32 addr, bool select_addr, bool force)
|
||||
list_item->setForeground(m_text_color_pc);
|
||||
list_item->setBackground(m_color_pc);
|
||||
}
|
||||
else if (select_addr && pc == addr)
|
||||
else if (pc == m_selected_instruction)
|
||||
{
|
||||
list_item->setSelected(true);
|
||||
// setSelected may invoke a resize event which causes stack overflow, terminate recursion
|
||||
if (!list_item->isSelected())
|
||||
{
|
||||
list_item->setSelected(true);
|
||||
}
|
||||
}
|
||||
else if (IsBreakpoint(pc))
|
||||
{
|
||||
|
@ -20,6 +20,7 @@ public:
|
||||
u32 m_pc = 0;
|
||||
u32 m_item_count = 30;
|
||||
bool m_follow_thread = true; // If true, follow the selected thread to wherever it goes in code
|
||||
u32 m_selected_instruction = -1;
|
||||
QColor m_color_bp;
|
||||
QColor m_color_pc;
|
||||
QColor m_text_color_bp;
|
||||
|
Loading…
Reference in New Issue
Block a user