* 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:
ansstuff 2012-08-08 13:19:22 +00:00
parent 6188e68811
commit 714e9282f8
7 changed files with 168 additions and 74 deletions

View File

@ -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;

View File

@ -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);

View File

@ -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);

View File

@ -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

View File

@ -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

View File

@ -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;

View File

@ -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;