parent
e20cd71549
commit
063ce31ec6
|
@ -281,3 +281,19 @@ bool cbInstrFoldDisassembly(int argc, char* argv[])
|
|||
GuiFoldDisassembly(start, length);
|
||||
return true;
|
||||
}
|
||||
|
||||
bool cbDebugUpdateTitle(int argc, char* argv[])
|
||||
{
|
||||
duint addr = 0;
|
||||
if(argc > 1)
|
||||
{
|
||||
if(!valfromstring(argv[1], &addr))
|
||||
addr = GetContextDataEx(hActiveThread, UE_CIP);
|
||||
}
|
||||
else
|
||||
{
|
||||
addr = GetContextDataEx(hActiveThread, UE_CIP);
|
||||
}
|
||||
DebugUpdateTitleAsync(addr, false);
|
||||
return true;
|
||||
}
|
||||
|
|
|
@ -19,3 +19,4 @@ bool cbInstrAddFavTool(int argc, char* argv[]);
|
|||
bool cbInstrAddFavCmd(int argc, char* argv[]);
|
||||
bool cbInstrSetFavToolShortcut(int argc, char* argv[]);
|
||||
bool cbInstrFoldDisassembly(int argc, char* argv[]);
|
||||
bool cbDebugUpdateTitle(int argc, char* argv[]);
|
||||
|
|
|
@ -444,6 +444,49 @@ void updateSEHChainAsync()
|
|||
updateSEHChainTask.WakeUp();
|
||||
}
|
||||
|
||||
static void DebugUpdateTitle(duint disasm_addr, bool analyzeThreadSwitch)
|
||||
{
|
||||
char modname[MAX_MODULE_SIZE] = "";
|
||||
char modtext[MAX_MODULE_SIZE * 2] = "";
|
||||
if(!ModNameFromAddr(disasm_addr, modname, true))
|
||||
*modname = 0;
|
||||
else
|
||||
sprintf_s(modtext, GuiTranslateText(QT_TRANSLATE_NOOP("DBG", "Module: %s - ")), modname);
|
||||
char threadswitch[256] = "";
|
||||
DWORD currentThreadId = ThreadGetId(hActiveThread);
|
||||
if(analyzeThreadSwitch)
|
||||
{
|
||||
static DWORD PrevThreadId = 0;
|
||||
if(PrevThreadId == 0)
|
||||
PrevThreadId = fdProcessInfo->dwThreadId; // Initialize to Main Thread
|
||||
if(currentThreadId != PrevThreadId && PrevThreadId != 0)
|
||||
{
|
||||
char threadName2[MAX_THREAD_NAME_SIZE] = "";
|
||||
if(!ThreadGetName(PrevThreadId, threadName2) || threadName2[0] == 0)
|
||||
sprintf_s(threadName2, "%X", PrevThreadId);
|
||||
sprintf_s(threadswitch, GuiTranslateText(QT_TRANSLATE_NOOP("DBG", " (switched from %s)")), threadName2);
|
||||
PrevThreadId = currentThreadId;
|
||||
}
|
||||
}
|
||||
char title[deflen] = "";
|
||||
char threadName[MAX_THREAD_NAME_SIZE + 1] = "";
|
||||
if(ThreadGetName(currentThreadId, threadName) && *threadName)
|
||||
strcat_s(threadName, " ");
|
||||
char PIDnumber[64], TIDnumber[64];
|
||||
if(settingboolget("Gui", "PidInHex"))
|
||||
{
|
||||
sprintf_s(PIDnumber, "%X", fdProcessInfo->dwProcessId);
|
||||
sprintf_s(TIDnumber, "%X", currentThreadId);
|
||||
}
|
||||
else
|
||||
{
|
||||
sprintf_s(PIDnumber, "%u", fdProcessInfo->dwProcessId);
|
||||
sprintf_s(TIDnumber, "%u", currentThreadId);
|
||||
}
|
||||
sprintf_s(title, GuiTranslateText(QT_TRANSLATE_NOOP("DBG", "%s - PID: %s - %sThread: %s%s%s")), szBaseFileName, PIDnumber, modtext, threadName, TIDnumber, threadswitch);
|
||||
GuiUpdateWindowTitle(title);
|
||||
}
|
||||
|
||||
void DebugUpdateGui(duint disasm_addr, bool stack)
|
||||
{
|
||||
if(GuiIsUpdateDisabled())
|
||||
|
@ -479,45 +522,7 @@ void DebugUpdateGui(duint disasm_addr, bool stack)
|
|||
updateCallStackAsync(csp);
|
||||
updateSEHChainAsync();
|
||||
}
|
||||
char modname[MAX_MODULE_SIZE] = "";
|
||||
char modtext[MAX_MODULE_SIZE * 2] = "";
|
||||
if(!ModNameFromAddr(disasm_addr, modname, true))
|
||||
*modname = 0;
|
||||
else
|
||||
sprintf_s(modtext, GuiTranslateText(QT_TRANSLATE_NOOP("DBG", "Module: %s - ")), modname);
|
||||
char threadswitch[256] = "";
|
||||
DWORD currentThreadId = ThreadGetId(hActiveThread);
|
||||
{
|
||||
static DWORD PrevThreadId = 0;
|
||||
if(PrevThreadId == 0)
|
||||
PrevThreadId = fdProcessInfo->dwThreadId; // Initialize to Main Thread
|
||||
if(currentThreadId != PrevThreadId && PrevThreadId != 0)
|
||||
{
|
||||
char threadName2[MAX_THREAD_NAME_SIZE] = "";
|
||||
if(!ThreadGetName(PrevThreadId, threadName2) || threadName2[0] == 0)
|
||||
sprintf_s(threadName2, "%X", PrevThreadId);
|
||||
sprintf_s(threadswitch, GuiTranslateText(QT_TRANSLATE_NOOP("DBG", " (switched from %s)")), threadName2);
|
||||
PrevThreadId = currentThreadId;
|
||||
}
|
||||
}
|
||||
char title[deflen] = "";
|
||||
char threadName[MAX_THREAD_NAME_SIZE + 1] = "";
|
||||
if(ThreadGetName(currentThreadId, threadName) && *threadName)
|
||||
strcat_s(threadName, " ");
|
||||
//sprintf_s(title, GuiTranslateText(QT_TRANSLATE_NOOP("DBG", "File: %s - PID: %X - %sThread: %s%X%s")), szBaseFileName, fdProcessInfo->dwProcessId, modtext, threadName, currentThreadId, threadswitch);
|
||||
char PIDnumber[64], TIDnumber[64];
|
||||
if(settingboolget("Gui", "PidInHex"))
|
||||
{
|
||||
sprintf_s(PIDnumber, "%X", fdProcessInfo->dwProcessId);
|
||||
sprintf_s(TIDnumber, "%X", currentThreadId);
|
||||
}
|
||||
else
|
||||
{
|
||||
sprintf_s(PIDnumber, "%u", fdProcessInfo->dwProcessId);
|
||||
sprintf_s(TIDnumber, "%u", currentThreadId);
|
||||
}
|
||||
sprintf_s(title, GuiTranslateText(QT_TRANSLATE_NOOP("DBG", "%s - PID: %s - %sThread: %s%s%s")), szBaseFileName, PIDnumber, modtext, threadName, TIDnumber, threadswitch);
|
||||
GuiUpdateWindowTitle(title);
|
||||
DebugUpdateTitle(disasm_addr, true);
|
||||
GuiUpdateRegisterView();
|
||||
GuiUpdateDisassemblyView();
|
||||
GuiUpdateThreadView();
|
||||
|
@ -537,6 +542,12 @@ void DebugUpdateGuiAsync(duint disasm_addr, bool stack)
|
|||
DebugUpdateGuiTask.WakeUp(disasm_addr, stack);
|
||||
}
|
||||
|
||||
void DebugUpdateTitleAsync(duint disasm_addr, bool analyzeThreadSwitch)
|
||||
{
|
||||
static TaskThread_<decltype(&DebugUpdateTitle), duint, bool> DebugUpdateTitleTask(&DebugUpdateTitle);
|
||||
DebugUpdateTitleTask.WakeUp(disasm_addr, analyzeThreadSwitch);
|
||||
}
|
||||
|
||||
void DebugUpdateGuiSetStateAsync(duint disasm_addr, bool stack, DBGSTATE state)
|
||||
{
|
||||
// call paused routine to clean up various tracing states.
|
||||
|
|
|
@ -45,6 +45,7 @@ void dbgsetattachevent(HANDLE handle);
|
|||
void dbgsetresumetid(duint tid);
|
||||
void DebugUpdateGui(duint disasm_addr, bool stack);
|
||||
void DebugUpdateGuiAsync(duint disasm_addr, bool stack);
|
||||
void DebugUpdateTitleAsync(duint disasm_addr, bool analyzeThreadSwitch);
|
||||
void DebugUpdateGuiSetStateAsync(duint disasm_addr, bool stack, DBGSTATE state = paused);
|
||||
void DebugUpdateBreakpointsViewAsync();
|
||||
void DebugUpdateStack(duint dumpAddr, duint csp, bool forceDump = false);
|
||||
|
|
|
@ -402,6 +402,7 @@ static void registercommands()
|
|||
dbgcmdnew("AddFavouriteCommand", cbInstrAddFavCmd, false); //add favourite command
|
||||
dbgcmdnew("AddFavouriteToolShortcut,SetFavouriteToolShortcut", cbInstrSetFavToolShortcut, false); //set favourite tool shortcut
|
||||
dbgcmdnew("FoldDisassembly", cbInstrFoldDisassembly, true); //fold disassembly segment
|
||||
dbgcmdnew("guiupdatetitle", cbDebugUpdateTitle, true); // set relevant disassembly title
|
||||
|
||||
//misc
|
||||
dbgcmdnew("chd", cbInstrChd, false); //Change directory
|
||||
|
|
|
@ -3,7 +3,6 @@
|
|||
#include "CodeFolding.h"
|
||||
#include "EncodeMap.h"
|
||||
#include "Bridge.h"
|
||||
#include "MainWindow.h"
|
||||
#include "CachedFontMetrics.h"
|
||||
#include "QBeaEngine.h"
|
||||
#include "MemoryPage.h"
|
||||
|
@ -901,7 +900,7 @@ void Disassembly::keyPressEvent(QKeyEvent* event)
|
|||
{
|
||||
ShowDisassemblyPopup(0, 0, 0);
|
||||
duint dest = DbgGetBranchDestination(rvaToVa(getInitialSelection()));
|
||||
if(!dest)
|
||||
if(!DbgMemIsValidReadPtr(dest))
|
||||
return;
|
||||
QString cmd = "disasm " + ToPtrString(dest);
|
||||
DbgCmdExec(cmd.toUtf8().constData());
|
||||
|
@ -1780,7 +1779,6 @@ void Disassembly::disassembleAt(dsint parVA, dsint parCIP, bool history, dsint n
|
|||
mCurrentVa++;
|
||||
newHistory.va = selectionVA;
|
||||
newHistory.tableOffset = selectionTableOffset;
|
||||
newHistory.windowTitle = MainWindow::windowTitle;
|
||||
mVaHistory.push_back(newHistory);
|
||||
}
|
||||
}
|
||||
|
@ -1842,7 +1840,6 @@ void Disassembly::disassembleAt(dsint parVA, dsint parCIP, bool history, dsint n
|
|||
//new disassembled address
|
||||
newHistory.va = parVA;
|
||||
newHistory.tableOffset = getTableOffset();
|
||||
newHistory.windowTitle = MainWindow::windowTitle;
|
||||
if(mVaHistory.size())
|
||||
{
|
||||
if(mVaHistory.last().va != parVA) //not 2x the same va in history
|
||||
|
@ -1952,7 +1949,7 @@ void Disassembly::historyPrevious()
|
|||
disassembleAt(va, rvaToVa(mCipRva), false, mVaHistory.at(mCurrentVa).tableOffset);
|
||||
|
||||
// Update window title
|
||||
emit updateWindowTitle(mVaHistory.at(mCurrentVa).windowTitle);
|
||||
DbgCmdExecDirect(QString("guiupdatetitle %1").arg(ToPtrString(va)));
|
||||
GuiUpdateAllViews();
|
||||
}
|
||||
|
||||
|
@ -1967,7 +1964,7 @@ void Disassembly::historyNext()
|
|||
disassembleAt(va, rvaToVa(mCipRva), false, mVaHistory.at(mCurrentVa).tableOffset);
|
||||
|
||||
// Update window title
|
||||
emit updateWindowTitle(mVaHistory.at(mCurrentVa).windowTitle);
|
||||
DbgCmdExecDirect(QString("guiupdatetitle %1").arg(ToPtrString(va)));
|
||||
GuiUpdateAllViews();
|
||||
}
|
||||
|
||||
|
|
|
@ -165,7 +165,6 @@ private:
|
|||
{
|
||||
dsint va;
|
||||
dsint tableOffset;
|
||||
QString windowTitle;
|
||||
};
|
||||
|
||||
QList<HistoryData> mVaHistory;
|
||||
|
|
|
@ -53,8 +53,6 @@
|
|||
#include "UpdateChecker.h"
|
||||
#include "Tracer/TraceBrowser.h"
|
||||
|
||||
QString MainWindow::windowTitle = "";
|
||||
|
||||
MainWindow::MainWindow(QWidget* parent)
|
||||
: QMainWindow(parent),
|
||||
ui(new Ui::MainWindow)
|
||||
|
@ -960,12 +958,10 @@ void MainWindow::updateWindowTitleSlot(QString filename)
|
|||
if(filename.length())
|
||||
{
|
||||
setWindowTitle(filename + QString(" - ") + mWindowMainTitle);
|
||||
windowTitle = filename;
|
||||
}
|
||||
else
|
||||
{
|
||||
setWindowTitle(mWindowMainTitle);
|
||||
windowTitle = mWindowMainTitle;
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -269,9 +269,6 @@ protected:
|
|||
void dropEvent(QDropEvent* pEvent);
|
||||
bool event(QEvent* event);
|
||||
|
||||
public:
|
||||
static QString windowTitle;
|
||||
|
||||
private slots:
|
||||
void setupLanguagesMenu2();
|
||||
|
||||
|
|
Loading…
Reference in New Issue