/** * \file bridgemain.cpp * * \brief Defines functions to initialize and start the Bridge and * to interface with the GUI and the DBG. */ #include "_global.h" #include "bridgemain.h" #include #include "Utf8Ini.h" static HINSTANCE hInst; static Utf8Ini settings; static wchar_t szIniFile[MAX_PATH] = L""; static CRITICAL_SECTION csIni; static CRITICAL_SECTION csTranslate; static bool bDisableGUIUpdate; #define CHECK_GUI_UPDATE_DISABLED \ if (bDisableGUIUpdate) \ return; #ifdef _WIN64 #define dbg_lib L"x64dbg.dll" #define gui_lib L"x64gui.dll" #else #define dbg_lib L"x32dbg.dll" #define gui_lib L"x32gui.dll" #endif // _WIN64 #define LOADLIBRARY(name) \ szLib=name; \ hInst=LoadLibraryW(name); \ if(!hInst) \ return L"Error loading library \"" name L"\"!" #define LOADEXPORT(name) \ *((FARPROC*)&name)=GetProcAddress(hInst, #name); \ if(!name) \ { \ wsprintfW(szError, L"Export %s:%S could not be found!", szLib, #name); \ return szError; \ } BRIDGE_IMPEXP const wchar_t* BridgeInit() { //Initialize critial section InitializeCriticalSection(&csIni); InitializeCriticalSection(&csTranslate); //Settings load if(!GetModuleFileNameW(0, szIniFile, MAX_PATH)) return L"Error getting module path!"; int len = (int)wcslen(szIniFile); while(szIniFile[len] != L'.' && szIniFile[len] != L'\\' && len) len--; if(szIniFile[len] == L'\\') wcscat_s(szIniFile, L".ini"); else wcscpy_s(&szIniFile[len], _countof(szIniFile) - len, L".ini"); HINSTANCE hInst; const wchar_t* szLib; static wchar_t szError[256] = L""; //GUI Load LOADLIBRARY(gui_lib); LOADEXPORT(_gui_guiinit); LOADEXPORT(_gui_sendmessage); LOADEXPORT(_gui_translate_text); //DBG Load LOADLIBRARY(dbg_lib); LOADEXPORT(_dbg_dbginit); LOADEXPORT(_dbg_memfindbaseaddr); LOADEXPORT(_dbg_memread); LOADEXPORT(_dbg_memwrite); LOADEXPORT(_dbg_dbgcmdexec); LOADEXPORT(_dbg_memmap); LOADEXPORT(_dbg_dbgexitsignal); LOADEXPORT(_dbg_valfromstring); LOADEXPORT(_dbg_isdebugging); LOADEXPORT(_dbg_isjumpgoingtoexecute); LOADEXPORT(_dbg_addrinfoget); LOADEXPORT(_dbg_addrinfoset); LOADEXPORT(_dbg_encodetypeset); LOADEXPORT(_dbg_bpgettypeat); LOADEXPORT(_dbg_getregdump); LOADEXPORT(_dbg_valtostring); LOADEXPORT(_dbg_memisvalidreadptr); LOADEXPORT(_dbg_getbplist); LOADEXPORT(_dbg_dbgcmddirectexec); LOADEXPORT(_dbg_getbranchdestination); LOADEXPORT(_dbg_sendmessage); return 0; } BRIDGE_IMPEXP const wchar_t* BridgeStart() { if(!_dbg_dbginit || !_gui_guiinit) return L"\"_dbg_dbginit\" || \"_gui_guiinit\" was not loaded yet, call BridgeInit!"; int errorLine = 0; BridgeSettingRead(&errorLine); _dbg_sendmessage(DBG_INITIALIZE_LOCKS, nullptr, nullptr); //initialize locks before any other thread than the main thread are started _gui_guiinit(0, 0); //remove arguments if(!BridgeSettingFlush()) return L"Failed to save settings!"; _dbg_sendmessage(DBG_DEINITIALIZE_LOCKS, nullptr, nullptr); //deinitialize locks when only one thread is left (hopefully) DeleteCriticalSection(&csIni); DeleteCriticalSection(&csTranslate); return 0; } BRIDGE_IMPEXP void* BridgeAlloc(size_t size) { unsigned char* ptr = (unsigned char*)GlobalAlloc(GMEM_FIXED, size); if(!ptr) { MessageBoxW(0, L"Could not allocate memory", L"Error", MB_ICONERROR); ExitProcess(1); } memset(ptr, 0, size); return ptr; } BRIDGE_IMPEXP void BridgeFree(void* ptr) { if(ptr) GlobalFree(ptr); } BRIDGE_IMPEXP bool BridgeSettingGet(const char* section, const char* key, char* value) { if(!section || !key || !value) return false; EnterCriticalSection(&csIni); auto foundValue = settings.GetValue(section, key); bool result = foundValue.length() > 0; if(result) strcpy_s(value, MAX_SETTING_SIZE, foundValue.c_str()); LeaveCriticalSection(&csIni); return result; } BRIDGE_IMPEXP bool BridgeSettingGetUint(const char* section, const char* key, duint* value) { if(!section || !key || !value) return false; char newvalue[MAX_SETTING_SIZE] = ""; if(!BridgeSettingGet(section, key, newvalue)) return false; #ifdef _WIN64 int ret = sscanf(newvalue, "%llX", value); #else int ret = sscanf(newvalue, "%X", value); #endif //_WIN64 if(ret) return true; return false; } BRIDGE_IMPEXP bool BridgeSettingSet(const char* section, const char* key, const char* value) { bool success = false; if(section) { EnterCriticalSection(&csIni); if(!key) success = settings.ClearSection(section); else if(!value) success = settings.SetValue(section, key, ""); else success = settings.SetValue(section, key, value); LeaveCriticalSection(&csIni); } return success; } BRIDGE_IMPEXP bool BridgeSettingSetUint(const char* section, const char* key, duint value) { if(!section || !key) return false; char newvalue[32] = ""; #ifdef _WIN64 sprintf_s(newvalue, "%llX", value); #else sprintf_s(newvalue, "%X", value); #endif //_WIN64 return BridgeSettingSet(section, key, newvalue); } BRIDGE_IMPEXP bool BridgeSettingFlush() { EnterCriticalSection(&csIni); std::string iniData = settings.Serialize(); LeaveCriticalSection(&csIni); bool success = false; HANDLE hFile = CreateFileW(szIniFile, GENERIC_WRITE, 0, nullptr, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, nullptr); if(hFile != INVALID_HANDLE_VALUE) { SetEndOfFile(hFile); DWORD written = 0; if(WriteFile(hFile, iniData.c_str(), (DWORD)iniData.length(), &written, nullptr)) success = true; CloseHandle(hFile); } return success; } BRIDGE_IMPEXP bool BridgeSettingRead(int* errorLine) { if(errorLine) *errorLine = 0; bool success = false; std::string iniData; HANDLE hFile = CreateFileW(szIniFile, GENERIC_READ, FILE_SHARE_READ, nullptr, OPEN_EXISTING, 0, nullptr); if(hFile != INVALID_HANDLE_VALUE) { DWORD fileSize = GetFileSize(hFile, nullptr); if(fileSize) { unsigned char utf8bom[] = { 0xEF, 0xBB, 0xBF }; char* fileData = (char*)BridgeAlloc(sizeof(utf8bom) + fileSize + 1); DWORD read = 0; if(ReadFile(hFile, fileData, fileSize, &read, nullptr)) { success = true; if(!memcmp(fileData, utf8bom, sizeof(utf8bom))) iniData.assign(fileData + sizeof(utf8bom)); else iniData.assign(fileData); } BridgeFree(fileData); } CloseHandle(hFile); } if(success) //if we failed to read the file, the current settings are better than none at all { EnterCriticalSection(&csIni); int errline = 0; success = settings.Deserialize(iniData, errline); if(errorLine) *errorLine = errline; LeaveCriticalSection(&csIni); } return success; } BRIDGE_IMPEXP int BridgeGetDbgVersion() { return DBG_VERSION; } BRIDGE_IMPEXP bool DbgMemRead(duint va, void* dest, duint size) { #ifdef _DEBUG if(IsBadWritePtr(dest, size)) { GuiAddLogMessage("DbgMemRead with invalid boundaries!\n"); __debugbreak(); return false; } #endif //_DEBUG if(!_dbg_memread(va, dest, size, 0)) { // Zero the buffer on failure memset(dest, 0, size); return false; } return true; } BRIDGE_IMPEXP bool DbgMemWrite(duint va, const void* src, duint size) { #ifdef _DEBUG if(IsBadReadPtr(src, size)) { GuiAddLogMessage("DbgMemWrite with invalid boundaries!\n"); __debugbreak(); return false; } #endif //_DEBUG return _dbg_memwrite(va, src, size, 0); } // FIXME, not exactly base if it still does a find? BRIDGE_IMPEXP duint DbgMemGetPageSize(duint base) { duint size = 0; _dbg_memfindbaseaddr(base, &size); return size; } BRIDGE_IMPEXP duint DbgMemFindBaseAddr(duint addr, duint* size) { return _dbg_memfindbaseaddr(addr, size); } BRIDGE_IMPEXP bool DbgCmdExec(const char* cmd) { return _dbg_dbgcmdexec(cmd); } // FIXME BRIDGE_IMPEXP bool DbgMemMap(MEMMAP* memmap) { return _dbg_memmap(memmap); } BRIDGE_IMPEXP bool DbgIsValidExpression(const char* expression) { duint value = 0; return _dbg_valfromstring(expression, &value); } BRIDGE_IMPEXP bool DbgIsDebugging() { return _dbg_isdebugging(); } BRIDGE_IMPEXP bool DbgIsJumpGoingToExecute(duint addr) { return _dbg_isjumpgoingtoexecute(addr); } // FIXME required size of arg _text_? BRIDGE_IMPEXP bool DbgGetLabelAt(duint addr, SEGMENTREG segment, char* text) //(module.)+label { if(!text || !addr) return false; BRIDGE_ADDRINFO info; memset(&info, 0, sizeof(info)); info.flags = flaglabel | flagNoFuncOffset; if(!_dbg_addrinfoget(addr, segment, &info)) { duint addr_ = 0; if(!DbgMemIsValidReadPtr(addr)) return false; DbgMemRead(addr, (unsigned char*)&addr_, sizeof(duint)); BRIDGE_ADDRINFO ptrinfo = info; if(!_dbg_addrinfoget(addr_, SEG_DEFAULT, &ptrinfo)) return false; sprintf_s(info.label, "&%s", ptrinfo.label); } strcpy_s(text, MAX_LABEL_SIZE, info.label); return true; } BRIDGE_IMPEXP bool DbgSetLabelAt(duint addr, const char* text) { if(!text || strlen(text) >= MAX_LABEL_SIZE || !addr) return false; BRIDGE_ADDRINFO info; memset(&info, 0, sizeof(info)); info.flags = flaglabel; strcpy_s(info.label, text); if(!_dbg_addrinfoset(addr, &info)) return false; return true; } BRIDGE_IMPEXP void DbgClearLabelRange(duint start, duint end) { _dbg_sendmessage(DBG_DELETE_LABEL_RANGE, (void*)start, (void*)end); } // FIXME required size of arg _text_? BRIDGE_IMPEXP bool DbgGetCommentAt(duint addr, char* text) //comment (not live) { if(!text || !addr) return false; BRIDGE_ADDRINFO info; memset(&info, 0, sizeof(info)); info.flags = flagcomment; if(!_dbg_addrinfoget(addr, SEG_DEFAULT, &info)) return false; strcpy_s(text, MAX_COMMENT_SIZE, info.comment); return true; } BRIDGE_IMPEXP bool DbgSetCommentAt(duint addr, const char* text) { if(!text || strlen(text) >= MAX_COMMENT_SIZE || !addr) return false; BRIDGE_ADDRINFO info; memset(&info, 0, sizeof(info)); info.flags = flagcomment; strcpy_s(info.comment, MAX_COMMENT_SIZE, text); if(!_dbg_addrinfoset(addr, &info)) return false; return true; } BRIDGE_IMPEXP void DbgClearCommentRange(duint start, duint end) { _dbg_sendmessage(DBG_DELETE_COMMENT_RANGE, (void*)start, (void*)end); } // FIXME required size of arg _text_? BRIDGE_IMPEXP bool DbgGetModuleAt(duint addr, char* text) { if(!text || !addr) return false; BRIDGE_ADDRINFO info; memset(&info, 0, sizeof(info)); info.flags = flagmodule; if(!_dbg_addrinfoget(addr, SEG_DEFAULT, &info)) return false; strcpy_s(text, MAX_MODULE_SIZE, info.module); return true; } BRIDGE_IMPEXP bool DbgGetBookmarkAt(duint addr) { if(!addr) return false; BRIDGE_ADDRINFO info; memset(&info, 0, sizeof(info)); info.flags = flagbookmark; if(!_dbg_addrinfoget(addr, SEG_DEFAULT, &info)) return false; return info.isbookmark; } BRIDGE_IMPEXP bool DbgSetBookmarkAt(duint addr, bool isbookmark) { if(!addr) return false; BRIDGE_ADDRINFO info; memset(&info, 0, sizeof(info)); info.flags = flagbookmark; info.isbookmark = isbookmark; return _dbg_addrinfoset(addr, &info); } BRIDGE_IMPEXP void DbgClearBookmarkRange(duint start, duint end) { _dbg_sendmessage(DBG_DELETE_BOOKMARK_RANGE, (void*)start, (void*)end); } // FIXME return on success? BRIDGE_IMPEXP const char* DbgInit() { return _dbg_dbginit(); } BRIDGE_IMPEXP void DbgExit() { _dbg_dbgexitsignal(); //send exit signal to debugger } BRIDGE_IMPEXP BPXTYPE DbgGetBpxTypeAt(duint addr) { return _dbg_bpgettypeat(addr); } BRIDGE_IMPEXP duint DbgValFromString(const char* string) { duint value = 0; _dbg_valfromstring(string, &value); return value; } BRIDGE_IMPEXP bool DbgGetRegDump(REGDUMP* regdump) { return _dbg_getregdump(regdump); } // FIXME all BRIDGE_IMPEXP bool DbgValToString(const char* string, duint value) { return _dbg_valtostring(string, value); } BRIDGE_IMPEXP bool DbgMemIsValidReadPtr(duint addr) { return _dbg_memisvalidreadptr(addr); } // FIXME return BRIDGE_IMPEXP int DbgGetBpList(BPXTYPE type, BPMAP* list) { return _dbg_getbplist(type, list); } // FIXME all BRIDGE_IMPEXP bool DbgCmdExecDirect(const char* cmd) { return _dbg_dbgcmddirectexec(cmd); } BRIDGE_IMPEXP FUNCTYPE DbgGetFunctionTypeAt(duint addr) { BRIDGE_ADDRINFO info; memset(&info, 0, sizeof(info)); info.flags = flagfunction; if(!_dbg_addrinfoget(addr, SEG_DEFAULT, &info)) return FUNC_NONE; duint start = info.function.start; duint end = info.function.end; if(start == end || info.function.instrcount == 1) return FUNC_SINGLE; else if(addr == start) return FUNC_BEGIN; else if(addr == end) return FUNC_END; return FUNC_MIDDLE; } // FIXME depth BRIDGE_IMPEXP LOOPTYPE DbgGetLoopTypeAt(duint addr, int depth) { BRIDGE_ADDRINFO info; memset(&info, 0, sizeof(info)); info.flags = flagloop; info.loop.depth = depth; if(!_dbg_addrinfoget(addr, SEG_DEFAULT, &info)) return LOOP_NONE; duint start = info.loop.start; duint end = info.loop.end; if(start == end || info.loop.instrcount == 1) return LOOP_SINGLE; else if(addr == start) return LOOP_BEGIN; else if(addr == end) return LOOP_END; return LOOP_MIDDLE; } BRIDGE_IMPEXP duint DbgGetBranchDestination(duint addr) { return _dbg_getbranchdestination(addr); } BRIDGE_IMPEXP void DbgScriptLoad(const char* filename) { _dbg_sendmessage(DBG_SCRIPT_LOAD, (void*)filename, 0); } // FIXME every? BRIDGE_IMPEXP void DbgScriptUnload() { _dbg_sendmessage(DBG_SCRIPT_UNLOAD, 0, 0); } // FIXME "the script?"; destline BRIDGE_IMPEXP void DbgScriptRun(int destline) { _dbg_sendmessage(DBG_SCRIPT_RUN, (void*)(duint)destline, 0); } BRIDGE_IMPEXP void DbgScriptStep() { _dbg_sendmessage(DBG_SCRIPT_STEP, 0, 0); } BRIDGE_IMPEXP bool DbgScriptBpToggle(int line) { if(_dbg_sendmessage(DBG_SCRIPT_BPTOGGLE, (void*)(duint)line, 0)) return true; return false; } BRIDGE_IMPEXP bool DbgScriptBpGet(int line) { if(_dbg_sendmessage(DBG_SCRIPT_BPGET, (void*)(duint)line, 0)) return true; return false; } BRIDGE_IMPEXP bool DbgScriptCmdExec(const char* command) { if(_dbg_sendmessage(DBG_SCRIPT_CMDEXEC, (void*)command, 0)) return true; return false; } BRIDGE_IMPEXP void DbgScriptAbort() { _dbg_sendmessage(DBG_SCRIPT_ABORT, 0, 0); } BRIDGE_IMPEXP SCRIPTLINETYPE DbgScriptGetLineType(int line) { return (SCRIPTLINETYPE)_dbg_sendmessage(DBG_SCRIPT_GETLINETYPE, (void*)(duint)line, 0); } BRIDGE_IMPEXP void DbgScriptSetIp(int line) { _dbg_sendmessage(DBG_SCRIPT_SETIP, (void*)(duint)line, 0); } // FIXME non-null? BRIDGE_IMPEXP bool DbgScriptGetBranchInfo(int line, SCRIPTBRANCH* info) { return !!_dbg_sendmessage(DBG_SCRIPT_GETBRANCHINFO, (void*)(duint)line, info); } // FIXME all BRIDGE_IMPEXP void DbgSymbolEnum(duint base, CBSYMBOLENUM cbSymbolEnum, void* user) { SYMBOLCBINFO cbInfo; cbInfo.base = base; cbInfo.cbSymbolEnum = cbSymbolEnum; cbInfo.user = user; _dbg_sendmessage(DBG_SYMBOL_ENUM, &cbInfo, 0); } // FIXME all BRIDGE_IMPEXP void DbgSymbolEnumFromCache(duint base, CBSYMBOLENUM cbSymbolEnum, void* user) { SYMBOLCBINFO cbInfo; cbInfo.base = base; cbInfo.cbSymbolEnum = cbSymbolEnum; cbInfo.user = user; _dbg_sendmessage(DBG_SYMBOL_ENUM_FROMCACHE, &cbInfo, 0); } BRIDGE_IMPEXP bool DbgAssembleAt(duint addr, const char* instruction) { if(_dbg_sendmessage(DBG_ASSEMBLE_AT, (void*)addr, (void*)instruction)) return true; return false; } BRIDGE_IMPEXP duint DbgModBaseFromName(const char* name) { return _dbg_sendmessage(DBG_MODBASE_FROM_NAME, (void*)name, 0); } BRIDGE_IMPEXP void DbgDisasmAt(duint addr, DISASM_INSTR* instr) { _dbg_sendmessage(DBG_DISASM_AT, (void*)addr, instr); } BRIDGE_IMPEXP bool DbgStackCommentGet(duint addr, STACK_COMMENT* comment) { return !!_dbg_sendmessage(DBG_STACK_COMMENT_GET, (void*)addr, comment); } BRIDGE_IMPEXP void DbgGetThreadList(THREADLIST* list) { _dbg_sendmessage(DBG_GET_THREAD_LIST, list, 0); } BRIDGE_IMPEXP void DbgSettingsUpdated() { _dbg_sendmessage(DBG_SETTINGS_UPDATED, 0, 0); } BRIDGE_IMPEXP void DbgDisasmFastAt(duint addr, BASIC_INSTRUCTION_INFO* basicinfo) { _dbg_sendmessage(DBG_DISASM_FAST_AT, (void*)addr, basicinfo); } BRIDGE_IMPEXP void DbgMenuEntryClicked(int hEntry) { _dbg_sendmessage(DBG_MENU_ENTRY_CLICKED, (void*)(duint)hEntry, 0); } // FIXME not sure BRIDGE_IMPEXP bool DbgFunctionGet(duint addr, duint* start, duint* end) { FUNCTION_LOOP_INFO info; info.addr = addr; if(!_dbg_sendmessage(DBG_FUNCTION_GET, &info, 0)) return false; if(start) *start = info.start; if(end) *end = info.end; return true; } // FIXME brief, return BRIDGE_IMPEXP bool DbgFunctionOverlaps(duint start, duint end) { FUNCTION_LOOP_INFO info; info.start = start; info.end = end; if(!_dbg_sendmessage(DBG_FUNCTION_OVERLAPS, &info, 0)) return false; return true; } // FIXME brief, return BRIDGE_IMPEXP bool DbgFunctionAdd(duint start, duint end) { FUNCTION_LOOP_INFO info; info.start = start; info.end = end; info.manual = false; if(!_dbg_sendmessage(DBG_FUNCTION_ADD, &info, 0)) return false; return true; } // FIXME brief, return BRIDGE_IMPEXP bool DbgFunctionDel(duint addr) { FUNCTION_LOOP_INFO info; info.addr = addr; if(!_dbg_sendmessage(DBG_FUNCTION_DEL, &info, 0)) return false; return true; } BRIDGE_IMPEXP bool DbgArgumentGet(duint addr, duint* start, duint* end) { FUNCTION_LOOP_INFO info; info.addr = addr; if(!_dbg_sendmessage(DBG_ARGUMENT_GET, &info, 0)) return false; if(start) *start = info.start; if(end) *end = info.end; return true; } BRIDGE_IMPEXP bool DbgArgumentOverlaps(duint start, duint end) { FUNCTION_LOOP_INFO info; info.start = start; info.end = end; if(!_dbg_sendmessage(DBG_ARGUMENT_OVERLAPS, &info, 0)) return false; return true; } BRIDGE_IMPEXP bool DbgArgumentAdd(duint start, duint end) { FUNCTION_LOOP_INFO info; info.start = start; info.end = end; info.manual = false; if(!_dbg_sendmessage(DBG_ARGUMENT_ADD, &info, 0)) return false; return true; } BRIDGE_IMPEXP bool DbgArgumentDel(duint addr) { FUNCTION_LOOP_INFO info; info.addr = addr; if(!_dbg_sendmessage(DBG_ARGUMENT_DEL, &info, 0)) return false; return true; } // FIXME depth BRIDGE_IMPEXP bool DbgLoopGet(int depth, duint addr, duint* start, duint* end) { FUNCTION_LOOP_INFO info; info.addr = addr; info.depth = depth; if(!_dbg_sendmessage(DBG_LOOP_GET, &info, 0)) return false; *start = info.start; *end = info.end; return true; } // FIXME brief, depth, return BRIDGE_IMPEXP bool DbgLoopOverlaps(int depth, duint start, duint end) { FUNCTION_LOOP_INFO info; info.start = start; info.end = end; info.depth = depth; if(!_dbg_sendmessage(DBG_LOOP_OVERLAPS, &info, 0)) return false; return true; } // FIXME brief, return BRIDGE_IMPEXP bool DbgLoopAdd(duint start, duint end) { FUNCTION_LOOP_INFO info; info.start = start; info.end = end; info.manual = false; if(!_dbg_sendmessage(DBG_LOOP_ADD, &info, 0)) return false; return true; } // FIXME brief, brief BRIDGE_IMPEXP bool DbgLoopDel(int depth, duint addr) { FUNCTION_LOOP_INFO info; info.addr = addr; info.depth = depth; if(!_dbg_sendmessage(DBG_LOOP_DEL, &info, 0)) return false; return true; } BRIDGE_IMPEXP size_t DbgGetXrefCountAt(duint addr) { return _dbg_sendmessage(DBG_GET_XREF_COUNT_AT, (void*)addr, 0); } BRIDGE_IMPEXP XREFTYPE DbgGetXrefTypeAt(duint addr) { return (XREFTYPE)_dbg_sendmessage(DBG_GET_XREF_TYPE_AT, (void*)addr, 0); } BRIDGE_IMPEXP bool DbgXrefAdd(duint addr, duint from) { if(!_dbg_sendmessage(DBG_XREF_ADD, (void*)addr, (void*)from)) return false; return true; } BRIDGE_IMPEXP bool DbgXrefDelAll(duint addr) { if(!_dbg_sendmessage(DBG_XREF_DEL_ALL, (void*)addr, 0)) return false; return true; } BRIDGE_IMPEXP bool DbgXrefGet(duint addr, XREF_INFO* info) { if(!_dbg_sendmessage(DBG_XREF_GET, (void*)addr, info)) return false; return true; } BRIDGE_IMPEXP bool DbgGetWatchList(ListOf(WATCHINFO) list) { return !!_dbg_sendmessage(DBG_GET_WATCH_LIST, list, nullptr); } // FIXME all BRIDGE_IMPEXP bool DbgIsRunLocked() { if(_dbg_sendmessage(DBG_IS_RUN_LOCKED, 0, 0)) return true; return false; } BRIDGE_IMPEXP bool DbgIsBpDisabled(duint addr) { if(_dbg_sendmessage(DBG_IS_BP_DISABLED, (void*)addr, 0)) return true; return false; } BRIDGE_IMPEXP bool DbgSetAutoCommentAt(duint addr, const char* text) { if(_dbg_sendmessage(DBG_SET_AUTO_COMMENT_AT, (void*)addr, (void*)text)) return true; return false; } // FIXME brief BRIDGE_IMPEXP void DbgClearAutoCommentRange(duint start, duint end) { _dbg_sendmessage(DBG_DELETE_AUTO_COMMENT_RANGE, (void*)start, (void*)end); } BRIDGE_IMPEXP bool DbgSetAutoLabelAt(duint addr, const char* text) { if(_dbg_sendmessage(DBG_SET_AUTO_LABEL_AT, (void*)addr, (void*)text)) return true; return false; } // FIXME brief BRIDGE_IMPEXP void DbgClearAutoLabelRange(duint start, duint end) { _dbg_sendmessage(DBG_DELETE_AUTO_LABEL_RANGE, (void*)start, (void*)end); } BRIDGE_IMPEXP bool DbgSetAutoBookmarkAt(duint addr) { if(_dbg_sendmessage(DBG_SET_AUTO_BOOKMARK_AT, (void*)addr, 0)) return true; return false; } // FIXME brief BRIDGE_IMPEXP void DbgClearAutoBookmarkRange(duint start, duint end) { _dbg_sendmessage(DBG_DELETE_AUTO_BOOKMARK_RANGE, (void*)start, (void*)end); } BRIDGE_IMPEXP bool DbgSetAutoFunctionAt(duint start, duint end) { if(_dbg_sendmessage(DBG_SET_AUTO_FUNCTION_AT, (void*)start, (void*)end)) return true; return false; } // FIXME brief BRIDGE_IMPEXP void DbgClearAutoFunctionRange(duint start, duint end) { _dbg_sendmessage(DBG_DELETE_AUTO_FUNCTION_RANGE, (void*)start, (void*)end); } // FIXME size of the buffer? BRIDGE_IMPEXP bool DbgGetStringAt(duint addr, char* text) { if(_dbg_sendmessage(DBG_GET_STRING_AT, (void*)addr, text)) return true; return false; } BRIDGE_IMPEXP const DBGFUNCTIONS* DbgFunctions() { return (const DBGFUNCTIONS*)_dbg_sendmessage(DBG_GET_FUNCTIONS, 0, 0); } BRIDGE_IMPEXP bool DbgWinEvent(MSG* message, long* result) { if(_dbg_sendmessage(DBG_WIN_EVENT, message, result)) return true; return false; } BRIDGE_IMPEXP bool DbgWinEventGlobal(MSG* message) { if(_dbg_sendmessage(DBG_WIN_EVENT_GLOBAL, message, 0)) return true; return false; } BRIDGE_IMPEXP bool DbgIsRunning() { return !DbgIsRunLocked(); } BRIDGE_IMPEXP duint DbgGetTimeWastedCounter() { return _dbg_sendmessage(DBG_GET_TIME_WASTED_COUNTER, nullptr, nullptr); } BRIDGE_IMPEXP ARGTYPE DbgGetArgTypeAt(duint addr) { BRIDGE_ADDRINFO info; memset(&info, 0, sizeof(info)); info.flags = flagargs; if(!_dbg_addrinfoget(addr, SEG_DEFAULT, &info)) return ARG_NONE; duint start = info.args.start; duint end = info.args.end; if(start == end || info.args.instrcount == 1) return ARG_SINGLE; else if(addr == start) return ARG_BEGIN; else if(addr == end) return ARG_END; return ARG_MIDDLE; } BRIDGE_IMPEXP void* DbgGetEncodeTypeBuffer(duint addr, duint* size) { return (void*)_dbg_sendmessage(DBG_GET_ENCODE_TYPE_BUFFER, (void*)addr, size); } BRIDGE_IMPEXP void DbgReleaseEncodeTypeBuffer(void* buffer) { _dbg_sendmessage(DBG_RELEASE_ENCODE_TYPE_BUFFER, buffer, nullptr); } BRIDGE_IMPEXP ENCODETYPE DbgGetEncodeTypeAt(duint addr, duint size) { return (ENCODETYPE)_dbg_sendmessage(DBG_ENCODE_TYPE_GET, (void*)addr, (void*)size); } BRIDGE_IMPEXP duint DbgGetEncodeSizeAt(duint addr, duint codesize) { return _dbg_sendmessage(DBG_ENCODE_SIZE_GET, (void*)addr, (void*)codesize); } BRIDGE_IMPEXP bool DbgSetEncodeType(duint addr, duint size, ENCODETYPE type) { return _dbg_encodetypeset(addr, size, type); } BRIDGE_IMPEXP void DbgDelEncodeTypeRange(duint start, duint end) { _dbg_sendmessage(DBG_DELETE_ENCODE_TYPE_RANGE, (void*)start, (void*)end); } BRIDGE_IMPEXP void DbgDelEncodeTypeSegment(duint start) { _dbg_sendmessage(DBG_DELETE_ENCODE_TYPE_SEG, (void*)start, 0); } BRIDGE_IMPEXP void DbgSelChanged(int hWindow, duint VA) { _dbg_sendmessage(DBG_SELCHANGED, (void*)hWindow, (void*)VA); } BRIDGE_IMPEXP HANDLE DbgGetProcessHandle() { return (HANDLE)_dbg_sendmessage(DBG_GET_PROCESS_HANDLE, nullptr, nullptr); } BRIDGE_IMPEXP HANDLE DbgGetThreadHandle() { return (HANDLE)_dbg_sendmessage(DBG_GET_THREAD_HANDLE, nullptr, nullptr); } BRIDGE_IMPEXP DWORD DbgGetProcessId() { return (DWORD)_dbg_sendmessage(DBG_GET_PROCESS_ID, nullptr, nullptr); } BRIDGE_IMPEXP DWORD DbgGetThreadId() { return (DWORD)_dbg_sendmessage(DBG_GET_THREAD_ID, nullptr, nullptr); } BRIDGE_IMPEXP duint DbgGetPebAddress(DWORD ProcessId) { return (duint)_dbg_sendmessage(DBG_GET_PEB_ADDRESS, (void*)ProcessId, nullptr); } BRIDGE_IMPEXP duint DbgGetTebAddress(DWORD ThreadId) { return (duint)_dbg_sendmessage(DBG_GET_TEB_ADDRESS, (void*)ThreadId, nullptr); } BRIDGE_IMPEXP bool DbgAnalyzeFunction(duint entry, BridgeCFGraphList* graph) { return !!_dbg_sendmessage(DBG_ANALYZE_FUNCTION, (void*)entry, graph); } BRIDGE_IMPEXP duint DbgEval(const char* expression, bool* success) { duint value = 0; auto res = _dbg_valfromstring(expression, &value); if(success) *success = res; return value; } BRIDGE_IMPEXP void DbgMenuPrepare(int hMenu) { _dbg_sendmessage(DBG_MENU_PREPARE, (void*)hMenu, nullptr); } BRIDGE_IMPEXP const char* GuiTranslateText(const char* Source) { EnterCriticalSection(&csTranslate); const char* text = _gui_translate_text(Source); LeaveCriticalSection(&csTranslate); return text; } BRIDGE_IMPEXP void GuiDisasmAt(duint addr, duint cip) { _gui_sendmessage(GUI_DISASSEMBLE_AT, (void*)addr, (void*)cip); } BRIDGE_IMPEXP void GuiSetDebugState(DBGSTATE state) { _gui_sendmessage(GUI_SET_DEBUG_STATE, (void*)state, (void*)false); } BRIDGE_IMPEXP void GuiSetDebugStateFast(DBGSTATE state) { _gui_sendmessage(GUI_SET_DEBUG_STATE, (void*)state, (void*)true); } BRIDGE_IMPEXP void GuiAddLogMessage(const char* msg) { _gui_sendmessage(GUI_ADD_MSG_TO_LOG, (void*)msg, 0); } BRIDGE_IMPEXP void GuiLogClear() { _gui_sendmessage(GUI_CLEAR_LOG, 0, 0); } BRIDGE_IMPEXP void GuiUpdateEnable(bool updateNow) { bDisableGUIUpdate = false; if(updateNow) GuiUpdateAllViews(); } BRIDGE_IMPEXP void GuiUpdateDisable() { bDisableGUIUpdate = true; } BRIDGE_IMPEXP bool GuiIsUpdateDisabled() { return bDisableGUIUpdate; } BRIDGE_IMPEXP void GuiUpdateAllViews() { CHECK_GUI_UPDATE_DISABLED GuiUpdateRegisterView(); GuiUpdateDisassemblyView(); GuiUpdateBreakpointsView(); GuiUpdateDumpView(); GuiUpdateWatchView(); GuiUpdateThreadView(); GuiUpdateSideBar(); //Patches are not refreshed here, see #1407 GuiUpdateCallStack(); GuiRepaintTableView(); GuiUpdateSEHChain(); GuiUpdateArgumentWidget(); GuiUpdateGraphView(); GuiUpdateTypeWidget(); } BRIDGE_IMPEXP void GuiUpdateRegisterView() { CHECK_GUI_UPDATE_DISABLED _gui_sendmessage(GUI_UPDATE_REGISTER_VIEW, 0, 0); } BRIDGE_IMPEXP void GuiUpdateDisassemblyView() { CHECK_GUI_UPDATE_DISABLED _gui_sendmessage(GUI_UPDATE_DISASSEMBLY_VIEW, 0, 0); } BRIDGE_IMPEXP void GuiUpdateBreakpointsView() { CHECK_GUI_UPDATE_DISABLED _gui_sendmessage(GUI_UPDATE_BREAKPOINTS_VIEW, 0, 0); } BRIDGE_IMPEXP void GuiUpdateWindowTitle(const char* filename) { CHECK_GUI_UPDATE_DISABLED _gui_sendmessage(GUI_UPDATE_WINDOW_TITLE, (void*)filename, 0); } BRIDGE_IMPEXP HWND GuiGetWindowHandle() { return (HWND)_gui_sendmessage(GUI_GET_WINDOW_HANDLE, 0, 0); } BRIDGE_IMPEXP void GuiDumpAt(duint va) { _gui_sendmessage(GUI_DUMP_AT, (void*)va, 0); } BRIDGE_IMPEXP void GuiScriptAdd(int count, const char** lines) { _gui_sendmessage(GUI_SCRIPT_ADD, (void*)(duint)count, (void*)lines); } BRIDGE_IMPEXP void GuiScriptClear() { _gui_sendmessage(GUI_SCRIPT_CLEAR, 0, 0); } BRIDGE_IMPEXP void GuiScriptSetIp(int line) { _gui_sendmessage(GUI_SCRIPT_SETIP, (void*)(duint)line, 0); } BRIDGE_IMPEXP void GuiScriptError(int line, const char* message) { _gui_sendmessage(GUI_SCRIPT_ERROR, (void*)(duint)line, (void*)message); } BRIDGE_IMPEXP void GuiScriptSetTitle(const char* title) { _gui_sendmessage(GUI_SCRIPT_SETTITLE, (void*)title, 0); } BRIDGE_IMPEXP void GuiScriptSetInfoLine(int line, const char* info) { _gui_sendmessage(GUI_SCRIPT_SETINFOLINE, (void*)(duint)line, (void*)info); } BRIDGE_IMPEXP void GuiScriptMessage(const char* message) { _gui_sendmessage(GUI_SCRIPT_MESSAGE, (void*)message, 0); } BRIDGE_IMPEXP int GuiScriptMsgyn(const char* message) { return (int)(duint)_gui_sendmessage(GUI_SCRIPT_MSGYN, (void*)message, 0); } BRIDGE_IMPEXP void GuiScriptEnableHighlighting(bool enable) { _gui_sendmessage(GUI_SCRIPT_ENABLEHIGHLIGHTING, (void*)(duint)enable, 0); } BRIDGE_IMPEXP void GuiSymbolLogAdd(const char* message) { _gui_sendmessage(GUI_SYMBOL_LOG_ADD, (void*)message, 0); } BRIDGE_IMPEXP void GuiSymbolLogClear() { _gui_sendmessage(GUI_SYMBOL_LOG_CLEAR, 0, 0); } BRIDGE_IMPEXP void GuiSymbolSetProgress(int percent) { _gui_sendmessage(GUI_SYMBOL_SET_PROGRESS, (void*)(duint)percent, 0); } BRIDGE_IMPEXP void GuiSymbolUpdateModuleList(int count, SYMBOLMODULEINFO* modules) { _gui_sendmessage(GUI_SYMBOL_UPDATE_MODULE_LIST, (void*)(duint)count, (void*)modules); } BRIDGE_IMPEXP void GuiReferenceAddColumn(int width, const char* title) { _gui_sendmessage(GUI_REF_ADDCOLUMN, (void*)(duint)width, (void*)title); } BRIDGE_IMPEXP void GuiSymbolRefreshCurrent() { _gui_sendmessage(GUI_SYMBOL_REFRESH_CURRENT, 0, 0); } BRIDGE_IMPEXP void GuiReferenceSetRowCount(int count) { _gui_sendmessage(GUI_REF_SETROWCOUNT, (void*)(duint)count, 0); } BRIDGE_IMPEXP int GuiReferenceGetRowCount() { return (int)(duint)_gui_sendmessage(GUI_REF_GETROWCOUNT, 0, 0); } BRIDGE_IMPEXP int GuiReferenceSearchGetRowCount() { return int(_gui_sendmessage(GUI_REF_SEARCH_GETROWCOUNT, 0, 0)); } BRIDGE_IMPEXP void GuiReferenceDeleteAllColumns() { _gui_sendmessage(GUI_REF_DELETEALLCOLUMNS, 0, 0); } BRIDGE_IMPEXP void GuiReferenceInitialize(const char* name) { _gui_sendmessage(GUI_REF_INITIALIZE, (void*)name, 0); } BRIDGE_IMPEXP void GuiReferenceSetCellContent(int row, int col, const char* str) { CELLINFO info; info.row = row; info.col = col; info.str = str; _gui_sendmessage(GUI_REF_SETCELLCONTENT, &info, 0); } BRIDGE_IMPEXP char* GuiReferenceGetCellContent(int row, int col) { return (char*)_gui_sendmessage(GUI_REF_GETCELLCONTENT, (void*)(duint)row, (void*)(duint)col); } BRIDGE_IMPEXP char* GuiReferenceSearchGetCellContent(int row, int col) { return (char*)_gui_sendmessage(GUI_REF_SEARCH_GETCELLCONTENT, (void*)row, (void*)col); } BRIDGE_IMPEXP void GuiReferenceReloadData() { _gui_sendmessage(GUI_REF_RELOADDATA, 0, 0); } BRIDGE_IMPEXP void GuiReferenceSetSingleSelection(int index, bool scroll) { _gui_sendmessage(GUI_REF_SETSINGLESELECTION, (void*)(duint)index, (void*)(duint)scroll); } BRIDGE_IMPEXP void GuiReferenceSetProgress(int progress) { _gui_sendmessage(GUI_REF_SETPROGRESS, (void*)(duint)progress, 0); } BRIDGE_IMPEXP void GuiReferenceSetCurrentTaskProgress(int progress, const char* taskTitle) { _gui_sendmessage(GUI_REF_SETCURRENTTASKPROGRESS, (void*)(duint)progress, (void*)taskTitle); } BRIDGE_IMPEXP void GuiReferenceSetSearchStartCol(int col) { _gui_sendmessage(GUI_REF_SETSEARCHSTARTCOL, (void*)(duint)col, 0); } BRIDGE_IMPEXP void GuiStackDumpAt(duint addr, duint csp) { _gui_sendmessage(GUI_STACK_DUMP_AT, (void*)addr, (void*)csp); } BRIDGE_IMPEXP void GuiUpdateDumpView() { CHECK_GUI_UPDATE_DISABLED _gui_sendmessage(GUI_UPDATE_DUMP_VIEW, 0, 0); } BRIDGE_IMPEXP void GuiUpdateWatchView() { CHECK_GUI_UPDATE_DISABLED _gui_sendmessage(GUI_UPDATE_WATCH_VIEW, 0, 0); } BRIDGE_IMPEXP void GuiUpdateMemoryView() { CHECK_GUI_UPDATE_DISABLED _gui_sendmessage(GUI_UPDATE_MEMORY_VIEW, 0, 0); } BRIDGE_IMPEXP void GuiUpdateThreadView() { CHECK_GUI_UPDATE_DISABLED _gui_sendmessage(GUI_UPDATE_THREAD_VIEW, 0, 0); } BRIDGE_IMPEXP void GuiAddRecentFile(const char* file) { _gui_sendmessage(GUI_ADD_RECENT_FILE, (void*)file, 0); } BRIDGE_IMPEXP void GuiSetLastException(unsigned int exception) { _gui_sendmessage(GUI_SET_LAST_EXCEPTION, (void*)(duint)exception, 0); } BRIDGE_IMPEXP bool GuiGetDisassembly(duint addr, char* text) { return !!_gui_sendmessage(GUI_GET_DISASSEMBLY, (void*)addr, text); } BRIDGE_IMPEXP int GuiMenuAdd(int hMenu, const char* title) { return (int)(duint)_gui_sendmessage(GUI_MENU_ADD, (void*)(duint)hMenu, (void*)title); } BRIDGE_IMPEXP int GuiMenuAddEntry(int hMenu, const char* title) { return (int)(duint)_gui_sendmessage(GUI_MENU_ADD_ENTRY, (void*)(duint)hMenu, (void*)title); } BRIDGE_IMPEXP void GuiMenuAddSeparator(int hMenu) { _gui_sendmessage(GUI_MENU_ADD_SEPARATOR, (void*)(duint)hMenu, 0); } BRIDGE_IMPEXP void GuiMenuClear(int hMenu) { _gui_sendmessage(GUI_MENU_CLEAR, (void*)(duint)hMenu, 0); } BRIDGE_IMPEXP void GuiMenuRemove(int hEntryMenu) { _gui_sendmessage(GUI_MENU_REMOVE, (void*)(duint)hEntryMenu, 0); } BRIDGE_IMPEXP bool GuiSelectionGet(int hWindow, SELECTIONDATA* selection) { return !!_gui_sendmessage(GUI_SELECTION_GET, (void*)(duint)hWindow, selection); } BRIDGE_IMPEXP bool GuiSelectionSet(int hWindow, const SELECTIONDATA* selection) { return !!_gui_sendmessage(GUI_SELECTION_SET, (void*)(duint)hWindow, (void*)selection); } BRIDGE_IMPEXP bool GuiGetLineWindow(const char* title, char* text) { return !!_gui_sendmessage(GUI_GETLINE_WINDOW, (void*)title, text); } BRIDGE_IMPEXP void GuiAutoCompleteAddCmd(const char* cmd) { _gui_sendmessage(GUI_AUTOCOMPLETE_ADDCMD, (void*)cmd, 0); } BRIDGE_IMPEXP void GuiAutoCompleteDelCmd(const char* cmd) { _gui_sendmessage(GUI_AUTOCOMPLETE_DELCMD, (void*)cmd, 0); } BRIDGE_IMPEXP void GuiAutoCompleteClearAll() { _gui_sendmessage(GUI_AUTOCOMPLETE_CLEARALL, 0, 0); } BRIDGE_IMPEXP void GuiAddStatusBarMessage(const char* msg) { _gui_sendmessage(GUI_ADD_MSG_TO_STATUSBAR, (void*)msg, 0); } BRIDGE_IMPEXP void GuiUpdateSideBar() { CHECK_GUI_UPDATE_DISABLED _gui_sendmessage(GUI_UPDATE_SIDEBAR, 0, 0); } BRIDGE_IMPEXP void GuiRepaintTableView() { CHECK_GUI_UPDATE_DISABLED _gui_sendmessage(GUI_REPAINT_TABLE_VIEW, 0, 0); } BRIDGE_IMPEXP void GuiUpdatePatches() { CHECK_GUI_UPDATE_DISABLED _gui_sendmessage(GUI_UPDATE_PATCHES, 0, 0); } BRIDGE_IMPEXP void GuiUpdateCallStack() { CHECK_GUI_UPDATE_DISABLED _gui_sendmessage(GUI_UPDATE_CALLSTACK, 0, 0); } BRIDGE_IMPEXP void GuiUpdateSEHChain() { CHECK_GUI_UPDATE_DISABLED _gui_sendmessage(GUI_UPDATE_SEHCHAIN, 0, 0); } BRIDGE_IMPEXP void GuiLoadSourceFile(const char* path, int line) { _gui_sendmessage(GUI_LOAD_SOURCE_FILE, (void*)path, (void*)line); } BRIDGE_IMPEXP void GuiMenuSetIcon(int hMenu, const ICONDATA* icon) { _gui_sendmessage(GUI_MENU_SET_ICON, (void*)hMenu, (void*)icon); } BRIDGE_IMPEXP void GuiMenuSetEntryIcon(int hEntry, const ICONDATA* icon) { _gui_sendmessage(GUI_MENU_SET_ENTRY_ICON, (void*)hEntry, (void*)icon); } BRIDGE_IMPEXP void GuiMenuSetEntryChecked(int hEntry, bool checked) { _gui_sendmessage(GUI_MENU_SET_ENTRY_CHECKED, (void*)hEntry, (void*)checked); } BRIDGE_IMPEXP void GuiMenuSetVisible(int hMenu, bool visible) { _gui_sendmessage(GUI_MENU_SET_VISIBLE, (void*)hMenu, (void*)visible); } BRIDGE_IMPEXP void GuiMenuSetEntryVisible(int hEntry, bool visible) { _gui_sendmessage(GUI_MENU_SET_VISIBLE, (void*)hEntry, (void*)visible); } BRIDGE_IMPEXP void GuiMenuSetName(int hMenu, const char* name) { _gui_sendmessage(GUI_MENU_SET_VISIBLE, (void*)hMenu, (void*)name); } BRIDGE_IMPEXP void GuiMenuSetEntryName(int hEntry, const char* name) { _gui_sendmessage(GUI_MENU_SET_VISIBLE, (void*)hEntry, (void*)name); } BRIDGE_IMPEXP void GuiMenuSetEntryHotkey(int hEntry, const char* hack) { _gui_sendmessage(GUI_MENU_SET_ENTRY_HOTKEY, (void*)hEntry, (void*)hack); } BRIDGE_IMPEXP void GuiShowCpu() { _gui_sendmessage(GUI_SHOW_CPU, 0, 0); } BRIDGE_IMPEXP void GuiAddQWidgetTab(void* qWidget) { _gui_sendmessage(GUI_ADD_QWIDGET_TAB, qWidget, nullptr); } BRIDGE_IMPEXP void GuiShowQWidgetTab(void* qWidget) { _gui_sendmessage(GUI_SHOW_QWIDGET_TAB, qWidget, nullptr); } BRIDGE_IMPEXP void GuiCloseQWidgetTab(void* qWidget) { _gui_sendmessage(GUI_CLOSE_QWIDGET_TAB, qWidget, nullptr); } BRIDGE_IMPEXP void GuiExecuteOnGuiThread(GUICALLBACK cbGuiThread) { _gui_sendmessage(GUI_EXECUTE_ON_GUI_THREAD, (void*)cbGuiThread, nullptr); } BRIDGE_IMPEXP void GuiUpdateTimeWastedCounter() { _gui_sendmessage(GUI_UPDATE_TIME_WASTED_COUNTER, nullptr, nullptr); } BRIDGE_IMPEXP void GuiSetGlobalNotes(const char* text) { _gui_sendmessage(GUI_SET_GLOBAL_NOTES, (void*)text, nullptr); } BRIDGE_IMPEXP void GuiGetGlobalNotes(char** text) { _gui_sendmessage(GUI_GET_GLOBAL_NOTES, text, nullptr); } BRIDGE_IMPEXP void GuiSetDebuggeeNotes(const char* text) { _gui_sendmessage(GUI_SET_DEBUGGEE_NOTES, (void*)text, nullptr); } BRIDGE_IMPEXP void GuiGetDebuggeeNotes(char** text) { _gui_sendmessage(GUI_GET_DEBUGGEE_NOTES, text, nullptr); } BRIDGE_IMPEXP void GuiDumpAtN(duint va, int index) { _gui_sendmessage(GUI_DUMP_AT_N, (void*)va, (void*)index); } BRIDGE_IMPEXP void GuiDisplayWarning(const char* title, const char* text) { _gui_sendmessage(GUI_DISPLAY_WARNING, (void*)title, (void*)text); } BRIDGE_IMPEXP void GuiRegisterScriptLanguage(SCRIPTTYPEINFO* info) { _gui_sendmessage(GUI_REGISTER_SCRIPT_LANG, (void*)info, nullptr); } BRIDGE_IMPEXP void GuiUnregisterScriptLanguage(int id) { _gui_sendmessage(GUI_UNREGISTER_SCRIPT_LANG, (void*)id, nullptr); } BRIDGE_IMPEXP void GuiUpdateArgumentWidget() { CHECK_GUI_UPDATE_DISABLED _gui_sendmessage(GUI_UPDATE_ARGUMENT_VIEW, nullptr, nullptr); } BRIDGE_IMPEXP void GuiFocusView(int hWindow) { _gui_sendmessage(GUI_FOCUS_VIEW, (void*)hWindow, nullptr); } BRIDGE_IMPEXP bool GuiLoadGraph(BridgeCFGraphList* graph, duint addr) { return !!_gui_sendmessage(GUI_LOAD_GRAPH, graph, (void*)addr); } BRIDGE_IMPEXP duint GuiGraphAt(duint addr) { return (duint)_gui_sendmessage(GUI_GRAPH_AT, (void*)addr, nullptr); } BRIDGE_IMPEXP void GuiUpdateGraphView() { CHECK_GUI_UPDATE_DISABLED _gui_sendmessage(GUI_UPDATE_GRAPH_VIEW, nullptr, nullptr); } BRIDGE_IMPEXP void GuiDisableLog() { _gui_sendmessage(GUI_SET_LOG_ENABLED, (void*)0, nullptr); } BRIDGE_IMPEXP void GuiEnableLog() { _gui_sendmessage(GUI_SET_LOG_ENABLED, (void*)1, nullptr); } BRIDGE_IMPEXP void GuiAddFavouriteTool(const char* name, const char* description) { _gui_sendmessage(GUI_ADD_FAVOURITE_TOOL, (void*)name, (void*)description); } BRIDGE_IMPEXP void GuiAddFavouriteCommand(const char* name, const char* shortcut) { _gui_sendmessage(GUI_ADD_FAVOURITE_COMMAND, (void*)name, (void*)shortcut); } BRIDGE_IMPEXP void GuiSetFavouriteToolShortcut(const char* name, const char* shortcut) { _gui_sendmessage(GUI_SET_FAVOURITE_TOOL_SHORTCUT, (void*)name, (void*)shortcut); } BRIDGE_IMPEXP void GuiFoldDisassembly(duint startAddress, duint length) { _gui_sendmessage(GUI_FOLD_DISASSEMBLY, (void*)startAddress, (void*)length); } BRIDGE_IMPEXP void GuiSelectInMemoryMap(duint addr) { _gui_sendmessage(GUI_SELECT_IN_MEMORY_MAP, (void*)addr, nullptr); } BRIDGE_IMPEXP void GuiGetActiveView(ACTIVEVIEW* activeView) { _gui_sendmessage(GUI_GET_ACTIVE_VIEW, activeView, nullptr); } BRIDGE_IMPEXP void GuiAddInfoLine(const char* infoLine) { _gui_sendmessage(GUI_ADD_INFO_LINE, (void*)infoLine, nullptr); } BRIDGE_IMPEXP void GuiProcessEvents() { _gui_sendmessage(GUI_PROCESS_EVENTS, nullptr, nullptr); } BRIDGE_IMPEXP void* GuiTypeAddNode(void* parent, const TYPEDESCRIPTOR* type) { return _gui_sendmessage(GUI_TYPE_ADDNODE, parent, (void*)type); } BRIDGE_IMPEXP bool GuiTypeClear() { return !!_gui_sendmessage(GUI_TYPE_CLEAR, nullptr, nullptr); } BRIDGE_IMPEXP void GuiUpdateTypeWidget() { _gui_sendmessage(GUI_UPDATE_TYPE_WIDGET, nullptr, nullptr); } BRIDGE_IMPEXP void GuiCloseApplication() { _gui_sendmessage(GUI_CLOSE_APPLICATION, nullptr, nullptr); } BRIDGE_IMPEXP void GuiFlushLog() { _gui_sendmessage(GUI_FLUSH_LOG, nullptr, nullptr); } BRIDGE_IMPEXP void GuiReferenceAddCommand(const char* title, const char* command) { _gui_sendmessage(GUI_REF_ADDCOMMAND, (void*)title, (void*)command); } BOOL WINAPI DllMain(HINSTANCE hinstDLL, DWORD fdwReason, LPVOID lpvReserved) { hInst = hinstDLL; return TRUE; }