forked from qt-creator/qt-creator
clean up ThreadData
Reviewed-by: hjk
This commit is contained in:
@@ -52,6 +52,7 @@ HEADERS += breakhandler.h \
|
|||||||
watchhandler.h \
|
watchhandler.h \
|
||||||
watchutils.h \
|
watchutils.h \
|
||||||
watchwindow.h \
|
watchwindow.h \
|
||||||
|
threaddata.h \
|
||||||
threadshandler.h \
|
threadshandler.h \
|
||||||
watchdelegatewidgets.h
|
watchdelegatewidgets.h
|
||||||
|
|
||||||
|
|||||||
@@ -3033,7 +3033,7 @@ void GdbEngine::handleThreadNames(const GdbResponse &response)
|
|||||||
int id = name.findChild("id").data().toInt();
|
int id = name.findChild("id").data().toInt();
|
||||||
for (int index = 0, n = threads.size(); index != n; ++index) {
|
for (int index = 0, n = threads.size(); index != n; ++index) {
|
||||||
ThreadData & thread = threads[index];
|
ThreadData & thread = threads[index];
|
||||||
if (thread.id == id) {
|
if (thread.id == (quint64)id) {
|
||||||
thread.name = decodeData(name.findChild("value").data(), name.findChild("valueencoded").data().toInt());
|
thread.name = decodeData(name.findChild("value").data(), name.findChild("valueencoded").data().toInt());
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|||||||
98
src/plugins/debugger/threaddata.h
Normal file
98
src/plugins/debugger/threaddata.h
Normal file
@@ -0,0 +1,98 @@
|
|||||||
|
/**************************************************************************
|
||||||
|
**
|
||||||
|
** This file is part of Qt Creator
|
||||||
|
**
|
||||||
|
** Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies).
|
||||||
|
**
|
||||||
|
** Contact: Nokia Corporation (qt-info@nokia.com)
|
||||||
|
**
|
||||||
|
** Commercial Usage
|
||||||
|
**
|
||||||
|
** 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.
|
||||||
|
**
|
||||||
|
** GNU Lesser General Public License Usage
|
||||||
|
**
|
||||||
|
** 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.
|
||||||
|
**
|
||||||
|
** If you are unsure which license is appropriate for your use, please
|
||||||
|
** contact the sales department at http://qt.nokia.com/contact.
|
||||||
|
**
|
||||||
|
**************************************************************************/
|
||||||
|
|
||||||
|
#ifndef THREADDATA_H
|
||||||
|
#define THREADDATA_H
|
||||||
|
|
||||||
|
#include <QtCore/QList>
|
||||||
|
|
||||||
|
namespace Debugger {
|
||||||
|
|
||||||
|
namespace Internal {
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////////////////
|
||||||
|
//
|
||||||
|
// ThreadData
|
||||||
|
//
|
||||||
|
////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
/*! A structure containing information about a single thread */
|
||||||
|
struct ThreadData
|
||||||
|
{
|
||||||
|
inline ThreadData(quint64 threadid = 0)
|
||||||
|
: id (threadid)
|
||||||
|
, frameLevel(-1)
|
||||||
|
, address (0)
|
||||||
|
, lineNumber(-1)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
enum {
|
||||||
|
IdColumn,
|
||||||
|
AddressColumn,
|
||||||
|
FunctionColumn,
|
||||||
|
FileColumn,
|
||||||
|
LineColumn,
|
||||||
|
StateColumn,
|
||||||
|
NameColumn,
|
||||||
|
CoreColumn,
|
||||||
|
ColumnCount = CoreColumn
|
||||||
|
};
|
||||||
|
|
||||||
|
// Permanent data.
|
||||||
|
quint64 id;
|
||||||
|
QString targetId;
|
||||||
|
QString core;
|
||||||
|
|
||||||
|
// State information when stopped
|
||||||
|
inline void notifyRunning() // Clear state information
|
||||||
|
{
|
||||||
|
address = 0;
|
||||||
|
function.clear();
|
||||||
|
fileName.clear();
|
||||||
|
frameLevel = -1;
|
||||||
|
state.clear();
|
||||||
|
lineNumber = -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
qint32 frameLevel;
|
||||||
|
quint64 address;
|
||||||
|
QString function;
|
||||||
|
QString fileName;
|
||||||
|
QString state;
|
||||||
|
qint32 lineNumber;
|
||||||
|
QString name;
|
||||||
|
};
|
||||||
|
|
||||||
|
typedef QVector<ThreadData> Threads;
|
||||||
|
|
||||||
|
} // namespace Internal
|
||||||
|
} // namespace Debugger
|
||||||
|
|
||||||
|
#endif // THREADDATA_H
|
||||||
@@ -43,23 +43,6 @@ namespace Internal {
|
|||||||
// ThreadsHandler
|
// ThreadsHandler
|
||||||
//
|
//
|
||||||
///////////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
ThreadData::ThreadData(int threadId)
|
|
||||||
{
|
|
||||||
notifyRunning();
|
|
||||||
id = threadId;
|
|
||||||
}
|
|
||||||
|
|
||||||
void ThreadData::notifyRunning()
|
|
||||||
{
|
|
||||||
address = 0;
|
|
||||||
function.clear();
|
|
||||||
fileName.clear();
|
|
||||||
frameLevel = -1;
|
|
||||||
state.clear();
|
|
||||||
lineNumber = -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline QString threadToolTip(const ThreadData &thread)
|
static inline QString threadToolTip(const ThreadData &thread)
|
||||||
{
|
{
|
||||||
const char tableRowStartC[] = "<tr><td>";
|
const char tableRowStartC[] = "<tr><td>";
|
||||||
@@ -239,7 +222,7 @@ void ThreadsHandler::setCurrentThreadId(int id)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int ThreadsHandler::indexOf(int threadId) const
|
int ThreadsHandler::indexOf(quint64 threadId) const
|
||||||
{
|
{
|
||||||
const int count = m_threads.size();
|
const int count = m_threads.size();
|
||||||
for(int i = 0; i < count; i++)
|
for(int i = 0; i < count; i++)
|
||||||
|
|||||||
@@ -35,55 +35,13 @@
|
|||||||
|
|
||||||
#include <QtGui/QIcon>
|
#include <QtGui/QIcon>
|
||||||
|
|
||||||
|
#include "threaddata.h"
|
||||||
|
|
||||||
namespace Debugger {
|
namespace Debugger {
|
||||||
class DebuggerEngine;
|
class DebuggerEngine;
|
||||||
|
|
||||||
namespace Internal {
|
namespace Internal {
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////
|
|
||||||
//
|
|
||||||
// ThreadData
|
|
||||||
//
|
|
||||||
////////////////////////////////////////////////////////////////////////
|
|
||||||
|
|
||||||
/*! A structure containing information about a single thread */
|
|
||||||
struct ThreadData
|
|
||||||
{
|
|
||||||
ThreadData(int threadId = 0);
|
|
||||||
|
|
||||||
enum {
|
|
||||||
IdColumn,
|
|
||||||
AddressColumn,
|
|
||||||
FunctionColumn,
|
|
||||||
FileColumn,
|
|
||||||
LineColumn,
|
|
||||||
StateColumn,
|
|
||||||
NameColumn,
|
|
||||||
CoreColumn,
|
|
||||||
ColumnCount = CoreColumn
|
|
||||||
};
|
|
||||||
|
|
||||||
// Permanent data.
|
|
||||||
int id;
|
|
||||||
QString targetId;
|
|
||||||
QString core;
|
|
||||||
|
|
||||||
// State information when stopped
|
|
||||||
void notifyRunning(); // Clear state information
|
|
||||||
|
|
||||||
int frameLevel;
|
|
||||||
quint64 address;
|
|
||||||
QString function;
|
|
||||||
QString fileName;
|
|
||||||
QString state;
|
|
||||||
int lineNumber;
|
|
||||||
QString name;
|
|
||||||
};
|
|
||||||
|
|
||||||
typedef QVector<ThreadData> Threads;
|
|
||||||
|
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////////////
|
||||||
//
|
//
|
||||||
// ThreadsHandler
|
// ThreadsHandler
|
||||||
@@ -102,7 +60,7 @@ public:
|
|||||||
void setCurrentThread(int index);
|
void setCurrentThread(int index);
|
||||||
int currentThreadId() const;
|
int currentThreadId() const;
|
||||||
void setCurrentThreadId(int id);
|
void setCurrentThreadId(int id);
|
||||||
int indexOf(int threadId) const;
|
int indexOf(quint64 threadId) const;
|
||||||
|
|
||||||
void selectThread(int index);
|
void selectThread(int index);
|
||||||
void setThreads(const Threads &threads);
|
void setThreads(const Threads &threads);
|
||||||
|
|||||||
Reference in New Issue
Block a user