Merge pull request #1603 from shygoo/search-improvements
[Debugger] Improve the search tool
This commit is contained in:
commit
bfda4597da
|
@ -100,6 +100,7 @@
|
||||||
<ClCompile Include="UserInterface\Debugger\Debugger-ViewMemory.cpp" />
|
<ClCompile Include="UserInterface\Debugger\Debugger-ViewMemory.cpp" />
|
||||||
<ClCompile Include="UserInterface\Debugger\Debugger.cpp" />
|
<ClCompile Include="UserInterface\Debugger\Debugger.cpp" />
|
||||||
<ClCompile Include="UserInterface\Debugger\DMALog.cpp" />
|
<ClCompile Include="UserInterface\Debugger\DMALog.cpp" />
|
||||||
|
<ClCompile Include="UserInterface\Debugger\MemoryScanner.cpp" />
|
||||||
<ClCompile Include="UserInterface\Debugger\ScriptHook.cpp" />
|
<ClCompile Include="UserInterface\Debugger\ScriptHook.cpp" />
|
||||||
<ClCompile Include="UserInterface\Debugger\ScriptInstance.cpp" />
|
<ClCompile Include="UserInterface\Debugger\ScriptInstance.cpp" />
|
||||||
<ClCompile Include="UserInterface\Debugger\ScriptSystem.cpp" />
|
<ClCompile Include="UserInterface\Debugger\ScriptSystem.cpp" />
|
||||||
|
@ -165,6 +166,7 @@
|
||||||
<ClInclude Include="UserInterface\Debugger\debugger.h" />
|
<ClInclude Include="UserInterface\Debugger\debugger.h" />
|
||||||
<ClInclude Include="UserInterface\Debugger\DebuggerUI.h" />
|
<ClInclude Include="UserInterface\Debugger\DebuggerUI.h" />
|
||||||
<ClInclude Include="UserInterface\Debugger\DMALog.h" />
|
<ClInclude Include="UserInterface\Debugger\DMALog.h" />
|
||||||
|
<ClInclude Include="UserInterface\Debugger\MemoryScanner.h" />
|
||||||
<ClInclude Include="UserInterface\Debugger\OpInfo.h" />
|
<ClInclude Include="UserInterface\Debugger\OpInfo.h" />
|
||||||
<ClInclude Include="UserInterface\Debugger\ScriptHook.h" />
|
<ClInclude Include="UserInterface\Debugger\ScriptHook.h" />
|
||||||
<ClInclude Include="UserInterface\Debugger\ScriptInstance.h" />
|
<ClInclude Include="UserInterface\Debugger\ScriptInstance.h" />
|
||||||
|
|
|
@ -216,6 +216,9 @@
|
||||||
<ClCompile Include="UserInterface\Notification.cpp">
|
<ClCompile Include="UserInterface\Notification.cpp">
|
||||||
<Filter>Source Files</Filter>
|
<Filter>Source Files</Filter>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
|
<ClCompile Include="UserInterface\Debugger\MemoryScanner.cpp">
|
||||||
|
<Filter>Source Files\User Interface Source\Debugger Source</Filter>
|
||||||
|
</ClCompile>
|
||||||
<ClCompile Include="UserInterface\Settings\SettingsPage-Defaults.cpp">
|
<ClCompile Include="UserInterface\Settings\SettingsPage-Defaults.cpp">
|
||||||
<Filter>Source Files\User Interface Source\Settings Source</Filter>
|
<Filter>Source Files\User Interface Source\Settings Source</Filter>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
|
@ -428,6 +431,9 @@
|
||||||
<ClInclude Include="UserInterface\Notification.h">
|
<ClInclude Include="UserInterface\Notification.h">
|
||||||
<Filter>Header Files</Filter>
|
<Filter>Header Files</Filter>
|
||||||
</ClInclude>
|
</ClInclude>
|
||||||
|
<ClInclude Include="UserInterface\Debugger\MemoryScanner.h">
|
||||||
|
<Filter>Header Files\User Interface Headers\Settings Header</Filter>
|
||||||
|
</ClInclude>
|
||||||
<ClInclude Include="UserInterface\Settings\SettingsPage-Defaults.h">
|
<ClInclude Include="UserInterface\Settings\SettingsPage-Defaults.h">
|
||||||
<Filter>Header Files\User Interface Headers\Settings Header</Filter>
|
<Filter>Header Files\User Interface Headers\Settings Header</Filter>
|
||||||
</ClInclude>
|
</ClInclude>
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -1,6 +1,6 @@
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* *
|
* *
|
||||||
* Project64 - A Nintendo 64 emulator. *
|
* Project64 - A Nintendo 64 emulator. *
|
||||||
* http://www.pj64-emu.com/ *
|
* http://www.pj64-emu.com/ *
|
||||||
* Copyright (C) 2012 Project64. All rights reserved. *
|
* Copyright (C) 2012 Project64. All rights reserved. *
|
||||||
* *
|
* *
|
||||||
|
@ -10,8 +10,113 @@
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
|
#include "MemoryScanner.h"
|
||||||
|
#include "Debugger-AddSymbol.h"
|
||||||
|
|
||||||
|
class CEditMixed :
|
||||||
|
public CWindowImpl<CEditMixed, CEdit>,
|
||||||
|
public CMixed
|
||||||
|
{
|
||||||
|
private:
|
||||||
|
ValueType m_Type;
|
||||||
|
DisplayFormat m_DisplayFormat;
|
||||||
|
char *m_String;
|
||||||
|
int m_StringLength;
|
||||||
|
void ReloadString(void);
|
||||||
|
|
||||||
|
//void OnChar(UINT nChar, UINT nRepCnt, UINT nFlags);
|
||||||
|
|
||||||
|
public:
|
||||||
|
CEditMixed(void);
|
||||||
|
~CEditMixed(void);
|
||||||
|
|
||||||
|
BOOL Attach(HWND hWndNew);
|
||||||
|
|
||||||
|
DisplayFormat GetDisplayFormat(void);
|
||||||
|
void SetDisplayFormat(DisplayFormat fmt);
|
||||||
|
|
||||||
|
bool GetValue(uint8_t& value);
|
||||||
|
bool GetValue(int8_t& value);
|
||||||
|
bool GetValue(uint16_t& value);
|
||||||
|
bool GetValue(int16_t& value);
|
||||||
|
bool GetValue(uint32_t& value);
|
||||||
|
bool GetValue(int32_t& value);
|
||||||
|
bool GetValue(uint64_t& value);
|
||||||
|
bool GetValue(int64_t& value);
|
||||||
|
bool GetValue(float& value);
|
||||||
|
bool GetValue(double& value);
|
||||||
|
bool GetValueString(const char*& value, int& length);
|
||||||
|
bool GetValueHexString(const char*& value, int& length);
|
||||||
|
|
||||||
|
BEGIN_MSG_MAP_EX(CEditMixed)
|
||||||
|
//MSG_WM_CHAR(OnChar)
|
||||||
|
END_MSG_MAP()
|
||||||
|
};
|
||||||
|
|
||||||
|
//////////////
|
||||||
|
|
||||||
|
class CSetValueDlg : public CDialogImpl<CSetValueDlg>
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
enum { IDD = IDD_Debugger_Search_SetValue };
|
||||||
|
|
||||||
|
typedef struct
|
||||||
|
{
|
||||||
|
const char* str;
|
||||||
|
DWORD_PTR data;
|
||||||
|
} ComboItem;
|
||||||
|
|
||||||
|
INT_PTR DoModal(const char* caption, const char* label, const char* initialText);
|
||||||
|
INT_PTR DoModal(const char* caption, const char* label, DWORD_PTR initialData, const ComboItem items[]);
|
||||||
|
char* GetEnteredString(void);
|
||||||
|
DWORD_PTR GetEnteredData(void);
|
||||||
|
|
||||||
|
CSetValueDlg(void);
|
||||||
|
virtual ~CSetValueDlg(void);
|
||||||
|
|
||||||
|
private:
|
||||||
|
enum Mode
|
||||||
|
{
|
||||||
|
Mode_TextBox,
|
||||||
|
Mode_ComboBox
|
||||||
|
};
|
||||||
|
|
||||||
|
Mode m_Mode;
|
||||||
|
|
||||||
|
const char* m_Caption;
|
||||||
|
const char* m_Label;
|
||||||
|
const ComboItem* m_ComboItems;
|
||||||
|
|
||||||
|
const char* m_InitialText;
|
||||||
|
char *m_EnteredString;
|
||||||
|
|
||||||
|
DWORD_PTR m_InitialData;
|
||||||
|
DWORD_PTR m_EnteredData;
|
||||||
|
|
||||||
|
CStatic m_Prompt;
|
||||||
|
CEdit m_Value;
|
||||||
|
CComboBox m_CmbValue;
|
||||||
|
|
||||||
|
LRESULT OnInitDialog(UINT /*uMsg*/, WPARAM /*wParam*/, LPARAM /*lParam*/, BOOL& /*bHandled*/);
|
||||||
|
LRESULT OnDestroy(void);
|
||||||
|
LRESULT OnOK(WORD wNotifyCode, WORD wID, HWND hwnd, BOOL& bHandled);
|
||||||
|
LRESULT OnCancel(WORD wNotifyCode, WORD wID, HWND hwnd, BOOL& bHandled);
|
||||||
|
|
||||||
|
BEGIN_MSG_MAP_EX(CSetValueDlg)
|
||||||
|
MESSAGE_HANDLER(WM_INITDIALOG, OnInitDialog)
|
||||||
|
COMMAND_HANDLER(IDOK, BN_CLICKED, OnOK)
|
||||||
|
COMMAND_HANDLER(IDCANCEL, BN_CLICKED, OnCancel)
|
||||||
|
MSG_WM_DESTROY(OnDestroy)
|
||||||
|
END_MSG_MAP()
|
||||||
|
};
|
||||||
|
|
||||||
|
//////////////
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
class CDebugMemorySearch :
|
class CDebugMemorySearch :
|
||||||
public CDebugDialog < CDebugMemorySearch >
|
public CDebugDialog<CDebugMemorySearch>,
|
||||||
|
public CDialogResize<CDebugMemorySearch>
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
enum { IDD = IDD_Debugger_Search };
|
enum { IDD = IDD_Debugger_Search };
|
||||||
|
@ -19,72 +124,236 @@ public:
|
||||||
CDebugMemorySearch(CDebuggerUI * debugger);
|
CDebugMemorySearch(CDebuggerUI * debugger);
|
||||||
virtual ~CDebugMemorySearch(void);
|
virtual ~CDebugMemorySearch(void);
|
||||||
|
|
||||||
|
void GameReset(void);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
CDebugMemorySearch(void); // Disable default constructor
|
enum
|
||||||
CDebugMemorySearch(const CDebugMemorySearch&); // Disable copy constructor
|
|
||||||
CDebugMemorySearch& operator=(const CDebugMemorySearch&); // Disable assignment
|
|
||||||
|
|
||||||
enum MemorySize
|
|
||||||
{
|
{
|
||||||
_8Bit,
|
WM_GAMERESET = WM_USER + 1
|
||||||
_16Bit,
|
|
||||||
_32Bit,
|
|
||||||
};
|
};
|
||||||
|
|
||||||
//Searching for value
|
enum {
|
||||||
enum SearchMemChangeState
|
TIMER_ID_AUTO_REFRESH
|
||||||
{
|
|
||||||
SearchChangeState_Reset,
|
|
||||||
SearchChangeState_Changed,
|
|
||||||
SearchChangeState_Unchanged,
|
|
||||||
SearchChangeState_Greater,
|
|
||||||
SearchChangeState_Lessthan,
|
|
||||||
};
|
};
|
||||||
|
|
||||||
struct SearchResultItem
|
enum
|
||||||
{
|
{
|
||||||
DWORD PAddr;
|
GS_LINE_LEN = (sizeof("00000000 0000\n") - 1),
|
||||||
DWORD Value;
|
GS_TWOBYTE = 0x01000000
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef std::vector<SearchResultItem> SearchResult;
|
enum {
|
||||||
|
WatchListCtrl_Col_Lock,
|
||||||
|
WatchListCtrl_Col_BP,
|
||||||
|
WatchListCtrl_Col_Address,
|
||||||
|
WatchListCtrl_Col_Description,
|
||||||
|
WatchListCtrl_Col_Type,
|
||||||
|
WatchListCtrl_Col_Value,
|
||||||
|
WatchListCtrl_Num_Columns
|
||||||
|
};
|
||||||
|
|
||||||
|
enum {
|
||||||
|
ResultsListCtrl_Col_Address,
|
||||||
|
ResultsListCtrl_Col_Value,
|
||||||
|
ResultsListCtrl_Col_Previous
|
||||||
|
};
|
||||||
|
|
||||||
|
CDebugMemorySearch(void); // Disable default constructor
|
||||||
|
CDebugMemorySearch(const CDebugMemorySearch&); // Disable copy constructor
|
||||||
|
CDebugMemorySearch& operator=(const CDebugMemorySearch&); // Disable assignment
|
||||||
|
|
||||||
|
static LRESULT CALLBACK HookProc(int nCode, WPARAM wParam, LPARAM lParam);
|
||||||
|
static CDebugMemorySearch* _this;
|
||||||
|
static HHOOK hWinMessageHook;
|
||||||
|
|
||||||
|
static const CSetValueDlg::ComboItem ModalChangeTypeItems[];
|
||||||
|
|
||||||
|
LRESULT OnSetFont(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL& bHandled);
|
||||||
|
LRESULT OnInitDialog(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL& bHandled);
|
||||||
|
LRESULT OnDestroy(void);
|
||||||
|
LRESULT OnGameReset(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL& bHandled);
|
||||||
|
void OnExitSizeMove(void);
|
||||||
|
void OnSizing(UINT fwSide, LPRECT pRect);
|
||||||
|
void OnTimer(UINT_PTR nIDEvent);
|
||||||
|
LRESULT OnScroll(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL& bHandled);
|
||||||
|
LRESULT OnMouseDown(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL& bHandled);
|
||||||
|
LRESULT OnMouseUp(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL& bHandled);
|
||||||
|
void OnInterceptMouseWheel(WPARAM wParam, LPARAM lParam);
|
||||||
|
void OnInterceptMouseMove(WPARAM wParam, LPARAM lParam);
|
||||||
|
LRESULT OnMeasureItem(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL& bHandled);
|
||||||
|
LRESULT OnCancel(WORD wNotifyCode, WORD wID, HWND hwnd, BOOL& bHandled);
|
||||||
|
LRESULT OnHexCheckbox(WORD wNotifyCode, WORD wID, HWND hwnd, BOOL& bHandled);
|
||||||
|
LRESULT OnSearchButton(WORD wNotifyCode, WORD wID, HWND hwnd, BOOL& bHandled);
|
||||||
|
LRESULT OnResetButton(WORD wNotifyCode, WORD wID, HWND hwnd, BOOL& bHandled);
|
||||||
|
LRESULT OnRdramButton(WORD wNotifyCode, WORD wID, HWND hwnd, BOOL& bHandled);
|
||||||
|
LRESULT OnRomButton(WORD wNotifyCode, WORD wID, HWND hwnd, BOOL& bHandled);
|
||||||
|
LRESULT OnSpmemButton(WORD wNotifyCode, WORD wID, HWND hwnd, BOOL& bHandled);
|
||||||
|
LRESULT OnScanTypeChanged(WORD wNotifyCode, WORD wID, HWND hwnd, BOOL& bHandled);
|
||||||
|
LRESULT OnValueTypeChanged(WORD wNotifyCode, WORD wID, HWND hwnd, BOOL& bHandled);
|
||||||
|
LRESULT OnResultsCustomDraw(LPNMHDR lpnmh);
|
||||||
|
LRESULT OnResultsDblClick(LPNMHDR lpnmh);
|
||||||
|
LRESULT OnResultsRClick(LPNMHDR lpnmh);
|
||||||
|
LRESULT OnResultsPopupViewMemory(WORD wNotifyCode, WORD wID, HWND hwnd, BOOL& bHandled);
|
||||||
|
LRESULT OnResultsPopupAddToWatchList(WORD wNotifyCode, WORD wID, HWND hwnd, BOOL& bHandled);
|
||||||
|
LRESULT OnResultsPopupAddAllToWatchList(WORD wNotifyCode, WORD wID, HWND hwnd, BOOL& bHandled);
|
||||||
|
LRESULT OnResultsPopupSetValue(WORD wNotifyCode, WORD wID, HWND hwnd, BOOL& bHandled);
|
||||||
|
LRESULT OnResultsPopupRemove(WORD wNotifyCode, WORD wID, HWND hwnd, BOOL& bHandled);
|
||||||
|
LRESULT OnWatchListItemChanged(LPNMHDR lpnmh);
|
||||||
|
LRESULT OnWatchListCustomDraw(LPNMHDR lpnmh);
|
||||||
|
LRESULT OnWatchListRClick(LPNMHDR lpnmh);
|
||||||
|
LRESULT OnWatchListDblClick(LPNMHDR lpnmh);
|
||||||
|
LRESULT OnWatchListPopupLock(WORD wNotifyCode, WORD wID, HWND hwnd, BOOL& bHandled);
|
||||||
|
LRESULT OnWatchListPopupReadBP(WORD wNotifyCode, WORD wID, HWND hwnd, BOOL& bHandled);
|
||||||
|
LRESULT OnWatchListPopupWriteBP(WORD wNotifyCode, WORD wID, HWND hwnd, BOOL& bHandled);
|
||||||
|
LRESULT OnWatchListPopupViewMemory(WORD wNotifyCode, WORD wID, HWND hwnd, BOOL& bHandled);
|
||||||
|
LRESULT OnWatchListPopupAddSymbol(WORD wNotifyCode, WORD wID, HWND hwnd, BOOL& bHandled);
|
||||||
|
LRESULT OnWatchListPopupHexadecimal(WORD wNotifyCode, WORD wID, HWND hwnd, BOOL& bHandled);
|
||||||
|
LRESULT OnWatchListPopupChangeValue(WORD wNotifyCode, WORD wID, HWND hwnd, BOOL& bHandled);
|
||||||
|
LRESULT OnWatchListPopupChangeDescription(WORD wNotifyCode, WORD wID, HWND hwnd, BOOL& bHandled);
|
||||||
|
LRESULT OnWatchListPopupChangeType(WORD wNotifyCode, WORD wID, HWND hwnd, BOOL& bHandled);
|
||||||
|
LRESULT OnWatchListPopupChangeAddress(WORD wNotifyCode, WORD wID, HWND hwnd, BOOL& bHandled);
|
||||||
|
LRESULT OnWatchListPopupChangeAddressBy(WORD wNotifyCode, WORD wID, HWND hwnd, BOOL& bHandled);
|
||||||
|
LRESULT OnWatchListPopupRemove(WORD wNotifyCode, WORD wID, HWND hwnd, BOOL& bHandled);
|
||||||
|
LRESULT OnWatchListPopupRemoveAll(WORD wNotifyCode, WORD wID, HWND hwnd, BOOL& bHandled);
|
||||||
|
LRESULT OnWatchListPopupCopyGamesharkCode(WORD wNotifyCode, WORD wID, HWND hwnd, BOOL& bHandled);
|
||||||
|
LRESULT OnWatchListPopupCopyAddressAndDescription(WORD wNotifyCode, WORD wID, HWND hwnd, BOOL& bHandled);
|
||||||
|
|
||||||
|
CScanResult* GetFirstSelectedScanResult(void);
|
||||||
|
CScanResult* GetFirstSelectedWatchListResult(void);
|
||||||
|
|
||||||
|
void ResetResults(void);
|
||||||
|
void Search(void);
|
||||||
|
void UpdateOptions(void);
|
||||||
|
void UpdateResultsList(bool bUpdateScrollbar = false, bool bResetScrollPos = true);
|
||||||
|
void UpdateWatchList(bool bUpdateScrollbar = false);
|
||||||
|
void RefreshResultsListValues(void);
|
||||||
|
void RefreshWatchListValues(void);
|
||||||
|
void RemoveWatchListItem(int index);
|
||||||
|
void ClearWatchList(void);
|
||||||
|
void ReloadWatchList(void);
|
||||||
|
void FlushWatchList(void);
|
||||||
|
void LoadWatchList(void);
|
||||||
|
void RemoveSelectedWatchListItems(void);
|
||||||
|
void AddResultToWatchList(int resultIndex);
|
||||||
|
|
||||||
|
void SeparatorMoveCtrl(WORD ctrlId, int yChange, bool bResize);
|
||||||
|
|
||||||
|
CPath GetWatchListPath(void);
|
||||||
|
|
||||||
|
/* generic ui util */
|
||||||
|
void FixListHeader(CListViewCtrl& listCtrl);
|
||||||
|
void SetComboBoxSelByData(CComboBox& cb, DWORD_PTR data);
|
||||||
|
bool MouseHovering(WORD ctrlId, int hMargin = 0, int vMargin = 0);
|
||||||
|
int GetNumVisibleRows(CListViewCtrl& list);
|
||||||
|
/*******************/
|
||||||
|
|
||||||
|
bool m_bJalSelected;
|
||||||
|
bool m_bJalHexWasChecked;
|
||||||
|
bool m_bJalUnsignedWasChecked;
|
||||||
|
|
||||||
|
stdstr m_StrGame;
|
||||||
|
DWORD m_ThreadId;
|
||||||
|
CFile m_WatchListFile;
|
||||||
|
|
||||||
|
CSetValueDlg m_SetValueDlg;
|
||||||
|
CAddSymbolDlg m_AddSymbolDlg;
|
||||||
|
|
||||||
|
CEditMixed m_SearchValue;
|
||||||
|
CEditNumber32 m_AddrStart, m_AddrEnd;
|
||||||
|
CComboBox m_SearchTypeOptions, m_ValueTypeOptions;
|
||||||
|
CListViewCtrl m_ResultsListCtrl, m_WatchListCtrl;
|
||||||
|
CScrollBar m_ResultsScrollbar, m_WatchListScrollbar;
|
||||||
|
CButton m_PhysicalCheckbox, m_HexCheckbox;
|
||||||
|
CButton m_UnsignedCheckbox, m_IgnoreCaseCheckbox, m_UnkEncodingCheckbox;
|
||||||
|
|
||||||
|
CMemoryScanner m_MemoryScanner;
|
||||||
|
std::vector<CScanResult> m_WatchList;
|
||||||
|
|
||||||
|
bool m_bDraggingSeparator;
|
||||||
|
CRect m_InitialSeparatorRect, m_LastSeparatorRect;
|
||||||
|
|
||||||
|
int m_ListCtrlRowHeight;
|
||||||
|
|
||||||
|
HCURSOR m_hCursorSizeNS;
|
||||||
|
|
||||||
BEGIN_MSG_MAP_EX(CDebugMemorySearch)
|
BEGIN_MSG_MAP_EX(CDebugMemorySearch)
|
||||||
|
MESSAGE_HANDLER(WM_GAMERESET, OnGameReset)
|
||||||
MESSAGE_HANDLER(WM_INITDIALOG, OnInitDialog)
|
MESSAGE_HANDLER(WM_INITDIALOG, OnInitDialog)
|
||||||
COMMAND_CODE_HANDLER(BN_CLICKED, OnClicked)
|
MSG_WM_DESTROY(OnDestroy)
|
||||||
NOTIFY_HANDLER_EX(IDC_LST_RESULTS, NM_RCLICK, OnResultRClick)
|
MSG_WM_EXITSIZEMOVE(OnExitSizeMove)
|
||||||
NOTIFY_HANDLER_EX(IDC_LST_RESULTS, NM_DBLCLK, OnResultDblClick)
|
MSG_WM_SIZING(OnSizing)
|
||||||
MSG_WM_EXITSIZEMOVE(OnExitSizeMove)
|
MSG_WM_TIMER(OnTimer)
|
||||||
END_MSG_MAP()
|
COMMAND_HANDLER(IDCANCEL, BN_CLICKED, OnCancel)
|
||||||
|
MESSAGE_HANDLER(WM_VSCROLL, OnScroll)
|
||||||
|
MESSAGE_HANDLER(WM_LBUTTONDOWN, OnMouseDown)
|
||||||
|
MESSAGE_HANDLER(WM_LBUTTONUP, OnMouseUp)
|
||||||
|
MESSAGE_HANDLER(WM_MEASUREITEM, OnMeasureItem)
|
||||||
|
MESSAGE_HANDLER(WM_SETFONT, OnSetFont)
|
||||||
|
COMMAND_HANDLER(IDC_CHK_HEX, BN_CLICKED, OnHexCheckbox)
|
||||||
|
COMMAND_HANDLER(IDC_BTN_SEARCH, BN_CLICKED, OnSearchButton)
|
||||||
|
COMMAND_HANDLER(IDC_BTN_RESET, BN_CLICKED, OnResetButton)
|
||||||
|
COMMAND_HANDLER(IDC_CMB_SCANTYPE, CBN_SELCHANGE, OnScanTypeChanged)
|
||||||
|
COMMAND_HANDLER(IDC_CMB_VALUETYPE, CBN_SELCHANGE, OnValueTypeChanged)
|
||||||
|
COMMAND_HANDLER(IDC_BTN_RDRAM, BN_CLICKED, OnRdramButton)
|
||||||
|
COMMAND_HANDLER(IDC_BTN_ROM, BN_CLICKED, OnRomButton)
|
||||||
|
COMMAND_HANDLER(IDC_BTN_SPMEM, BN_CLICKED, OnSpmemButton)
|
||||||
|
NOTIFY_HANDLER_EX(IDC_LST_RESULTS, NM_CUSTOMDRAW, OnResultsCustomDraw)
|
||||||
|
NOTIFY_HANDLER_EX(IDC_LST_RESULTS, NM_DBLCLK, OnResultsDblClick)
|
||||||
|
NOTIFY_HANDLER_EX(IDC_LST_RESULTS, NM_RCLICK, OnResultsRClick)
|
||||||
|
COMMAND_HANDLER(ID_RESULTS_VIEWMEMORY, BN_CLICKED, OnResultsPopupViewMemory)
|
||||||
|
COMMAND_HANDLER(ID_RESULTS_ADDTOWATCHLIST, BN_CLICKED, OnResultsPopupAddToWatchList)
|
||||||
|
COMMAND_HANDLER(ID_RESULTS_ADDALLTOWATCHLIST, BN_CLICKED, OnResultsPopupAddAllToWatchList)
|
||||||
|
COMMAND_HANDLER(ID_RESULTS_CHANGEVALUE, BN_CLICKED, OnResultsPopupSetValue)
|
||||||
|
COMMAND_HANDLER(ID_RESULTS_REMOVE, BN_CLICKED, OnResultsPopupRemove)
|
||||||
|
NOTIFY_HANDLER_EX(IDC_LST_WATCHLIST, LVN_ITEMCHANGED, OnWatchListItemChanged)
|
||||||
|
NOTIFY_HANDLER_EX(IDC_LST_WATCHLIST, NM_CUSTOMDRAW, OnWatchListCustomDraw)
|
||||||
|
NOTIFY_HANDLER_EX(IDC_LST_WATCHLIST, NM_DBLCLK, OnWatchListDblClick)
|
||||||
|
NOTIFY_HANDLER_EX(IDC_LST_WATCHLIST, NM_RCLICK, OnWatchListRClick)
|
||||||
|
COMMAND_HANDLER(ID_WATCHLIST_VIEWMEMORY, BN_CLICKED, OnWatchListPopupViewMemory)
|
||||||
|
COMMAND_HANDLER(ID_WATCHLIST_LOCKVALUE, BN_CLICKED, OnWatchListPopupLock)
|
||||||
|
COMMAND_HANDLER(ID_WATCHLIST_READBP, BN_CLICKED, OnWatchListPopupReadBP)
|
||||||
|
COMMAND_HANDLER(ID_WATCHLIST_WRITEBP, BN_CLICKED, OnWatchListPopupWriteBP)
|
||||||
|
COMMAND_HANDLER(ID_WATCHLIST_ADDSYMBOL, BN_CLICKED, OnWatchListPopupAddSymbol)
|
||||||
|
COMMAND_HANDLER(ID_WATCHLIST_HEXADECIMAL, BN_CLICKED, OnWatchListPopupHexadecimal)
|
||||||
|
COMMAND_HANDLER(ID_WATCHLIST_CHANGE_VALUE, BN_CLICKED, OnWatchListPopupChangeValue)
|
||||||
|
COMMAND_HANDLER(ID_WATCHLIST_CHANGE_DESCRIPTION, BN_CLICKED, OnWatchListPopupChangeDescription)
|
||||||
|
COMMAND_HANDLER(ID_WATCHLIST_CHANGE_TYPE, BN_CLICKED, OnWatchListPopupChangeType)
|
||||||
|
COMMAND_HANDLER(ID_WATCHLIST_CHANGE_ADDRESS, BN_CLICKED, OnWatchListPopupChangeAddress)
|
||||||
|
COMMAND_HANDLER(ID_WATCHLIST_CHANGE_ADDRESSBY, BN_CLICKED, OnWatchListPopupChangeAddressBy)
|
||||||
|
COMMAND_HANDLER(ID_WATCHLIST_REMOVE, BN_CLICKED, OnWatchListPopupRemove)
|
||||||
|
COMMAND_HANDLER(ID_WATCHLIST_REMOVEALL, BN_CLICKED, OnWatchListPopupRemoveAll)
|
||||||
|
COMMAND_HANDLER(ID_WATCHLIST_COPY_GSCODE, BN_CLICKED, OnWatchListPopupCopyGamesharkCode)
|
||||||
|
COMMAND_HANDLER(ID_WATCHLIST_COPY_ADDRDESC, BN_CLICKED, OnWatchListPopupCopyAddressAndDescription)
|
||||||
|
CHAIN_MSG_MAP(CDialogResize<CDebugMemorySearch>)
|
||||||
|
END_MSG_MAP()
|
||||||
|
|
||||||
LRESULT OnInitDialog(UINT /*uMsg*/, WPARAM /*wParam*/, LPARAM /*lParam*/, BOOL& /*bHandled*/);
|
BEGIN_DLGRESIZE_MAP(CDebugMemorySearch)
|
||||||
LRESULT OnClicked(WORD wNotifyCode, WORD wID, HWND /*hWndCtl*/, BOOL& bHandled);
|
DLGRESIZE_CONTROL(IDC_LST_WATCHLIST, DLSZ_SIZE_X | DLSZ_SIZE_Y)
|
||||||
LRESULT OnResultRClick(LPNMHDR lpnmh);
|
DLGRESIZE_CONTROL(IDC_SCRL_WATCHLIST, DLSZ_MOVE_X | DLSZ_SIZE_Y)
|
||||||
LRESULT OnResultDblClick(LPNMHDR lpnmh);
|
DLGRESIZE_CONTROL(IDC_NUM_RESULTS, DLSZ_SIZE_X)
|
||||||
void OnExitSizeMove(void);
|
DLGRESIZE_CONTROL(IDC_LST_RESULTS, DLSZ_SIZE_X)
|
||||||
|
DLGRESIZE_CONTROL(IDC_SCRL_RESULTS, DLSZ_MOVE_X)
|
||||||
void EnableUnknownOptions(bool Enable);
|
DLGRESIZE_CONTROL(IDC_SEPARATOR, DLSZ_SIZE_X)
|
||||||
void EnableValueOptions(bool Enable);
|
DLGRESIZE_CONTROL(IDC_BTN_SEARCH, DLSZ_MOVE_X)
|
||||||
void EnableTextOptions(bool Enable);
|
DLGRESIZE_CONTROL(IDC_BTN_RESET, DLSZ_MOVE_X)
|
||||||
void EnableJalOptions(bool Enable);
|
DLGRESIZE_CONTROL(IDC_GRP_SEARCH, DLSZ_MOVE_X)
|
||||||
void AddAlignmentOptions(CComboBox & ctrl);
|
DLGRESIZE_CONTROL(IDC_CHK_HEX, DLSZ_MOVE_X)
|
||||||
|
DLGRESIZE_CONTROL(IDC_CHK_UNSIGNED, DLSZ_MOVE_X)
|
||||||
CEditNumber32 m_PAddrStart, m_SearchLen, m_SearchValue, m_MaxSearch;
|
DLGRESIZE_CONTROL(IDC_CHK_IGNORECASE, DLSZ_MOVE_X)
|
||||||
CComboBox m_UnknownOptions, m_ValueSize, m_UnknownSize;
|
DLGRESIZE_CONTROL(IDC_CHK_UNKENCODING, DLSZ_MOVE_X)
|
||||||
CListViewCtrl m_SearchResults;
|
DLGRESIZE_CONTROL(IDC_SEARCH_VALUE, DLSZ_MOVE_X)
|
||||||
SearchResult m_SearchResult;
|
DLGRESIZE_CONTROL(IDC_LBL_SCANTYPE, DLSZ_MOVE_X)
|
||||||
bool m_HaveResults;
|
DLGRESIZE_CONTROL(IDC_LBL_VALUETYPE, DLSZ_MOVE_X)
|
||||||
|
DLGRESIZE_CONTROL(IDC_CMB_SCANTYPE, DLSZ_MOVE_X)
|
||||||
//Searching memory
|
DLGRESIZE_CONTROL(IDC_CMB_VALUETYPE, DLSZ_MOVE_X)
|
||||||
BYTE * m_MemoryState;
|
DLGRESIZE_CONTROL(IDC_LBL_ADDRSTART, DLSZ_MOVE_X)
|
||||||
DWORD m_MemoryStateSize;
|
DLGRESIZE_CONTROL(IDC_LBL_ADDREND, DLSZ_MOVE_X)
|
||||||
|
DLGRESIZE_CONTROL(IDC_ADDR_START, DLSZ_MOVE_X)
|
||||||
void FixUnknownOptions(bool Reset);
|
DLGRESIZE_CONTROL(IDC_ADDR_END, DLSZ_MOVE_X)
|
||||||
void SearchForUnknown(void);
|
DLGRESIZE_CONTROL(IDC_CHK_PHYSICAL, DLSZ_MOVE_X)
|
||||||
void SearchForValue(void);
|
DLGRESIZE_CONTROL(IDC_BTN_RDRAM, DLSZ_MOVE_X)
|
||||||
void SearchForText(void);
|
DLGRESIZE_CONTROL(IDC_BTN_ROM, DLSZ_MOVE_X)
|
||||||
void Reset(void);
|
DLGRESIZE_CONTROL(IDC_BTN_SPMEM, DLSZ_MOVE_X)
|
||||||
bool SearchSetBaseForChanges(void);
|
DLGRESIZE_CONTROL(IDC_GRP_ADDR, DLSZ_MOVE_X)
|
||||||
bool SearchForChanges(SearchMemChangeState SearchType, MemorySize Size, DWORD &StartAddress, DWORD &Len, DWORD &OldValue, DWORD &NewValue);
|
END_DLGRESIZE_MAP()
|
||||||
bool SearchForValue(DWORD Value, MemorySize Size, DWORD &StartAddress, DWORD &Len);
|
|
||||||
};
|
};
|
||||||
|
|
|
@ -49,12 +49,16 @@ CDebuggerUI::CDebuggerUI() :
|
||||||
CSymbols::InitializeCriticalSection();
|
CSymbols::InitializeCriticalSection();
|
||||||
g_Settings->RegisterChangeCB(GameRunning_InReset, this, (CSettings::SettingChangedFunc)GameReset);
|
g_Settings->RegisterChangeCB(GameRunning_InReset, this, (CSettings::SettingChangedFunc)GameReset);
|
||||||
g_Settings->RegisterChangeCB(Debugger_SteppingOps, this, (CSettings::SettingChangedFunc)SteppingOpsChanged);
|
g_Settings->RegisterChangeCB(Debugger_SteppingOps, this, (CSettings::SettingChangedFunc)SteppingOpsChanged);
|
||||||
|
g_Settings->RegisterChangeCB(GameRunning_CPU_Running, this, (CSettings::SettingChangedFunc)GameCpuRunningChanged);
|
||||||
|
g_Settings->RegisterChangeCB(Game_GameName, this, (CSettings::SettingChangedFunc)GameNameChanged);
|
||||||
}
|
}
|
||||||
|
|
||||||
CDebuggerUI::~CDebuggerUI(void)
|
CDebuggerUI::~CDebuggerUI(void)
|
||||||
{
|
{
|
||||||
g_Settings->UnregisterChangeCB(Debugger_SteppingOps, this, (CSettings::SettingChangedFunc)SteppingOpsChanged);
|
g_Settings->UnregisterChangeCB(Debugger_SteppingOps, this, (CSettings::SettingChangedFunc)SteppingOpsChanged);
|
||||||
g_Settings->UnregisterChangeCB(GameRunning_InReset, this, (CSettings::SettingChangedFunc)GameReset);
|
g_Settings->UnregisterChangeCB(GameRunning_InReset, this, (CSettings::SettingChangedFunc)GameReset);
|
||||||
|
g_Settings->RegisterChangeCB(GameRunning_CPU_Running, this, (CSettings::SettingChangedFunc)GameCpuRunningChanged);
|
||||||
|
g_Settings->UnregisterChangeCB(Game_GameName, this, (CSettings::SettingChangedFunc)GameNameChanged);
|
||||||
Debug_Reset();
|
Debug_Reset();
|
||||||
delete m_MemoryView;
|
delete m_MemoryView;
|
||||||
delete m_CommandsView;
|
delete m_CommandsView;
|
||||||
|
@ -81,6 +85,25 @@ void CDebuggerUI::SteppingOpsChanged(CDebuggerUI * _this)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void CDebuggerUI::GameCpuRunningChanged(CDebuggerUI * _this)
|
||||||
|
{
|
||||||
|
if (!g_Settings->LoadBool(GameRunning_CPU_Running))
|
||||||
|
{
|
||||||
|
if (_this->m_MemorySearch)
|
||||||
|
{
|
||||||
|
_this->m_MemorySearch->GameReset();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void CDebuggerUI::GameNameChanged(CDebuggerUI * _this)
|
||||||
|
{
|
||||||
|
if (_this->m_MemorySearch)
|
||||||
|
{
|
||||||
|
_this->m_MemorySearch->GameReset();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void CDebuggerUI::GameReset(CDebuggerUI * _this)
|
void CDebuggerUI::GameReset(CDebuggerUI * _this)
|
||||||
{
|
{
|
||||||
if (!g_Settings->LoadBool(GameRunning_InReset))
|
if (!g_Settings->LoadBool(GameRunning_InReset))
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -0,0 +1,394 @@
|
||||||
|
/****************************************************************************
|
||||||
|
* *
|
||||||
|
* Project64 - A Nintendo 64 emulator. *
|
||||||
|
* http://www.pj64-emu.com/ *
|
||||||
|
* Copyright (C) 2012 Project64. All rights reserved. *
|
||||||
|
* *
|
||||||
|
* License: *
|
||||||
|
* GNU/GPLv2 http://www.gnu.org/licenses/gpl-2.0.html *
|
||||||
|
* *
|
||||||
|
****************************************************************************/
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include <stdafx.h>
|
||||||
|
|
||||||
|
enum ValueType
|
||||||
|
{
|
||||||
|
ValueType_invalid = -1,
|
||||||
|
ValueType_uint8,
|
||||||
|
ValueType_int8,
|
||||||
|
ValueType_uint16,
|
||||||
|
ValueType_int16,
|
||||||
|
ValueType_uint32,
|
||||||
|
ValueType_int32,
|
||||||
|
ValueType_uint64,
|
||||||
|
ValueType_int64,
|
||||||
|
ValueType_float,
|
||||||
|
ValueType_double,
|
||||||
|
// non-primitives:
|
||||||
|
ValueType_string,
|
||||||
|
ValueType_istring,
|
||||||
|
ValueType_unkstring
|
||||||
|
};
|
||||||
|
|
||||||
|
enum AddressType
|
||||||
|
{
|
||||||
|
AddressType_Physical,
|
||||||
|
AddressType_Virtual
|
||||||
|
};
|
||||||
|
|
||||||
|
enum SearchType
|
||||||
|
{
|
||||||
|
SearchType_ExactValue,
|
||||||
|
SearchType_LessThanValue,
|
||||||
|
SearchType_GreaterThanValue,
|
||||||
|
SearchType_LessThanOrEqualToValue,
|
||||||
|
SearchType_GreaterThanOrEqualToValue,
|
||||||
|
// first scan only:
|
||||||
|
SearchType_UnknownValue,
|
||||||
|
SearchType_JalTo,
|
||||||
|
// next scan only:
|
||||||
|
SearchType_ChangedValue,
|
||||||
|
SearchType_UnchangedValue,
|
||||||
|
SearchType_IncreasedValue,
|
||||||
|
SearchType_DecreasedValue
|
||||||
|
};
|
||||||
|
|
||||||
|
enum DisplayFormat
|
||||||
|
{
|
||||||
|
DisplayDefault,
|
||||||
|
DisplayHex
|
||||||
|
};
|
||||||
|
|
||||||
|
typedef union {
|
||||||
|
uint8_t _uint8;
|
||||||
|
int8_t _sint8;
|
||||||
|
uint16_t _uint16;
|
||||||
|
int16_t _sint16;
|
||||||
|
uint32_t _uint32;
|
||||||
|
int32_t _sint32;
|
||||||
|
uint64_t _uint64;
|
||||||
|
int64_t _sint64;
|
||||||
|
float _float;
|
||||||
|
double _double;
|
||||||
|
const char* _string;
|
||||||
|
} MixedValue;
|
||||||
|
|
||||||
|
class CMixed
|
||||||
|
{
|
||||||
|
protected:
|
||||||
|
ValueType m_Type;
|
||||||
|
int m_StrLength;
|
||||||
|
|
||||||
|
public:
|
||||||
|
MixedValue m_Value;
|
||||||
|
|
||||||
|
CMixed()
|
||||||
|
{
|
||||||
|
m_StrLength = 0;
|
||||||
|
m_Value._uint64 = 0;
|
||||||
|
m_Type = ValueType_uint64;
|
||||||
|
}
|
||||||
|
|
||||||
|
inline void SetType(ValueType t) { m_Type = t; }
|
||||||
|
inline ValueType GetType(void) { return m_Type; }
|
||||||
|
|
||||||
|
inline void SetStrLength(int length) { m_StrLength = length; }
|
||||||
|
inline int GetStrLength(void) { return m_StrLength; }
|
||||||
|
|
||||||
|
inline void Set(uint8_t v) { SetType(ValueType_uint8); m_Value._uint8 = v; }
|
||||||
|
inline void Set(int8_t v) { SetType(ValueType_int8); m_Value._sint8 = v; }
|
||||||
|
inline void Set(uint16_t v) { SetType(ValueType_uint16); m_Value._uint16 = v; }
|
||||||
|
inline void Set(int16_t v) { SetType(ValueType_int16); m_Value._sint16 = v; }
|
||||||
|
inline void Set(uint32_t v) { SetType(ValueType_uint32); m_Value._uint32 = v; }
|
||||||
|
inline void Set(int32_t v) { SetType(ValueType_int32); m_Value._sint32 = v; }
|
||||||
|
inline void Set(uint64_t v) { SetType(ValueType_uint64); m_Value._uint64 = v; }
|
||||||
|
inline void Set(int64_t v) { SetType(ValueType_int64); m_Value._sint64 = v; }
|
||||||
|
inline void Set(float v) { SetType(ValueType_float); m_Value._float = v; }
|
||||||
|
inline void Set(double v) { SetType(ValueType_double); m_Value._double = v; }
|
||||||
|
inline void Set(const char* v) { SetType(ValueType_string); m_Value._string = v; }
|
||||||
|
|
||||||
|
inline void Get(uint8_t* v) { *v = m_Value._uint8; }
|
||||||
|
inline void Get(int8_t* v) { *v = m_Value._sint8; }
|
||||||
|
inline void Get(uint16_t* v) { *v = m_Value._uint16; }
|
||||||
|
inline void Get(int16_t* v) { *v = m_Value._sint16; }
|
||||||
|
inline void Get(uint32_t* v) { *v = m_Value._uint32; }
|
||||||
|
inline void Get(int32_t* v) { *v = m_Value._sint32; }
|
||||||
|
inline void Get(uint64_t* v) { *v = m_Value._uint64; }
|
||||||
|
inline void Get(int64_t* v) { *v = m_Value._sint64; }
|
||||||
|
inline void Get(float* v) { *v = m_Value._float; }
|
||||||
|
inline void Get(double* v) { *v = m_Value._double; }
|
||||||
|
inline void Get(const char** v) { *v = m_Value._string; }
|
||||||
|
|
||||||
|
const char* GetTypeName(void);
|
||||||
|
int GetTypeSize(void);
|
||||||
|
bool IsStringType(void);
|
||||||
|
int ToString(char* buffer, bool bHex, size_t size);
|
||||||
|
|
||||||
|
static ValueType GetTypeFromString(const char* name, int* typeArraySize);
|
||||||
|
|
||||||
|
private:
|
||||||
|
typedef struct
|
||||||
|
{
|
||||||
|
const char* name;
|
||||||
|
ValueType type;
|
||||||
|
} TypeNameEntry;
|
||||||
|
|
||||||
|
static TypeNameEntry TypeNames[];
|
||||||
|
};
|
||||||
|
|
||||||
|
class CScanResult : public CMixed
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
CScanResult(AddressType addressType, DisplayFormat displayFormat);
|
||||||
|
~CScanResult(void);
|
||||||
|
|
||||||
|
uint32_t m_Address;
|
||||||
|
AddressType m_AddressType;
|
||||||
|
DisplayFormat m_DisplayFormat;
|
||||||
|
bool m_bSelected;
|
||||||
|
char* m_Description;
|
||||||
|
|
||||||
|
public:
|
||||||
|
int GetValueString(char* buffer, size_t size);
|
||||||
|
int GetMemoryValueString(char* buffer, size_t size);
|
||||||
|
int GetAddressString(char *buffer);
|
||||||
|
uint32_t GetVirtualAddress(void);
|
||||||
|
bool SetMemoryValueFromString(char* str);
|
||||||
|
//bool IsSelected(void);
|
||||||
|
//void SetSelected(bool bSelected);
|
||||||
|
void SetDescription(char* str);
|
||||||
|
const char* GetDescription(void);
|
||||||
|
void DeleteDescription(void);
|
||||||
|
bool GetMemoryValue(CMixed* v);
|
||||||
|
|
||||||
|
bool SetAddressSafe(uint32_t address);
|
||||||
|
bool SetStrLengthSafe(int length);
|
||||||
|
};
|
||||||
|
|
||||||
|
class CMemoryScanner
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
CMemoryScanner(void);
|
||||||
|
|
||||||
|
bool SetAddressRange(uint32_t startAddress, uint32_t endAddress);
|
||||||
|
bool SetValueType(ValueType type);
|
||||||
|
bool SetSearchType(SearchType searchType);
|
||||||
|
void SetAddressType(AddressType addressType);
|
||||||
|
|
||||||
|
static int ParseHexString(char* dst, char* src);
|
||||||
|
|
||||||
|
static bool AddrCheck(uint32_t addr, uint32_t rangeStart, uint32_t rangeEnd);
|
||||||
|
static bool RangeCheck(uint32_t addrStart, uint32_t addrEnd, uint32_t rangeStart, uint32_t rangeEnd);
|
||||||
|
static bool PAddrValid(uint32_t physAddr);
|
||||||
|
static bool PAddrRangeValid(uint32_t physAddrStart, uint32_t physAddrEnd);
|
||||||
|
|
||||||
|
template <class T>
|
||||||
|
void SetValue(T value)
|
||||||
|
{
|
||||||
|
*(T*)&m_Value = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
void SetStringValueLength(int length);
|
||||||
|
|
||||||
|
void Reset(void);
|
||||||
|
bool FirstScan(DisplayFormat resDisplayFormat = DisplayDefault);
|
||||||
|
bool NextScan(void);
|
||||||
|
|
||||||
|
bool DidFirstScan(void);
|
||||||
|
|
||||||
|
size_t GetNumResults(void);
|
||||||
|
CScanResult* GetResult(size_t index);
|
||||||
|
void RemoveResult(size_t index);
|
||||||
|
|
||||||
|
private:
|
||||||
|
static int HexDigitVal(char c);
|
||||||
|
|
||||||
|
uint8_t* m_Memory;
|
||||||
|
bool m_DidFirstScan;
|
||||||
|
|
||||||
|
uint32_t m_RangeStartAddress;
|
||||||
|
uint32_t m_RangeEndAddress;
|
||||||
|
|
||||||
|
ValueType m_ValueType;
|
||||||
|
bool m_bDataTypePrimitive;
|
||||||
|
SearchType m_SearchType;
|
||||||
|
AddressType m_AddressType;
|
||||||
|
uint32_t m_VAddrBits;
|
||||||
|
|
||||||
|
std::vector<CScanResult> m_Results;
|
||||||
|
std::vector<CScanResult> m_NewResults;
|
||||||
|
|
||||||
|
MixedValue m_Value;
|
||||||
|
int m_StringValueLength;
|
||||||
|
|
||||||
|
friend class CScanResult;
|
||||||
|
static uint8_t* GetMemoryPool(uint32_t physAddr);
|
||||||
|
|
||||||
|
template <class T> static bool CompareLessThan(T a, T b) { return a < b; }
|
||||||
|
template <class T> static bool CompareLessThanOrEqual(T a, T b) { return a <= b; }
|
||||||
|
template <class T> static bool CompareGreaterThan(T a, T b) { return a > b; }
|
||||||
|
template <class T> static bool CompareGreaterThanOrEqual(T a, T b) { return a >= b; }
|
||||||
|
template <class T> static bool CompareEqual(T a, T b) { return a == b; }
|
||||||
|
template <class T> static bool CompareNotEqual(T a, T b) { return a != b; }
|
||||||
|
template <class T> static bool NoCompare(T /*a*/, T /*b*/) { return true; }
|
||||||
|
|
||||||
|
void FirstScanLoopString(DisplayFormat resultDisplayFormat);
|
||||||
|
void FirstScanLoopIString(DisplayFormat resultDisplayFormat);
|
||||||
|
void FirstScanLoopUnkString(void);
|
||||||
|
|
||||||
|
template <class T>
|
||||||
|
void FirstScanLoopPrimitive(bool(*CompareFunc)(T, T), DisplayFormat resultDisplayFormat)
|
||||||
|
{
|
||||||
|
T searchValue = *(T*)&m_Value;
|
||||||
|
uint32_t startAddr = ((m_RangeStartAddress - 1) | (sizeof(T) - 1)) + 1;
|
||||||
|
uint32_t endAddr = m_RangeEndAddress;
|
||||||
|
|
||||||
|
CScanResult result(m_AddressType, resultDisplayFormat);
|
||||||
|
|
||||||
|
for (uint32_t addr = startAddr; addr <= endAddr; addr += sizeof(T))
|
||||||
|
{
|
||||||
|
uint32_t leAddr = (addr ^ (4 - sizeof(T)));
|
||||||
|
T memValue = *(T*)&m_Memory[leAddr];
|
||||||
|
|
||||||
|
if (CompareFunc(memValue, searchValue))
|
||||||
|
{
|
||||||
|
result.m_Address = addr | m_VAddrBits;
|
||||||
|
result.Set(memValue);
|
||||||
|
m_Results.push_back(result);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// for int64 and double
|
||||||
|
template <class T>
|
||||||
|
void FirstScanLoopPrimitive64(bool(*CompareFunc)(T, T), DisplayFormat resultDisplayFormat)
|
||||||
|
{
|
||||||
|
T searchValue = *(T*)&m_Value;
|
||||||
|
uint32_t startAddr = ((m_RangeStartAddress - 1) | (sizeof(T) - 1)) + 1;
|
||||||
|
uint32_t endAddr = m_RangeEndAddress;
|
||||||
|
|
||||||
|
CScanResult result(m_AddressType, resultDisplayFormat);
|
||||||
|
|
||||||
|
for (uint32_t addr = startAddr; addr <= endAddr; addr += sizeof(T))
|
||||||
|
{
|
||||||
|
T memValue;
|
||||||
|
|
||||||
|
*((uint32_t*)(&memValue) + 1) = *(uint32_t*) &m_Memory[addr];
|
||||||
|
*((uint32_t*)(&memValue) + 0) = *(uint32_t*) &m_Memory[addr + 4];
|
||||||
|
|
||||||
|
if (CompareFunc(memValue, searchValue))
|
||||||
|
{
|
||||||
|
result.m_Address = addr | m_VAddrBits;
|
||||||
|
result.Set(memValue);
|
||||||
|
m_Results.push_back(result);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// compare result's current value in memory against m_Value
|
||||||
|
template <class T>
|
||||||
|
void NextScanLoopPrimitive(bool(*CompareFunc)(T, T))
|
||||||
|
{
|
||||||
|
T searchValue = *(T*)&m_Value;
|
||||||
|
|
||||||
|
for (size_t index = 0; index < m_Results.size(); index++)
|
||||||
|
{
|
||||||
|
CScanResult* presult = &m_Results[index];
|
||||||
|
|
||||||
|
uint32_t addr = presult->m_Address & 0x1FFFFFFF;
|
||||||
|
uint32_t leAddr = (addr ^ (4 - sizeof(T)));
|
||||||
|
T memValue = *(T*) &m_Memory[leAddr];
|
||||||
|
|
||||||
|
if (CompareFunc(memValue, searchValue))
|
||||||
|
{
|
||||||
|
presult->Set(memValue);
|
||||||
|
m_NewResults.push_back(*presult);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
m_Results.clear();
|
||||||
|
m_Results.swap(m_NewResults);
|
||||||
|
}
|
||||||
|
|
||||||
|
// compare result's current value in memory against m_Value (for 64 bit types)
|
||||||
|
template <class T>
|
||||||
|
void NextScanLoopPrimitive64(bool(*CompareFunc)(T, T))
|
||||||
|
{
|
||||||
|
T searchValue = *(T*)&m_Value;
|
||||||
|
|
||||||
|
for (size_t index = 0; index < m_Results.size(); index++)
|
||||||
|
{
|
||||||
|
CScanResult* presult = &m_Results[index];
|
||||||
|
|
||||||
|
uint32_t addr = presult->m_Address & 0x1FFFFFFF;
|
||||||
|
T memValue;
|
||||||
|
|
||||||
|
*((uint32_t*)(&memValue) + 1) = *(uint32_t*) &m_Memory[addr];
|
||||||
|
*((uint32_t*)(&memValue) + 0) = *(uint32_t*) &m_Memory[addr + 4];
|
||||||
|
|
||||||
|
if (CompareFunc(memValue, searchValue))
|
||||||
|
{
|
||||||
|
presult->Set(memValue);
|
||||||
|
m_NewResults.push_back(*presult);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
m_Results.clear();
|
||||||
|
m_Results.swap(m_NewResults);
|
||||||
|
}
|
||||||
|
|
||||||
|
// compare result's current value in memory against result's old value
|
||||||
|
template <class T>
|
||||||
|
void NextScanLoopPrimitiveResults(bool(*CompareFunc)(T, T))
|
||||||
|
{
|
||||||
|
for (size_t index = 0; index < m_Results.size(); index++)
|
||||||
|
{
|
||||||
|
CScanResult* presult = &m_Results[index];
|
||||||
|
|
||||||
|
uint32_t addr = presult->m_Address & 0x1FFFFFFF;
|
||||||
|
uint32_t leAddr = (addr ^ (4 - sizeof(T)));
|
||||||
|
|
||||||
|
T memValue, oldValue;
|
||||||
|
memValue = *(T*)&m_Memory[leAddr];
|
||||||
|
presult->Get(&oldValue);
|
||||||
|
|
||||||
|
if (CompareFunc(memValue, oldValue))
|
||||||
|
{
|
||||||
|
presult->Set(memValue);
|
||||||
|
m_NewResults.push_back(*presult);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
m_Results.clear();
|
||||||
|
m_Results.swap(m_NewResults);
|
||||||
|
}
|
||||||
|
|
||||||
|
// compare result's current value in memory against result's old value (for 64 bit types)
|
||||||
|
template <class T>
|
||||||
|
void NextScanLoopPrimitiveResults64(bool(*CompareFunc)(T, T))
|
||||||
|
{
|
||||||
|
for (size_t index = 0; index < m_Results.size(); index++)
|
||||||
|
{
|
||||||
|
CScanResult* presult = &m_Results[index];
|
||||||
|
|
||||||
|
uint32_t addr = presult->m_Address & 0x1FFFFFFF;
|
||||||
|
|
||||||
|
T memValue, oldValue;
|
||||||
|
|
||||||
|
*((uint32_t*)(&memValue) + 1) = *(uint32_t*)&m_Memory[addr];
|
||||||
|
*((uint32_t*)(&memValue) + 0) = *(uint32_t*)&m_Memory[addr + 4];
|
||||||
|
|
||||||
|
presult->Get(&oldValue);
|
||||||
|
|
||||||
|
if (CompareFunc(memValue, oldValue))
|
||||||
|
{
|
||||||
|
presult->Set(memValue);
|
||||||
|
m_NewResults.push_back(*presult);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
m_Results.clear();
|
||||||
|
m_Results.swap(m_NewResults);
|
||||||
|
}
|
||||||
|
};
|
|
@ -84,6 +84,8 @@ public:
|
||||||
CCPULog* CPULog();
|
CCPULog* CPULog();
|
||||||
|
|
||||||
static void GameReset(CDebuggerUI * _this);
|
static void GameReset(CDebuggerUI * _this);
|
||||||
|
static void GameCpuRunningChanged(CDebuggerUI * _this);
|
||||||
|
static void GameNameChanged(CDebuggerUI * _this);
|
||||||
static void SteppingOpsChanged(CDebuggerUI * _this);
|
static void SteppingOpsChanged(CDebuggerUI * _this);
|
||||||
|
|
||||||
bool DebugLW_PAddr(uint32_t vaddr, uint32_t& value);
|
bool DebugLW_PAddr(uint32_t vaddr, uint32_t& value);
|
||||||
|
|
|
@ -531,38 +531,38 @@ BEGIN
|
||||||
CONTROL "Auto",IDC_CHK_AUTOREFRESH,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,218,7,31,8
|
CONTROL "Auto",IDC_CHK_AUTOREFRESH,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,218,7,31,8
|
||||||
END
|
END
|
||||||
|
|
||||||
IDD_Debugger_Search DIALOGEX 0, 0, 229, 233
|
IDD_Debugger_Search DIALOGEX 0, 0, 357, 257
|
||||||
STYLE DS_SETFONT | DS_MODALFRAME | DS_FIXEDSYS | DS_CENTER | WS_MINIMIZEBOX | WS_POPUP | WS_CAPTION | WS_SYSMENU
|
STYLE DS_SETFONT | DS_FIXEDSYS | DS_CENTER | WS_MINIMIZEBOX | WS_POPUP | WS_CAPTION | WS_SYSMENU | WS_THICKFRAME
|
||||||
CAPTION "Search Memory"
|
CAPTION "Search Memory"
|
||||||
FONT 8, "MS Shell Dlg", 0, 0, 0x0
|
FONT 8, "MS Shell Dlg", 0, 0, 0x0
|
||||||
BEGIN
|
BEGIN
|
||||||
GROUPBOX "Search Location:",IDC_STATIC,7,3,215,44
|
PUSHBUTTON "Search",IDC_BTN_SEARCH,193,6,44,14
|
||||||
LTEXT "PAddr Start: ",IDC_STATIC,13,15,41,9
|
PUSHBUTTON "Reset",IDC_BTN_RESET,238,6,43,14
|
||||||
EDITTEXT IDC_PADDR_START,58,13,52,12,ES_AUTOHSCROLL
|
CONTROL "Hex",IDC_CHK_HEX,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,208,31,25,13
|
||||||
LTEXT "Length:",IDC_STATIC,132,14,28,9
|
EDITTEXT IDC_SEARCH_VALUE,238,31,110,13,ES_AUTOHSCROLL
|
||||||
EDITTEXT IDC_ADDR_END,164,13,52,12,ES_AUTOHSCROLL
|
COMBOBOX IDC_CMB_SCANTYPE,238,46,110,72,CBS_DROPDOWNLIST | WS_VSCROLL | WS_TABSTOP
|
||||||
PUSHBUTTON "RDRAM",IDC_BTN_RDRAM,13,30,59,11
|
COMBOBOX IDC_CMB_VALUETYPE,238,62,110,13,CBS_DROPDOWNLIST | WS_VSCROLL | WS_TABSTOP
|
||||||
PUSHBUTTON "ROM",IDC_BTN_ROM,85,30,59,11
|
EDITTEXT IDC_ADDR_START,224,101,52,12,ES_AUTOHSCROLL
|
||||||
PUSHBUTTON "SPMEN",IDC_BTN_SPMEM,157,30,59,11
|
EDITTEXT IDC_ADDR_END,296,101,52,12,ES_AUTOHSCROLL
|
||||||
GROUPBOX "Search Value",IDC_STATIC,7,49,215,74
|
CONTROL "Physical",IDC_CHK_PHYSICAL,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,201,116,36,10
|
||||||
CONTROL "Unknown",IDC_RADIO_UNKNOWN,"Button",BS_AUTORADIOBUTTON,13,63,44,9
|
PUSHBUTTON "RDRAM",IDC_BTN_RDRAM,241,115,35,12
|
||||||
COMBOBOX IDC_CMB_UNKNOWN,64,61,84,72,CBS_DROPDOWNLIST | WS_VSCROLL | WS_TABSTOP
|
PUSHBUTTON "ROM",IDC_BTN_ROM,277,115,35,12
|
||||||
CONTROL "Value",IDC_RADIO_VALUE,"Button",BS_AUTORADIOBUTTON,13,78,33,9
|
PUSHBUTTON "SPMEM",IDC_BTN_SPMEM,313,115,35,12
|
||||||
EDITTEXT IDC_SEARCH_VALUE,64,76,53,12,ES_AUTOHSCROLL
|
CONTROL "",IDC_LST_WATCHLIST,"SysListView32",LVS_REPORT | LVS_OWNERDRAWFIXED | LVS_NOSCROLL | LVS_NOSORTHEADER | WS_BORDER | WS_TABSTOP,4,139,337,114
|
||||||
CONTROL "Hex",IDC_SEARCH_HEX,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,123,78,27,9
|
CONTROL "List1",IDC_LST_RESULTS,"SysListView32",LVS_REPORT | LVS_OWNERDRAWFIXED | LVS_NOSCROLL | LVS_NOSORTHEADER | WS_BORDER | WS_TABSTOP,9,13,166,115
|
||||||
COMBOBOX IDC_VALUE_ALIGN,155,76,64,104,CBS_DROPDOWNLIST | CBS_SORT | WS_VSCROLL | WS_TABSTOP
|
SCROLLBAR IDC_SCRL_RESULTS,175,13,12,115,SBS_VERT | WS_DISABLED
|
||||||
CONTROL "Text",IDC_RADIO_TEXT,"Button",BS_AUTORADIOBUTTON,13,94,35,8
|
GROUPBOX "Address range",IDC_GRP_ADDR,193,91,159,42,0,WS_EX_TRANSPARENT
|
||||||
EDITTEXT IDC_SEARCH_TEXT,64,91,84,12,ES_AUTOHSCROLL
|
LTEXT "Start: ",IDC_LBL_ADDRSTART,201,103,19,9
|
||||||
CONTROL "Case-sensitive",IDC_CASE_SENSITIVE,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,155,92,62,8
|
LTEXT "End:",IDC_LBL_ADDREND,279,103,15,9
|
||||||
CONTROL "JAL to:",IDC_RADIO_JAL,"Button",BS_AUTORADIOBUTTON,13,107,39,13
|
GROUPBOX "Search value",IDC_GRP_SEARCH,193,20,159,71,0,WS_EX_TRANSPARENT
|
||||||
EDITTEXT IDC_JAL_ADDR,64,106,53,12,ES_AUTOHSCROLL
|
LTEXT "Scan type",IDC_LBL_SCANTYPE,200,48,33,8
|
||||||
GROUPBOX "Results",IDC_BORDER_RESULTS,7,125,215,100
|
LTEXT "Value type",IDC_LBL_VALUETYPE,200,65,35,8
|
||||||
PUSHBUTTON "Search",IDC_BTN_SEARCH,12,136,61,13
|
GROUPBOX "Results",IDC_NUM_RESULTS,3,3,188,130,0,WS_EX_TRANSPARENT
|
||||||
PUSHBUTTON "Reset",IDC_RESET_BUTTON,76,136,45,13,NOT WS_VISIBLE
|
CONTROL "",IDC_SEPARATOR,"Static",SS_BLACKFRAME,4,135,349,1
|
||||||
LTEXT "Max Results: ",IDC_STATIC,124,138,41,8
|
SCROLLBAR IDC_SCRL_WATCHLIST,341,139,12,114,SBS_VERT | WS_DISABLED
|
||||||
EDITTEXT IDC_MAX_SEARCH,170,136,44,12,ES_AUTOHSCROLL | ES_NUMBER
|
CONTROL "Unsigned",IDC_CHK_UNSIGNED,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,307,78,40,9
|
||||||
COMBOBOX IDC_UNKNOWN_ALIGN,155,61,64,104,CBS_DROPDOWNLIST | CBS_SORT | WS_VSCROLL | WS_TABSTOP
|
CONTROL "Ignore case",IDC_CHK_IGNORECASE,"Button",BS_AUTOCHECKBOX | NOT WS_VISIBLE | WS_TABSTOP,222,78,50,9
|
||||||
CONTROL "List1",IDC_LST_RESULTS,"SysListView32",LVS_REPORT | LVS_SINGLESEL | LVS_NOSORTHEADER | WS_BORDER | WS_TABSTOP,13,153,202,65
|
CONTROL "Unknown encoding",IDC_CHK_UNKENCODING,"Button",BS_AUTOCHECKBOX | NOT WS_VISIBLE | WS_TABSTOP,276,78,71,9
|
||||||
END
|
END
|
||||||
|
|
||||||
IDD_About_UserInfo DIALOGEX 0, 0, 186, 97
|
IDD_About_UserInfo DIALOGEX 0, 0, 186, 97
|
||||||
|
@ -1357,6 +1357,18 @@ BEGIN
|
||||||
CONTROL "Virt. Coherency on data read",IDC_CHK_VCED,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,96,88,106,11
|
CONTROL "Virt. Coherency on data read",IDC_CHK_VCED,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,96,88,106,11
|
||||||
END
|
END
|
||||||
|
|
||||||
|
IDD_Debugger_Search_SetValue DIALOGEX 0, 0, 109, 56
|
||||||
|
STYLE DS_SETFONT | DS_MODALFRAME | DS_FIXEDSYS | WS_POPUP | WS_CAPTION | WS_SYSMENU
|
||||||
|
CAPTION "Caption"
|
||||||
|
FONT 8, "MS Shell Dlg", 400, 0, 0x1
|
||||||
|
BEGIN
|
||||||
|
DEFPUSHBUTTON "OK",IDOK,52,35,50,14
|
||||||
|
EDITTEXT IDC_EDIT_VALUE,7,18,95,12,ES_AUTOHSCROLL
|
||||||
|
LTEXT "Label:",IDC_LBL_PROMPT,7,7,95,10
|
||||||
|
COMBOBOX IDC_CMB_VALUE,7,18,95,13,CBS_DROPDOWNLIST | WS_VSCROLL | WS_TABSTOP
|
||||||
|
END
|
||||||
|
|
||||||
|
|
||||||
/////////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////////
|
||||||
//
|
//
|
||||||
// DESIGNINFO
|
// DESIGNINFO
|
||||||
|
@ -1549,10 +1561,7 @@ BEGIN
|
||||||
|
|
||||||
IDD_Debugger_Search, DIALOG
|
IDD_Debugger_Search, DIALOG
|
||||||
BEGIN
|
BEGIN
|
||||||
LEFTMARGIN, 7
|
BOTTOMMARGIN, 256
|
||||||
RIGHTMARGIN, 222
|
|
||||||
TOPMARGIN, 7
|
|
||||||
BOTTOMMARGIN, 226
|
|
||||||
END
|
END
|
||||||
|
|
||||||
IDD_About_UserInfo, DIALOG
|
IDD_About_UserInfo, DIALOG
|
||||||
|
@ -1817,6 +1826,14 @@ BEGIN
|
||||||
TOPMARGIN, 7
|
TOPMARGIN, 7
|
||||||
BOTTOMMARGIN, 100
|
BOTTOMMARGIN, 100
|
||||||
END
|
END
|
||||||
|
|
||||||
|
IDD_Debugger_Search_SetValue, DIALOG
|
||||||
|
BEGIN
|
||||||
|
LEFTMARGIN, 7
|
||||||
|
RIGHTMARGIN, 102
|
||||||
|
TOPMARGIN, 7
|
||||||
|
BOTTOMMARGIN, 49
|
||||||
|
END
|
||||||
END
|
END
|
||||||
#endif // APSTUDIO_INVOKED
|
#endif // APSTUDIO_INVOKED
|
||||||
|
|
||||||
|
@ -1872,7 +1889,12 @@ IDR_MEM_SEARCH MENU
|
||||||
BEGIN
|
BEGIN
|
||||||
POPUP "Popup"
|
POPUP "Popup"
|
||||||
BEGIN
|
BEGIN
|
||||||
MENUITEM "Show in memory &viewer...", ID_POPUP_SHOWINMEMORYVIEWER
|
MENUITEM "Add to watch list", ID_RESULTS_ADDTOWATCHLIST
|
||||||
|
MENUITEM "Add all to watch list", ID_RESULTS_ADDALLTOWATCHLIST
|
||||||
|
MENUITEM "Change value", ID_RESULTS_CHANGEVALUE
|
||||||
|
MENUITEM "&View memory...", ID_RESULTS_VIEWMEMORY
|
||||||
|
MENUITEM SEPARATOR
|
||||||
|
MENUITEM "Remove selected", ID_RESULTS_REMOVE
|
||||||
END
|
END
|
||||||
END
|
END
|
||||||
|
|
||||||
|
@ -1922,6 +1944,38 @@ BEGIN
|
||||||
END
|
END
|
||||||
END
|
END
|
||||||
|
|
||||||
|
IDR_MEM_WATCHLIST MENU
|
||||||
|
BEGIN
|
||||||
|
POPUP "PopupMenu"
|
||||||
|
BEGIN
|
||||||
|
POPUP "Change"
|
||||||
|
BEGIN
|
||||||
|
MENUITEM "Value", ID_WATCHLIST_CHANGE_VALUE
|
||||||
|
MENUITEM "Description", ID_WATCHLIST_CHANGE_DESCRIPTION
|
||||||
|
MENUITEM "Type", ID_WATCHLIST_CHANGE_TYPE
|
||||||
|
MENUITEM "Address", ID_WATCHLIST_CHANGE_ADDRESS
|
||||||
|
MENUITEM "Address by...", ID_WATCHLIST_CHANGE_ADDRESSBY
|
||||||
|
END
|
||||||
|
MENUITEM "Lock value", ID_WATCHLIST_LOCKVALUE
|
||||||
|
MENUITEM "Read breakpoint", ID_WATCHLIST_READBP
|
||||||
|
MENUITEM "Write breakpoint", ID_WATCHLIST_WRITEBP
|
||||||
|
MENUITEM SEPARATOR
|
||||||
|
MENUITEM "Hexadecimal", ID_WATCHLIST_HEXADECIMAL
|
||||||
|
MENUITEM SEPARATOR
|
||||||
|
MENUITEM "View memory...", ID_WATCHLIST_VIEWMEMORY
|
||||||
|
MENUITEM "Add Symbol...", ID_WATCHLIST_ADDSYMBOL
|
||||||
|
MENUITEM SEPARATOR
|
||||||
|
POPUP "Copy"
|
||||||
|
BEGIN
|
||||||
|
MENUITEM "GameShark code", ID_WATCHLIST_COPY_GSCODE
|
||||||
|
MENUITEM "Address and description", ID_WATCHLIST_COPY_ADDRDESC
|
||||||
|
END
|
||||||
|
MENUITEM SEPARATOR
|
||||||
|
MENUITEM "Remove selected", ID_WATCHLIST_REMOVE
|
||||||
|
MENUITEM "Remove all", ID_WATCHLIST_REMOVEALL
|
||||||
|
END
|
||||||
|
END
|
||||||
|
|
||||||
IDR_ENHANCEMENT_MENU MENU
|
IDR_ENHANCEMENT_MENU MENU
|
||||||
BEGIN
|
BEGIN
|
||||||
POPUP "Popup"
|
POPUP "Popup"
|
||||||
|
@ -2008,6 +2062,11 @@ BEGIN
|
||||||
0, 0, 0, 0
|
0, 0, 0, 0
|
||||||
END
|
END
|
||||||
|
|
||||||
|
IDD_Debugger_Search AFX_DIALOG_LAYOUT
|
||||||
|
BEGIN
|
||||||
|
0
|
||||||
|
END
|
||||||
|
|
||||||
IDD_Settings_Defaults AFX_DIALOG_LAYOUT
|
IDD_Settings_Defaults AFX_DIALOG_LAYOUT
|
||||||
BEGIN
|
BEGIN
|
||||||
0
|
0
|
||||||
|
@ -2068,6 +2127,17 @@ BEGIN
|
||||||
0
|
0
|
||||||
END
|
END
|
||||||
|
|
||||||
|
IDD_Debugger_AddSymbol AFX_DIALOG_LAYOUT
|
||||||
|
BEGIN
|
||||||
|
0
|
||||||
|
END
|
||||||
|
|
||||||
|
IDD_Debugger_Search_SetValue AFX_DIALOG_LAYOUT
|
||||||
|
BEGIN
|
||||||
|
0
|
||||||
|
END
|
||||||
|
|
||||||
|
|
||||||
/////////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////////
|
||||||
//
|
//
|
||||||
// Dialog Info
|
// Dialog Info
|
||||||
|
|
|
@ -59,7 +59,6 @@
|
||||||
#define IDD_Debugger_DMALog 182
|
#define IDD_Debugger_DMALog 182
|
||||||
#define IDD_Debugger_StackTrace 184
|
#define IDD_Debugger_StackTrace 184
|
||||||
#define IDD_Debugger_RegCOP0 185
|
#define IDD_Debugger_RegCOP0 185
|
||||||
#define IDR_MENU1 186
|
|
||||||
#define IDR_SCRIPT_POPUP 186
|
#define IDR_SCRIPT_POPUP 186
|
||||||
#define IDR_OP_POPUP 187
|
#define IDR_OP_POPUP 187
|
||||||
#define IDR_ENHANCEMENT_MENU 188
|
#define IDR_ENHANCEMENT_MENU 188
|
||||||
|
@ -68,6 +67,7 @@
|
||||||
#define IDD_Debugger_RegMI 193
|
#define IDD_Debugger_RegMI 193
|
||||||
#define IDD_Debugger_RegAI 194
|
#define IDD_Debugger_RegAI 194
|
||||||
#define IDD_Debugger_RegSI 195
|
#define IDD_Debugger_RegSI 195
|
||||||
|
#define IDR_MEM_WATCHLIST 195
|
||||||
#define IDD_Debugger_RegRI 196
|
#define IDD_Debugger_RegRI 196
|
||||||
#define IDD_Debugger_RegDPC 197
|
#define IDD_Debugger_RegDPC 197
|
||||||
#define IDD_Debugger_RegRDRAM 198
|
#define IDD_Debugger_RegRDRAM 198
|
||||||
|
@ -79,6 +79,7 @@
|
||||||
#define IDD_Debugger_CPULog 204
|
#define IDD_Debugger_CPULog 204
|
||||||
#define IDD_Enhancement_GS 205
|
#define IDD_Enhancement_GS 205
|
||||||
#define IDD_Debugger_ExceptionBP 207
|
#define IDD_Debugger_ExceptionBP 207
|
||||||
|
#define IDD_Debugger_Search_SetValue 210
|
||||||
#define IDC_MENU_ITEM_TEXT 1000
|
#define IDC_MENU_ITEM_TEXT 1000
|
||||||
#define IDC_CLOSE_BUTTON 1001
|
#define IDC_CLOSE_BUTTON 1001
|
||||||
#define IDC_LIST2 1003
|
#define IDC_LIST2 1003
|
||||||
|
@ -96,9 +97,9 @@
|
||||||
#define IDC_RESET_PAGE 1008
|
#define IDC_RESET_PAGE 1008
|
||||||
#define IDC_INFO_CARTID 1009
|
#define IDC_INFO_CARTID 1009
|
||||||
#define IDC_VIRTUALKEY 1009
|
#define IDC_VIRTUALKEY 1009
|
||||||
#define IDC_VALUE_ALIGN 1009
|
|
||||||
#define IDC_FRAME_DISPLAY_TYPE 1009
|
#define IDC_FRAME_DISPLAY_TYPE 1009
|
||||||
#define IDC_RESET_ALL 1009
|
#define IDC_RESET_ALL 1009
|
||||||
|
#define IDC_CMB_VALUETYPE 1009
|
||||||
#define IDC_INFO_ROMSIZE 1010
|
#define IDC_INFO_ROMSIZE 1010
|
||||||
#define IDC_KEY_PROMPT 1010
|
#define IDC_KEY_PROMPT 1010
|
||||||
#define IDC_BTN_SPMEM 1010
|
#define IDC_BTN_SPMEM 1010
|
||||||
|
@ -109,21 +110,19 @@
|
||||||
#define IDC_USE_ALT_PC 1011
|
#define IDC_USE_ALT_PC 1011
|
||||||
#define IDC_HLE_GFX 1011
|
#define IDC_HLE_GFX 1011
|
||||||
#define IDC_CHK_VADDR 1011
|
#define IDC_CHK_VADDR 1011
|
||||||
#define IDC_SEARCH_HEX 1011
|
#define IDC_CHK_HEX 1011
|
||||||
#define IDC_DISPLAY_FRAMERATE 1012
|
#define IDC_DISPLAY_FRAMERATE 1012
|
||||||
#define IDC_INFO_MANUFACTURER 1012
|
#define IDC_INFO_MANUFACTURER 1012
|
||||||
#define IDC_ALT 1012
|
#define IDC_ALT 1012
|
||||||
#define IDC_LIST 1012
|
#define IDC_LIST 1012
|
||||||
#define IDC_HLE_AUDIO 1012
|
#define IDC_HLE_AUDIO 1012
|
||||||
#define IDC_SMM_CACHE 1012
|
#define IDC_SMM_CACHE 1012
|
||||||
#define IDC_CASE_SENSITIVE 1012
|
|
||||||
#define IDC_ROM_32BIT 1012
|
#define IDC_ROM_32BIT 1012
|
||||||
#define IDC_INFO_COUNTRY 1013
|
#define IDC_INFO_COUNTRY 1013
|
||||||
#define IDC_SHIFT 1013
|
#define IDC_SHIFT 1013
|
||||||
#define IDC_TLB 1013
|
#define IDC_TLB 1013
|
||||||
#define IDC_TLB_ENTRIES 1013
|
#define IDC_TLB_ENTRIES 1013
|
||||||
#define IDC_SMM_DMA 1013
|
#define IDC_SMM_DMA 1013
|
||||||
#define IDC_UNKNOWN_ALIGN 1013
|
|
||||||
#define IDC_DELAY_DP 1013
|
#define IDC_DELAY_DP 1013
|
||||||
#define IDC_INTERPRETER 1013
|
#define IDC_INTERPRETER 1013
|
||||||
#define IDC_INFO_CRC1 1014
|
#define IDC_INFO_CRC1 1014
|
||||||
|
@ -176,41 +175,33 @@
|
||||||
#define IDC_RDRAM 1046
|
#define IDC_RDRAM 1046
|
||||||
#define IDC_SMM_FRAME 1046
|
#define IDC_SMM_FRAME 1046
|
||||||
#define IDC_SP_REG 1047
|
#define IDC_SP_REG 1047
|
||||||
#define IDC_PADDR_START 1047
|
#define IDC_ADDR_START 1047
|
||||||
#define IDC_DPC_REG 1048
|
#define IDC_DPC_REG 1048
|
||||||
#define IDC_ADDR_END 1048
|
#define IDC_ADDR_END 1048
|
||||||
#define IDC_DPS_REG 1049
|
#define IDC_DPS_REG 1049
|
||||||
#define IDC_RADIO_VALUE 1049
|
|
||||||
#define IDC_MI_REG 1050
|
#define IDC_MI_REG 1050
|
||||||
#define IDC_RADIO_TEXT 1050
|
|
||||||
#define IDC_VI_REG 1051
|
#define IDC_VI_REG 1051
|
||||||
#define IDC_RADIO_JAL 1051
|
|
||||||
#define IDC_AI_REG 1052
|
#define IDC_AI_REG 1052
|
||||||
#define IDC_SEARCH_VALUE 1052
|
#define IDC_SEARCH_VALUE 1052
|
||||||
#define IDC_PI_REG 1053
|
#define IDC_PI_REG 1053
|
||||||
#define IDC_SEARCH_TEXT 1053
|
|
||||||
#define IDC_SI_DMA 1054
|
#define IDC_SI_DMA 1054
|
||||||
#define IDC_JAL_ADDR 1054
|
|
||||||
#define IDC_DIRECT_WRITE 1055
|
#define IDC_DIRECT_WRITE 1055
|
||||||
#define IDC_BTN_SEARCH 1055
|
#define IDC_BTN_SEARCH 1055
|
||||||
#define IDC_DMA_WRITE 1056
|
#define IDC_DMA_WRITE 1056
|
||||||
#define IDC_RESET_BUTTON 1056
|
#define IDC_BTN_RESET 1056
|
||||||
#define IDC_DIRECT_READ 1057
|
#define IDC_DIRECT_READ 1057
|
||||||
#define IDC_MAX_SEARCH 1057
|
|
||||||
#define IDC_DMA_READ 1058
|
#define IDC_DMA_READ 1058
|
||||||
#define IDC_CONT_PAK 1059
|
#define IDC_CONT_PAK 1059
|
||||||
#define IDC_SEARCH_MEM 1059
|
#define IDC_SEARCH_MEM 1059
|
||||||
#define IDC_BTN_ROM 1061
|
#define IDC_BTN_ROM 1061
|
||||||
#define IDC_TEXTURE_OTHER 1062
|
#define IDC_TEXTURE_OTHER 1062
|
||||||
#define IDC_RADIO_UNKNOWN 1062
|
|
||||||
#define IDC_TEXTURE_DIR 1063
|
#define IDC_TEXTURE_DIR 1063
|
||||||
#define IDC_CMB_UNKNOWN 1063
|
#define IDC_CMB_SCANTYPE 1063
|
||||||
#define IDC_TEXTURE_DEFAULT 1064
|
#define IDC_TEXTURE_DEFAULT 1064
|
||||||
#define IDC_LST_RESULTS 1064
|
#define IDC_LST_RESULTS 1064
|
||||||
#define IDC_SELECT_TEXTURE_DIR 1065
|
#define IDC_SELECT_TEXTURE_DIR 1065
|
||||||
#define IDC_MEM_DETAILS 1065
|
#define IDC_MEM_DETAILS 1065
|
||||||
#define IDC_PLUGIN_OTHER 1066
|
#define IDC_PLUGIN_OTHER 1066
|
||||||
#define IDC_BORDER_RESULTS 1066
|
|
||||||
#define IDC_PLUGIN_DIR 1067
|
#define IDC_PLUGIN_DIR 1067
|
||||||
#define IDC_PLUGIN_DEFAULT 1068
|
#define IDC_PLUGIN_DEFAULT 1068
|
||||||
#define IDC_SELECT_PLUGIN_DIR 1069
|
#define IDC_SELECT_PLUGIN_DIR 1069
|
||||||
|
@ -628,7 +619,6 @@
|
||||||
#define IDC_CHK_WMISS 1465
|
#define IDC_CHK_WMISS 1465
|
||||||
#define IDC_CHK_RADE 1466
|
#define IDC_CHK_RADE 1466
|
||||||
#define IDC_CHK_WADE 1467
|
#define IDC_CHK_WADE 1467
|
||||||
#define IDC_CHECK7 1468
|
|
||||||
#define IDC_CHK_IBE 1468
|
#define IDC_CHK_IBE 1468
|
||||||
#define IDC_CHK_DBE 1469
|
#define IDC_CHK_DBE 1469
|
||||||
#define IDC_CHK_SYSCALL 1470
|
#define IDC_CHK_SYSCALL 1470
|
||||||
|
@ -675,7 +665,24 @@
|
||||||
#define IDC_R14_LBL 1512
|
#define IDC_R14_LBL 1512
|
||||||
#define IDC_HI_LBL 1513
|
#define IDC_HI_LBL 1513
|
||||||
#define IDC_LO_LBL 1514
|
#define IDC_LO_LBL 1514
|
||||||
#define ID_POPUP_SHOWINMEMORYVIEWER 40005
|
#define IDC_NUM_RESULTS 1515
|
||||||
|
#define IDC_SCRL_RESULTS 1518
|
||||||
|
#define IDC_LST_WATCHLIST 1520
|
||||||
|
#define IDC_CHK_PHYSICAL 1522
|
||||||
|
#define IDC_SEPARATOR 1524
|
||||||
|
#define IDC_GRP_SEARCH 1525
|
||||||
|
#define IDC_GRP_ADDR 1526
|
||||||
|
#define IDC_LBL_SCANTYPE 1527
|
||||||
|
#define IDC_LBL_VALUETYPE 1528
|
||||||
|
#define IDC_LBL_ADDRSTART 1529
|
||||||
|
#define IDC_LBL_ADDREND 1530
|
||||||
|
#define IDC_SCRL_WATCHLIST 1531
|
||||||
|
#define IDC_EDIT_VALUE 1532
|
||||||
|
#define IDC_LBL_PROMPT 1533
|
||||||
|
#define IDC_CMB_VALUE 1534
|
||||||
|
#define IDC_CHK_UNSIGNED 1535
|
||||||
|
#define IDC_CHK_IGNORECASE 1536
|
||||||
|
#define IDC_CHK_UNKENCODING 1537
|
||||||
#define ID_POPUPMENU_PLAYGAMEWITHDISK 40008
|
#define ID_POPUPMENU_PLAYGAMEWITHDISK 40008
|
||||||
#define ID_POPUPMENU_ADDSYMBOL 40013
|
#define ID_POPUPMENU_ADDSYMBOL 40013
|
||||||
#define ID_POPUPMENU_VIEWDISASM 40017
|
#define ID_POPUPMENU_VIEWDISASM 40017
|
||||||
|
@ -690,12 +697,31 @@
|
||||||
#define ID_POPUPMENU_EDIT 40030
|
#define ID_POPUPMENU_EDIT 40030
|
||||||
#define ID_POPUPMENU_FOLLOWJUMP 40032
|
#define ID_POPUPMENU_FOLLOWJUMP 40032
|
||||||
#define ID_POPUPMENU_RUNTO 40034
|
#define ID_POPUPMENU_RUNTO 40034
|
||||||
#define ID_Menu 40035
|
|
||||||
#define ID_POPUPMENU_VIEWMEMORY 40036
|
#define ID_POPUPMENU_VIEWMEMORY 40036
|
||||||
#define ID_POPUPMENU_TOGGLEBP 40039
|
#define ID_POPUPMENU_TOGGLEBP 40039
|
||||||
#define ID_POPUPMENU_CLEARBPS 40040
|
#define ID_POPUPMENU_CLEARBPS 40040
|
||||||
#define ID_POPUPMENU_TOGGLELOCK 40041
|
#define ID_POPUPMENU_TOGGLELOCK 40041
|
||||||
#define ID_POPUPMENU_CLEARLOCKS 40042
|
#define ID_POPUPMENU_CLEARLOCKS 40042
|
||||||
|
#define ID_RESULTS_ADDTOWATCHLIST 40054
|
||||||
|
#define ID_RESULTS_CHANGEVALUE 40055
|
||||||
|
#define ID_RESULTS_VIEWMEMORY 40056
|
||||||
|
#define ID_RESULTS_REMOVE 40057
|
||||||
|
#define ID_WATCHLIST_LOCKVALUE 40060
|
||||||
|
#define ID_WATCHLIST_READBP 40061
|
||||||
|
#define ID_WATCHLIST_WRITEBP 40062
|
||||||
|
#define ID_WATCHLIST_HEXADECIMAL 40063
|
||||||
|
#define ID_WATCHLIST_VIEWMEMORY 40064
|
||||||
|
#define ID_WATCHLIST_ADDSYMBOL 40065
|
||||||
|
#define ID_WATCHLIST_REMOVE 40066
|
||||||
|
#define ID_WATCHLIST_REMOVEALL 40067
|
||||||
|
#define ID_WATCHLIST_COPY_GSCODE 40070
|
||||||
|
#define ID_WATCHLIST_COPY_ADDRDESC 40073
|
||||||
|
#define ID_WATCHLIST_CHANGE_TYPE 40076
|
||||||
|
#define ID_WATCHLIST_CHANGE_VALUE 40077
|
||||||
|
#define ID_WATCHLIST_CHANGE_DESCRIPTION 40078
|
||||||
|
#define ID_RESULTS_ADDALLTOWATCHLIST 40080
|
||||||
|
#define ID_WATCHLIST_CHANGE_ADDRESS 40082
|
||||||
|
#define ID_WATCHLIST_CHANGE_ADDRESSBY 40084
|
||||||
#define ID_POPUPMENU_ROMDIRECTORY 40137
|
#define ID_POPUPMENU_ROMDIRECTORY 40137
|
||||||
#define ID_POPUPMENU_REFRESHROMLIST 40138
|
#define ID_POPUPMENU_REFRESHROMLIST 40138
|
||||||
#define ID_POPUPMENU_PLAYGAME 40152
|
#define ID_POPUPMENU_PLAYGAME 40152
|
||||||
|
@ -712,9 +738,9 @@
|
||||||
//
|
//
|
||||||
#ifdef APSTUDIO_INVOKED
|
#ifdef APSTUDIO_INVOKED
|
||||||
#ifndef APSTUDIO_READONLY_SYMBOLS
|
#ifndef APSTUDIO_READONLY_SYMBOLS
|
||||||
#define _APS_NEXT_RESOURCE_VALUE 210
|
#define _APS_NEXT_RESOURCE_VALUE 213
|
||||||
#define _APS_NEXT_COMMAND_VALUE 40043
|
#define _APS_NEXT_COMMAND_VALUE 40085
|
||||||
#define _APS_NEXT_CONTROL_VALUE 1515
|
#define _APS_NEXT_CONTROL_VALUE 1538
|
||||||
#define _APS_NEXT_SYMED_VALUE 102
|
#define _APS_NEXT_SYMED_VALUE 102
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
Loading…
Reference in New Issue