2009-02-25 09:15:00 +01:00
|
|
|
/**************************************************************************
|
2008-12-02 12:01:29 +01:00
|
|
|
**
|
|
|
|
|
** This file is part of Qt Creator
|
|
|
|
|
**
|
2011-01-11 16:28:15 +01:00
|
|
|
** Copyright (c) 2011 Nokia Corporation and/or its subsidiary(-ies).
|
2008-12-02 12:01:29 +01:00
|
|
|
**
|
2009-06-17 00:01:27 +10:00
|
|
|
** Contact: Nokia Corporation (qt-info@nokia.com)
|
2008-12-02 12:01:29 +01:00
|
|
|
**
|
2010-12-17 16:01:08 +01:00
|
|
|
** No Commercial Usage
|
2008-12-02 14:17:16 +01:00
|
|
|
**
|
2010-12-17 16:01:08 +01:00
|
|
|
** This file contains pre-release code and may not be distributed.
|
|
|
|
|
** You may use this file in accordance with the terms and conditions
|
|
|
|
|
** contained in the Technology Preview License Agreement accompanying
|
|
|
|
|
** this package.
|
2008-12-02 14:17:16 +01:00
|
|
|
**
|
2009-02-25 09:15:00 +01:00
|
|
|
** GNU Lesser General Public License Usage
|
2008-12-02 14:17:16 +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.
|
2008-12-02 14:17:16 +01:00
|
|
|
**
|
2010-12-17 16:01:08 +01:00
|
|
|
** In addition, as a special exception, Nokia gives you certain additional
|
|
|
|
|
** rights. These rights are described in the Nokia Qt LGPL Exception
|
|
|
|
|
** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
|
|
|
|
|
**
|
|
|
|
|
** If you have questions regarding the use of this file, please contact
|
|
|
|
|
** Nokia at qt-info@nokia.com.
|
2008-12-02 12:01:29 +01:00
|
|
|
**
|
2009-02-25 09:15:00 +01:00
|
|
|
**************************************************************************/
|
2008-12-02 14:09:21 +01:00
|
|
|
|
2008-12-02 12:01:29 +01:00
|
|
|
#ifndef SYNCHRONOUSPROCESS_H
|
|
|
|
|
#define SYNCHRONOUSPROCESS_H
|
|
|
|
|
|
2008-12-02 14:09:21 +01:00
|
|
|
#include "utils_global.h"
|
|
|
|
|
|
2008-12-02 12:01:29 +01:00
|
|
|
#include <QtCore/QObject>
|
|
|
|
|
#include <QtCore/QProcess>
|
|
|
|
|
#include <QtCore/QStringList>
|
2010-05-21 17:41:51 +02:00
|
|
|
#include <QtCore/QSharedPointer>
|
2008-12-02 12:01:29 +01:00
|
|
|
|
|
|
|
|
QT_BEGIN_NAMESPACE
|
|
|
|
|
class QTextCodec;
|
|
|
|
|
class QDebug;
|
|
|
|
|
class QByteArray;
|
|
|
|
|
QT_END_NAMESPACE
|
|
|
|
|
|
|
|
|
|
namespace Utils {
|
|
|
|
|
|
|
|
|
|
struct SynchronousProcessPrivate;
|
|
|
|
|
|
|
|
|
|
/* Result of SynchronousProcess execution */
|
2009-05-08 12:09:21 +02:00
|
|
|
struct QTCREATOR_UTILS_EXPORT SynchronousProcessResponse
|
2008-12-02 14:09:21 +01:00
|
|
|
{
|
2008-12-02 12:01:29 +01:00
|
|
|
enum Result {
|
|
|
|
|
// Finished with return code 0
|
|
|
|
|
Finished,
|
|
|
|
|
// Finished with return code != 0
|
|
|
|
|
FinishedError,
|
|
|
|
|
// Process terminated abnormally (kill)
|
|
|
|
|
TerminatedAbnormally,
|
|
|
|
|
// Executable could not be started
|
|
|
|
|
StartFailed,
|
|
|
|
|
// Hang, no output after time out
|
|
|
|
|
Hang };
|
|
|
|
|
|
|
|
|
|
SynchronousProcessResponse();
|
|
|
|
|
void clear();
|
|
|
|
|
|
2010-05-21 17:41:51 +02:00
|
|
|
// Helper to format an exit message.
|
|
|
|
|
QString exitMessage(const QString &binary, int timeoutMS) const;
|
|
|
|
|
|
2008-12-02 12:01:29 +01:00
|
|
|
Result result;
|
|
|
|
|
int exitCode;
|
|
|
|
|
QString stdOut;
|
|
|
|
|
QString stdErr;
|
|
|
|
|
};
|
|
|
|
|
|
2009-05-08 12:09:21 +02:00
|
|
|
QTCREATOR_UTILS_EXPORT QDebug operator<<(QDebug str, const SynchronousProcessResponse &);
|
2008-12-02 12:01:29 +01:00
|
|
|
|
2009-05-08 12:09:21 +02:00
|
|
|
class QTCREATOR_UTILS_EXPORT SynchronousProcess : public QObject
|
2008-12-02 14:09:21 +01:00
|
|
|
{
|
2008-12-02 12:01:29 +01:00
|
|
|
Q_OBJECT
|
|
|
|
|
public:
|
2010-05-21 17:41:51 +02:00
|
|
|
enum Flags {
|
|
|
|
|
// Unix: Do not give the child process a terminal for input prompting.
|
|
|
|
|
UnixTerminalDisabled = 0x1
|
|
|
|
|
};
|
|
|
|
|
|
2008-12-02 12:01:29 +01:00
|
|
|
SynchronousProcess();
|
|
|
|
|
virtual ~SynchronousProcess();
|
|
|
|
|
|
2010-03-01 10:06:05 +01:00
|
|
|
/* Timeout for hanging processes (triggers after no more output
|
|
|
|
|
* occurs on stderr/stdout). */
|
2008-12-02 12:01:29 +01:00
|
|
|
void setTimeout(int timeoutMS);
|
|
|
|
|
int timeout() const;
|
|
|
|
|
|
|
|
|
|
void setStdOutCodec(QTextCodec *c);
|
|
|
|
|
QTextCodec *stdOutCodec() const;
|
|
|
|
|
|
2009-07-14 17:20:20 +02:00
|
|
|
QProcess::ProcessChannelMode processChannelMode () const;
|
|
|
|
|
void setProcessChannelMode(QProcess::ProcessChannelMode m);
|
|
|
|
|
|
2008-12-02 12:01:29 +01:00
|
|
|
bool stdOutBufferedSignalsEnabled() const;
|
|
|
|
|
void setStdOutBufferedSignalsEnabled(bool);
|
|
|
|
|
|
|
|
|
|
bool stdErrBufferedSignalsEnabled() const;
|
|
|
|
|
void setStdErrBufferedSignalsEnabled(bool);
|
|
|
|
|
|
2010-05-21 17:41:51 +02:00
|
|
|
bool timeOutMessageBoxEnabled() const;
|
|
|
|
|
void setTimeOutMessageBoxEnabled(bool);
|
|
|
|
|
|
2008-12-02 12:01:29 +01:00
|
|
|
QStringList environment() const;
|
|
|
|
|
void setEnvironment(const QStringList &);
|
|
|
|
|
|
2009-12-11 16:43:39 +01:00
|
|
|
void setProcessEnvironment(const QProcessEnvironment &environment);
|
|
|
|
|
QProcessEnvironment processEnvironment() const;
|
|
|
|
|
|
2009-07-14 17:20:20 +02:00
|
|
|
void setWorkingDirectory(const QString &workingDirectory);
|
|
|
|
|
QString workingDirectory() const;
|
|
|
|
|
|
2010-05-21 17:41:51 +02:00
|
|
|
unsigned flags() const;
|
|
|
|
|
void setFlags(unsigned);
|
|
|
|
|
|
2008-12-02 12:01:29 +01:00
|
|
|
SynchronousProcessResponse run(const QString &binary, const QStringList &args);
|
|
|
|
|
|
2010-05-21 17:41:51 +02:00
|
|
|
// Create a (derived) processes with flags applied.
|
|
|
|
|
static QSharedPointer<QProcess> createProcess(unsigned flags);
|
|
|
|
|
|
2010-03-01 10:06:05 +01:00
|
|
|
// Static helper for running a process synchronously in the foreground with timeout
|
|
|
|
|
// detection similar SynchronousProcess' handling (taking effect after no more output
|
|
|
|
|
// occurs on stderr/stdout as opposed to waitForFinished()). Returns false if a timeout
|
|
|
|
|
// occurs. Checking of the process' exit state/code still has to be done.
|
|
|
|
|
static bool readDataFromProcess(QProcess &p, int timeOutMS,
|
2010-05-21 17:41:51 +02:00
|
|
|
QByteArray *stdOut = 0, QByteArray *stdErr = 0,
|
|
|
|
|
bool timeOutMessageBox = false);
|
2010-03-01 10:06:05 +01:00
|
|
|
// Stop a process by first calling terminate() (allowing for signal handling) and
|
|
|
|
|
// then kill().
|
|
|
|
|
static bool stopProcess(QProcess &p);
|
|
|
|
|
|
2009-02-19 17:47:44 +01:00
|
|
|
// Helpers to find binaries. Do not use it for other path variables
|
|
|
|
|
// and file types.
|
|
|
|
|
static QString locateBinary(const QString &binary);
|
|
|
|
|
static QString locateBinary(const QString &path, const QString &binary);
|
|
|
|
|
static QChar pathSeparator();
|
|
|
|
|
|
2008-12-02 12:01:29 +01:00
|
|
|
signals:
|
|
|
|
|
void stdOut(const QByteArray &data, bool firstTime);
|
|
|
|
|
void stdErr(const QByteArray &data, bool firstTime);
|
|
|
|
|
|
|
|
|
|
void stdOutBuffered(const QString &data, bool firstTime);
|
|
|
|
|
void stdErrBuffered(const QString &data, bool firstTime);
|
|
|
|
|
|
|
|
|
|
private slots:
|
|
|
|
|
void slotTimeout();
|
|
|
|
|
void finished(int exitCode, QProcess::ExitStatus e);
|
|
|
|
|
void error(QProcess::ProcessError);
|
|
|
|
|
void stdOutReady();
|
|
|
|
|
void stdErrReady();
|
|
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
void processStdOut(bool emitSignals);
|
|
|
|
|
void processStdErr(bool emitSignals);
|
|
|
|
|
static QString convertStdErr(const QByteArray &);
|
|
|
|
|
QString convertStdOut(const QByteArray &) const;
|
|
|
|
|
|
|
|
|
|
SynchronousProcessPrivate *m_d;
|
|
|
|
|
};
|
|
|
|
|
|
2008-12-02 14:09:21 +01:00
|
|
|
} // namespace Utils
|
|
|
|
|
|
2008-12-02 12:01:29 +01:00
|
|
|
#endif
|