mirror of
				https://github.com/dolphin-emu/dolphin.git
				synced 2025-10-24 17:09:06 +00:00 
			
		
		
		
	There were three distinct mechanisms for signaling breakpoint changes in DolphinQt, and the wiring had room for improvement. The behavior of these signals has been consolidated into the new `Host::PPCBreakpointsChanged` signal, which can be emitted from anywhere in DolphinQt to properly update breakpoints everywhere in DolphinQt. This improves a few things: - For the `CodeViewWidget` and `MemoryViewWidget`, signals no longer need to propagate through the `CodeWidget` and `MemoryWidget` (respectively) to reach their destination (incoming or outgoing). - For the `BreakpointWidget`, by self-triggering from its own signal, it no longer must manually call `Update()` after all of the emission sites. - For the `BranchWatchDialog`, it now has one less thing it must go through the `CodeWidget` for, which is a plus.
		
			
				
	
	
		
			116 lines
		
	
	
	
		
			2.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			116 lines
		
	
	
	
		
			2.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| // Copyright 2018 Dolphin Emulator Project
 | |
| // SPDX-License-Identifier: GPL-2.0-or-later
 | |
| 
 | |
| #pragma once
 | |
| 
 | |
| #include <vector>
 | |
| 
 | |
| #include <QTableWidget>
 | |
| 
 | |
| #include "Common/CommonTypes.h"
 | |
| #include "Core/Debugger/CodeTrace.h"
 | |
| 
 | |
| class QFont;
 | |
| class QKeyEvent;
 | |
| class QMouseEvent;
 | |
| class QResizeEvent;
 | |
| class QShowEvent;
 | |
| 
 | |
| namespace Core
 | |
| {
 | |
| class CPUThreadGuard;
 | |
| class System;
 | |
| }  // namespace Core
 | |
| 
 | |
| struct CodeViewBranch;
 | |
| class BranchDisplayDelegate;
 | |
| class PPCSymbolDB;
 | |
| 
 | |
| class CodeViewWidget : public QTableWidget
 | |
| {
 | |
|   Q_OBJECT
 | |
| public:
 | |
|   enum class SetAddressUpdate
 | |
|   {
 | |
|     WithUpdate,
 | |
|     WithoutUpdate,
 | |
|     WithDetailedUpdate
 | |
|   };
 | |
| 
 | |
|   explicit CodeViewWidget();
 | |
|   ~CodeViewWidget() override;
 | |
| 
 | |
|   u32 GetAddress() const;
 | |
|   u32 GetContextAddress() const;
 | |
|   void SetAddress(u32 address, SetAddressUpdate update);
 | |
| 
 | |
|   // Set tighter row height. Set BP column sizing. This needs to run when font type changes.
 | |
|   void FontBasedSizing();
 | |
|   void Update();
 | |
|   void Update(const Core::CPUThreadGuard* guard);
 | |
| 
 | |
|   void ToggleBreakpoint();
 | |
|   void AddBreakpoint();
 | |
| 
 | |
|   u32 AddressForRow(int row) const;
 | |
| 
 | |
| signals:
 | |
|   void RequestPPCComparison(u32 addr);
 | |
|   void ShowMemory(u32 address);
 | |
|   void UpdateCodeWidget();
 | |
| 
 | |
| private:
 | |
|   enum class ReplaceWith
 | |
|   {
 | |
|     BLR,
 | |
|     NOP
 | |
|   };
 | |
| 
 | |
|   void ReplaceAddress(u32 address, ReplaceWith replace);
 | |
| 
 | |
|   void resizeEvent(QResizeEvent*) override;
 | |
|   void keyPressEvent(QKeyEvent* event) override;
 | |
|   void mousePressEvent(QMouseEvent* event) override;
 | |
|   void wheelEvent(QWheelEvent* event) override;
 | |
|   void showEvent(QShowEvent* event) override;
 | |
| 
 | |
|   void OnContextMenu();
 | |
| 
 | |
|   void AutoStep(CodeTrace::AutoStop option = CodeTrace::AutoStop::Always);
 | |
|   void OnDebugFontChanged(const QFont& font);
 | |
|   void OnFollowBranch();
 | |
|   void OnCopyAddress();
 | |
|   void OnCopyTargetAddress();
 | |
|   void OnShowInMemory();
 | |
|   void OnShowTargetInMemory();
 | |
|   void OnCopyFunction();
 | |
|   void OnCopyCode();
 | |
|   void OnCopyHex();
 | |
|   void OnRenameSymbol();
 | |
|   void OnSelectionChanged();
 | |
|   void OnSetSymbolSize();
 | |
|   void OnSetSymbolEndAddress();
 | |
|   void OnRunToHere();
 | |
|   void OnAddFunction();
 | |
|   void OnPPCComparison();
 | |
|   void OnInsertBLR();
 | |
|   void OnInsertNOP();
 | |
|   void OnReplaceInstruction();
 | |
|   void OnAssembleInstruction();
 | |
|   void DoPatchInstruction(bool assemble);
 | |
|   void OnRestoreInstruction();
 | |
| 
 | |
|   void CalculateBranchIndentation();
 | |
| 
 | |
|   Core::System& m_system;
 | |
|   PPCSymbolDB& m_ppc_symbol_db;
 | |
| 
 | |
|   bool m_updating = false;
 | |
| 
 | |
|   u32 m_address = 0;
 | |
|   u32 m_context_address = 0;
 | |
| 
 | |
|   std::vector<CodeViewBranch> m_branches;
 | |
| 
 | |
|   friend class BranchDisplayDelegate;
 | |
| };
 |