2009-02-25 09:15:00 +01:00
|
|
|
/**************************************************************************
|
2009-02-20 17:07:00 +01:00
|
|
|
**
|
|
|
|
|
** This file is part of Qt Creator
|
|
|
|
|
**
|
2009-02-25 09:15:00 +01:00
|
|
|
** Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
|
2009-02-20 17:07:00 +01:00
|
|
|
**
|
2009-06-17 00:01:27 +10:00
|
|
|
** Contact: Nokia Corporation (qt-info@nokia.com)
|
2009-02-20 17:07:00 +01:00
|
|
|
**
|
2009-02-25 09:15:00 +01:00
|
|
|
** Commercial Usage
|
2009-02-20 17:07:00 +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.
|
2009-02-20 17:07:00 +01:00
|
|
|
**
|
2009-02-25 09:15:00 +01:00
|
|
|
** GNU Lesser General Public License Usage
|
2009-02-20 17:07:00 +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.
|
2009-02-20 17:07:00 +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.
|
2009-02-20 17:07:00 +01:00
|
|
|
**
|
2009-02-25 09:15:00 +01:00
|
|
|
**************************************************************************/
|
2009-02-20 17:07:00 +01:00
|
|
|
|
|
|
|
|
#ifndef DEBUGGER_CDBENGINEPRIVATE_H
|
|
|
|
|
#define DEBUGGER_CDBENGINEPRIVATE_H
|
|
|
|
|
|
|
|
|
|
#include "cdbdebugeventcallback.h"
|
|
|
|
|
#include "cdbdebugoutput.h"
|
2009-04-17 09:03:32 +02:00
|
|
|
#include "cdboptions.h"
|
2009-04-20 16:40:50 +02:00
|
|
|
#include "cdbdumperhelper.h"
|
2009-03-06 17:10:23 +01:00
|
|
|
#include "stackhandler.h"
|
|
|
|
|
#include "debuggermanager.h"
|
2009-04-17 09:03:32 +02:00
|
|
|
|
2009-03-17 16:54:35 +01:00
|
|
|
#include <utils/consoleprocess.h>
|
2009-04-17 09:03:32 +02:00
|
|
|
#include <QtCore/QSharedPointer>
|
2009-05-14 14:29:37 +02:00
|
|
|
#include <QtCore/QMap>
|
2009-02-20 17:07:00 +01:00
|
|
|
|
|
|
|
|
namespace Debugger {
|
2009-09-25 16:01:28 +02:00
|
|
|
class DebuggerManager;
|
|
|
|
|
|
2009-02-20 17:07:00 +01:00
|
|
|
namespace Internal {
|
|
|
|
|
|
2009-03-06 17:10:23 +01:00
|
|
|
class WatchHandler;
|
2009-04-29 14:15:09 +02:00
|
|
|
class CdbStackFrameContext;
|
2009-03-26 16:49:28 +01:00
|
|
|
class CdbStackTraceContext;
|
2009-02-20 17:07:00 +01:00
|
|
|
|
2009-02-23 16:13:35 +01:00
|
|
|
// Thin wrapper around the 'DBEng' debugger engine shared library
|
|
|
|
|
// which is loaded at runtime.
|
|
|
|
|
|
2009-04-15 14:26:08 +02:00
|
|
|
class DebuggerEngineLibrary
|
|
|
|
|
{
|
2009-02-23 16:13:35 +01:00
|
|
|
public:
|
|
|
|
|
DebuggerEngineLibrary();
|
2009-10-09 17:33:24 +02:00
|
|
|
bool init(const QString &path, QString *dbgEngDLL, QString *errorMessage);
|
2009-02-23 16:13:35 +01:00
|
|
|
|
|
|
|
|
inline HRESULT debugCreate(REFIID interfaceId, PVOID *interfaceHandle) const
|
|
|
|
|
{ return m_debugCreate(interfaceId, interfaceHandle); }
|
|
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
// The exported functions of the library
|
2009-04-23 09:25:57 +02:00
|
|
|
typedef HRESULT (STDAPICALLTYPE *DebugCreateFunction)(REFIID, PVOID *);
|
2009-02-23 16:13:35 +01:00
|
|
|
|
|
|
|
|
DebugCreateFunction m_debugCreate;
|
|
|
|
|
};
|
|
|
|
|
|
2009-04-20 16:40:50 +02:00
|
|
|
// A class that sets an expression syntax on the debug control while in scope.
|
|
|
|
|
// Can be nested as it checks for the old value.
|
|
|
|
|
class SyntaxSetter {
|
|
|
|
|
Q_DISABLE_COPY(SyntaxSetter)
|
|
|
|
|
public:
|
2009-04-21 12:30:12 +02:00
|
|
|
explicit inline SyntaxSetter(CIDebugControl *ctl, ULONG desiredSyntax);
|
2009-04-20 16:40:50 +02:00
|
|
|
inline ~SyntaxSetter();
|
|
|
|
|
private:
|
|
|
|
|
const ULONG m_desiredSyntax;
|
2009-04-21 12:30:12 +02:00
|
|
|
CIDebugControl *m_ctl;
|
2009-04-20 16:40:50 +02:00
|
|
|
ULONG m_oldSyntax;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
// helper struct to pass interfaces around
|
|
|
|
|
struct CdbComInterfaces
|
|
|
|
|
{
|
|
|
|
|
CdbComInterfaces();
|
2009-04-21 12:30:12 +02:00
|
|
|
CIDebugClient* debugClient;
|
|
|
|
|
CIDebugControl* debugControl;
|
|
|
|
|
CIDebugSystemObjects* debugSystemObjects;
|
|
|
|
|
CIDebugSymbols* debugSymbols;
|
|
|
|
|
CIDebugRegisters* debugRegisters;
|
|
|
|
|
CIDebugDataSpaces* debugDataSpaces;
|
2009-04-20 16:40:50 +02:00
|
|
|
};
|
|
|
|
|
|
2009-02-20 17:07:00 +01:00
|
|
|
struct CdbDebugEnginePrivate
|
2009-05-14 14:29:37 +02:00
|
|
|
{
|
|
|
|
|
typedef QMap<QString, QString> EditorToolTipCache;
|
|
|
|
|
|
2009-04-08 16:37:41 +02:00
|
|
|
enum HandleBreakEventMode { // Special modes for break event handler.
|
|
|
|
|
BreakEventHandle,
|
|
|
|
|
BreakEventIgnoreOnce,
|
|
|
|
|
BreakEventSyncBreakPoints,
|
|
|
|
|
};
|
|
|
|
|
|
2009-04-17 09:03:32 +02:00
|
|
|
explicit CdbDebugEnginePrivate(DebuggerManager *parent,
|
|
|
|
|
const QSharedPointer<CdbOptions> &options,
|
|
|
|
|
CdbDebugEngine* engine);
|
2009-03-06 17:10:23 +01:00
|
|
|
bool init(QString *errorMessage);
|
2009-10-09 17:33:24 +02:00
|
|
|
~CdbDebugEnginePrivate();
|
2009-02-20 17:07:00 +01:00
|
|
|
|
2009-10-09 17:33:24 +02:00
|
|
|
void checkVersion();
|
2009-04-22 17:28:26 +02:00
|
|
|
void processCreatedAttached(ULONG64 processHandle, ULONG64 initialThreadHandle);
|
2009-03-05 17:30:29 +01:00
|
|
|
void setDebuggeeHandles(HANDLE hDebuggeeProcess, HANDLE hDebuggeeThread);
|
|
|
|
|
|
2009-02-20 17:07:00 +01:00
|
|
|
bool isDebuggeeRunning() const { return m_watchTimer != -1; }
|
|
|
|
|
void handleDebugEvent();
|
2009-07-24 16:05:46 +02:00
|
|
|
ULONG updateThreadList();
|
2009-09-29 17:33:51 +02:00
|
|
|
bool setCDBThreadId(unsigned long threadId, QString *errorMessage);
|
2009-02-20 17:07:00 +01:00
|
|
|
void updateStackTrace();
|
2009-04-09 16:51:13 +02:00
|
|
|
void updateModules();
|
|
|
|
|
|
2009-04-20 16:40:50 +02:00
|
|
|
void handleBreakpointEvent(PDEBUG_BREAKPOINT2 pBP);
|
2009-03-26 16:49:28 +01:00
|
|
|
void cleanStackTrace();
|
2009-04-08 16:37:41 +02:00
|
|
|
void clearForRun();
|
2009-04-20 16:40:50 +02:00
|
|
|
void handleModuleLoad(const QString &);
|
2009-07-13 09:11:07 +02:00
|
|
|
CdbStackFrameContext *getStackFrameContext(int frameIndex, QString *errorMessage) const;
|
2009-04-09 16:51:13 +02:00
|
|
|
void clearDisplay();
|
2009-02-20 17:07:00 +01:00
|
|
|
|
2009-04-08 16:37:41 +02:00
|
|
|
bool interruptInterferiorProcess(QString *errorMessage);
|
|
|
|
|
|
2009-04-22 17:28:26 +02:00
|
|
|
bool continueInferiorProcess(QString *errorMessage = 0);
|
2009-04-08 16:37:41 +02:00
|
|
|
bool continueInferior(QString *errorMessage);
|
2009-09-30 17:13:52 +02:00
|
|
|
bool executeContinueCommand(const QString &command);
|
2009-04-08 16:37:41 +02:00
|
|
|
|
|
|
|
|
bool attemptBreakpointSynchronization(QString *errorMessage);
|
2009-05-05 09:52:24 +02:00
|
|
|
void notifyCrashed();
|
2009-04-08 16:37:41 +02:00
|
|
|
|
2009-09-30 11:44:04 +02:00
|
|
|
enum EndInferiorAction { DetachInferior, TerminateInferior };
|
|
|
|
|
bool endInferior(EndInferiorAction a, QString *errorMessage);
|
|
|
|
|
|
2009-05-11 16:54:35 +02:00
|
|
|
enum EndDebuggingMode { EndDebuggingDetach, EndDebuggingTerminate, EndDebuggingAuto };
|
|
|
|
|
void endDebugging(EndDebuggingMode em = EndDebuggingAuto);
|
|
|
|
|
|
2009-04-21 12:30:12 +02:00
|
|
|
static bool executeDebuggerCommand(CIDebugControl *ctrl, const QString &command, QString *errorMessage);
|
2009-04-29 14:15:09 +02:00
|
|
|
static bool evaluateExpression(CIDebugControl *ctrl, const QString &expression, DEBUG_VALUE *v, QString *errorMessage);
|
2009-04-20 16:40:50 +02:00
|
|
|
|
2009-05-08 16:56:48 +02:00
|
|
|
QStringList sourcePaths() const;
|
|
|
|
|
bool setSourcePaths(const QStringList &s, QString *errorMessage);
|
|
|
|
|
|
|
|
|
|
QStringList symbolPaths() const;
|
|
|
|
|
bool setSymbolPaths(const QStringList &s, QString *errorMessage);
|
|
|
|
|
|
2009-08-18 09:59:15 +02:00
|
|
|
bool setCodeLevel();
|
|
|
|
|
|
2009-04-17 09:03:32 +02:00
|
|
|
const QSharedPointer<CdbOptions> m_options;
|
2009-02-20 17:07:00 +01:00
|
|
|
HANDLE m_hDebuggeeProcess;
|
|
|
|
|
HANDLE m_hDebuggeeThread;
|
2009-10-06 15:50:48 +02:00
|
|
|
bool m_interrupted;
|
2009-02-20 17:07:00 +01:00
|
|
|
int m_currentThreadId;
|
2009-10-01 14:41:30 +02:00
|
|
|
int m_eventThreadId;
|
2009-04-08 16:37:41 +02:00
|
|
|
HandleBreakEventMode m_breakEventMode;
|
2009-02-20 17:07:00 +01:00
|
|
|
|
|
|
|
|
int m_watchTimer;
|
2009-04-20 16:40:50 +02:00
|
|
|
CdbComInterfaces m_cif;
|
2009-02-20 17:07:00 +01:00
|
|
|
CdbDebugEventCallback m_debugEventCallBack;
|
2009-07-13 09:11:07 +02:00
|
|
|
CdbDebugOutput m_debugOutputCallBack;
|
2009-04-29 14:15:09 +02:00
|
|
|
QSharedPointer<CdbDumperHelper> m_dumper;
|
2009-07-27 15:32:46 +02:00
|
|
|
QString m_baseImagePath;
|
2009-02-20 17:07:00 +01:00
|
|
|
|
2009-09-25 08:35:31 +02:00
|
|
|
CdbDebugEngine *m_engine;
|
2009-09-25 09:31:35 +02:00
|
|
|
inline DebuggerManager *manager() const;
|
2009-03-26 16:49:28 +01:00
|
|
|
CdbStackTraceContext *m_currentStackTrace;
|
2009-05-14 14:29:37 +02:00
|
|
|
EditorToolTipCache m_editorToolTipCache;
|
|
|
|
|
|
2009-03-27 17:19:39 +01:00
|
|
|
bool m_firstActivatedFrame;
|
2009-03-26 16:49:28 +01:00
|
|
|
|
2009-03-06 17:10:23 +01:00
|
|
|
DebuggerStartMode m_mode;
|
2009-10-05 11:06:05 +02:00
|
|
|
Utils::ConsoleProcess m_consoleStubProc;
|
2009-10-09 17:33:24 +02:00
|
|
|
QString m_dbengDLL;
|
2009-02-20 17:07:00 +01:00
|
|
|
};
|
|
|
|
|
|
2009-04-21 12:30:12 +02:00
|
|
|
// helper functions
|
|
|
|
|
|
|
|
|
|
bool getExecutionStatus(CIDebugControl *ctl, ULONG *executionStatus, QString *errorMessage = 0);
|
|
|
|
|
const char *executionStatusString(ULONG executionStatus);
|
|
|
|
|
const char *executionStatusString(CIDebugControl *ctl);
|
|
|
|
|
|
2009-03-26 16:49:28 +01:00
|
|
|
// Message
|
|
|
|
|
QString msgDebugEngineComResult(HRESULT hr);
|
|
|
|
|
QString msgComFailed(const char *func, HRESULT hr);
|
|
|
|
|
|
2009-02-23 14:46:46 +01:00
|
|
|
enum { debugCDB = 0 };
|
2009-06-18 10:34:53 +02:00
|
|
|
enum { debugCDBWatchHandling = 0 };
|
2009-02-23 14:46:46 +01:00
|
|
|
|
2009-02-20 17:07:00 +01:00
|
|
|
} // namespace Internal
|
|
|
|
|
} // namespace Debugger
|
|
|
|
|
|
|
|
|
|
#endif // DEBUGGER_CDBENGINEPRIVATE_H
|
2009-02-23 16:13:35 +01:00
|
|
|
|