/**************************************************************************** ** ** Copyright (C) 2016 The Qt Company Ltd. ** Contact: https://www.qt.io/licensing/ ** ** This file is part of Qt Creator. ** ** Commercial License Usage ** Licensees holding valid commercial Qt licenses may use this file in ** accordance with the commercial license agreement provided with the ** Software or, alternatively, in accordance with the terms contained in ** a written agreement between you and The Qt Company. For licensing terms ** and conditions see https://www.qt.io/terms-conditions. For further ** information use the contact form at https://www.qt.io/contact-us. ** ** GNU General Public License Usage ** Alternatively, this file may be used under the terms of the GNU ** General Public License version 3 as published by the Free Software ** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT ** included in the packaging of this file. Please review the following ** information to ensure the GNU General Public License requirements will ** be met: https://www.gnu.org/licenses/gpl-3.0.html. ** ****************************************************************************/ #pragma once #include #include QT_BEGIN_NAMESPACE class QVariant; class QDebug; QT_END_NAMESPACE namespace Debugger { namespace Internal { class BreakpointParameters; struct ThreadData; class Register; class GdbMi; class DisassemblerLines; // Perform mapping on parts of the source tree as reported by/passed to debugger // in case the user has specified such mappings in the global settings. enum SourcePathMode { DebuggerToSource, SourceToDebugger }; QString cdbSourcePathMapping(QString fileName, const QList > &sourcePathMapping, SourcePathMode mode); // Ensure unique 'namespace' for breakpoints of the breakhandler. enum { cdbBreakPointStartId = 100000, cdbBreakPointIdMinorPart = 100}; QString breakPointCdbId(const Breakpoint &bp); // Convert breakpoint in CDB syntax (applying source path mappings using native paths). QString cdbAddBreakpointCommand(const BreakpointParameters &d, const QList > &sourcePathMapping, const QString &responseId = QString()); QString cdbClearBreakpointCommand(const Breakpoint &bp); // Parse extension command listing breakpoints. // Note that not all fields are returned, since file, line, function are encoded // in the expression (that is in addition deleted on resolving for a bp-type breakpoint). void parseBreakPoint(const GdbMi &gdbmi, BreakpointParameters *r, QString *expression = nullptr); // Write memory (f ...). QString cdbWriteMemoryCommand(quint64 addr, const QByteArray &data); QString debugByteArray(const QByteArray &a); DisassemblerLines parseCdbDisassembler(const QString &a); // Model EXCEPTION_RECORD + firstchance struct WinException { WinException(); void fromGdbMI(const GdbMi &); QString toString(bool includeLocation = false) const; unsigned exceptionCode = 0; unsigned exceptionFlags = 0; quint64 exceptionAddress = 0; quint64 info1 = 0; quint64 info2 = 0; bool firstChance = false; QString file; int lineNumber = 0; QString function; }; QDebug operator<<(QDebug s, const WinException &e); } // namespace Internal } // namespace Debugger