debuggger: code cosmetics

This commit is contained in:
hjk
2010-03-26 08:52:49 +01:00
parent acc4563f37
commit 1883baa56e
2 changed files with 90 additions and 81 deletions

View File

@@ -34,6 +34,7 @@
#include "stackframe.h" #include "stackframe.h"
#include <texteditor/basetextmark.h> #include <texteditor/basetextmark.h>
#include <utils/qtcassert.h>
#include <QtCore/QDebug> #include <QtCore/QDebug>
#include <QtCore/QTextStream> #include <QtCore/QTextStream>
@@ -203,32 +204,35 @@ QString BreakpointData::toToolTip() const
{ {
QString rc; QString rc;
QTextStream str(&rc); QTextStream str(&rc);
str << "<html><body><table>"; str << "<html><body><table>"
str << "<tr><td>" << BreakHandler::tr("Marker File:") << "<tr><td>" << BreakHandler::tr("Marker File:")
<< "</td><td>" << markerFileName << "</td></tr>"; << "</td><td>" << markerFileName << "</td></tr>"
str << "<tr><td>" << BreakHandler::tr("Marker Line:") << "<tr><td>" << BreakHandler::tr("Marker Line:")
<< "</td><td>" << markerLineNumber << "</td></tr>"; << "</td><td>" << markerLineNumber << "</td></tr>"
str << "<tr><td>" << BreakHandler::tr("Breakpoint Number:") << "<tr><td>" << BreakHandler::tr("Breakpoint Number:")
<< "</td><td>" << bpNumber << "</td></tr>"; << "</td><td>" << bpNumber << "</td></tr>"
str << "<tr><td>" << BreakHandler::tr("Breakpoint Address:") << "<tr><td>" << BreakHandler::tr("Breakpoint Address:")
<< "</td><td>" << bpAddress << "</td></tr>"; << "</td><td>" << bpAddress << "</td></tr>"
str << "</table><br><hr><table>"; << "</table><br><hr><table>"
str << "<tr><th>" << BreakHandler::tr("Property") << "<tr><th>" << BreakHandler::tr("Property")
<< "</th><th>" << BreakHandler::tr("Requested") << "</th><th>" << BreakHandler::tr("Requested")
<< "</th><th>" << BreakHandler::tr("Obtained") << "</th></tr>"; << "</th><th>" << BreakHandler::tr("Obtained") << "</th></tr>"
str << "<tr><td>" << BreakHandler::tr("Internal Number:") << "<tr><td>" << BreakHandler::tr("Internal Number:")
<< "</td><td>&mdash;</td><td>" << bpNumber << "</td></tr>"; << "</td><td>&mdash;</td><td>" << bpNumber << "</td></tr>"
str << "<tr><td>" << BreakHandler::tr("File Name:") << "<tr><td>" << BreakHandler::tr("File Name:")
<< "</td><td>" << fileName << "</td><td>" << bpFileName << "</td></tr>"; << "</td><td>" << fileName << "</td><td>" << bpFileName << "</td></tr>"
str << "<tr><td>" << BreakHandler::tr("Function Name:") << "<tr><td>" << BreakHandler::tr("Function Name:")
<< "</td><td>" << funcName << "</td><td>" << bpFuncName << "</td></tr>"; << "</td><td>" << funcName << "</td><td>" << bpFuncName << "</td></tr>"
str << "<tr><td>" << BreakHandler::tr("Line Number:") << "<tr><td>" << BreakHandler::tr("Line Number:")
<< "</td><td>" << lineNumber << "</td><td>" << bpLineNumber << "</td></tr>"; << "</td><td>" << lineNumber << "</td><td>" << bpLineNumber << "</td></tr>"
str << "<tr><td>" << BreakHandler::tr("Condition:") << "<tr><td>" << BreakHandler::tr("Corrected Line Number:")
<< "</td><td>" << condition << "</td><td>" << bpCondition << "</td></tr>"; << "</td><td>" << lineNumber
str << "<tr><td>" << BreakHandler::tr("Ignore Count:") << "</td><td>" << bpCorrectedLineNumber << "</td></tr>"
<< "</td><td>" << ignoreCount << "</td><td>" << bpIgnoreCount << "</td></tr>"; << "<tr><td>" << BreakHandler::tr("Condition:")
str << "</table></body></html>"; << "</td><td>" << condition << "</td><td>" << bpCondition << "</td></tr>"
<< "<tr><td>" << BreakHandler::tr("Ignore Count:")
<< "</td><td>" << ignoreCount << "</td><td>" << bpIgnoreCount << "</td></tr>"
<< "</table></body></html>";
return rc; return rc;
} }
@@ -236,19 +240,19 @@ QString BreakpointData::toString() const
{ {
QString rc; QString rc;
QTextStream str(&rc); QTextStream str(&rc);
str << BreakHandler::tr("Marker File:") << markerFileName << ' '; str << BreakHandler::tr("Marker File:") << markerFileName << ' '
str << BreakHandler::tr("Marker Line:") << markerLineNumber << ' '; << BreakHandler::tr("Marker Line:") << markerLineNumber << ' '
str << BreakHandler::tr("Breakpoint Number:") << bpNumber << ' '; << BreakHandler::tr("Breakpoint Number:") << bpNumber << ' '
str << BreakHandler::tr("Breakpoint Address:") << bpAddress << '\n'; << BreakHandler::tr("Breakpoint Address:") << bpAddress << '\n'
str << BreakHandler::tr("File Name:") << BreakHandler::tr("File Name:")
<< fileName << " -- " << bpFileName << '\n'; << fileName << " -- " << bpFileName << '\n'
str << BreakHandler::tr("Function Name:") << BreakHandler::tr("Function Name:")
<< funcName << " -- " << bpFuncName << '\n'; << funcName << " -- " << bpFuncName << '\n'
str << BreakHandler::tr("Line Number:") << BreakHandler::tr("Line Number:")
<< lineNumber << " -- " << bpLineNumber << '\n'; << lineNumber << " -- " << bpLineNumber << '\n'
str << BreakHandler::tr("Condition:") << BreakHandler::tr("Condition:")
<< condition << " -- " << bpCondition << '\n'; << condition << " -- " << bpCondition << '\n'
str << BreakHandler::tr("Ignore Count:") << BreakHandler::tr("Ignore Count:")
<< ignoreCount << " -- " << bpIgnoreCount << '\n'; << ignoreCount << " -- " << bpIgnoreCount << '\n';
return rc; return rc;
} }
@@ -269,7 +273,7 @@ bool BreakpointData::isLocatedAt(const QString &fileName_, int lineNumber_) cons
bool BreakpointData::conditionsMatch() const bool BreakpointData::conditionsMatch() const
{ {
// same versions of gdb "beautify" the passed condition // Some versions of gdb "beautify" the passed condition.
QString s1 = condition; QString s1 = condition;
s1.remove(QChar(' ')); s1.remove(QChar(' '));
QString s2 = bpCondition; QString s2 = bpCondition;
@@ -316,6 +320,12 @@ bool BreakHandler::hasPendingBreakpoints() const
return false; return false;
} }
BreakpointData *BreakHandler::at(int index) const
{
QTC_ASSERT(index < size(), return 0);
return m_bp.at(index);
}
void BreakHandler::removeAt(int index) void BreakHandler::removeAt(int index)
{ {
BreakpointData *data = at(index); BreakpointData *data = at(index);
@@ -443,7 +453,7 @@ void BreakHandler::resetBreakpoints()
data->bpCondition.clear(); data->bpCondition.clear();
data->bpIgnoreCount.clear(); data->bpIgnoreCount.clear();
data->bpAddress.clear(); data->bpAddress.clear();
// keep marker data if it was primary // Keep marker data if it was primary.
if (data->markerFileName != data->fileName) if (data->markerFileName != data->fileName)
data->markerFileName.clear(); data->markerFileName.clear();
if (data->markerLineNumber != data->lineNumber.toInt()) if (data->markerLineNumber != data->lineNumber.toInt())
@@ -728,7 +738,6 @@ void BreakHandler::loadSessionData()
void BreakHandler::activateBreakpoint(int index) void BreakHandler::activateBreakpoint(int index)
{ {
const BreakpointData *data = at(index); const BreakpointData *data = at(index);
//qDebug() << "BREAKPOINT ACTIVATED: " << data->fileName;
if (!data->markerFileName.isEmpty()) { if (!data->markerFileName.isEmpty()) {
StackFrame frame; StackFrame frame;
frame.file = data->markerFileName; frame.file = data->markerFileName;
@@ -739,7 +748,8 @@ void BreakHandler::activateBreakpoint(int index)
void BreakHandler::breakByFunction(const QString &functionName) void BreakHandler::breakByFunction(const QString &functionName)
{ {
// One per function is enough for now // One breakpoint per function is enough for now. This does not handle
// combinations of multiple conditions and ignore counts, though.
for (int index = size(); --index >= 0;) { for (int index = size(); --index >= 0;) {
const BreakpointData *data = at(index); const BreakpointData *data = at(index);
QTC_ASSERT(data, break); QTC_ASSERT(data, break);

View File

@@ -30,8 +30,6 @@
#ifndef DEBUGGER_BREAKHANDLER_H #ifndef DEBUGGER_BREAKHANDLER_H
#define DEBUGGER_BREAKHANDLER_H #define DEBUGGER_BREAKHANDLER_H
#include <utils/qtcassert.h>
#include <QtCore/QObject> #include <QtCore/QObject>
#include <QtCore/QAbstractTableModel> #include <QtCore/QAbstractTableModel>
#include <QtGui/QIcon> #include <QtGui/QIcon>
@@ -66,41 +64,42 @@ public:
private: private:
// Intentionally unimplemented. // Intentionally unimplemented.
// Making it copiable is tricky because of the markers. // Making it copyable is tricky because of the markers.
void operator=(const BreakpointData &); void operator=(const BreakpointData &);
BreakpointData(const BreakpointData &); BreakpointData(const BreakpointData &);
// Our owner // Our owner
BreakHandler *m_handler; // not owned. BreakHandler *m_handler; // Not owned.
public: public:
bool enabled; // should we talk to the debugger engine? bool enabled; // Should we talk to the debugger engine?
bool pending; // does the debugger engine know about us already? bool pending; // Does the debugger engine know about us already?
// this "user requested information". will get stored in the session // This "user requested information" will get stored in the session.
QString fileName; // short name of source file QString fileName; // Short name of source file.
QByteArray condition; // condition associated with breakpoint QByteArray condition; // Condition associated with breakpoint.
QByteArray ignoreCount; // ignore count associated with breakpoint QByteArray ignoreCount; // Ignore count associated with breakpoint.
QByteArray lineNumber; // line in source file QByteArray lineNumber; // Line in source file.
QString funcName; // name of containing function QString funcName; // Name of containing function.
bool useFullPath; // should we use the full path when setting the bp? bool useFullPath; // Should we use the full path when setting the bp?
// this is what gdb produced in response // This is what gdb produced in response.
QByteArray bpNumber; // breakpoint number assigned by the debugger engine QByteArray bpNumber; // Breakpoint number assigned by the debugger engine.
QByteArray bpCondition; // condition acknowledged by the debugger engine QByteArray bpCondition; // Condition acknowledged by the debugger engine.
QByteArray bpIgnoreCount;// ignore count acknowledged by the debugger engine QByteArray bpIgnoreCount;// Ignore count acknowledged by the debugger engine.
QString bpFileName; // file name acknowledged by the debugger engine QString bpFileName; // File name acknowledged by the debugger engine.
QByteArray bpLineNumber; // line number acknowledged by the debugger engine QByteArray bpLineNumber; // Line number acknowledged by the debugger engine.
QString bpFuncName; // function name acknowledged by the debugger engine QByteArray bpCorrectedLineNumber; // Acknowledged by the debugger engine.
QByteArray bpAddress; // address acknowledged by the debugger engine QString bpFuncName; // Function name acknowledged by the debugger engine.
bool bpMultiple; // happens in constructors/gdb QByteArray bpAddress; // Address acknowledged by the debugger engine.
bool bpEnabled; // enable/disable command sent bool bpMultiple; // Happens in constructors/gdb.
bool bpEnabled; // Enable/disable command sent.
// taken from either user input or gdb responses // Taken from either user input or gdb responses.
QString markerFileName; // used to locate the marker QString markerFileName; // Used to locate the marker.
int markerLineNumber; int markerLineNumber;
// our red blob in the editor // Our red blob in the editor.
BreakpointMarker *marker; BreakpointMarker *marker;
}; };
@@ -126,23 +125,23 @@ public:
QAbstractItemModel *model() { return this; } QAbstractItemModel *model() { return this; }
BreakpointData *at(int index) const { QTC_ASSERT(index < size(), return 0); return m_bp.at(index); } BreakpointData *at(int index) const;
int size() const { return m_bp.size(); } int size() const { return m_bp.size(); }
bool hasPendingBreakpoints() const; bool hasPendingBreakpoints() const;
void append(BreakpointData *data); void append(BreakpointData *data);
void removeAt(int index); // also deletes the marker void removeAt(int index); // This also deletes the marker.
void clear(); // also deletes all the marker void clear(); // This also deletes all the marker.
int indexOf(BreakpointData *data) { return m_bp.indexOf(data); } int indexOf(BreakpointData *data) { return m_bp.indexOf(data); }
int findBreakpoint(const QString &fileName, int lineNumber); int findBreakpoint(const QString &fileName, int lineNumber);
int findBreakpoint(const BreakpointData &data); // returns index int findBreakpoint(const BreakpointData &data); // Returns index.
int findBreakpoint(int bpNumber); // returns index int findBreakpoint(int bpNumber); // Returns index.
void updateMarkers(); void updateMarkers();
QList<BreakpointData *> insertedBreakpoints() const; QList<BreakpointData *> insertedBreakpoints() const;
void takeInsertedBreakPoint(BreakpointData *); void takeInsertedBreakPoint(BreakpointData *);
QList<BreakpointData *> takeRemovedBreakpoints(); // owned QList<BreakpointData *> takeRemovedBreakpoints(); // Owned.
QList<BreakpointData *> takeEnabledBreakpoints(); // not owned QList<BreakpointData *> takeEnabledBreakpoints(); // Not owned.
QList<BreakpointData *> takeDisabledBreakpoints(); // not owned QList<BreakpointData *> takeDisabledBreakpoints(); // Not owned.
QIcon breakpointIcon() const { return m_breakpointIcon; } QIcon breakpointIcon() const { return m_breakpointIcon; }
QIcon disabledBreakpointIcon() const { return m_disabledBreakpointIcon; } QIcon disabledBreakpointIcon() const { return m_disabledBreakpointIcon; }
@@ -177,12 +176,12 @@ private:
const QIcon m_disabledBreakpointIcon; const QIcon m_disabledBreakpointIcon;
const QIcon m_pendingBreakPointIcon; const QIcon m_pendingBreakPointIcon;
DebuggerManager *m_manager; // not owned DebuggerManager *m_manager; // Not owned.
QList<BreakpointData *> m_bp; QList<BreakpointData *> m_bp;
QList<BreakpointData *> m_inserted; // lately inserted breakpoints QList<BreakpointData *> m_inserted; // Lately inserted breakpoints.
QList<BreakpointData *> m_removed; // lately removed breakpoints QList<BreakpointData *> m_removed; // Lately removed breakpoints.
QList<BreakpointData *> m_enabled; // lately enabled breakpoints QList<BreakpointData *> m_enabled; // Lately enabled breakpoints.
QList<BreakpointData *> m_disabled; // lately disabled breakpoints QList<BreakpointData *> m_disabled; // Lately disabled breakpoints.
}; };
} // namespace Internal } // namespace Internal