2009-02-25 09:15:00 +01:00
|
|
|
/**************************************************************************
|
2008-12-02 12:01:29 +01:00
|
|
|
**
|
|
|
|
|
** This file is part of Qt Creator
|
|
|
|
|
**
|
2010-03-05 11:25:49 +01:00
|
|
|
** Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies).
|
2008-12-02 12:01:29 +01:00
|
|
|
**
|
2009-06-17 00:01:27 +10:00
|
|
|
** Contact: Nokia Corporation (qt-info@nokia.com)
|
2008-12-02 12:01:29 +01:00
|
|
|
**
|
2009-02-25 09:15:00 +01:00
|
|
|
** Commercial Usage
|
2008-12-02 14:17:16 +01:00
|
|
|
**
|
2009-02-25 09:15:00 +01:00
|
|
|
** Licensees holding valid Qt Commercial licenses may use this file in
|
|
|
|
|
** accordance with the Qt Commercial License Agreement provided with the
|
|
|
|
|
** Software or, alternatively, in accordance with the terms contained in
|
|
|
|
|
** a written agreement between you and Nokia.
|
2008-12-02 14:17:16 +01:00
|
|
|
**
|
2009-02-25 09:15:00 +01:00
|
|
|
** GNU Lesser General Public License Usage
|
2008-12-02 14:17:16 +01:00
|
|
|
**
|
2009-02-25 09:15:00 +01:00
|
|
|
** Alternatively, this file may be used under the terms of the GNU Lesser
|
|
|
|
|
** General Public License version 2.1 as published by the Free Software
|
|
|
|
|
** Foundation and appearing in the file LICENSE.LGPL included in the
|
|
|
|
|
** packaging of this file. Please review the following information to
|
|
|
|
|
** ensure the GNU Lesser General Public License version 2.1 requirements
|
|
|
|
|
** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
|
2008-12-02 14:17:16 +01:00
|
|
|
**
|
2009-02-25 09:15:00 +01:00
|
|
|
** If you are unsure which license is appropriate for your use, please
|
2009-08-14 09:30:56 +02:00
|
|
|
** contact the sales department at http://qt.nokia.com/contact.
|
2008-12-02 12:01:29 +01:00
|
|
|
**
|
2009-02-25 09:15:00 +01:00
|
|
|
**************************************************************************/
|
2008-12-02 15:08:31 +01:00
|
|
|
|
2008-12-02 12:01:29 +01:00
|
|
|
#ifndef DEBUGGER_BREAKHANDLER_H
|
|
|
|
|
#define DEBUGGER_BREAKHANDLER_H
|
|
|
|
|
|
|
|
|
|
#include <QtCore/QObject>
|
2009-10-01 11:22:44 +02:00
|
|
|
#include <QtCore/QAbstractTableModel>
|
2010-02-10 10:47:34 +01:00
|
|
|
#include <QtGui/QIcon>
|
2008-12-02 12:01:29 +01:00
|
|
|
|
|
|
|
|
namespace Debugger {
|
2009-09-25 16:01:28 +02:00
|
|
|
class DebuggerManager;
|
2008-12-02 12:01:29 +01:00
|
|
|
namespace Internal {
|
|
|
|
|
|
|
|
|
|
class BreakpointMarker;
|
|
|
|
|
class BreakHandler;
|
|
|
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////
|
|
|
|
|
//
|
|
|
|
|
// BreakpointData
|
|
|
|
|
//
|
|
|
|
|
//////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
|
|
class BreakpointData
|
|
|
|
|
{
|
|
|
|
|
public:
|
|
|
|
|
explicit BreakpointData(BreakHandler *handler);
|
|
|
|
|
~BreakpointData();
|
|
|
|
|
|
|
|
|
|
void removeMarker();
|
|
|
|
|
void updateMarker();
|
|
|
|
|
QString toToolTip() const;
|
2010-01-19 18:10:50 +01:00
|
|
|
QString toString() const;
|
2008-12-02 12:01:29 +01:00
|
|
|
BreakHandler *handler() { return m_handler; }
|
|
|
|
|
|
|
|
|
|
bool isLocatedAt(const QString &fileName, int lineNumber) const;
|
|
|
|
|
bool conditionsMatch() const;
|
|
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
// Intentionally unimplemented.
|
2010-03-26 08:52:49 +01:00
|
|
|
// Making it copyable is tricky because of the markers.
|
2008-12-02 12:01:29 +01:00
|
|
|
void operator=(const BreakpointData &);
|
|
|
|
|
BreakpointData(const BreakpointData &);
|
|
|
|
|
|
|
|
|
|
// Our owner
|
2010-03-26 08:52:49 +01:00
|
|
|
BreakHandler *m_handler; // Not owned.
|
2008-12-02 12:01:29 +01:00
|
|
|
|
|
|
|
|
public:
|
2010-03-26 08:52:49 +01:00
|
|
|
bool enabled; // Should we talk to the debugger engine?
|
|
|
|
|
bool pending; // Does the debugger engine know about us already?
|
|
|
|
|
|
|
|
|
|
// This "user requested information" will get stored in the session.
|
|
|
|
|
QString fileName; // Short name of source file.
|
|
|
|
|
QByteArray condition; // Condition associated with breakpoint.
|
|
|
|
|
QByteArray ignoreCount; // Ignore count associated with breakpoint.
|
|
|
|
|
QByteArray lineNumber; // Line in source file.
|
2010-04-29 18:36:18 +02:00
|
|
|
QByteArray threadSpec; // Thread specification.
|
2010-03-26 08:52:49 +01:00
|
|
|
QString funcName; // Name of containing function.
|
|
|
|
|
bool useFullPath; // Should we use the full path when setting the bp?
|
|
|
|
|
|
|
|
|
|
// This is what gdb produced in response.
|
|
|
|
|
QByteArray bpNumber; // Breakpoint number assigned by the debugger engine.
|
|
|
|
|
QByteArray bpCondition; // Condition acknowledged by the debugger engine.
|
|
|
|
|
QByteArray bpIgnoreCount;// Ignore count acknowledged by the debugger engine.
|
|
|
|
|
QString bpFileName; // File name acknowledged by the debugger engine.
|
2010-03-26 10:29:19 +01:00
|
|
|
QString bpFullName; // Full file name acknowledged by the debugger engine.
|
2010-03-26 08:52:49 +01:00
|
|
|
QByteArray bpLineNumber; // Line number acknowledged by the debugger engine.
|
|
|
|
|
QByteArray bpCorrectedLineNumber; // Acknowledged by the debugger engine.
|
2010-04-29 18:36:18 +02:00
|
|
|
QByteArray bpThreadSpec; // Thread spec acknowledged by the debugger engine.
|
2010-03-26 08:52:49 +01:00
|
|
|
QString bpFuncName; // Function name acknowledged by the debugger engine.
|
|
|
|
|
QByteArray bpAddress; // Address acknowledged by the debugger engine.
|
2010-03-26 10:29:19 +01:00
|
|
|
bool bpMultiple; // Happens in constructors/gdb.
|
|
|
|
|
bool bpEnabled; // Enable/disable command sent.
|
2010-03-26 08:52:49 +01:00
|
|
|
|
2010-03-26 10:29:19 +01:00
|
|
|
void setMarkerFileName(const QString &fileName);
|
|
|
|
|
QString markerFileName() const { return m_markerFileName; }
|
|
|
|
|
|
|
|
|
|
void setMarkerLineNumber(int lineNumber);
|
|
|
|
|
int markerLineNumber() const { return m_markerLineNumber; }
|
|
|
|
|
|
|
|
|
|
private:
|
2010-03-26 08:52:49 +01:00
|
|
|
// Taken from either user input or gdb responses.
|
2010-03-26 10:29:19 +01:00
|
|
|
QString m_markerFileName; // Used to locate the marker.
|
|
|
|
|
int m_markerLineNumber;
|
2008-12-02 12:01:29 +01:00
|
|
|
|
2010-03-26 08:52:49 +01:00
|
|
|
// Our red blob in the editor.
|
2008-12-02 12:01:29 +01:00
|
|
|
BreakpointMarker *marker;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////
|
|
|
|
|
//
|
|
|
|
|
// BreakHandler
|
|
|
|
|
//
|
|
|
|
|
//////////////////////////////////////////////////////////////////
|
|
|
|
|
|
2009-10-01 11:22:44 +02:00
|
|
|
class BreakHandler : public QAbstractTableModel
|
2008-12-02 12:01:29 +01:00
|
|
|
{
|
|
|
|
|
Q_OBJECT
|
|
|
|
|
|
|
|
|
|
public:
|
2009-08-14 13:04:05 +02:00
|
|
|
explicit BreakHandler(DebuggerManager *manager, QObject *parent = 0);
|
2008-12-04 11:37:43 +01:00
|
|
|
~BreakHandler();
|
2008-12-02 12:01:29 +01:00
|
|
|
|
|
|
|
|
void removeAllBreakpoints();
|
|
|
|
|
void setAllPending();
|
|
|
|
|
void loadSessionData();
|
|
|
|
|
void saveSessionData();
|
|
|
|
|
|
|
|
|
|
QAbstractItemModel *model() { return this; }
|
|
|
|
|
|
2010-03-26 08:52:49 +01:00
|
|
|
BreakpointData *at(int index) const;
|
2008-12-02 12:01:29 +01:00
|
|
|
int size() const { return m_bp.size(); }
|
2009-04-08 16:37:41 +02:00
|
|
|
bool hasPendingBreakpoints() const;
|
2009-05-12 14:28:27 +02:00
|
|
|
void append(BreakpointData *data);
|
2010-03-26 08:52:49 +01:00
|
|
|
void removeAt(int index); // This also deletes the marker.
|
|
|
|
|
void clear(); // This also deletes all the marker.
|
2008-12-02 12:01:29 +01:00
|
|
|
int indexOf(BreakpointData *data) { return m_bp.indexOf(data); }
|
2010-04-09 14:55:09 +02:00
|
|
|
// If lineNumber < 0, interpret fileName as address.
|
2010-03-26 10:29:19 +01:00
|
|
|
int findBreakpoint(const QString &fileName, int lineNumber) const;
|
|
|
|
|
int findBreakpoint(const BreakpointData &data) const; // Returns index.
|
|
|
|
|
BreakpointData *findBreakpoint(int bpNumber) const;
|
2008-12-02 12:01:29 +01:00
|
|
|
void updateMarkers();
|
|
|
|
|
|
2009-05-12 14:28:27 +02:00
|
|
|
QList<BreakpointData *> insertedBreakpoints() const;
|
|
|
|
|
void takeInsertedBreakPoint(BreakpointData *);
|
2010-03-26 08:52:49 +01:00
|
|
|
QList<BreakpointData *> takeRemovedBreakpoints(); // Owned.
|
|
|
|
|
QList<BreakpointData *> takeEnabledBreakpoints(); // Not owned.
|
|
|
|
|
QList<BreakpointData *> takeDisabledBreakpoints(); // Not owned.
|
2008-12-02 12:01:29 +01:00
|
|
|
|
2010-02-10 10:47:34 +01:00
|
|
|
QIcon breakpointIcon() const { return m_breakpointIcon; }
|
|
|
|
|
QIcon disabledBreakpointIcon() const { return m_disabledBreakpointIcon; }
|
|
|
|
|
QIcon pendingBreakPointIcon() const { return m_pendingBreakPointIcon; }
|
|
|
|
|
|
2008-12-02 12:01:29 +01:00
|
|
|
public slots:
|
2010-04-09 15:19:10 +02:00
|
|
|
void appendBreakpoint(BreakpointData *data);
|
2009-04-28 15:08:52 +02:00
|
|
|
void toggleBreakpointEnabled(BreakpointData *data);
|
2008-12-02 12:01:29 +01:00
|
|
|
void breakByFunction(const QString &functionName);
|
|
|
|
|
void removeBreakpoint(int index);
|
|
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
friend class BreakpointMarker;
|
|
|
|
|
|
|
|
|
|
// QAbstractItemModel
|
|
|
|
|
int columnCount(const QModelIndex &parent) const;
|
|
|
|
|
int rowCount(const QModelIndex &parent) const;
|
|
|
|
|
QVariant data(const QModelIndex &index, int role) const;
|
|
|
|
|
bool setData(const QModelIndex &index, const QVariant &, int role);
|
|
|
|
|
QVariant headerData(int section, Qt::Orientation orientation, int role) const;
|
2009-04-28 15:08:52 +02:00
|
|
|
Qt::ItemFlags flags(const QModelIndex &index) const;
|
2008-12-02 12:01:29 +01:00
|
|
|
|
|
|
|
|
void markerUpdated(BreakpointMarker *, int lineNumber);
|
|
|
|
|
void loadBreakpoints();
|
|
|
|
|
void saveBreakpoints();
|
|
|
|
|
void resetBreakpoints();
|
|
|
|
|
void removeBreakpointHelper(int index);
|
|
|
|
|
|
2010-02-10 10:47:34 +01:00
|
|
|
const QIcon m_breakpointIcon;
|
|
|
|
|
const QIcon m_disabledBreakpointIcon;
|
|
|
|
|
const QIcon m_pendingBreakPointIcon;
|
|
|
|
|
|
2010-03-26 08:52:49 +01:00
|
|
|
DebuggerManager *m_manager; // Not owned.
|
2008-12-02 12:01:29 +01:00
|
|
|
QList<BreakpointData *> m_bp;
|
2010-03-26 08:52:49 +01:00
|
|
|
QList<BreakpointData *> m_inserted; // Lately inserted breakpoints.
|
|
|
|
|
QList<BreakpointData *> m_removed; // Lately removed breakpoints.
|
|
|
|
|
QList<BreakpointData *> m_enabled; // Lately enabled breakpoints.
|
|
|
|
|
QList<BreakpointData *> m_disabled; // Lately disabled breakpoints.
|
2008-12-02 12:01:29 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
} // namespace Internal
|
|
|
|
|
} // namespace Debugger
|
|
|
|
|
|
|
|
|
|
#endif // DEBUGGER_BREAKHANDLER_H
|