citra/src/citra_qt/debugger/disassembler.h

83 lines
1.8 KiB
C
Raw Normal View History

// Copyright 2014 Citra Emulator Project
// Licensed under GPLv2 or any later version
// Refer to the license.txt file included.
#pragma once
#include <QAbstractListModel>
2014-04-01 04:26:50 +02:00
#include <QDockWidget>
#include "ui_disassembler.h"
2014-04-01 04:26:50 +02:00
2014-04-11 02:50:10 +02:00
#include "common/common.h"
#include "common/break_points.h"
2014-04-01 04:26:50 +02:00
class QAction;
class EmuThread;
2014-04-01 04:26:50 +02:00
class DisassemblerModel : public QAbstractListModel
2014-07-02 21:16:36 +02:00
{
Q_OBJECT
public:
DisassemblerModel(QObject* parent);
int columnCount(const QModelIndex& parent = QModelIndex()) const override;
int rowCount(const QModelIndex& parent = QModelIndex()) const override;
QVariant data(const QModelIndex& index, int role = Qt::DisplayRole) const override;
QModelIndex IndexFromAbsoluteAddress(unsigned int address) const;
const BreakPoints& GetBreakPoints() const;
public slots:
void ParseFromAddress(unsigned int address);
void OnSelectionChanged(const QModelIndex&);
void OnSetOrUnsetBreakpoint();
void SetNextInstruction(unsigned int address);
private:
unsigned int base_address;
unsigned int code_size;
unsigned int program_counter;
QModelIndex selection;
// TODO: Make BreakPoints less crappy (i.e. const-correct) so that this needn't be mutable.
mutable BreakPoints breakpoints;
};
2014-04-19 00:30:53 +02:00
class DisassemblerWidget : public QDockWidget
2014-04-01 04:26:50 +02:00
{
Q_OBJECT
public:
DisassemblerWidget(QWidget* parent, EmuThread* emu_thread);
2014-04-01 04:26:50 +02:00
2014-04-04 03:24:07 +02:00
void Init();
2014-04-01 04:26:50 +02:00
public slots:
2014-04-04 03:24:07 +02:00
void OnContinue();
2014-04-01 04:26:50 +02:00
void OnStep();
2014-04-04 03:24:07 +02:00
void OnStepInto();
2014-04-01 04:26:50 +02:00
void OnPause();
2014-04-04 03:24:07 +02:00
void OnToggleStartStop();
2014-04-01 04:26:50 +02:00
void OnDebugModeEntered();
void OnDebugModeLeft();
2014-04-01 04:26:50 +02:00
void OnEmulationStarted(EmuThread* emu_thread);
void OnEmulationStopped();
2014-04-01 04:26:50 +02:00
private:
// returns -1 if no row is selected
int SelectedRow();
Ui::DockWidget disasm_ui;
2014-07-02 21:16:36 +02:00
DisassemblerModel* model;
2014-04-01 04:26:50 +02:00
2014-07-02 21:16:36 +02:00
u32 base_addr;
2014-04-01 04:26:50 +02:00
EmuThread* emu_thread;
2014-04-01 04:26:50 +02:00
};