1
/****************************************************************************
2
**
3
** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
4
** All rights reserved.
5
** Contact: Nokia Corporation (qt-info@nokia.com)
6
**
7
** This file is part of the QtCore module of the Qt Toolkit.
8
**
9
** $QT_BEGIN_LICENSE:LGPL$
10
** No Commercial Usage
11
** This file contains pre-release code and may not be distributed.
12
** You may use this file in accordance with the terms and conditions
13
** contained in the Technology Preview License Agreement accompanying
14
** this package.
15
**
16
** GNU Lesser General Public License Usage
17
** Alternatively, this file may be used under the terms of the GNU Lesser
18
** General Public License version 2.1 as published by the Free Software
19
** Foundation and appearing in the file LICENSE.LGPL included in the
20
** packaging of this file.  Please review the following information to
21
** ensure the GNU Lesser General Public License version 2.1 requirements
22
** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
23
**
24
** In addition, as a special exception, Nokia gives you certain additional
25
** rights.  These rights are described in the Nokia Qt LGPL Exception
26
** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
27
**
28
** If you have questions regarding the use of this file, please contact
29
** Nokia at qt-info@nokia.com.
30
**
31
**
32
**
33
**
34
**
35
**
36
**
37
**
38
** $QT_END_LICENSE$
39
**
40
****************************************************************************/
41
42
#ifndef QPROCESS_H
43
#define QPROCESS_H
44
45
#include <QtCore/qiodevice.h>
46
#include <QtCore/qstringlist.h>
47
48
QT_BEGIN_HEADER
49
50
QT_BEGIN_NAMESPACE
51
52
QT_MODULE(Core)
53
54
#ifndef QT_NO_PROCESS
55
56
#if (!defined(Q_OS_WIN32) && !defined(Q_OS_WINCE)) || defined(qdoc)
57
typedef qint64 Q_PID;
58
#else
59
QT_END_NAMESPACE
60
typedef struct _PROCESS_INFORMATION *Q_PID;
61
QT_BEGIN_NAMESPACE
62
#endif
63
64
class QProcessPrivate;
65
66
class Q_CORE_EXPORT QProcess : public QIODevice
67
{
68
    Q_OBJECT
69
public:
70
    enum ProcessError {
71
        FailedToStart, //### file not found, resource error
72
        Crashed,
73
        Timedout,
74
        ReadError,
75
        WriteError,
76
        UnknownError
77
    };
78
    enum ProcessState {
79
        NotRunning,
80
        Starting,
81
        Running
82
    };
83
    enum ProcessChannel {
84
        StandardOutput,
85
        StandardError
86
    };
87
    enum ProcessChannelMode {
88
        SeparateChannels,
89
        MergedChannels,
90
        ForwardedChannels
91
    };
92
    enum ExitStatus {
93
        NormalExit,
94
        CrashExit
95
    };
96
97
    explicit QProcess(QObject *parent = 0);
98
    virtual ~QProcess();
99
100
    void start(const QString &program, const QStringList &arguments, OpenMode mode = ReadWrite);
101
    void start(const QString &program, OpenMode mode = ReadWrite);
102
103
    ProcessChannelMode readChannelMode() const;
104
    void setReadChannelMode(ProcessChannelMode mode);
105
    ProcessChannelMode processChannelMode() const;
106
    void setProcessChannelMode(ProcessChannelMode mode);
107
108
    ProcessChannel readChannel() const;
109
    void setReadChannel(ProcessChannel channel);
110
111
    void closeReadChannel(ProcessChannel channel);
112
    void closeWriteChannel();
113
114
    void setStandardInputFile(const QString &fileName);
115
    void setStandardOutputFile(const QString &fileName, OpenMode mode = Truncate);
116
    void setStandardErrorFile(const QString &fileName, OpenMode mode = Truncate);
117
    void setStandardOutputProcess(QProcess *destination);
118
119
    QString workingDirectory() const;
120
    void setWorkingDirectory(const QString &dir);
121
122
    void setEnvironment(const QStringList &environment);
123
    QStringList environment() const;
124
125
    QProcess::ProcessError error() const;
126
    QProcess::ProcessState state() const;
127
128
    // #### Qt 5: Q_PID is a pointer on Windows and a value on Unix
129
    Q_PID pid() const;
130
131
    bool waitForStarted(int msecs = 30000);
132
    bool waitForReadyRead(int msecs = 30000);
133
    bool waitForBytesWritten(int msecs = 30000);
134
    bool waitForFinished(int msecs = 30000);
135
136
    QByteArray readAllStandardOutput();
137
    QByteArray readAllStandardError();
138
139
    int exitCode() const;
140
    QProcess::ExitStatus exitStatus() const;
141
142
    // QIODevice
143
    qint64 bytesAvailable() const;
144
    qint64 bytesToWrite() const;
145
    bool isSequential() const;
146
    bool canReadLine() const;
147
    void close();
148
    bool atEnd() const;
149
150
    static int execute(const QString &program, const QStringList &arguments);
151
    static int execute(const QString &program);
152
153
    static bool startDetached(const QString &program, const QStringList &arguments, const QString &workingDirectory,
154
                              qint64 *pid = 0);
155
    static bool startDetached(const QString &program, const QStringList &arguments);
156
    static bool startDetached(const QString &program);
157
158
    static QStringList systemEnvironment();
159
160
public Q_SLOTS:
161
    void terminate();
162
    void kill();
163
164
Q_SIGNALS:
165
    void started();
166
    void finished(int exitCode);
167
    void finished(int exitCode, QProcess::ExitStatus exitStatus);
168
    void error(QProcess::ProcessError error);
169
    void stateChanged(QProcess::ProcessState state);
170
171
    void readyReadStandardOutput();
172
    void readyReadStandardError();
173
174
protected:
175
    void setProcessState(ProcessState state);
176
177
    virtual void setupChildProcess();
178
179
    // QIODevice
180
    qint64 readData(char *data, qint64 maxlen);
181
    qint64 writeData(const char *data, qint64 len);
182
183
private:
184
    Q_DECLARE_PRIVATE(QProcess)
185
    Q_DISABLE_COPY(QProcess)
186
187
    Q_PRIVATE_SLOT(d_func(), bool _q_canReadStandardOutput())
188
    Q_PRIVATE_SLOT(d_func(), bool _q_canReadStandardError())
189
    Q_PRIVATE_SLOT(d_func(), bool _q_canWrite())
190
    Q_PRIVATE_SLOT(d_func(), bool _q_startupNotification())
191
    Q_PRIVATE_SLOT(d_func(), bool _q_processDied())
192
    Q_PRIVATE_SLOT(d_func(), void _q_notified())
193
    friend class QProcessManager;
194
};
195
196
#endif // QT_NO_PROCESS
197
198
QT_END_NAMESPACE
199
200
QT_END_HEADER
201
202
#endif // QPROCESS_H