Found a way around an inefficient comparison method I was using.
This commit is contained in:
parent
ef4af2ff0e
commit
3a750d276e
|
@ -351,35 +351,28 @@ BOOL CALLBACK CheatConsoleCallB(HWND hwndDlg, UINT uMsg, WPARAM wParam, LPARAM l
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case WM_CONTEXTMENU:
|
case WM_CONTEXTMENU:
|
||||||
{
|
{
|
||||||
// Handle certain subborn context menus for nearly incapable controls.
|
// Handle certain subborn context menus for nearly incapable controls.
|
||||||
|
|
||||||
// Convert wParam to a string
|
if (wParam == (uint32)GetDlgItem(hwndDlg,IDC_LIST_CHEATS)) {
|
||||||
sprintf(str,"%08x",wParam);
|
// Only open the menu if a cheat is selected
|
||||||
|
if (selcheat >= 0) {
|
||||||
// Convert HWND of IDC_LIST_CHEATS to a string
|
// Open IDC_LIST_CHEATS Context Menu
|
||||||
sprintf(str2,"%08x",GetDlgItem(hwndDlg,IDC_LIST_CHEATS));
|
hCheatcontextsub = GetSubMenu(hCheatcontext,0);
|
||||||
|
|
||||||
// Compare the now-compatible data with strcmp.
|
|
||||||
if (!strcmp(str, str2)) {
|
|
||||||
// Only open the menu if a cheat is selected
|
|
||||||
if (selcheat >= 0) {
|
|
||||||
// Open IDC_LIST_CHEATS Context Menu
|
|
||||||
hCheatcontextsub = GetSubMenu(hCheatcontext,0);
|
|
||||||
|
|
||||||
if (lParam != -1)
|
|
||||||
TrackPopupMenu(hCheatcontextsub,0,LOWORD(lParam),HIWORD(lParam),TPM_RIGHTBUTTON,hwndDlg,0); //Create menu
|
|
||||||
else { // Handle the context menu keyboard key
|
|
||||||
GetWindowRect(GetDlgItem(hwndDlg,IDC_LIST_CHEATS), &wrect);
|
|
||||||
TrackPopupMenu(hCheatcontextsub,0,wrect.left + int((wrect.right - wrect.left) / 3),wrect.top + int((wrect.bottom - wrect.top) / 3),TPM_RIGHTBUTTON,hwndDlg,0); //Create menu
|
|
||||||
}
|
|
||||||
|
|
||||||
|
if (lParam != -1)
|
||||||
|
TrackPopupMenu(hCheatcontextsub,0,LOWORD(lParam),HIWORD(lParam),TPM_RIGHTBUTTON,hwndDlg,0); //Create menu
|
||||||
|
else { // Handle the context menu keyboard key
|
||||||
|
GetWindowRect(GetDlgItem(hwndDlg,IDC_LIST_CHEATS), &wrect);
|
||||||
|
TrackPopupMenu(hCheatcontextsub,0,wrect.left + int((wrect.right - wrect.left) / 3),wrect.top + int((wrect.bottom - wrect.top) / 3),TPM_RIGHTBUTTON,hwndDlg,0); //Create menu
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
|
}
|
||||||
}
|
}
|
||||||
break;
|
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
case WM_COMMAND:
|
case WM_COMMAND:
|
||||||
switch (HIWORD(wParam)) {
|
switch (HIWORD(wParam)) {
|
||||||
|
|
|
@ -1001,7 +1001,7 @@ void LoadGameDebuggerData(HWND hwndDlg = hDebug) {
|
||||||
|
|
||||||
BOOL CALLBACK DebuggerCallB(HWND hwndDlg, UINT uMsg, WPARAM wParam, LPARAM lParam) {
|
BOOL CALLBACK DebuggerCallB(HWND hwndDlg, UINT uMsg, WPARAM wParam, LPARAM lParam) {
|
||||||
RECT wrect;
|
RECT wrect;
|
||||||
char str[256]={0},str2[256]={0},*ptr,dotdot[4];
|
char str[256]={0},*ptr,dotdot[4];
|
||||||
int tmp,tmp2;
|
int tmp,tmp2;
|
||||||
int mouse_x,mouse_y;
|
int mouse_x,mouse_y;
|
||||||
int ret,i;
|
int ret,i;
|
||||||
|
@ -1171,14 +1171,7 @@ BOOL CALLBACK DebuggerCallB(HWND hwndDlg, UINT uMsg, WPARAM wParam, LPARAM lPara
|
||||||
{
|
{
|
||||||
// Handle certain subborn context menus for nearly incapable controls.
|
// Handle certain subborn context menus for nearly incapable controls.
|
||||||
|
|
||||||
// Convert wParam to a string
|
if (wParam == (uint32)GetDlgItem(hwndDlg,IDC_DEBUGGER_BP_LIST)) {
|
||||||
sprintf(str,"%08x",wParam);
|
|
||||||
|
|
||||||
// Convert HWND of IDC_LIST_CHEATS to a string
|
|
||||||
sprintf(str2,"%08x",GetDlgItem(hwndDlg,IDC_DEBUGGER_BP_LIST));
|
|
||||||
|
|
||||||
// Compare the now-compatible data with strcmp.
|
|
||||||
if (!strcmp(str, str2)) {
|
|
||||||
// Only open the menu if a cheat is selected
|
// Only open the menu if a cheat is selected
|
||||||
if (SendDlgItemMessage(hwndDlg,IDC_DEBUGGER_BP_LIST,LB_GETCURSEL,0,0) >= 0) {
|
if (SendDlgItemMessage(hwndDlg,IDC_DEBUGGER_BP_LIST,LB_GETCURSEL,0,0) >= 0) {
|
||||||
// Open IDC_LIST_CHEATS Context Menu
|
// Open IDC_LIST_CHEATS Context Menu
|
||||||
|
@ -1191,7 +1184,6 @@ BOOL CALLBACK DebuggerCallB(HWND hwndDlg, UINT uMsg, WPARAM wParam, LPARAM lPara
|
||||||
TrackPopupMenu(hDebugcontextsub,0,wrect.left + int((wrect.right - wrect.left) / 3),wrect.top + int((wrect.bottom - wrect.top) / 3),TPM_RIGHTBUTTON,hwndDlg,0); //Create menu
|
TrackPopupMenu(hDebugcontextsub,0,wrect.left + int((wrect.right - wrect.left) / 3),wrect.top + int((wrect.bottom - wrect.top) / 3),TPM_RIGHTBUTTON,hwndDlg,0); //Create menu
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue