debuggerrunner.cpp 7.82 KB
Newer Older
1
/**************************************************************************
con's avatar
con committed
2
3
4
**
** This file is part of Qt Creator
**
hjk's avatar
hjk committed
5
** Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies).
con's avatar
con committed
6
**
7
** Contact: Nokia Corporation (qt-info@nokia.com)
con's avatar
con committed
8
**
9
** Commercial Usage
10
**
11
12
13
14
** 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.
15
**
16
** GNU Lesser General Public License Usage
17
**
18
19
20
21
22
23
** 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.
24
**
25
** If you are unsure which license is appropriate for your use, please
hjk's avatar
hjk committed
26
** contact the sales department at http://qt.nokia.com/contact.
con's avatar
con committed
27
**
28
**************************************************************************/
hjk's avatar
hjk committed
29

con's avatar
con committed
30
#include "debuggerrunner.h"
hjk's avatar
hjk committed
31
#include "debuggermanager.h"
32
#include "debuggeroutputwindow.h"
con's avatar
con committed
33

hjk's avatar
hjk committed
34
#include <projectexplorer/debugginghelper.h>
con's avatar
con committed
35
36
37
#include <projectexplorer/environment.h>
#include <projectexplorer/project.h>
#include <projectexplorer/projectexplorerconstants.h>
Tobias Hunger's avatar
Tobias Hunger committed
38
#include <projectexplorer/target.h>
39
#include <projectexplorer/buildconfiguration.h>
40
#include <projectexplorer/applicationrunconfiguration.h> // For LocalApplication*
con's avatar
con committed
41

hjk's avatar
hjk committed
42
#include <utils/qtcassert.h>
43
#include <coreplugin/icore.h>
hjk's avatar
hjk committed
44

con's avatar
con committed
45
46
47
#include <QtCore/QDebug>
#include <QtCore/QDir>
#include <QtCore/QFileInfo>
hjk's avatar
hjk committed
48

49
#include <QtGui/QTextDocument>
con's avatar
con committed
50

51
using namespace ProjectExplorer;
52
53
using namespace Debugger::Internal;

54

