* Debugger: show the number of breakpoints (enabled and total) above the breakpoints list
* Debugger: ">" shows current line in disassembly * Debugger: fixed RAM peek by a rightclick on left pane * Debugger: doubleclick on the disassembly prompts "Add Execute breakpoint" dialog * Debugger: improved stack display * Taseditor: frame counter display is auto-on when Taseditor launches
This commit is contained in:
parent
6188e68811
commit
714e9282f8
|
@ -457,7 +457,7 @@ int iaPC;
|
||||||
uint32 iapoffset; //mbg merge 7/18/06 changed from int
|
uint32 iapoffset; //mbg merge 7/18/06 changed from int
|
||||||
int u; //deleteme
|
int u; //deleteme
|
||||||
int skipdebug; //deleteme
|
int skipdebug; //deleteme
|
||||||
int numWPs;
|
int numWPs;
|
||||||
|
|
||||||
// for CPU cycles and Instructions counters
|
// for CPU cycles and Instructions counters
|
||||||
unsigned long int total_cycles_base = 0;
|
unsigned long int total_cycles_base = 0;
|
||||||
|
|
|
@ -485,7 +485,7 @@ BOOL CALLBACK CheatConsoleCallB(HWND hwndDlg, UINT uMsg, WPARAM wParam, LPARAM l
|
||||||
SetDlgItemText(hwndDlg,IDC_CHEAT_VAL,(LPTSTR)U8ToStr(v));
|
SetDlgItemText(hwndDlg,IDC_CHEAT_VAL,(LPTSTR)U8ToStr(v));
|
||||||
if(hMemView)UpdateColorTable(); //if the memory viewer is open then update any blue freeze locations in it as well
|
if(hMemView)UpdateColorTable(); //if the memory viewer is open then update any blue freeze locations in it as well
|
||||||
break;
|
break;
|
||||||
case IDC_BTN_CHEAT_RESET:
|
case IDC_BTN_CHEAT_RESET:
|
||||||
FCEUI_CheatSearchBegin();
|
FCEUI_CheatSearchBegin();
|
||||||
ShowResults(hwndDlg);
|
ShowResults(hwndDlg);
|
||||||
EnableCheatButtons(hwndDlg,TRUE);
|
EnableCheatButtons(hwndDlg,TRUE);
|
||||||
|
|
|
@ -76,6 +76,7 @@ uint8 debugger_open=0;
|
||||||
HWND hDebug;
|
HWND hDebug;
|
||||||
static HMENU hDebugcontext; //Handle to context menu
|
static HMENU hDebugcontext; //Handle to context menu
|
||||||
static HMENU hDebugcontextsub; //Handle to context sub menu
|
static HMENU hDebugcontextsub; //Handle to context sub menu
|
||||||
|
WNDPROC IDC_DEBUGGER_DISASSEMBLY_oldWndProc = 0;
|
||||||
|
|
||||||
static HFONT hFont;
|
static HFONT hFont;
|
||||||
static SCROLLINFO si;
|
static SCROLLINFO si;
|
||||||
|
@ -210,7 +211,7 @@ static void UpdateDialog(HWND hwndDlg) {
|
||||||
|
|
||||||
BOOL CALLBACK AddbpCallB(HWND hwndDlg, UINT uMsg, WPARAM wParam, LPARAM lParam)
|
BOOL CALLBACK AddbpCallB(HWND hwndDlg, UINT uMsg, WPARAM wParam, LPARAM lParam)
|
||||||
{
|
{
|
||||||
char str[8]={0};
|
char str[8] = {0};
|
||||||
int tmp;
|
int tmp;
|
||||||
|
|
||||||
switch(uMsg) {
|
switch(uMsg) {
|
||||||
|
@ -218,7 +219,8 @@ BOOL CALLBACK AddbpCallB(HWND hwndDlg, UINT uMsg, WPARAM wParam, LPARAM lParam)
|
||||||
CenterWindow(hwndDlg);
|
CenterWindow(hwndDlg);
|
||||||
SendDlgItemMessage(hwndDlg,IDC_ADDBP_ADDR_START,EM_SETLIMITTEXT,4,0);
|
SendDlgItemMessage(hwndDlg,IDC_ADDBP_ADDR_START,EM_SETLIMITTEXT,4,0);
|
||||||
SendDlgItemMessage(hwndDlg,IDC_ADDBP_ADDR_END,EM_SETLIMITTEXT,4,0);
|
SendDlgItemMessage(hwndDlg,IDC_ADDBP_ADDR_END,EM_SETLIMITTEXT,4,0);
|
||||||
if (WP_edit >= 0) {
|
if (WP_edit >= 0)
|
||||||
|
{
|
||||||
SetWindowText(hwndDlg,"Edit Breakpoint...");
|
SetWindowText(hwndDlg,"Edit Breakpoint...");
|
||||||
|
|
||||||
sprintf(str,"%04X",watchpoint[WP_edit].address);
|
sprintf(str,"%04X",watchpoint[WP_edit].address);
|
||||||
|
@ -266,8 +268,17 @@ BOOL CALLBACK AddbpCallB(HWND hwndDlg, UINT uMsg, WPARAM wParam, LPARAM lParam)
|
||||||
}
|
}
|
||||||
|
|
||||||
// ################################## End of SP CODE ###########################
|
// ################################## End of SP CODE ###########################
|
||||||
|
} else
|
||||||
|
{
|
||||||
|
CheckDlgButton(hwndDlg, IDC_ADDBP_MEM_CPU, BST_CHECKED);
|
||||||
|
// if lParam is not 0 then we should suggest to add PC breakpoint
|
||||||
|
if (lParam)
|
||||||
|
{
|
||||||
|
CheckDlgButton(hwndDlg, IDC_ADDBP_MODE_X, BST_CHECKED);
|
||||||
|
sprintf(str, "%04X", lParam);
|
||||||
|
SetDlgItemText(hwndDlg,IDC_ADDBP_ADDR_START,str);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else CheckDlgButton(hwndDlg, IDC_ADDBP_MEM_CPU, BST_CHECKED);
|
|
||||||
break;
|
break;
|
||||||
case WM_CLOSE:
|
case WM_CLOSE:
|
||||||
case WM_QUIT:
|
case WM_QUIT:
|
||||||
|
@ -330,9 +341,11 @@ void Disassemble(HWND hWnd, int id, int scrollid, unsigned int addr) {
|
||||||
// Changed size of str (TODO: Better calculation of max size)
|
// Changed size of str (TODO: Better calculation of max size)
|
||||||
// Changed the buffer size of str to 35000
|
// Changed the buffer size of str to 35000
|
||||||
|
|
||||||
|
symbDebugEnabled = IsDlgButtonChecked(hWnd, IDC_DEBUGGER_ENABLE_SYMBOLIC);
|
||||||
|
|
||||||
// ################################## End of SP CODE ###########################
|
// ################################## End of SP CODE ###########################
|
||||||
|
|
||||||
char str[35000]={0},chr[34]={0};
|
char str[35000] = {0}, chr[40] = {0};
|
||||||
int size;
|
int size;
|
||||||
uint8 opcode[3];
|
uint8 opcode[3];
|
||||||
|
|
||||||
|
@ -347,20 +360,25 @@ void Disassemble(HWND hWnd, int id, int scrollid, unsigned int addr) {
|
||||||
|
|
||||||
//figure out how many lines we can draw
|
//figure out how many lines we can draw
|
||||||
RECT rect;
|
RECT rect;
|
||||||
GetWindowRect(hWnd,&rect);
|
GetClientRect(hWnd,&rect);
|
||||||
int lines = (rect.bottom-rect.top)/13;
|
int lines = (rect.bottom-rect.top)/14;
|
||||||
|
|
||||||
|
for (int i = 0; i < lines; i++)
|
||||||
for (int i = 0; i < lines; i++) {
|
{
|
||||||
|
// PC pointer
|
||||||
if (addr > 0xFFFF) break;
|
if (addr > 0xFFFF) break;
|
||||||
|
|
||||||
|
if (addr == X.PC)
|
||||||
|
strcat(str, ">");
|
||||||
|
else
|
||||||
|
strcat(str, " ");
|
||||||
|
|
||||||
if(addr >= 0x8000)
|
if(addr >= 0x8000)
|
||||||
sprintf(chr, "%02X:%04X", getBank(addr), addr);
|
sprintf(chr, "%02X:%04X", getBank(addr), addr);
|
||||||
else sprintf(chr, " :%04X", addr);
|
else sprintf(chr, " :%04X", addr);
|
||||||
|
|
||||||
// ################################## Start of SP CODE ###########################
|
// ################################## Start of SP CODE ###########################
|
||||||
|
|
||||||
symbDebugEnabled = IsDlgButtonChecked(hWnd, IDC_DEBUGGER_ENABLE_SYMBOLIC);
|
|
||||||
|
|
||||||
decorateAddress(addr, str, chr, symbDebugEnabled);
|
decorateAddress(addr, str, chr, symbDebugEnabled);
|
||||||
|
|
||||||
// ################################## End of SP CODE ###########################
|
// ################################## End of SP CODE ###########################
|
||||||
|
@ -566,6 +584,18 @@ void FCEUD_DebugBreakpoint(int bp_num)
|
||||||
ResetDebugStatisticsDeltaCounters();
|
ResetDebugStatisticsDeltaCounters();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void UpdateBreakpointsCaption()
|
||||||
|
{
|
||||||
|
char str[32];
|
||||||
|
// calculate the number of enabled breakpoints
|
||||||
|
int tmp = 0;
|
||||||
|
for (int i = 0; i < numWPs; i++)
|
||||||
|
if (watchpoint[i].flags & WP_E)
|
||||||
|
tmp++;
|
||||||
|
sprintf(str, "Breakpoints %02X of %02X", tmp, numWPs);
|
||||||
|
SetDlgItemText(hDebug, IDC_DEBUGGER_BREAKPOINTS, str);
|
||||||
|
}
|
||||||
|
|
||||||
void UpdateDebugger()
|
void UpdateDebugger()
|
||||||
{
|
{
|
||||||
//don't do anything if the debugger is not visible
|
//don't do anything if the debugger is not visible
|
||||||
|
@ -650,16 +680,28 @@ void UpdateDebugger()
|
||||||
sprintf(str, "(+%lu)", delta_instructions);
|
sprintf(str, "(+%lu)", delta_instructions);
|
||||||
SetDlgItemText(hDebug, IDC_DEBUGGER_VAL_INSTRUCTIONS_COUNT2, str);
|
SetDlgItemText(hDebug, IDC_DEBUGGER_VAL_INSTRUCTIONS_COUNT2, str);
|
||||||
|
|
||||||
|
UpdateBreakpointsCaption();
|
||||||
|
|
||||||
tmp = X.S|0x0100;
|
tmp = X.S|0x0100;
|
||||||
sprintf(str, "Stack $%04X", tmp);
|
sprintf(str, "Stack $%04X", tmp);
|
||||||
SetDlgItemText(hDebug, IDC_DEBUGGER_VAL_S, str);
|
SetDlgItemText(hDebug, IDC_DEBUGGER_VAL_S, str);
|
||||||
tmp = ((tmp+1)|0x0100)&0x01FF;
|
str[0] = 0;
|
||||||
sprintf(str, "%02X", GetMem(tmp));
|
tmp++;
|
||||||
for (i = 1; i < 128; i++) {
|
if (tmp <= 0x1FF)
|
||||||
tmp = ((tmp+1)|0x0100)&0x01FF; //increment and fix pointer to $0100-$01FF range
|
{
|
||||||
if ((i%4) == 0) sprintf(chr, ",\r\n%02X", GetMem(tmp));
|
sprintf(str, "%02X", GetMem(tmp));
|
||||||
else sprintf(chr, ",%02X", GetMem(tmp));
|
for (i = 1; i < 128; i++)
|
||||||
strcat(str,chr);
|
{
|
||||||
|
//tmp = ((tmp+1)|0x0100)&0x01FF; //increment and fix pointer to $0100-$01FF range
|
||||||
|
tmp++;
|
||||||
|
if (tmp > 0x1FF)
|
||||||
|
break;
|
||||||
|
if ((i%4) == 0)
|
||||||
|
sprintf(chr, ",\r\n%02X", GetMem(tmp));
|
||||||
|
else
|
||||||
|
sprintf(chr, ",%02X", GetMem(tmp));
|
||||||
|
strcat(str, chr);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
SetDlgItemText(hDebug, IDC_DEBUGGER_STACK_CONTENTS, str);
|
SetDlgItemText(hDebug, IDC_DEBUGGER_STACK_CONTENTS, str);
|
||||||
|
|
||||||
|
@ -748,16 +790,19 @@ void ClearBreakList(HWND hwndDlg) {
|
||||||
numWPs = 0;
|
numWPs = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void EnableBreak(int sel) {
|
void EnableBreak(int sel)
|
||||||
|
{
|
||||||
if(sel<0) return;
|
if(sel<0) return;
|
||||||
if(sel>=numWPs) return;
|
if(sel>=numWPs) return;
|
||||||
watchpoint[sel].flags^=WP_E;
|
watchpoint[sel].flags^=WP_E;
|
||||||
SendDlgItemMessage(hDebug,IDC_DEBUGGER_BP_LIST,LB_DELETESTRING,sel,0);
|
SendDlgItemMessage(hDebug,IDC_DEBUGGER_BP_LIST,LB_DELETESTRING,sel,0);
|
||||||
SendDlgItemMessage(hDebug,IDC_DEBUGGER_BP_LIST,LB_INSERTSTRING,sel,(LPARAM)(LPSTR)BreakToText(sel));
|
SendDlgItemMessage(hDebug,IDC_DEBUGGER_BP_LIST,LB_INSERTSTRING,sel,(LPARAM)(LPSTR)BreakToText(sel));
|
||||||
SendDlgItemMessage(hDebug,IDC_DEBUGGER_BP_LIST,LB_SETCURSEL,sel,0);
|
SendDlgItemMessage(hDebug,IDC_DEBUGGER_BP_LIST,LB_SETCURSEL,sel,0);
|
||||||
|
UpdateBreakpointsCaption();
|
||||||
}
|
}
|
||||||
|
|
||||||
void DeleteBreak(int sel) {
|
void DeleteBreak(int sel)
|
||||||
|
{
|
||||||
if(sel<0) return;
|
if(sel<0) return;
|
||||||
if(sel>=numWPs) return;
|
if(sel>=numWPs) return;
|
||||||
if (watchpoint[sel].cond)
|
if (watchpoint[sel].cond)
|
||||||
|
@ -791,6 +836,7 @@ void DeleteBreak(int sel) {
|
||||||
SendDlgItemMessage(hDebug,IDC_DEBUGGER_BP_LIST,LB_DELETESTRING,sel,0);
|
SendDlgItemMessage(hDebug,IDC_DEBUGGER_BP_LIST,LB_DELETESTRING,sel,0);
|
||||||
EnableWindow(GetDlgItem(hDebug,IDC_DEBUGGER_BP_DEL),FALSE);
|
EnableWindow(GetDlgItem(hDebug,IDC_DEBUGGER_BP_DEL),FALSE);
|
||||||
EnableWindow(GetDlgItem(hDebug,IDC_DEBUGGER_BP_EDIT),FALSE);
|
EnableWindow(GetDlgItem(hDebug,IDC_DEBUGGER_BP_EDIT),FALSE);
|
||||||
|
UpdateBreakpointsCaption();
|
||||||
}
|
}
|
||||||
|
|
||||||
void KillDebugger() {
|
void KillDebugger() {
|
||||||
|
@ -1095,7 +1141,42 @@ void LoadGameDebuggerData(HWND hwndDlg = hDebug) {
|
||||||
FillBreakList(hwndDlg);
|
FillBreakList(hwndDlg);
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOL CALLBACK DebuggerCallB(HWND hwndDlg, UINT uMsg, WPARAM wParam, LPARAM lParam) {
|
BOOL CALLBACK IDC_DEBUGGER_DISASSEMBLY_WndProc(HWND hwndDlg, UINT uMsg, WPARAM wParam, LPARAM lParam)
|
||||||
|
{
|
||||||
|
switch(uMsg)
|
||||||
|
{
|
||||||
|
case WM_LBUTTONDBLCLK:
|
||||||
|
{
|
||||||
|
// select the text
|
||||||
|
CallWindowProc(IDC_DEBUGGER_DISASSEMBLY_oldWndProc, hwndDlg, uMsg, wParam, lParam);
|
||||||
|
int mouse_y = GET_Y_LPARAM(lParam);
|
||||||
|
int tmp = mouse_y / 14, tmp2;
|
||||||
|
int i = si.nPos;
|
||||||
|
while (tmp > 0)
|
||||||
|
{
|
||||||
|
tmp2 = opsize[GetMem(i)];
|
||||||
|
if (tmp2 == 0) tmp2++;
|
||||||
|
if ((i += tmp2) > 0xFFFF)
|
||||||
|
{
|
||||||
|
i = 0xFFFF;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
tmp--;
|
||||||
|
}
|
||||||
|
// prompt "Add PC breakpoint"
|
||||||
|
childwnd = 1;
|
||||||
|
if (DialogBoxParam(fceu_hInstance, "ADDBP", hwndDlg, AddbpCallB, i))
|
||||||
|
AddBreakList();
|
||||||
|
childwnd = 0;
|
||||||
|
UpdateDebugger();
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return CallWindowProc(IDC_DEBUGGER_DISASSEMBLY_oldWndProc, hwndDlg, uMsg, wParam, lParam);
|
||||||
|
}
|
||||||
|
|
||||||
|
BOOL CALLBACK DebuggerCallB(HWND hwndDlg, UINT uMsg, WPARAM wParam, LPARAM lParam)
|
||||||
|
{
|
||||||
RECT wrect;
|
RECT wrect;
|
||||||
char str[256] = {0}, *ptr, dotdot[4];
|
char str[256] = {0}, *ptr, dotdot[4];
|
||||||
int tmp,tmp2;
|
int tmp,tmp2;
|
||||||
|
@ -1171,6 +1252,9 @@ BOOL CALLBACK DebuggerCallB(HWND hwndDlg, UINT uMsg, WPARAM wParam, LPARAM lPara
|
||||||
// Enable Context Sub-Menus
|
// Enable Context Sub-Menus
|
||||||
hDebugcontext = LoadMenu(fceu_hInstance,"DEBUGCONTEXTMENUS");
|
hDebugcontext = LoadMenu(fceu_hInstance,"DEBUGCONTEXTMENUS");
|
||||||
|
|
||||||
|
// subclass editfield
|
||||||
|
IDC_DEBUGGER_DISASSEMBLY_oldWndProc = (WNDPROC)SetWindowLong(GetDlgItem(hwndDlg, IDC_DEBUGGER_DISASSEMBLY), GWL_WNDPROC, (LONG)IDC_DEBUGGER_DISASSEMBLY_WndProc);
|
||||||
|
|
||||||
debugger_open = 1;
|
debugger_open = 1;
|
||||||
inDebugger = true;
|
inDebugger = true;
|
||||||
break;
|
break;
|
||||||
|
@ -1346,7 +1430,8 @@ BOOL CALLBACK DebuggerCallB(HWND hwndDlg, UINT uMsg, WPARAM wParam, LPARAM lPara
|
||||||
//}
|
//}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case WM_MOUSEMOVE: {
|
case WM_MOUSEMOVE:
|
||||||
|
{
|
||||||
mouse_x = GET_X_LPARAM(lParam);
|
mouse_x = GET_X_LPARAM(lParam);
|
||||||
mouse_y = GET_Y_LPARAM(lParam);
|
mouse_y = GET_Y_LPARAM(lParam);
|
||||||
|
|
||||||
|
@ -1388,12 +1473,12 @@ BOOL CALLBACK DebuggerCallB(HWND hwndDlg, UINT uMsg, WPARAM wParam, LPARAM lPara
|
||||||
}
|
}
|
||||||
} else
|
} else
|
||||||
{
|
{
|
||||||
SetDlgItemText(hwndDlg,IDC_DEBUGGER_ADDR_LINE,"Hover the mouse over the left pane to see the ROM address of the data. Also leftclick/rightclick.");
|
SetDlgItemText(hwndDlg,IDC_DEBUGGER_ADDR_LINE,"Hover the mouse over the left pane to see the ROM address of the code. Also leftclick/midclick/rightclick.");
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
case WM_LBUTTONDOWN:
|
case WM_LBUTTONDOWN:
|
||||||
|
{
|
||||||
mouse_x = GET_X_LPARAM(lParam);
|
mouse_x = GET_X_LPARAM(lParam);
|
||||||
mouse_y = GET_Y_LPARAM(lParam);
|
mouse_y = GET_Y_LPARAM(lParam);
|
||||||
// ################################## Start of SP CODE ###########################
|
// ################################## Start of SP CODE ###########################
|
||||||
|
@ -1401,8 +1486,9 @@ BOOL CALLBACK DebuggerCallB(HWND hwndDlg, UINT uMsg, WPARAM wParam, LPARAM lPara
|
||||||
// mouse_y < 538
|
// mouse_y < 538
|
||||||
// > 33) tmp = 33
|
// > 33) tmp = 33
|
||||||
//mbg merge 7/18/06 changed pausing check
|
//mbg merge 7/18/06 changed pausing check
|
||||||
if (FCEUI_EmulationPaused() && (mouse_x > 8) && (mouse_x < 22) && (mouse_y > 10) && (mouse_y < 538)) {
|
if (FCEUI_EmulationPaused() && (mouse_x > 8) && (mouse_x < 22) && (mouse_y > 10) && (mouse_y < 538))
|
||||||
if ((tmp=((mouse_y - 10) / 13)) > 33) tmp = 33;
|
{
|
||||||
|
tmp = (mouse_y - 10) / 14;
|
||||||
// ################################## End of SP CODE ###########################
|
// ################################## End of SP CODE ###########################
|
||||||
i = si.nPos;
|
i = si.nPos;
|
||||||
while (tmp > 0) {
|
while (tmp > 0) {
|
||||||
|
@ -1421,13 +1507,14 @@ BOOL CALLBACK DebuggerCallB(HWND hwndDlg, UINT uMsg, WPARAM wParam, LPARAM lPara
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
case WM_RBUTTONDOWN:
|
case WM_RBUTTONDOWN:
|
||||||
mouse_x = GET_X_LPARAM(lParam);
|
mouse_x = GET_X_LPARAM(lParam);
|
||||||
mouse_y = GET_Y_LPARAM(lParam);
|
mouse_y = GET_Y_LPARAM(lParam);
|
||||||
//mbg merge 7/18/06 changed pausing check
|
//mbg merge 7/18/06 changed pausing check
|
||||||
if (FCEUI_EmulationPaused() && (mouse_x > 8) && (mouse_x < 22) && (mouse_y > 10) && (mouse_y < 338))
|
if (FCEUI_EmulationPaused() && (mouse_x > 8) && (mouse_x < 22) && (mouse_y > 10) && (mouse_y < 338))
|
||||||
{
|
{
|
||||||
if ((tmp=((mouse_y - 10) / 13)) > 24) tmp = 24;
|
tmp = (mouse_y - 10) / 14;
|
||||||
i = si.nPos;
|
i = si.nPos;
|
||||||
while (tmp > 0) {
|
while (tmp > 0) {
|
||||||
if ((tmp2=opsize[GetMem(i)]) == 0) tmp2++;
|
if ((tmp2=opsize[GetMem(i)]) == 0) tmp2++;
|
||||||
|
@ -1437,16 +1524,21 @@ BOOL CALLBACK DebuggerCallB(HWND hwndDlg, UINT uMsg, WPARAM wParam, LPARAM lPara
|
||||||
}
|
}
|
||||||
tmp--;
|
tmp--;
|
||||||
}
|
}
|
||||||
ChangeMemViewFocus(2,GetNesFileAddress(i),-1);
|
if (i >= 0x8000)
|
||||||
|
// show ROM data in Hexeditor
|
||||||
|
ChangeMemViewFocus(2, GetNesFileAddress(i), -1);
|
||||||
|
else
|
||||||
|
// show RAM data in Hexeditor
|
||||||
|
ChangeMemViewFocus(0, i, -1);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case WM_MBUTTONDOWN:
|
case WM_MBUTTONDOWN:
|
||||||
mouse_x = GET_X_LPARAM(lParam);
|
mouse_x = GET_X_LPARAM(lParam);
|
||||||
mouse_y = GET_Y_LPARAM(lParam);
|
mouse_y = GET_Y_LPARAM(lParam);
|
||||||
//mbg merge 7/18/06 changed pausing check
|
//mbg merge 7/18/06 changed pausing check
|
||||||
if (FCEUI_EmulationPaused() && (mouse_x > 8) && (mouse_x < 22) && (mouse_y > 10) && (mouse_y < 338))
|
if (FCEUI_EmulationPaused() && (mouse_x > 8) && (mouse_x < 22) && (mouse_y > 10) && (mouse_y < 338))
|
||||||
{
|
{
|
||||||
if ((tmp=((mouse_y - 10) / 13)) > 24) tmp = 24;
|
tmp = (mouse_y - 10) / 14;
|
||||||
i = si.nPos;
|
i = si.nPos;
|
||||||
while (tmp > 0) {
|
while (tmp > 0) {
|
||||||
if ((tmp2=opsize[GetMem(i)]) == 0) tmp2++;
|
if ((tmp2=opsize[GetMem(i)]) == 0) tmp2++;
|
||||||
|
@ -1471,7 +1563,7 @@ BOOL CALLBACK DebuggerCallB(HWND hwndDlg, UINT uMsg, WPARAM wParam, LPARAM lPara
|
||||||
break;
|
break;
|
||||||
case IDC_DEBUGGER_BP_ADD:
|
case IDC_DEBUGGER_BP_ADD:
|
||||||
childwnd = 1;
|
childwnd = 1;
|
||||||
if (DialogBox(fceu_hInstance,"ADDBP",hwndDlg,AddbpCallB)) AddBreakList();
|
if (DialogBoxParam(fceu_hInstance,"ADDBP",hwndDlg,AddbpCallB, 0)) AddBreakList();
|
||||||
childwnd = 0;
|
childwnd = 0;
|
||||||
UpdateDebugger();
|
UpdateDebugger();
|
||||||
break;
|
break;
|
||||||
|
@ -1480,7 +1572,7 @@ BOOL CALLBACK DebuggerCallB(HWND hwndDlg, UINT uMsg, WPARAM wParam, LPARAM lPara
|
||||||
break;
|
break;
|
||||||
case IDC_DEBUGGER_BP_EDIT:
|
case IDC_DEBUGGER_BP_EDIT:
|
||||||
WP_edit = SendDlgItemMessage(hwndDlg,IDC_DEBUGGER_BP_LIST,LB_GETCURSEL,0,0);
|
WP_edit = SendDlgItemMessage(hwndDlg,IDC_DEBUGGER_BP_LIST,LB_GETCURSEL,0,0);
|
||||||
if (DialogBox(fceu_hInstance,"ADDBP",hwndDlg,AddbpCallB)) EditBreakList();
|
if (DialogBoxParam(fceu_hInstance, "ADDBP", hwndDlg, AddbpCallB, 0)) EditBreakList();
|
||||||
WP_edit = -1;
|
WP_edit = -1;
|
||||||
UpdateDebugger();
|
UpdateDebugger();
|
||||||
break;
|
break;
|
||||||
|
@ -1623,7 +1715,7 @@ BOOL CALLBACK DebuggerCallB(HWND hwndDlg, UINT uMsg, WPARAM wParam, LPARAM lPara
|
||||||
case LBN_DBLCLK:
|
case LBN_DBLCLK:
|
||||||
switch(LOWORD(wParam)) {
|
switch(LOWORD(wParam)) {
|
||||||
case IDC_DEBUGGER_BP_LIST:
|
case IDC_DEBUGGER_BP_LIST:
|
||||||
EnableBreak(SendDlgItemMessage(hwndDlg,IDC_DEBUGGER_BP_LIST,LB_GETCURSEL,0,0));
|
EnableBreak(SendDlgItemMessage(hwndDlg,IDC_DEBUGGER_BP_LIST,LB_GETCURSEL,0,0));
|
||||||
break;
|
break;
|
||||||
// ################################## Start of SP CODE ###########################
|
// ################################## Start of SP CODE ###########################
|
||||||
|
|
||||||
|
@ -1725,7 +1817,8 @@ void DoDebug(uint8 halt) {
|
||||||
if(DbgSizeX != -1 && DbgSizeY != -1)
|
if(DbgSizeX != -1 && DbgSizeY != -1)
|
||||||
SetWindowPos(hDebug,0,0,0,DbgSizeX,DbgSizeY,SWP_NOMOVE|SWP_NOZORDER|SWP_NOOWNERZORDER);
|
SetWindowPos(hDebug,0,0,0,DbgSizeX,DbgSizeY,SWP_NOMOVE|SWP_NOZORDER|SWP_NOOWNERZORDER);
|
||||||
}
|
}
|
||||||
if (hDebug) {
|
if (hDebug)
|
||||||
|
{
|
||||||
SetWindowPos(hDebug,HWND_TOP,0,0,0,0,SWP_NOSIZE|SWP_NOMOVE|SWP_NOOWNERZORDER);
|
SetWindowPos(hDebug,HWND_TOP,0,0,0,0,SWP_NOSIZE|SWP_NOMOVE|SWP_NOOWNERZORDER);
|
||||||
|
|
||||||
updateGameDependentMenusDebugger(GameInfo != 0);
|
updateGameDependentMenusDebugger(GameInfo != 0);
|
||||||
|
|
|
@ -1086,7 +1086,7 @@ BEGIN
|
||||||
CONTROL "I",IDC_DEBUGGER_FLAG_I,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,463,160,18,12
|
CONTROL "I",IDC_DEBUGGER_FLAG_I,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,463,160,18,12
|
||||||
CONTROL "Z",IDC_DEBUGGER_FLAG_Z,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,486,160,18,12
|
CONTROL "Z",IDC_DEBUGGER_FLAG_Z,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,486,160,18,12
|
||||||
CONTROL "C",IDC_DEBUGGER_FLAG_C,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,509,160,18,12
|
CONTROL "C",IDC_DEBUGGER_FLAG_C,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,509,160,18,12
|
||||||
GROUPBOX "BreakPoints",402,433,3,100,135,WS_TABSTOP
|
GROUPBOX "Breakpoints",IDC_DEBUGGER_BREAKPOINTS,433,3,100,135,WS_TABSTOP
|
||||||
LISTBOX IDC_DEBUGGER_BP_LIST,437,13,92,91,LBS_HASSTRINGS | LBS_DISABLENOSCROLL | WS_VSCROLL
|
LISTBOX IDC_DEBUGGER_BP_LIST,437,13,92,91,LBS_HASSTRINGS | LBS_DISABLENOSCROLL | WS_VSCROLL
|
||||||
PUSHBUTTON "Add",IDC_DEBUGGER_BP_ADD,437,107,30,15
|
PUSHBUTTON "Add",IDC_DEBUGGER_BP_ADD,437,107,30,15
|
||||||
PUSHBUTTON "Delete",IDC_DEBUGGER_BP_DEL,469,107,29,15,WS_DISABLED
|
PUSHBUTTON "Delete",IDC_DEBUGGER_BP_DEL,469,107,29,15,WS_DISABLED
|
||||||
|
|
|
@ -142,7 +142,6 @@
|
||||||
#define IDC_CHECK_LINES_TABBING 117
|
#define IDC_CHECK_LINES_TABBING 117
|
||||||
#define CHEAT_CONTEXT_POKECHEATVALUE 118
|
#define CHEAT_CONTEXT_POKECHEATVALUE 118
|
||||||
#define IDC_DEBUGGER_RESET_ON_BP0 118
|
#define IDC_DEBUGGER_RESET_ON_BP0 118
|
||||||
#define IDC_CHECK_LOG_STATUSES_TO_THE_RIGHT 118
|
|
||||||
#define IDC_CHECK_LOG_STATUSES_TO_THE_LEFT 118
|
#define IDC_CHECK_LOG_STATUSES_TO_THE_LEFT 118
|
||||||
#define CHEAT_CONTEXT_GOTOINHEXEDITOR 119
|
#define CHEAT_CONTEXT_GOTOINHEXEDITOR 119
|
||||||
#define IDC_DEBUGGER_BREAK_ON_INSTRUCTIONS 119
|
#define IDC_DEBUGGER_BREAK_ON_INSTRUCTIONS 119
|
||||||
|
@ -398,6 +397,7 @@
|
||||||
#define CHECK_ENABLE_FOURSCORE 401
|
#define CHECK_ENABLE_FOURSCORE 401
|
||||||
#define IDC_CHEAT_CHECK_GT_BY 402
|
#define IDC_CHEAT_CHECK_GT_BY 402
|
||||||
#define IDC_FORCE_INT_VIDEO_SCALARS 402
|
#define IDC_FORCE_INT_VIDEO_SCALARS 402
|
||||||
|
#define IDC_DEBUGGER_BREAKPOINTS 402
|
||||||
#define IDC_CHEAT_CHECK_LT_BY 403
|
#define IDC_CHEAT_CHECK_LT_BY 403
|
||||||
#define IDC_FORCE_ASPECT_CORRECTION 403
|
#define IDC_FORCE_ASPECT_CORRECTION 403
|
||||||
#define IDC_DEBUGGER_VAL_S 403
|
#define IDC_DEBUGGER_VAL_S 403
|
||||||
|
|
|
@ -60,6 +60,7 @@ extern void RefreshThrottleFPS();
|
||||||
int saved_eoptions;
|
int saved_eoptions;
|
||||||
int saved_EnableAutosave;
|
int saved_EnableAutosave;
|
||||||
extern int EnableAutosave;
|
extern int EnableAutosave;
|
||||||
|
int saved_frame_display;
|
||||||
// FCEUX
|
// FCEUX
|
||||||
extern EMOVIEMODE movieMode; // maybe we need normal setter for movieMode, to encapsulate it
|
extern EMOVIEMODE movieMode; // maybe we need normal setter for movieMode, to encapsulate it
|
||||||
extern void UpdateCheckedMenuItems();
|
extern void UpdateCheckedMenuItems();
|
||||||
|
@ -90,6 +91,9 @@ bool EnterTasEditor()
|
||||||
// switch off autosaves
|
// switch off autosaves
|
||||||
saved_EnableAutosave = EnableAutosave;
|
saved_EnableAutosave = EnableAutosave;
|
||||||
EnableAutosave = 0;
|
EnableAutosave = 0;
|
||||||
|
// switch on frame_display
|
||||||
|
saved_frame_display = frame_display;
|
||||||
|
frame_display = 1;
|
||||||
UpdateCheckedMenuItems();
|
UpdateCheckedMenuItems();
|
||||||
|
|
||||||
// init modules
|
// init modules
|
||||||
|
@ -168,6 +172,8 @@ bool ExitTasEditor()
|
||||||
// restore autosaves
|
// restore autosaves
|
||||||
EnableAutosave = saved_EnableAutosave;
|
EnableAutosave = saved_EnableAutosave;
|
||||||
DoPriority();
|
DoPriority();
|
||||||
|
// restore frame_display
|
||||||
|
frame_display = saved_frame_display;
|
||||||
UpdateCheckedMenuItems();
|
UpdateCheckedMenuItems();
|
||||||
// switch off TAS Editor mode
|
// switch off TAS Editor mode
|
||||||
movieMode = MOVIEMODE_INACTIVE;
|
movieMode = MOVIEMODE_INACTIVE;
|
||||||
|
|
|
@ -63,7 +63,7 @@ int tracelogbufusedsize;
|
||||||
bool tracer_lines_tabbing = true;
|
bool tracer_lines_tabbing = true;
|
||||||
bool tracer_statuses_to_the_left = false;
|
bool tracer_statuses_to_the_left = false;
|
||||||
|
|
||||||
bool old_emu_paused = false; // thus the window only updates once after the game is paused
|
bool old_emu_paused = true; // thanks to this flag the window only updates once after the game is paused
|
||||||
extern bool JustFrameAdvanced;
|
extern bool JustFrameAdvanced;
|
||||||
|
|
||||||
FILE *LOG_FP;
|
FILE *LOG_FP;
|
||||||
|
@ -81,13 +81,8 @@ void UpdateLogText(void);
|
||||||
void EnableTracerMenuItems(void);
|
void EnableTracerMenuItems(void);
|
||||||
int PromptForCDLogger(void);
|
int PromptForCDLogger(void);
|
||||||
|
|
||||||
BOOL CALLBACK TracerCallB(HWND hwndDlg, UINT uMsg, WPARAM wParam, LPARAM lParam) {
|
BOOL CALLBACK TracerCallB(HWND hwndDlg, UINT uMsg, WPARAM wParam, LPARAM lParam)
|
||||||
//Assemble the message to pause the game. Uses the current hotkey mapping dynamically
|
{
|
||||||
string m1 = "Press " ;
|
|
||||||
string m2 = GetKeyComboName(FCEUD_CommandMapping[EMUCMD_PAUSE]);
|
|
||||||
string m3 = " to pause the game, or snap \r\nthe debugger to update this window.\r\n";
|
|
||||||
string message = m1+m2+m3;
|
|
||||||
|
|
||||||
int i;
|
int i;
|
||||||
LOGFONT lf;
|
LOGFONT lf;
|
||||||
switch(uMsg) {
|
switch(uMsg) {
|
||||||
|
@ -113,7 +108,7 @@ BOOL CALLBACK TracerCallB(HWND hwndDlg, UINT uMsg, WPARAM wParam, LPARAM lParam)
|
||||||
//setup font
|
//setup font
|
||||||
hlogFont = (HFONT)SendMessage(hwndDlg, WM_GETFONT, 0, 0);
|
hlogFont = (HFONT)SendMessage(hwndDlg, WM_GETFONT, 0, 0);
|
||||||
GetObject(hlogFont, sizeof(LOGFONT), &lf);
|
GetObject(hlogFont, sizeof(LOGFONT), &lf);
|
||||||
strcpy(lf.lfFaceName,"Courier");
|
strcpy(lf.lfFaceName,"Courier New");
|
||||||
hlogNewFont = CreateFontIndirect(&lf);
|
hlogNewFont = CreateFontIndirect(&lf);
|
||||||
SendDlgItemMessage(hwndDlg,IDC_TRACER_LOG,WM_SETFONT,(WPARAM)hlogNewFont,FALSE);
|
SendDlgItemMessage(hwndDlg,IDC_TRACER_LOG,WM_SETFONT,(WPARAM)hlogNewFont,FALSE);
|
||||||
|
|
||||||
|
@ -192,12 +187,21 @@ BOOL CALLBACK TracerCallB(HWND hwndDlg, UINT uMsg, WPARAM wParam, LPARAM lParam)
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case IDC_CHECK_LOG_UPDATE_WINDOW:
|
case IDC_CHECK_LOG_UPDATE_WINDOW:
|
||||||
|
{
|
||||||
//todo: if this gets unchecked then we need to clear out the window
|
//todo: if this gets unchecked then we need to clear out the window
|
||||||
log_update_window ^= 1;
|
log_update_window ^= 1;
|
||||||
if(!FCEUI_EmulationPaused() && !log_update_window) //mbg merge 7/19/06 changed to use EmulationPaused()
|
if(!FCEUI_EmulationPaused() && !log_update_window)
|
||||||
SetDlgItemText(hTracer, IDC_TRACER_LOG, message.c_str());
|
{
|
||||||
|
// Assemble the message to pause the game. Uses the current hotkey mapping dynamically
|
||||||
|
string m1 = "Pause the game (press ";
|
||||||
|
string m2 = GetKeyComboName(FCEUD_CommandMapping[EMUCMD_PAUSE]);
|
||||||
|
string m3 = " key or snap the Debugger) to update this window.\r\n";
|
||||||
|
string pauseMessage = m1 + m2 + m3;
|
||||||
|
SetDlgItemText(hTracer, IDC_TRACER_LOG, pauseMessage.c_str());
|
||||||
|
}
|
||||||
//PauseLoggingSequence();
|
//PauseLoggingSequence();
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
case IDC_BTN_LOG_BROWSE:
|
case IDC_BTN_LOG_BROWSE:
|
||||||
ShowLogDirDialog();
|
ShowLogDirDialog();
|
||||||
break;
|
break;
|
||||||
|
@ -244,19 +248,15 @@ BOOL CALLBACK TracerCallB(HWND hwndDlg, UINT uMsg, WPARAM wParam, LPARAM lParam)
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
void BeginLoggingSequence(void){
|
void BeginLoggingSequence(void)
|
||||||
//Assemble the message to pause the game. Uses the current hotkey mapping dynamically
|
{
|
||||||
string m1 = "Press ";
|
|
||||||
string m2 = GetKeyComboName(FCEUD_CommandMapping[EMUCMD_PAUSE]);
|
|
||||||
string m3 = " to pause the game, or snap \r\nthe debugger to update this window.\r\n";
|
|
||||||
string pauseMessage = m1 + m2 + m3;
|
|
||||||
|
|
||||||
char str[2048], str2[100];
|
char str[2048], str2[100];
|
||||||
int i, j;
|
int i, j;
|
||||||
|
|
||||||
if(!PromptForCDLogger())return; //do nothing if user selected no and CD Logger is needed
|
if(!PromptForCDLogger())return; //do nothing if user selected no and CD Logger is needed
|
||||||
|
|
||||||
if(logtofile){
|
if(logtofile)
|
||||||
|
{
|
||||||
if(logfilename == NULL) ShowLogDirDialog();
|
if(logfilename == NULL) ShowLogDirDialog();
|
||||||
if (!logfilename) return;
|
if (!logfilename) return;
|
||||||
LOG_FP = fopen(logfilename,"w");
|
LOG_FP = fopen(logfilename,"w");
|
||||||
|
@ -266,18 +266,25 @@ void BeginLoggingSequence(void){
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
fprintf(LOG_FP,FCEU_NAME_AND_VERSION" - Trace Log File\n"); //mbg merge 7/19/06 changed string
|
fprintf(LOG_FP,FCEU_NAME_AND_VERSION" - Trace Log File\n"); //mbg merge 7/19/06 changed string
|
||||||
} else {
|
} else
|
||||||
|
{
|
||||||
strcpy(str,"Allocating Memory...\r\n");
|
strcpy(str,"Allocating Memory...\r\n");
|
||||||
SetDlgItemText(hTracer, IDC_TRACER_LOG, str);
|
SetDlgItemText(hTracer, IDC_TRACER_LOG, str);
|
||||||
tracelogbufsize = j = log_optn_intlst[SendDlgItemMessage(hTracer,IDC_TRACER_LOG_SIZE,CB_GETCURSEL,0,0)];
|
tracelogbufsize = j = log_optn_intlst[SendDlgItemMessage(hTracer,IDC_TRACER_LOG_SIZE,CB_GETCURSEL,0,0)];
|
||||||
tracelogbuf = (char**)malloc(j*sizeof(char *)); //mbg merge 7/19/06 added cast
|
tracelogbuf = (char**)malloc(j*sizeof(char *)); //mbg merge 7/19/06 added cast
|
||||||
for(i = 0;i < j;i++){
|
for(i = 0;i < j;i++)
|
||||||
|
{
|
||||||
tracelogbuf[i] = (char*)malloc(LOG_LINE_MAX_LEN); //mbg merge 7/19/06 added cast
|
tracelogbuf[i] = (char*)malloc(LOG_LINE_MAX_LEN); //mbg merge 7/19/06 added cast
|
||||||
tracelogbuf[i][0] = 0;
|
tracelogbuf[i][0] = 0;
|
||||||
}
|
}
|
||||||
sprintf(str2, "%d Bytes Allocated...\r\n", j * LOG_LINE_MAX_LEN);
|
sprintf(str2, "%d Bytes Allocated...\r\n", j * LOG_LINE_MAX_LEN);
|
||||||
strcat(str,str2);
|
strcat(str,str2);
|
||||||
strcat(str,pauseMessage.c_str());
|
// Assemble the message to pause the game. Uses the current hotkey mapping dynamically
|
||||||
|
string m1 = "Pause the game (press ";
|
||||||
|
string m2 = GetKeyComboName(FCEUD_CommandMapping[EMUCMD_PAUSE]);
|
||||||
|
string m3 = " key or snap the Debugger) to update this window.\r\n";
|
||||||
|
string pauseMessage = m1 + m2 + m3;
|
||||||
|
strcat(str, pauseMessage.c_str());
|
||||||
SetDlgItemText(hTracer, IDC_TRACER_LOG, str);
|
SetDlgItemText(hTracer, IDC_TRACER_LOG, str);
|
||||||
tracelogbufpos = tracelogbufusedsize = 0;
|
tracelogbufpos = tracelogbufusedsize = 0;
|
||||||
}
|
}
|
||||||
|
@ -489,20 +496,8 @@ void EndLoggingSequence(void){
|
||||||
}
|
}
|
||||||
|
|
||||||
//void PauseLoggingSequence(void){
|
//void PauseLoggingSequence(void){
|
||||||
void UpdateLogWindow(void){
|
void UpdateLogWindow(void)
|
||||||
|
{
|
||||||
//if((tracelogbufpos == 0) || (tracelogbuf[tracelogbufpos][0]))
|
|
||||||
// tracesi.nMax = tracelogbufsize;
|
|
||||||
//else tracesi.nMax = tracelogbufpos;
|
|
||||||
|
|
||||||
//todo: fix this up.
|
|
||||||
//if(!log_update_window && !userpause){
|
|
||||||
// SetDlgItemText(hTracer, IDC_TRACER_LOG, "Press F2 to pause the game, or snap \r\nthe debugger to update this window.\r\n");
|
|
||||||
// return;
|
|
||||||
//}
|
|
||||||
|
|
||||||
//
|
|
||||||
|
|
||||||
//we don't want to continue if the trace logger isn't logging, or if its logging to a file.
|
//we don't want to continue if the trace logger isn't logging, or if its logging to a file.
|
||||||
if ((!logging) || logtofile)
|
if ((!logging) || logtofile)
|
||||||
return;
|
return;
|
||||||
|
|
Loading…
Reference in New Issue