1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112
|
/*
SPDX-FileCopyrightText: 2012 Sven Brauch <svenbrauch@googlemail.com>
SPDX-License-Identifier: GPL-2.0-or-later
*/
#include "pdbframestackmodel.h"
#include "debugsession.h"
#include <QRegularExpression>
#include <QDebug>
#include "debuggerdebug.h"
using namespace KDevelop;
namespace Python {
PdbFrameStackModel::PdbFrameStackModel(IDebugSession* session): FrameStackModel(session), m_debuggerAtFrame(0)
{
}
int PdbFrameStackModel::debuggerAtFrame() const
{
return m_debuggerAtFrame;
}
void PdbFrameStackModel::setDebuggerAtFrame(int newFrame)
{
// Q_ASSERT(newFrame >= 0);
m_debuggerAtFrame = newFrame;
}
void PdbFrameStackModel::framesFetched(QByteArray framelist)
{
qCDebug(KDEV_PYTHON_DEBUGGER) << "frames fetched:" << framelist;
QStringList lines = QString::fromLatin1(framelist).split(QLatin1Char('\n'));
QList<FrameItem> frames;
bool parsingLocation = false;
FrameItem* currentFrame = nullptr;
int framesCount = 0;
for (const QString& line : std::as_const(lines)) {
if ( line.startsWith(QStringLiteral("-> ")) ) {
parsingLocation = true;
if ( currentFrame ) {
frames << *currentFrame;
}
currentFrame = new FrameItem();
currentFrame->nr = framesCount;
framesCount++;
}
else if ( parsingLocation ) {
static QRegularExpression location(QStringLiteral("(\\>?)\\s*(.*)\\(([0-9]+)\\)(.*)"));
// version 1 has some *really* weird "greedy" ruleset which makes no sense at all for me
//location.setPatternSyntax(QRegExp::RegExp2);
const auto match = location.match(line);
if ( match.hasMatch() ) {
qCDebug(KDEV_PYTHON_DEBUGGER) << match.capturedView();
if ( ! match.captured(1).isEmpty() ) {
m_debuggerAtFrame = framesCount;
}
currentFrame->file = QUrl::fromLocalFile(match.captured(2));
currentFrame->line = match.captured(3).toInt() - 1;
currentFrame->name = match.captured(4);
}
else {
qCDebug(KDEV_PYTHON_DEBUGGER) << "regular expression mismatches" << line;
}
}
}
m_debuggerAtFrame = framesCount - m_debuggerAtFrame - 1;
qCDebug(KDEV_PYTHON_DEBUGGER) << "at frame:" << m_debuggerAtFrame;
QVector<FrameItem> framesReversed;
framesReversed.reserve(frames.length());
for ( int i = frames.length() - 1; i >= 0; i-- ) {
framesReversed.append(frames.at(i));
framesReversed.last().nr = framesCount - i - 2;
}
setFrames(0, framesReversed);
}
void PdbFrameStackModel::threadsFetched(QByteArray threadsData)
{
qCDebug(KDEV_PYTHON_DEBUGGER) << "threads fetched" << threadsData;
qCDebug(KDEV_PYTHON_DEBUGGER) << "Implement me: Thread debugging is not supported by pdb.";
QVector<ThreadItem> threads;
ThreadItem mainThread;
mainThread.nr = 0;
mainThread.name = QStringLiteral("main thread");
threads << mainThread;
setThreads(threads);
setCurrentThread(0);
}
void PdbFrameStackModel::fetchFrames(int /*threadNumber*/, int /*from*/, int /*to*/)
{
qCDebug(KDEV_PYTHON_DEBUGGER) << "frames requested";
InternalPdbCommand* cmd = new InternalPdbCommand(this, "framesFetched", QStringLiteral("where\n"));
static_cast<DebugSession*>(session())->addCommand(cmd);
}
void PdbFrameStackModel::fetchThreads()
{
qCDebug(KDEV_PYTHON_DEBUGGER) << "threads requested";
// pdb doesn't support threads.
InternalPdbCommand* cmd = new InternalPdbCommand(this, "threadsFetched", QStringLiteral("pass\n"));
static_cast<DebugSession*>(session())->addCommand(cmd);
}
}
#include "moc_pdbframestackmodel.cpp"
|