5 changed files with 68 additions and 50 deletions
-
2src/citra_qt/CMakeLists.txt
-
32src/citra_qt/debugger/graphics_breakpoint_observer.cpp
-
33src/citra_qt/debugger/graphics_breakpoint_observer.h
-
27src/citra_qt/debugger/graphics_framebuffer.cpp
-
24src/citra_qt/debugger/graphics_framebuffer.h
@ -0,0 +1,32 @@ |
|||||
|
// Copyright 2014 Citra Emulator Project
|
||||
|
// Licensed under GPLv2 or any later version
|
||||
|
// Refer to the license.txt file included.
|
||||
|
|
||||
|
#include <QMetaType>
|
||||
|
|
||||
|
#include "graphics_breakpoint_observer.h"
|
||||
|
|
||||
|
BreakPointObserverDock::BreakPointObserverDock(std::shared_ptr<Pica::DebugContext> debug_context, |
||||
|
const QString& title, QWidget* parent) |
||||
|
: QDockWidget(title, parent), BreakPointObserver(debug_context) |
||||
|
{ |
||||
|
qRegisterMetaType<Pica::DebugContext::Event>("Pica::DebugContext::Event"); |
||||
|
|
||||
|
connect(this, SIGNAL(Resumed()), this, SLOT(OnResumed())); |
||||
|
|
||||
|
// NOTE: This signal is emitted from a non-GUI thread, but connect() takes
|
||||
|
// care of delaying its handling to the GUI thread.
|
||||
|
connect(this, SIGNAL(BreakPointHit(Pica::DebugContext::Event,void*)), |
||||
|
this, SLOT(OnBreakPointHit(Pica::DebugContext::Event,void*)), |
||||
|
Qt::BlockingQueuedConnection); |
||||
|
} |
||||
|
|
||||
|
void BreakPointObserverDock::OnPicaBreakPointHit(Pica::DebugContext::Event event, void* data) |
||||
|
{ |
||||
|
emit BreakPointHit(event, data); |
||||
|
} |
||||
|
|
||||
|
void BreakPointObserverDock::OnPicaResume() |
||||
|
{ |
||||
|
emit Resumed(); |
||||
|
} |
||||
@ -0,0 +1,33 @@ |
|||||
|
// Copyright 2014 Citra Emulator Project |
||||
|
// Licensed under GPLv2 or any later version |
||||
|
// Refer to the license.txt file included. |
||||
|
|
||||
|
#pragma once |
||||
|
|
||||
|
#include <QDockWidget> |
||||
|
|
||||
|
#include "video_core/debug_utils/debug_utils.h" |
||||
|
|
||||
|
/** |
||||
|
* Utility class which forwards calls to OnPicaBreakPointHit and OnPicaResume to public slots. |
||||
|
* This is because the Pica breakpoint callbacks are called from a non-GUI thread, while |
||||
|
* the widget usually wants to perform reactions in the GUI thread. |
||||
|
*/ |
||||
|
class BreakPointObserverDock : public QDockWidget, private Pica::DebugContext::BreakPointObserver { |
||||
|
Q_OBJECT |
||||
|
|
||||
|
public: |
||||
|
BreakPointObserverDock(std::shared_ptr<Pica::DebugContext> debug_context, const QString& title, |
||||
|
QWidget* parent = nullptr); |
||||
|
|
||||
|
void OnPicaBreakPointHit(Pica::DebugContext::Event event, void* data) override; |
||||
|
void OnPicaResume() override; |
||||
|
|
||||
|
private slots: |
||||
|
virtual void OnBreakPointHit(Pica::DebugContext::Event event, void* data) = 0; |
||||
|
virtual void OnResumed() = 0; |
||||
|
|
||||
|
signals: |
||||
|
void Resumed(); |
||||
|
void BreakPointHit(Pica::DebugContext::Event event, void* data); |
||||
|
}; |
||||
Write
Preview
Loading…
Cancel
Save
Reference in new issue