hjk's avatar
hjk committed
55
namespace Debugger {
con's avatar
con committed
56
57
58

////////////////////////////////////////////////////////////////////////
//
59
// DebuggerRunControlFactory
con's avatar
con committed
60
61
62
//
////////////////////////////////////////////////////////////////////////

63
// A factory to create DebuggerRunControls
64
DebuggerRunControlFactory::DebuggerRunControlFactory(DebuggerManager *manager)
65
    : m_manager(manager)
con's avatar
con committed
66
67
{}

68
bool DebuggerRunControlFactory::canRun(RunConfiguration *runConfiguration, const QString &mode) const
con's avatar
con committed
69
{
70
//    return mode == ProjectExplorer::Constants::DEBUGMODE;
71
    return mode == ProjectExplorer::Constants::DEBUGMODE
72
            && qobject_cast<LocalApplicationRunConfiguration *>(runConfiguration);
con's avatar
con committed
73
74
}

75
QString DebuggerRunControlFactory::displayName() const
con's avatar
con committed
76
{
Oswald Buddenhagen's avatar
Oswald Buddenhagen committed
77
    return tr("Debug");
con's avatar
con committed
78
79
}

80
static DebuggerStartParameters localStartParameters(RunConfiguration *runConfiguration)
81
{
82
    DebuggerStartParameters sp;
83
84
85
86
87
    QTC_ASSERT(runConfiguration, return sp);
    LocalApplicationRunConfiguration *rc =
            qobject_cast<LocalApplicationRunConfiguration *>(runConfiguration);
    QTC_ASSERT(rc, return sp);

88
89
90
91
92
93
94
95
96
97
    sp.startMode = StartInternal;
    sp.executable = rc->executable();
    sp.environment = rc->environment().toStringList();
    sp.workingDirectory = rc->workingDirectory();
    sp.processArgs = rc->commandLineArguments();
    sp.toolChainType = rc->toolChainType();
    sp.useTerminal = rc->runMode() == LocalApplicationRunConfiguration::Console;
    sp.dumperLibrary = rc->dumperLibrary();
    sp.dumperLibraryLocations = rc->dumperLibraryLocations();
    sp.displayName = rc->displayName();
98

99
100
    // Find qtInstallPath.
    QString qmakePath = DebuggingHelperLibrary::findSystemQt(rc->environment());
101
102
103
104
105
106
107
108
109
    if (!qmakePath.isEmpty()) {
        QProcess proc;
        QStringList args;
        args.append(QLatin1String("-query"));
        args.append(QLatin1String("QT_INSTALL_HEADERS"));
        proc.start(qmakePath, args);
        proc.waitForFinished();
        QByteArray ba = proc.readAllStandardOutput().trimmed();
        QFileInfo fi(QString::fromLocal8Bit(ba) + "/..");
110
        sp.qtInstallPath = fi.absoluteFilePath();
111
112
    }
    return sp;
113
114
}

115
RunControl *DebuggerRunControlFactory::create(RunConfiguration *runConfiguration,
116
                                              const QString &mode)
con's avatar
con committed
117
{
hjk's avatar
hjk committed
118
    QTC_ASSERT(mode == ProjectExplorer::Constants::DEBUGMODE, return 0);
119
    DebuggerStartParameters sp = localStartParameters(runConfiguration);
120
    return new DebuggerRunControl(m_manager, sp);
121
122
}

123
RunControl *DebuggerRunControlFactory::create(const DebuggerStartParameters &sp)
124
{
125
    return new DebuggerRunControl(m_manager, sp);
con's avatar
con committed
126
127
}

128
QWidget *DebuggerRunControlFactory::createConfigurationWidget(RunConfiguration *runConfiguration)
con's avatar
con committed
129
130
{
    // NBS TODO: Add GDB-specific configuration widget
131
    Q_UNUSED(runConfiguration)
con's avatar
con committed
132
133
134
135
136
137
138
139
140
141
142
143
    return 0;
}



////////////////////////////////////////////////////////////////////////
//
// DebuggerRunControl
//
////////////////////////////////////////////////////////////////////////

DebuggerRunControl::DebuggerRunControl(DebuggerManager *manager,
144
        const DebuggerStartParameters &startParameters)
145
    : RunControl(0, ProjectExplorer::Constants::DEBUGMODE),
146
147
148
149
      m_startParameters(startParameters),
      m_manager(manager),
      m_running(false)
{
150
151
152
153
154
155
156
157
158
159
    connect(m_manager, SIGNAL(debuggingFinished()),
            this, SLOT(debuggingFinished()),
            Qt::QueuedConnection);
    connect(m_manager, SIGNAL(messageAvailable(QString, bool)),
            this, SLOT(slotMessageAvailable(QString, bool)));
    connect(m_manager, SIGNAL(inferiorPidChanged(qint64)),
            this, SLOT(bringApplicationToForeground(qint64)),
            Qt::QueuedConnection);
    connect(this, SIGNAL(stopRequested()),
            m_manager, SLOT(exitDebugger()));
160

161
162
163
    if (m_startParameters.environment.empty())
        m_startParameters.environment = ProjectExplorer::Environment().toStringList();
    m_startParameters.useTerminal = false;
164

165
166
}

167
168
QString DebuggerRunControl::displayName() const
{
169
    return m_startParameters.displayName;
170
171
}

172
173
void DebuggerRunControl::setCustomEnvironment(ProjectExplorer::Environment env)
{
174
    m_startParameters.environment = env.toStringList();
175
176
}

177
178
179
180
void DebuggerRunControl::init()
{
}

181
182
183
void DebuggerRunControl::start()
{
    m_running = true;
184
185
186
    QString errorMessage;
    QString settingsCategory;
    QString settingsPage;
187
188
    if (m_manager->checkDebugConfiguration(m_startParameters.toolChainType,
            &errorMessage, &settingsCategory, &settingsPage)) {
189
        m_manager->startNewDebugger(this);
190
        emit started();
191
    } else {
192
        appendMessage(this, errorMessage, true);
193
        emit finished();
194
195
        Core::ICore::instance()->showWarningWithOptions(tr("Debugger"),
            errorMessage, QString(), settingsCategory, settingsPage);
196
    }
con's avatar
con committed
197
198
}

199
200
void DebuggerRunControl::showMessage(const QString &msg, int channel,
    int timeout)
201
{
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
    DebuggerOutputWindow *ow = m_manager->debuggerOutputWindow();
    QTC_ASSERT(ow, return);
    switch (channel) {
        case StatusBar:
            m_manager->showStatusMessage(msg, timeout);
            ow->showOutput(LogStatus, msg);
            break;
        case AppOutput:
            emit addToOutputWindowInline(this, msg, false);
            break;
        case AppError:
            emit addToOutputWindowInline(this, msg, true);
            break;
        case LogMiscInput:
            ow->showInput(LogMisc, msg);
            ow->showOutput(LogMisc, msg);
            break;
        case LogInput:
            ow->showInput(channel, msg);
            ow->showOutput(channel, msg);
            break;
        default:
            ow->showOutput(channel, msg);
            break;
    }
227
228
229
230
231
}

void DebuggerRunControl::slotMessageAvailable(const QString &data, bool isError)
{
    emit appendMessage(this, data, isError);
con's avatar
con committed
232
233
}

234

con's avatar
con committed
235
236
void DebuggerRunControl::stop()
{
hjk's avatar
hjk committed
237
238
    m_running = false;
    emit stopRequested();
con's avatar
con committed
239
240
241
242
243
244
245
246
247
248
249
250
}

void DebuggerRunControl::debuggingFinished()
{
    m_running = false;
    emit finished();
}

bool DebuggerRunControl::isRunning() const
{
    return m_running;
}
hjk's avatar
hjk committed
251
252

} // namespace Debugger