mirror of https://github.com/PCSX2/pcsx2.git
Debugger Breakpoints: Implement the user data role in the model
Consistent with the other models, and saves some awkward usage in the cpu widget where we have to interpret the variant as a string, to then convert it to a uint. I like this better as it provides an easy interface to get the 'raw' breakpoint data out of the model.
This commit is contained in:
parent
b6125e97e9
commit
752594f69a
|
@ -244,7 +244,7 @@ void CpuWidget::onBPListDoubleClicked(const QModelIndex& index)
|
||||||
{
|
{
|
||||||
if (index.column() == BreakpointModel::OFFSET)
|
if (index.column() == BreakpointModel::OFFSET)
|
||||||
{
|
{
|
||||||
m_ui.disassemblyWidget->gotoAddress(m_bpModel.data(index).toString().toUInt(nullptr, 16));
|
m_ui.disassemblyWidget->gotoAddress(m_bpModel.data(index, Qt::UserRole).toUInt());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -97,6 +97,52 @@ QVariant BreakpointModel::data(const QModelIndex& index, int role) const
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else if (role == Qt::UserRole)
|
||||||
|
{
|
||||||
|
auto bp_mc = m_breakpoints.at(index.row());
|
||||||
|
|
||||||
|
if (const auto* bp = std::get_if<BreakPoint>(&bp_mc))
|
||||||
|
{
|
||||||
|
switch (index.column())
|
||||||
|
{
|
||||||
|
case BreakpointColumns::TYPE:
|
||||||
|
return 0;
|
||||||
|
case BreakpointColumns::OFFSET:
|
||||||
|
return bp->addr;
|
||||||
|
case BreakpointColumns::SIZE_LABEL:
|
||||||
|
return m_cpu.GetSymbolMap().GetLabelString(bp->addr).c_str();
|
||||||
|
case BreakpointColumns::OPCODE:
|
||||||
|
// Note: Fix up the disassemblymanager so we can use it here, instead of calling a function through the disassemblyview (yuck)
|
||||||
|
return m_cpu.disasm(bp->addr, true).c_str();
|
||||||
|
case BreakpointColumns::CONDITION:
|
||||||
|
return bp->hasCond ? QString::fromLocal8Bit(bp->cond.expressionString) : tr("");
|
||||||
|
case BreakpointColumns::HITS:
|
||||||
|
return 0;
|
||||||
|
case BreakpointColumns::ENABLED:
|
||||||
|
return bp->enabled;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (const auto* mc = std::get_if<MemCheck>(&bp_mc))
|
||||||
|
{
|
||||||
|
switch (index.column())
|
||||||
|
{
|
||||||
|
case BreakpointColumns::TYPE:
|
||||||
|
return mc->cond;
|
||||||
|
case BreakpointColumns::OFFSET:
|
||||||
|
return mc->start;
|
||||||
|
case BreakpointColumns::SIZE_LABEL:
|
||||||
|
return mc->end - mc->start;
|
||||||
|
case BreakpointColumns::OPCODE:
|
||||||
|
return "";
|
||||||
|
case BreakpointColumns::CONDITION:
|
||||||
|
return "";
|
||||||
|
case BreakpointColumns::HITS:
|
||||||
|
return mc->numHits;
|
||||||
|
case BreakpointColumns::ENABLED:
|
||||||
|
return (mc->result & MEMCHECK_BREAK);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
else if (role == Qt::CheckStateRole)
|
else if (role == Qt::CheckStateRole)
|
||||||
{
|
{
|
||||||
if (index.column() == 6)
|
if (index.column() == 6)
|
||||||
|
|
Loading…
Reference in New Issue