Commit 0e25fb6e authored by Oswald Buddenhagen's avatar Oswald Buddenhagen

make initial breakpoint finding work on mac

unlike the upstream gdb, the mac one gives an MI response to "info
target" when in MI mode.
parent 4e1101ef
......@@ -1688,6 +1688,17 @@ void GdbEngine::continueInferior()
void GdbEngine::handleStart(const GdbResultRecord &response)
{
if (response.resultClass == GdbResultDone) {
#ifdef Q_OS_MAC
QString addr = response.data.findChild("section-info").findChild("entry-point").data();
if (!addr.isEmpty()) {
sendCommand("tbreak *" + addr);
m_waitingForFirstBreakpointToBeHit = true;
qq->notifyInferiorRunningRequested();
sendCommand("-exec-run");
} else {
debugMessage("CANNOT OBTAIN START ADDRESS");
}
#else
// [some leading stdout here]
// stdout:&" Entry point: 0x80831f0 0x08048134 - 0x08048147 is .interp\n"
// [some trailing stdout here]
......@@ -1702,6 +1713,7 @@ void GdbEngine::handleStart(const GdbResultRecord &response)
} else {
debugMessage("PARSING START ADDRESS FAILED: " + msg);
}
#endif
} else if (response.resultClass == GdbResultError) {
debugMessage("FETCHING START ADDRESS FAILED: " + response.toString());
}
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment