forked from qt-creator/qt-creator
Debugger: Implement "Load QML Stack" feature for LLDB
Fixes: QTCREATORBUG-25554 Change-Id: Ieafa22581c294d9b993efe077354750a8f986424 Reviewed-by: Christian Stenger <christian.stenger@qt.io>
This commit is contained in:
@@ -715,27 +715,6 @@ void LldbEngine::updateAll()
|
||||
runCommand(cmd);
|
||||
}
|
||||
|
||||
void LldbEngine::reloadFullStack()
|
||||
{
|
||||
fetchStack(-1);
|
||||
}
|
||||
|
||||
void LldbEngine::fetchStack(int limit)
|
||||
{
|
||||
DebuggerCommand cmd("fetchStack");
|
||||
cmd.arg("nativemixed", isNativeMixedActive());
|
||||
cmd.arg("stacklimit", limit);
|
||||
cmd.arg("context", stackHandler()->currentFrame().context);
|
||||
cmd.callback = [this](const DebuggerResponse &response) {
|
||||
const GdbMi &stack = response.data["stack"];
|
||||
const bool isFull = !stack["hasmore"].toInt();
|
||||
stackHandler()->setFramesAndCurrentIndex(stack["frames"], isFull);
|
||||
activateFrame(stackHandler()->currentIndex());
|
||||
};
|
||||
runCommand(cmd);
|
||||
}
|
||||
|
||||
|
||||
//////////////////////////////////////////////////////////////////////
|
||||
//
|
||||
// Watch specific stuff
|
||||
@@ -980,6 +959,33 @@ void LldbEngine::reloadDebuggingHelpers()
|
||||
updateAll();
|
||||
}
|
||||
|
||||
void LldbEngine::loadAdditionalQmlStack()
|
||||
{
|
||||
fetchStack(-1, true);
|
||||
}
|
||||
|
||||
void LldbEngine::reloadFullStack()
|
||||
{
|
||||
fetchStack(-1, false);
|
||||
}
|
||||
|
||||
void LldbEngine::fetchStack(int limit, bool extraQml)
|
||||
{
|
||||
DebuggerCommand cmd("fetchStack");
|
||||
cmd.arg("nativemixed", isNativeMixedActive());
|
||||
cmd.arg("stacklimit", limit);
|
||||
cmd.arg("context", stackHandler()->currentFrame().context);
|
||||
cmd.arg("extraqml", int(extraQml));
|
||||
cmd.callback = [this](const DebuggerResponse &response) {
|
||||
const GdbMi &stack = response.data["stack"];
|
||||
const bool isFull = !stack["hasmore"].toInt();
|
||||
stackHandler()->setFramesAndCurrentIndex(stack["frames"], isFull);
|
||||
activateFrame(stackHandler()->currentIndex());
|
||||
};
|
||||
runCommand(cmd);
|
||||
}
|
||||
|
||||
|
||||
void LldbEngine::fetchDisassembler(DisassemblerAgent *agent)
|
||||
{
|
||||
QPointer<DisassemblerAgent> p(agent);
|
||||
@@ -1090,7 +1096,8 @@ bool LldbEngine::hasCapability(unsigned cap) const
|
||||
| OperateByInstructionCapability
|
||||
| RunToLineCapability
|
||||
| WatchComplexExpressionsCapability
|
||||
| MemoryAddressCapability))
|
||||
| MemoryAddressCapability
|
||||
| AdditionalQmlStackCapability))
|
||||
return true;
|
||||
|
||||
if (runParameters().startMode == AttachToCore)
|
||||
|
||||
@@ -101,6 +101,7 @@ private:
|
||||
void reloadSourceFiles() override {}
|
||||
void reloadFullStack() override;
|
||||
void reloadDebuggingHelpers() override;
|
||||
void loadAdditionalQmlStack() override;
|
||||
void fetchDisassembler(Internal::DisassemblerAgent *) override;
|
||||
|
||||
void setRegisterValue(const QString &name, const QString &value) override;
|
||||
@@ -125,7 +126,7 @@ private:
|
||||
void updateAll() override;
|
||||
void doUpdateLocals(const UpdateParameters ¶ms) override;
|
||||
void updateBreakpointData(const Breakpoint &bp, const GdbMi &bkpt, bool added);
|
||||
void fetchStack(int limit);
|
||||
void fetchStack(int limit, bool alsoQml = false);
|
||||
|
||||
void runCommand(const DebuggerCommand &cmd) override;
|
||||
void debugLastCommand() override;
|
||||
|
||||
Reference in New Issue
Block a user